catboost 1.25.1 → 1.26.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/DEPLOYMENT.md +22 -15
- package/README.md +37 -27
- package/binding.gyp +5 -7
- package/build_scripts/bootstrap.js +2 -1
- package/build_scripts/out/build.js +46 -68
- package/build_scripts/out/build_model.js +1 -1
- package/build_scripts/out/{build_ya.js → build_native.js} +1 -1
- package/build_scripts/out/ci.js +5 -5
- package/build_scripts/out/config.js +32 -18
- package/build_scripts/out/install.js +5 -3
- package/build_scripts/out/package_prepublish.js +1 -1
- package/build_scripts/out/packaging.js +1 -19
- package/build_scripts/out/run_tests.js +1 -1
- package/build_scripts/out/test.js +8 -3
- package/config.json +18 -11
- package/inc/catboost/libs/model_interface/c_api.h +349 -3
- package/lib/catboost.d.ts +65 -21
- package/package.json +4 -4
- package/src/api_helpers.cpp +100 -24
- package/src/api_helpers.h +8 -7
- package/src/api_module.cpp +1 -2
- package/src/model.cpp +483 -83
- package/src/model.h +24 -9
- package/inc/contrib/libs/cxxsupp/system_stl/include/stlfwd +0 -14
- package/inc/util/charset/recode_result.h +0 -9
- package/inc/util/charset/unicode_table.h +0 -123
- package/inc/util/charset/unidata.h +0 -421
- package/inc/util/charset/utf8.h +0 -384
- package/inc/util/charset/wide.h +0 -843
- package/inc/util/charset/wide_specific.h +0 -22
- package/inc/util/datetime/base.h +0 -669
- package/inc/util/datetime/constants.h +0 -7
- package/inc/util/datetime/cputimer.h +0 -124
- package/inc/util/datetime/parser.h +0 -292
- package/inc/util/datetime/systime.h +0 -47
- package/inc/util/datetime/uptime.h +0 -8
- package/inc/util/digest/city.h +0 -88
- package/inc/util/digest/fnv.h +0 -73
- package/inc/util/digest/multi.h +0 -14
- package/inc/util/digest/murmur.h +0 -57
- package/inc/util/digest/numeric.h +0 -86
- package/inc/util/digest/sequence.h +0 -48
- package/inc/util/draft/date.h +0 -129
- package/inc/util/draft/datetime.h +0 -184
- package/inc/util/draft/enum.h +0 -136
- package/inc/util/draft/holder_vector.h +0 -102
- package/inc/util/draft/ip.h +0 -131
- package/inc/util/draft/matrix.h +0 -108
- package/inc/util/draft/memory.h +0 -40
- package/inc/util/folder/dirent_win.h +0 -46
- package/inc/util/folder/dirut.h +0 -121
- package/inc/util/folder/filelist.h +0 -81
- package/inc/util/folder/fts.h +0 -108
- package/inc/util/folder/iterator.h +0 -109
- package/inc/util/folder/lstat_win.h +0 -20
- package/inc/util/folder/path.h +0 -225
- package/inc/util/folder/pathsplit.h +0 -113
- package/inc/util/folder/tempdir.h +0 -42
- package/inc/util/generic/adaptor.h +0 -134
- package/inc/util/generic/algorithm.h +0 -765
- package/inc/util/generic/array_ref.h +0 -282
- package/inc/util/generic/array_size.h +0 -24
- package/inc/util/generic/benchmark/vector_count_ctor/f.h +0 -9
- package/inc/util/generic/bitmap.h +0 -1115
- package/inc/util/generic/bitops.h +0 -459
- package/inc/util/generic/bt_exception.h +0 -24
- package/inc/util/generic/buffer.h +0 -232
- package/inc/util/generic/cast.h +0 -176
- package/inc/util/generic/deque.h +0 -24
- package/inc/util/generic/explicit_type.h +0 -42
- package/inc/util/generic/fastqueue.h +0 -55
- package/inc/util/generic/flags.h +0 -244
- package/inc/util/generic/function.h +0 -103
- package/inc/util/generic/fwd.h +0 -171
- package/inc/util/generic/guid.h +0 -61
- package/inc/util/generic/hash.h +0 -2032
- package/inc/util/generic/hash_primes.h +0 -140
- package/inc/util/generic/hash_set.h +0 -490
- package/inc/util/generic/hide_ptr.h +0 -3
- package/inc/util/generic/intrlist.h +0 -876
- package/inc/util/generic/is_in.h +0 -53
- package/inc/util/generic/iterator.h +0 -137
- package/inc/util/generic/iterator_range.h +0 -105
- package/inc/util/generic/lazy_value.h +0 -66
- package/inc/util/generic/list.h +0 -22
- package/inc/util/generic/map.h +0 -44
- package/inc/util/generic/mapfindptr.h +0 -60
- package/inc/util/generic/maybe.h +0 -713
- package/inc/util/generic/maybe_traits.h +0 -164
- package/inc/util/generic/mem_copy.h +0 -55
- package/inc/util/generic/noncopyable.h +0 -38
- package/inc/util/generic/object_counter.h +0 -53
- package/inc/util/generic/ptr.h +0 -1113
- package/inc/util/generic/queue.h +0 -57
- package/inc/util/generic/refcount.h +0 -162
- package/inc/util/generic/reserve.h +0 -11
- package/inc/util/generic/scope.h +0 -65
- package/inc/util/generic/serialized_enum.h +0 -406
- package/inc/util/generic/set.h +0 -42
- package/inc/util/generic/singleton.h +0 -136
- package/inc/util/generic/size_literals.h +0 -65
- package/inc/util/generic/stack.h +0 -18
- package/inc/util/generic/store_policy.h +0 -120
- package/inc/util/generic/strbase.h +0 -612
- package/inc/util/generic/strbuf.h +0 -552
- package/inc/util/generic/strfcpy.h +0 -17
- package/inc/util/generic/string.h +0 -1572
- package/inc/util/generic/string_hash.h +0 -21
- package/inc/util/generic/string_ut.h +0 -1175
- package/inc/util/generic/type_name.h +0 -34
- package/inc/util/generic/typelist.h +0 -114
- package/inc/util/generic/typetraits.h +0 -325
- package/inc/util/generic/utility.h +0 -132
- package/inc/util/generic/va_args.h +0 -400
- package/inc/util/generic/variant.h +0 -631
- package/inc/util/generic/variant_traits.h +0 -171
- package/inc/util/generic/vector.h +0 -119
- package/inc/util/generic/xrange.h +0 -258
- package/inc/util/generic/yexception.h +0 -212
- package/inc/util/generic/yexception_ut.h +0 -14
- package/inc/util/generic/ylimits.h +0 -92
- package/inc/util/generic/ymath.h +0 -206
- package/inc/util/memory/addstorage.h +0 -93
- package/inc/util/memory/alloc.h +0 -27
- package/inc/util/memory/blob.h +0 -296
- package/inc/util/memory/mmapalloc.h +0 -8
- package/inc/util/memory/pool.h +0 -432
- package/inc/util/memory/segmented_string_pool.h +0 -194
- package/inc/util/memory/segpool_alloc.h +0 -118
- package/inc/util/memory/smallobj.h +0 -141
- package/inc/util/memory/tempbuf.h +0 -111
- package/inc/util/network/address.h +0 -136
- package/inc/util/network/endpoint.h +0 -61
- package/inc/util/network/hostip.h +0 -16
- package/inc/util/network/init.h +0 -60
- package/inc/util/network/interface.h +0 -17
- package/inc/util/network/iovec.h +0 -65
- package/inc/util/network/ip.h +0 -116
- package/inc/util/network/nonblock.h +0 -8
- package/inc/util/network/pair.h +0 -9
- package/inc/util/network/poller.h +0 -58
- package/inc/util/network/pollerimpl.h +0 -707
- package/inc/util/network/sock.h +0 -608
- package/inc/util/network/socket.h +0 -421
- package/inc/util/random/common_ops.h +0 -130
- package/inc/util/random/easy.h +0 -47
- package/inc/util/random/entropy.h +0 -21
- package/inc/util/random/fast.h +0 -101
- package/inc/util/random/init_atfork.h +0 -3
- package/inc/util/random/lcg_engine.h +0 -66
- package/inc/util/random/mersenne.h +0 -46
- package/inc/util/random/mersenne32.h +0 -50
- package/inc/util/random/mersenne64.h +0 -50
- package/inc/util/random/normal.h +0 -38
- package/inc/util/random/random.h +0 -30
- package/inc/util/random/shuffle.h +0 -39
- package/inc/util/str_stl.h +0 -266
- package/inc/util/stream/aligned.h +0 -99
- package/inc/util/stream/buffer.h +0 -119
- package/inc/util/stream/buffered.h +0 -225
- package/inc/util/stream/debug.h +0 -53
- package/inc/util/stream/direct_io.h +0 -43
- package/inc/util/stream/file.h +0 -108
- package/inc/util/stream/format.h +0 -444
- package/inc/util/stream/fwd.h +0 -100
- package/inc/util/stream/hex.h +0 -8
- package/inc/util/stream/holder.h +0 -44
- package/inc/util/stream/input.h +0 -273
- package/inc/util/stream/labeled.h +0 -19
- package/inc/util/stream/length.h +0 -100
- package/inc/util/stream/mem.h +0 -255
- package/inc/util/stream/multi.h +0 -32
- package/inc/util/stream/null.h +0 -61
- package/inc/util/stream/output.h +0 -304
- package/inc/util/stream/pipe.h +0 -112
- package/inc/util/stream/printf.h +0 -25
- package/inc/util/stream/str.h +0 -207
- package/inc/util/stream/tee.h +0 -28
- package/inc/util/stream/tempbuf.h +0 -21
- package/inc/util/stream/tokenizer.h +0 -214
- package/inc/util/stream/trace.h +0 -60
- package/inc/util/stream/walk.h +0 -35
- package/inc/util/stream/zerocopy.h +0 -91
- package/inc/util/stream/zerocopy_output.h +0 -57
- package/inc/util/stream/zlib.h +0 -173
- package/inc/util/string/ascii.h +0 -236
- package/inc/util/string/builder.h +0 -39
- package/inc/util/string/cast.h +0 -347
- package/inc/util/string/cstriter.h +0 -14
- package/inc/util/string/escape.h +0 -70
- package/inc/util/string/hex.h +0 -59
- package/inc/util/string/join.h +0 -194
- package/inc/util/string/printf.h +0 -13
- package/inc/util/string/reverse.h +0 -16
- package/inc/util/string/split.h +0 -1080
- package/inc/util/string/strip.h +0 -257
- package/inc/util/string/strspn.h +0 -65
- package/inc/util/string/subst.h +0 -56
- package/inc/util/string/type.h +0 -50
- package/inc/util/string/util.h +0 -195
- package/inc/util/string/vector.h +0 -132
- package/inc/util/system/align.h +0 -50
- package/inc/util/system/atexit.h +0 -22
- package/inc/util/system/atomic.h +0 -51
- package/inc/util/system/atomic_gcc.h +0 -90
- package/inc/util/system/atomic_ops.h +0 -189
- package/inc/util/system/atomic_win.h +0 -114
- package/inc/util/system/backtrace.h +0 -39
- package/inc/util/system/byteorder.h +0 -186
- package/inc/util/system/compat.h +0 -84
- package/inc/util/system/compiler.h +0 -620
- package/inc/util/system/condvar.h +0 -71
- package/inc/util/system/context.h +0 -181
- package/inc/util/system/context_aarch64.h +0 -8
- package/inc/util/system/context_i686.h +0 -9
- package/inc/util/system/context_x86.h +0 -12
- package/inc/util/system/context_x86_64.h +0 -7
- package/inc/util/system/cpu_id.h +0 -159
- package/inc/util/system/daemon.h +0 -28
- package/inc/util/system/datetime.h +0 -98
- package/inc/util/system/defaults.h +0 -149
- package/inc/util/system/demangle.h +0 -5
- package/inc/util/system/demangle_impl.h +0 -23
- package/inc/util/system/direct_io.h +0 -71
- package/inc/util/system/dynlib.h +0 -119
- package/inc/util/system/env.h +0 -32
- package/inc/util/system/error.h +0 -95
- package/inc/util/system/event.h +0 -122
- package/inc/util/system/execpath.h +0 -17
- package/inc/util/system/fasttime.h +0 -6
- package/inc/util/system/fhandle.h +0 -27
- package/inc/util/system/file.h +0 -210
- package/inc/util/system/file_lock.h +0 -34
- package/inc/util/system/filemap.h +0 -383
- package/inc/util/system/flock.h +0 -35
- package/inc/util/system/fs.h +0 -156
- package/inc/util/system/fs_win.h +0 -29
- package/inc/util/system/fstat.h +0 -46
- package/inc/util/system/getpid.h +0 -12
- package/inc/util/system/guard.h +0 -179
- package/inc/util/system/hi_lo.h +0 -139
- package/inc/util/system/hostname.h +0 -10
- package/inc/util/system/hp_timer.h +0 -36
- package/inc/util/system/info.h +0 -12
- package/inc/util/system/interrupt_signals.h +0 -22
- package/inc/util/system/madvise.h +0 -30
- package/inc/util/system/maxlen.h +0 -32
- package/inc/util/system/mem_info.h +0 -18
- package/inc/util/system/mincore.h +0 -38
- package/inc/util/system/mktemp.h +0 -11
- package/inc/util/system/mlock.h +0 -43
- package/inc/util/system/mutex.h +0 -67
- package/inc/util/system/nice.h +0 -3
- package/inc/util/system/pipe.h +0 -90
- package/inc/util/system/platform.h +0 -246
- package/inc/util/system/progname.h +0 -13
- package/inc/util/system/protect.h +0 -25
- package/inc/util/system/rusage.h +0 -26
- package/inc/util/system/rwlock.h +0 -78
- package/inc/util/system/sanitizers.h +0 -122
- package/inc/util/system/sem.h +0 -41
- package/inc/util/system/shellcommand.h +0 -472
- package/inc/util/system/shmat.h +0 -32
- package/inc/util/system/sigset.h +0 -78
- package/inc/util/system/spin_wait.h +0 -10
- package/inc/util/system/spinlock.h +0 -121
- package/inc/util/system/src_location.h +0 -25
- package/inc/util/system/src_root.h +0 -68
- package/inc/util/system/sys_alloc.h +0 -43
- package/inc/util/system/sysstat.h +0 -52
- package/inc/util/system/tempfile.h +0 -34
- package/inc/util/system/thread.h +0 -167
- package/inc/util/system/tls.h +0 -307
- package/inc/util/system/types.h +0 -119
- package/inc/util/system/unaligned_mem.h +0 -67
- package/inc/util/system/user.h +0 -5
- package/inc/util/system/utime.h +0 -6
- package/inc/util/system/valgrind.h +0 -48
- package/inc/util/system/winint.h +0 -43
- package/inc/util/system/yassert.h +0 -121
- package/inc/util/system/yield.h +0 -4
- package/inc/util/thread/factory.h +0 -65
- package/inc/util/thread/fwd.h +0 -30
- package/inc/util/thread/lfqueue.h +0 -406
- package/inc/util/thread/lfstack.h +0 -188
- package/inc/util/thread/pool.h +0 -388
- package/inc/util/thread/singleton.h +0 -42
- package/inc/util/ysafeptr.h +0 -427
- package/inc/util/ysaveload.h +0 -700
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include "src_root.h"
|
|
4
|
-
|
|
5
|
-
#include <util/generic/strbuf.h>
|
|
6
|
-
|
|
7
|
-
struct TSourceLocation {
|
|
8
|
-
constexpr TSourceLocation(const TStringBuf f, int l) noexcept
|
|
9
|
-
: File(f)
|
|
10
|
-
, Line(l)
|
|
11
|
-
{
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
TStringBuf File;
|
|
15
|
-
int Line;
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
// __SOURCE_FILE__ should be used instead of __FILE__
|
|
19
|
-
#if !defined(__NVCC__)
|
|
20
|
-
#define __SOURCE_FILE__ (__SOURCE_FILE_IMPL__.As<TStringBuf>())
|
|
21
|
-
#else
|
|
22
|
-
#define __SOURCE_FILE__ (__SOURCE_FILE_IMPL__.template As<TStringBuf>())
|
|
23
|
-
#endif
|
|
24
|
-
|
|
25
|
-
#define __LOCATION__ ::TSourceLocation(__SOURCE_FILE__, __LINE__)
|
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include "compiler.h"
|
|
4
|
-
#include "defaults.h"
|
|
5
|
-
|
|
6
|
-
#include <type_traits>
|
|
7
|
-
|
|
8
|
-
namespace NPrivate {
|
|
9
|
-
struct TStaticBuf {
|
|
10
|
-
constexpr TStaticBuf(const char* data, unsigned len) noexcept
|
|
11
|
-
: Data(data)
|
|
12
|
-
, Len(len)
|
|
13
|
-
{
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
template <class T>
|
|
17
|
-
constexpr T As() const noexcept {
|
|
18
|
-
return T(Data, Len);
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
template <class T>
|
|
22
|
-
constexpr operator T() const noexcept {
|
|
23
|
-
return this->As<T>();
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
const char* Data;
|
|
27
|
-
unsigned Len;
|
|
28
|
-
};
|
|
29
|
-
|
|
30
|
-
#define STATIC_BUF(x) ::NPrivate::TStaticBuf(x, sizeof(x) - 1)
|
|
31
|
-
|
|
32
|
-
constexpr TStaticBuf ArcRoot = STATIC_BUF(Y_STRINGIZE(ARCADIA_ROOT));
|
|
33
|
-
constexpr TStaticBuf BuildRoot = STATIC_BUF(Y_STRINGIZE(ARCADIA_BUILD_ROOT));
|
|
34
|
-
|
|
35
|
-
constexpr Y_FORCE_INLINE bool IsProperPrefix(const TStaticBuf prefix, const TStaticBuf string) noexcept {
|
|
36
|
-
if (prefix.Len < string.Len) {
|
|
37
|
-
for (unsigned i = prefix.Len; i-- > 0;) {
|
|
38
|
-
if (prefix.Data[i] != string.Data[i]) {
|
|
39
|
-
return false;
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
return true;
|
|
43
|
-
} else {
|
|
44
|
-
return false;
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
constexpr unsigned RootPrefixLength(const TStaticBuf& f) noexcept {
|
|
49
|
-
if (IsProperPrefix(ArcRoot, f)) {
|
|
50
|
-
return ArcRoot.Len + 1;
|
|
51
|
-
}
|
|
52
|
-
if (IsProperPrefix(BuildRoot, f)) {
|
|
53
|
-
return BuildRoot.Len + 1;
|
|
54
|
-
}
|
|
55
|
-
return 0;
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
constexpr Y_FORCE_INLINE TStaticBuf StripRoot(const TStaticBuf& f, unsigned prefixLength) noexcept {
|
|
59
|
-
return TStaticBuf(f.Data + prefixLength, f.Len - prefixLength);
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
//$(SRC_ROOT)/prj/blah.cpp -> prj/blah.cpp
|
|
63
|
-
constexpr Y_FORCE_INLINE TStaticBuf StripRoot(const TStaticBuf& f) noexcept {
|
|
64
|
-
return StripRoot(f, RootPrefixLength(f));
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
#define __SOURCE_FILE_IMPL__ ::NPrivate::StripRoot(STATIC_BUF(__FILE__), std::integral_constant<unsigned, ::NPrivate::RootPrefixLength(STATIC_BUF(__FILE__))>::value)
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include <util/system/compiler.h>
|
|
4
|
-
|
|
5
|
-
#include <cstdlib>
|
|
6
|
-
#include <new>
|
|
7
|
-
|
|
8
|
-
inline void* y_allocate(size_t n) {
|
|
9
|
-
void* r = malloc(n);
|
|
10
|
-
|
|
11
|
-
if (r == nullptr) {
|
|
12
|
-
throw std::bad_alloc();
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
return r;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
inline void y_deallocate(void* p) {
|
|
19
|
-
free(p);
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
/**
|
|
23
|
-
* Behavior of realloc from C++99 to C++11 changed (http://www.cplusplus.com/reference/cstdlib/realloc/).
|
|
24
|
-
*
|
|
25
|
-
* Our implementation work as C++99: if new_sz == 0 free will be called on 'p' and nullptr returned.
|
|
26
|
-
*/
|
|
27
|
-
inline void* y_reallocate(void* p, size_t new_sz) {
|
|
28
|
-
if (!new_sz) {
|
|
29
|
-
if (p) {
|
|
30
|
-
free(p);
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
return nullptr;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
void* r = realloc(p, new_sz);
|
|
37
|
-
|
|
38
|
-
if (r == nullptr) {
|
|
39
|
-
throw std::bad_alloc();
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
return r;
|
|
43
|
-
}
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include "defaults.h"
|
|
4
|
-
#include <sys/stat.h>
|
|
5
|
-
|
|
6
|
-
#ifdef _win_
|
|
7
|
-
#define S_IRUSR _S_IREAD
|
|
8
|
-
#define S_IWUSR _S_IWRITE
|
|
9
|
-
#define S_IXUSR _S_IEXEC
|
|
10
|
-
#define S_IRWXU (S_IRUSR | S_IWUSR | S_IXUSR)
|
|
11
|
-
|
|
12
|
-
#define S_IRGRP _S_IREAD
|
|
13
|
-
#define S_IWGRP _S_IWRITE
|
|
14
|
-
#define S_IXGRP _S_IEXEC
|
|
15
|
-
#define S_IRWXG (S_IRGRP | S_IWGRP | S_IXGRP)
|
|
16
|
-
|
|
17
|
-
#define S_IROTH _S_IREAD
|
|
18
|
-
#define S_IWOTH _S_IWRITE
|
|
19
|
-
#define S_IXOTH _S_IEXEC
|
|
20
|
-
#define S_IRWXO (S_IROTH | S_IWOTH | S_IXOTH)
|
|
21
|
-
#endif
|
|
22
|
-
|
|
23
|
-
int Chmod(const char* fname, int mode);
|
|
24
|
-
int Umask(int mode);
|
|
25
|
-
|
|
26
|
-
static constexpr int MODE0777 = (S_IRWXU | S_IRWXG | S_IRWXO);
|
|
27
|
-
static constexpr int MODE0775 = (S_IRWXU | S_IRWXG | S_IROTH | S_IXOTH);
|
|
28
|
-
static constexpr int MODE0755 = (S_IRWXU | S_IRGRP | S_IXGRP | S_IROTH | S_IXOTH);
|
|
29
|
-
|
|
30
|
-
int Mkdir(const char* path, int mode);
|
|
31
|
-
|
|
32
|
-
/* uff... mkfifo(...) is not used now */
|
|
33
|
-
|
|
34
|
-
#ifdef _unix_
|
|
35
|
-
inline int Chmod(const char* fname, int mode) {
|
|
36
|
-
return ::chmod(fname, mode);
|
|
37
|
-
}
|
|
38
|
-
inline int Umask(int mode) {
|
|
39
|
-
return ::umask(mode);
|
|
40
|
-
}
|
|
41
|
-
inline int Mkdir(const char* path, int mode) {
|
|
42
|
-
return ::mkdir(path, mode);
|
|
43
|
-
}
|
|
44
|
-
#endif
|
|
45
|
-
|
|
46
|
-
#ifdef _win_
|
|
47
|
-
inline int Umask(int /*mode*/) {
|
|
48
|
-
/* The only thing this method could make is to set FILE_ATTRIBUTE_READONLY on a handle from 'int open(...)',
|
|
49
|
-
but open() is deprecated. */
|
|
50
|
-
return 0;
|
|
51
|
-
}
|
|
52
|
-
#endif
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include "fs.h"
|
|
4
|
-
#include "file.h"
|
|
5
|
-
|
|
6
|
-
#include <util/generic/string.h>
|
|
7
|
-
|
|
8
|
-
class TTempFile {
|
|
9
|
-
public:
|
|
10
|
-
inline TTempFile(const TString& fname)
|
|
11
|
-
: Name_(fname)
|
|
12
|
-
{
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
inline ~TTempFile() {
|
|
16
|
-
NFs::Remove(Name());
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
inline const TString& Name() const noexcept {
|
|
20
|
-
return Name_;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
private:
|
|
24
|
-
const TString Name_;
|
|
25
|
-
};
|
|
26
|
-
|
|
27
|
-
class TTempFileHandle: public TTempFile, public TFile {
|
|
28
|
-
public:
|
|
29
|
-
TTempFileHandle();
|
|
30
|
-
TTempFileHandle(const TString& fname);
|
|
31
|
-
|
|
32
|
-
private:
|
|
33
|
-
TFile CreateFile() const;
|
|
34
|
-
};
|
package/inc/util/system/thread.h
DELETED
|
@@ -1,167 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
/// This code should not be used directly unless you really understand what you do.
|
|
4
|
-
/// If you need threads, use thread pool functionality in <util/thread/factory.h>
|
|
5
|
-
/// @see SystemThreadFactory()
|
|
6
|
-
|
|
7
|
-
#include <util/generic/ptr.h>
|
|
8
|
-
#include <util/generic/string.h>
|
|
9
|
-
|
|
10
|
-
#include "defaults.h"
|
|
11
|
-
#include "progname.h"
|
|
12
|
-
|
|
13
|
-
bool SetHighestThreadPriority();
|
|
14
|
-
|
|
15
|
-
class TThread {
|
|
16
|
-
template <typename Callable>
|
|
17
|
-
struct TCallableParams;
|
|
18
|
-
struct TPrivateCtor {};
|
|
19
|
-
|
|
20
|
-
public:
|
|
21
|
-
using TThreadProc = void* (*)(void*);
|
|
22
|
-
using TId = size_t;
|
|
23
|
-
|
|
24
|
-
struct TParams {
|
|
25
|
-
TThreadProc Proc;
|
|
26
|
-
void* Data;
|
|
27
|
-
size_t StackSize;
|
|
28
|
-
void* StackPointer;
|
|
29
|
-
// See comments for `SetCurrentThreadName`
|
|
30
|
-
TString Name = GetProgramName();
|
|
31
|
-
|
|
32
|
-
inline TParams()
|
|
33
|
-
: Proc(nullptr)
|
|
34
|
-
, Data(nullptr)
|
|
35
|
-
, StackSize(0)
|
|
36
|
-
, StackPointer(nullptr)
|
|
37
|
-
{
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
inline TParams(TThreadProc proc, void* data)
|
|
41
|
-
: Proc(proc)
|
|
42
|
-
, Data(data)
|
|
43
|
-
, StackSize(0)
|
|
44
|
-
, StackPointer(nullptr)
|
|
45
|
-
{
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
inline TParams(TThreadProc proc, void* data, size_t stackSize)
|
|
49
|
-
: Proc(proc)
|
|
50
|
-
, Data(data)
|
|
51
|
-
, StackSize(stackSize)
|
|
52
|
-
, StackPointer(nullptr)
|
|
53
|
-
{
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
inline TParams& SetName(const TString& name) noexcept {
|
|
57
|
-
Name = name;
|
|
58
|
-
|
|
59
|
-
return *this;
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
inline TParams& SetStackSize(size_t size) noexcept {
|
|
63
|
-
StackSize = size;
|
|
64
|
-
|
|
65
|
-
return *this;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
inline TParams& SetStackPointer(void* ptr) noexcept {
|
|
69
|
-
StackPointer = ptr;
|
|
70
|
-
|
|
71
|
-
return *this;
|
|
72
|
-
}
|
|
73
|
-
};
|
|
74
|
-
|
|
75
|
-
TThread(const TParams& params);
|
|
76
|
-
TThread(TThreadProc threadProc, void* param);
|
|
77
|
-
|
|
78
|
-
template <typename Callable>
|
|
79
|
-
TThread(Callable&& callable)
|
|
80
|
-
: TThread(TPrivateCtor{},
|
|
81
|
-
MakeHolder<TCallableParams<Callable>>(std::forward<Callable>(callable))) {
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
TThread(TParams&& params)
|
|
85
|
-
: TThread((const TParams&)params)
|
|
86
|
-
{
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
TThread(TParams& params)
|
|
90
|
-
: TThread((const TParams&)params)
|
|
91
|
-
{
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
~TThread();
|
|
95
|
-
|
|
96
|
-
void Start();
|
|
97
|
-
|
|
98
|
-
void* Join();
|
|
99
|
-
void Detach();
|
|
100
|
-
bool Running() const noexcept;
|
|
101
|
-
TId Id() const noexcept;
|
|
102
|
-
|
|
103
|
-
static TId ImpossibleThreadId() noexcept;
|
|
104
|
-
static TId CurrentThreadId() noexcept;
|
|
105
|
-
|
|
106
|
-
// NOTE: Content of `name` will be copied.
|
|
107
|
-
//
|
|
108
|
-
// NOTE: On Linux thread name is limited to 15 symbols which is probably the smallest one among
|
|
109
|
-
// all platforms. If you provide a name longer than 15 symbols it will be cut. So if you expect
|
|
110
|
-
// `CurrentThreadName` to return the same name as `name` make sure it's not longer than 15
|
|
111
|
-
// symbols.
|
|
112
|
-
static void SetCurrentThreadName(const char* name);
|
|
113
|
-
|
|
114
|
-
// NOTE: Will return empty string where CanGetCurrentThreadName() returns false.
|
|
115
|
-
static TString CurrentThreadName();
|
|
116
|
-
|
|
117
|
-
// NOTE: Depends on a platform version.
|
|
118
|
-
// Will return true for Darwin, Linux or fresh Windows 10.
|
|
119
|
-
static bool CanGetCurrentThreadName();
|
|
120
|
-
|
|
121
|
-
private:
|
|
122
|
-
struct TCallableBase {
|
|
123
|
-
virtual ~TCallableBase() = default;
|
|
124
|
-
virtual void run() = 0;
|
|
125
|
-
|
|
126
|
-
static void* ThreadWorker(void* arg) {
|
|
127
|
-
static_cast<TCallableBase*>(arg)->run();
|
|
128
|
-
return nullptr;
|
|
129
|
-
}
|
|
130
|
-
};
|
|
131
|
-
|
|
132
|
-
template <typename Callable>
|
|
133
|
-
struct TCallableParams: public TCallableBase {
|
|
134
|
-
TCallableParams(Callable&& callable)
|
|
135
|
-
: Callable_(std::forward<Callable>(callable))
|
|
136
|
-
{
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
Callable Callable_;
|
|
140
|
-
|
|
141
|
-
void run() override {
|
|
142
|
-
Callable_();
|
|
143
|
-
}
|
|
144
|
-
};
|
|
145
|
-
|
|
146
|
-
TThread(TPrivateCtor, THolder<TCallableBase> callable);
|
|
147
|
-
|
|
148
|
-
private:
|
|
149
|
-
class TImpl;
|
|
150
|
-
THolder<TImpl> Impl_;
|
|
151
|
-
};
|
|
152
|
-
|
|
153
|
-
class ISimpleThread: public TThread {
|
|
154
|
-
public:
|
|
155
|
-
ISimpleThread(size_t stackSize = 0);
|
|
156
|
-
|
|
157
|
-
virtual ~ISimpleThread() = default;
|
|
158
|
-
|
|
159
|
-
virtual void* ThreadProc() = 0;
|
|
160
|
-
};
|
|
161
|
-
|
|
162
|
-
struct TCurrentThreadLimits {
|
|
163
|
-
TCurrentThreadLimits() noexcept;
|
|
164
|
-
|
|
165
|
-
const void* StackBegin;
|
|
166
|
-
size_t StackLength;
|
|
167
|
-
};
|
package/inc/util/system/tls.h
DELETED
|
@@ -1,307 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include "defaults.h"
|
|
4
|
-
|
|
5
|
-
#include <util/generic/ptr.h>
|
|
6
|
-
#include <util/generic/noncopyable.h>
|
|
7
|
-
|
|
8
|
-
#include <new>
|
|
9
|
-
|
|
10
|
-
#if defined(_darwin_)
|
|
11
|
-
#define Y_DISABLE_THRKEY_OPTIMIZATION
|
|
12
|
-
#endif
|
|
13
|
-
|
|
14
|
-
#if defined(_arm_) && defined(_linux_)
|
|
15
|
-
#define Y_DISABLE_THRKEY_OPTIMIZATION
|
|
16
|
-
#endif
|
|
17
|
-
|
|
18
|
-
#if defined(__GNUC__) && defined(__ANDROID__) && defined(__i686__) // https://st.yandex-team.ru/DEVTOOLS-3352
|
|
19
|
-
#define Y_DISABLE_THRKEY_OPTIMIZATION
|
|
20
|
-
#endif
|
|
21
|
-
|
|
22
|
-
/**
|
|
23
|
-
@def Y_THREAD(TType)
|
|
24
|
-
|
|
25
|
-
A thread-local wrapper for a given class. Suitable for POD and classes with a constructor with a single argument.
|
|
26
|
-
|
|
27
|
-
The wrapper can be treated as the original class in many cases, as it has the same signature for the constructor and an implicit cast to the origianl class.
|
|
28
|
-
|
|
29
|
-
Has methods :
|
|
30
|
-
- implicit caster to TType
|
|
31
|
-
- TType& Get()
|
|
32
|
-
- TType* GetPtr()
|
|
33
|
-
|
|
34
|
-
Time complexity: getting a variable takes O(number of threads where the variable has been constructed)
|
|
35
|
-
|
|
36
|
-
Memory usage: O(number of threads where the variable has been constructed)
|
|
37
|
-
|
|
38
|
-
Best practices:
|
|
39
|
-
- storing singletons won't result in heavy memory overheads
|
|
40
|
-
- storing pointers allows complex constructors as well as lazy constructions
|
|
41
|
-
- storing static variables won't result in heavy memory overheads
|
|
42
|
-
|
|
43
|
-
Possibly bad practices:
|
|
44
|
-
- field in a class with numerous instances and numerous threads will result in slow working and memory overheads
|
|
45
|
-
|
|
46
|
-
Example:
|
|
47
|
-
@code
|
|
48
|
-
//the field declaration in header
|
|
49
|
-
Y_THREAD(TBuffer) TmpBuffer;
|
|
50
|
-
//...later somewhere in cpp...
|
|
51
|
-
TmpBuffer.Clear();
|
|
52
|
-
for (size_t i = 0; i < sz && TrieCursor[i].second.IsFork(); ++i) {
|
|
53
|
-
TmpBuffer.Append(TrieCursor[i].second.Char);
|
|
54
|
-
}
|
|
55
|
-
@endcode
|
|
56
|
-
|
|
57
|
-
Example:
|
|
58
|
-
@code
|
|
59
|
-
//the field decalrataion in header
|
|
60
|
-
Y_THREAD(TMyWriter*) ThreadLocalWriter;
|
|
61
|
-
//...later somewhere in cpp...
|
|
62
|
-
TMyWriter*& writerRef = ThreadLocalWriter.Get();
|
|
63
|
-
if (writerRef == nullptr) {
|
|
64
|
-
THolder<TMyWriter> threadLocalWriter( new TMyWriter(
|
|
65
|
-
*Session,
|
|
66
|
-
MinLogError,
|
|
67
|
-
MaxRps,
|
|
68
|
-
LogFraction,
|
|
69
|
-
WriteCounters,
|
|
70
|
-
Log));
|
|
71
|
-
writerRef = threadLocalWriter.Get();
|
|
72
|
-
}
|
|
73
|
-
@endcode
|
|
74
|
-
|
|
75
|
-
Example:
|
|
76
|
-
@code
|
|
77
|
-
//in header
|
|
78
|
-
namespace TMorph {
|
|
79
|
-
Y_THREAD(ELanguage) ThreadLocalMainLanguage;
|
|
80
|
-
}
|
|
81
|
-
//in cpp
|
|
82
|
-
Y_THREAD(ELanguage) TMorph::ThreadLocalMainLanguage(LANG_RUS);
|
|
83
|
-
@endcode
|
|
84
|
-
|
|
85
|
-
Example:
|
|
86
|
-
@code
|
|
87
|
-
Y_THREAD(TScoreCalcer*) ScoreCalcerPtr;
|
|
88
|
-
static TScoreCalcer* GetScoreCalcer(yint maxElemCount) {
|
|
89
|
-
if (ScoreCalcerPtr == 0) {
|
|
90
|
-
ScoreCalcerPtr = new TScoreCalcer();
|
|
91
|
-
ScoreCalcerPtr->Alloc(maxElemCount);
|
|
92
|
-
}
|
|
93
|
-
return ScoreCalcerPtr;
|
|
94
|
-
}
|
|
95
|
-
@endcode
|
|
96
|
-
|
|
97
|
-
@param TType POD or a class with a constructor taking 1 argument
|
|
98
|
-
**/
|
|
99
|
-
|
|
100
|
-
/**
|
|
101
|
-
@def Y_STATIC_THREAD(TType)
|
|
102
|
-
|
|
103
|
-
Equivalent to "static Y_THREAD(TType)"
|
|
104
|
-
|
|
105
|
-
@see Y_THREAD(TType)
|
|
106
|
-
**/
|
|
107
|
-
|
|
108
|
-
/**
|
|
109
|
-
@def Y_POD_THREAD(TType)
|
|
110
|
-
|
|
111
|
-
Same interface as Y_THREAD(TType), but TType must be a POD.
|
|
112
|
-
Implemented (based on the compiler) as Y_THREAD(TType) or as native tls.
|
|
113
|
-
|
|
114
|
-
@see Y_THREAD(TType)
|
|
115
|
-
**/
|
|
116
|
-
|
|
117
|
-
/**
|
|
118
|
-
@def STATIC_POD_THREAD(TType)
|
|
119
|
-
|
|
120
|
-
Equivalent to "static Y_POD_THREAD(TType)"
|
|
121
|
-
|
|
122
|
-
@see Y_POD_THREAD(TType)
|
|
123
|
-
**/
|
|
124
|
-
|
|
125
|
-
#define Y_THREAD(T) ::NTls::TValue<T>
|
|
126
|
-
#define Y_STATIC_THREAD(T) static Y_THREAD(T)
|
|
127
|
-
|
|
128
|
-
// gcc and msvc support automatic tls for POD types
|
|
129
|
-
#if defined(Y_DISABLE_THRKEY_OPTIMIZATION)
|
|
130
|
-
// nothing to do
|
|
131
|
-
#elif defined(__clang__)
|
|
132
|
-
#define Y_POD_THREAD(T) thread_local T
|
|
133
|
-
#define Y_POD_STATIC_THREAD(T) static thread_local T
|
|
134
|
-
#elif defined(__GNUC__) && !defined(_cygwin_) && !defined(_arm_) && !defined(__IOS_SIMULATOR__)
|
|
135
|
-
#define Y_POD_THREAD(T) __thread T
|
|
136
|
-
#define Y_POD_STATIC_THREAD(T) static __thread T
|
|
137
|
-
// msvc doesn't support __declspec(thread) in dlls, loaded manually (via LoadLibrary)
|
|
138
|
-
#elif (defined(_MSC_VER) && !defined(_WINDLL)) || defined(_arm_)
|
|
139
|
-
#define Y_POD_THREAD(T) __declspec(thread) T
|
|
140
|
-
#define Y_POD_STATIC_THREAD(T) __declspec(thread) static T
|
|
141
|
-
#endif
|
|
142
|
-
|
|
143
|
-
#if !defined(Y_POD_THREAD) || !defined(Y_POD_STATIC_THREAD)
|
|
144
|
-
#define Y_POD_THREAD(T) Y_THREAD(T)
|
|
145
|
-
#define Y_POD_STATIC_THREAD(T) Y_STATIC_THREAD(T)
|
|
146
|
-
#else
|
|
147
|
-
#define Y_HAVE_FAST_POD_TLS
|
|
148
|
-
#endif
|
|
149
|
-
|
|
150
|
-
namespace NPrivate {
|
|
151
|
-
void FillWithTrash(void* ptr, size_t len);
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
namespace NTls {
|
|
155
|
-
using TDtor = void (*)(void*);
|
|
156
|
-
|
|
157
|
-
class TKey {
|
|
158
|
-
public:
|
|
159
|
-
TKey(TDtor dtor);
|
|
160
|
-
TKey(TKey&&) noexcept;
|
|
161
|
-
~TKey();
|
|
162
|
-
|
|
163
|
-
void* Get() const;
|
|
164
|
-
void Set(void* ptr) const;
|
|
165
|
-
|
|
166
|
-
static void Cleanup() noexcept;
|
|
167
|
-
|
|
168
|
-
private:
|
|
169
|
-
class TImpl;
|
|
170
|
-
THolder<TImpl> Impl_;
|
|
171
|
-
};
|
|
172
|
-
|
|
173
|
-
struct TCleaner {
|
|
174
|
-
inline ~TCleaner() {
|
|
175
|
-
TKey::Cleanup();
|
|
176
|
-
}
|
|
177
|
-
};
|
|
178
|
-
|
|
179
|
-
template <class T>
|
|
180
|
-
class TValue: public TMoveOnly {
|
|
181
|
-
class TConstructor {
|
|
182
|
-
public:
|
|
183
|
-
TConstructor() noexcept = default;
|
|
184
|
-
|
|
185
|
-
virtual ~TConstructor() = default;
|
|
186
|
-
|
|
187
|
-
virtual T* Construct(void* ptr) const = 0;
|
|
188
|
-
};
|
|
189
|
-
|
|
190
|
-
class TDefaultConstructor: public TConstructor {
|
|
191
|
-
public:
|
|
192
|
-
~TDefaultConstructor() override = default;
|
|
193
|
-
|
|
194
|
-
T* Construct(void* ptr) const override {
|
|
195
|
-
//memset(ptr, 0, sizeof(T));
|
|
196
|
-
return ::new (ptr) T();
|
|
197
|
-
}
|
|
198
|
-
};
|
|
199
|
-
|
|
200
|
-
template <class T1>
|
|
201
|
-
class TCopyConstructor: public TConstructor {
|
|
202
|
-
public:
|
|
203
|
-
inline TCopyConstructor(const T1& value)
|
|
204
|
-
: Value(value)
|
|
205
|
-
{
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
~TCopyConstructor() override = default;
|
|
209
|
-
|
|
210
|
-
T* Construct(void* ptr) const override {
|
|
211
|
-
return ::new (ptr) T(Value);
|
|
212
|
-
}
|
|
213
|
-
|
|
214
|
-
private:
|
|
215
|
-
T1 Value;
|
|
216
|
-
};
|
|
217
|
-
|
|
218
|
-
public:
|
|
219
|
-
inline TValue()
|
|
220
|
-
: Constructor_(new TDefaultConstructor())
|
|
221
|
-
, Key_(Dtor)
|
|
222
|
-
{
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
template <class T1>
|
|
226
|
-
inline TValue(const T1& value)
|
|
227
|
-
: Constructor_(new TCopyConstructor<T1>(value))
|
|
228
|
-
, Key_(Dtor)
|
|
229
|
-
{
|
|
230
|
-
}
|
|
231
|
-
|
|
232
|
-
template <class T1>
|
|
233
|
-
inline T& operator=(const T1& val) {
|
|
234
|
-
return Get() = val;
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
inline operator const T&() const {
|
|
238
|
-
return Get();
|
|
239
|
-
}
|
|
240
|
-
|
|
241
|
-
inline operator T&() {
|
|
242
|
-
return Get();
|
|
243
|
-
}
|
|
244
|
-
|
|
245
|
-
inline const T& operator->() const {
|
|
246
|
-
return Get();
|
|
247
|
-
}
|
|
248
|
-
|
|
249
|
-
inline T& operator->() {
|
|
250
|
-
return Get();
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
inline const T* operator&() const {
|
|
254
|
-
return GetPtr();
|
|
255
|
-
}
|
|
256
|
-
|
|
257
|
-
inline T* operator&() {
|
|
258
|
-
return GetPtr();
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
inline T& Get() const {
|
|
262
|
-
return *GetPtr();
|
|
263
|
-
}
|
|
264
|
-
|
|
265
|
-
inline T* GetPtr() const {
|
|
266
|
-
T* val = static_cast<T*>(Key_.Get());
|
|
267
|
-
|
|
268
|
-
if (!val) {
|
|
269
|
-
THolder<void> mem(::operator new(sizeof(T)));
|
|
270
|
-
THolder<T> newval(Constructor_->Construct(mem.Get()));
|
|
271
|
-
|
|
272
|
-
Y_UNUSED(mem.Release());
|
|
273
|
-
Key_.Set((void*)newval.Get());
|
|
274
|
-
val = newval.Release();
|
|
275
|
-
}
|
|
276
|
-
|
|
277
|
-
return val;
|
|
278
|
-
}
|
|
279
|
-
|
|
280
|
-
private:
|
|
281
|
-
static void Dtor(void* ptr) {
|
|
282
|
-
THolder<void> mem(ptr);
|
|
283
|
-
|
|
284
|
-
((T*)ptr)->~T();
|
|
285
|
-
::NPrivate::FillWithTrash(ptr, sizeof(T));
|
|
286
|
-
}
|
|
287
|
-
|
|
288
|
-
private:
|
|
289
|
-
THolder<TConstructor> Constructor_;
|
|
290
|
-
TKey Key_;
|
|
291
|
-
};
|
|
292
|
-
}
|
|
293
|
-
|
|
294
|
-
template <class T>
|
|
295
|
-
static inline T& TlsRef(NTls::TValue<T>& v) noexcept {
|
|
296
|
-
return v;
|
|
297
|
-
}
|
|
298
|
-
|
|
299
|
-
template <class T>
|
|
300
|
-
static inline const T& TlsRef(const NTls::TValue<T>& v) noexcept {
|
|
301
|
-
return v;
|
|
302
|
-
}
|
|
303
|
-
|
|
304
|
-
template <class T>
|
|
305
|
-
static inline T& TlsRef(T& v) noexcept {
|
|
306
|
-
return v;
|
|
307
|
-
}
|