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
package/inc/util/generic/is_in.h
DELETED
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include "typetraits.h"
|
|
4
|
-
|
|
5
|
-
#include <algorithm>
|
|
6
|
-
#include <initializer_list>
|
|
7
|
-
|
|
8
|
-
template <class I, class T>
|
|
9
|
-
static inline bool IsIn(I f, I l, const T& v);
|
|
10
|
-
|
|
11
|
-
template <class C, class T>
|
|
12
|
-
static inline bool IsIn(const C& c, const T& e);
|
|
13
|
-
|
|
14
|
-
namespace NIsInHelper {
|
|
15
|
-
Y_HAS_MEMBER(find, FindMethod);
|
|
16
|
-
Y_HAS_SUBTYPE(const_iterator, ConstIterator);
|
|
17
|
-
Y_HAS_SUBTYPE(key_type, KeyType);
|
|
18
|
-
|
|
19
|
-
template <class T>
|
|
20
|
-
using TIsAssocCont = TConjunction<THasFindMethod<T>, THasConstIterator<T>, THasKeyType<T>>;
|
|
21
|
-
|
|
22
|
-
template <class C, class T, bool isAssoc>
|
|
23
|
-
struct TIsInTraits {
|
|
24
|
-
static bool IsIn(const C& c, const T& e) {
|
|
25
|
-
using std::begin;
|
|
26
|
-
using std::end;
|
|
27
|
-
return ::IsIn(begin(c), end(c), e);
|
|
28
|
-
}
|
|
29
|
-
};
|
|
30
|
-
|
|
31
|
-
template <class C, class T>
|
|
32
|
-
struct TIsInTraits<C, T, true> {
|
|
33
|
-
static bool IsIn(const C& c, const T& e) {
|
|
34
|
-
return c.find(e) != c.end();
|
|
35
|
-
}
|
|
36
|
-
};
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
template <class I, class T>
|
|
40
|
-
static inline bool IsIn(I f, I l, const T& v) {
|
|
41
|
-
return std::find(f, l, v) != l;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
template <class C, class T>
|
|
45
|
-
static inline bool IsIn(const C& c, const T& e) {
|
|
46
|
-
using namespace NIsInHelper;
|
|
47
|
-
return TIsInTraits<C, T, TIsAssocCont<C>::value>::IsIn(c, e);
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
template <class T, class U>
|
|
51
|
-
static inline bool IsIn(std::initializer_list<T> l, const U& e) {
|
|
52
|
-
return ::IsIn(l.begin(), l.end(), e);
|
|
53
|
-
}
|
|
@@ -1,137 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include <iterator>
|
|
4
|
-
#include <utility>
|
|
5
|
-
|
|
6
|
-
namespace NStlIterator {
|
|
7
|
-
template <class T>
|
|
8
|
-
class TProxy {
|
|
9
|
-
public:
|
|
10
|
-
TProxy() = default;
|
|
11
|
-
TProxy(T&& value) : Value_(std::move(value)) {
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
const T* operator->() const noexcept {
|
|
15
|
-
return &Value_;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
const T& operator*() const noexcept {
|
|
19
|
-
return Value_;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
bool operator==(const TProxy& rhs) const {
|
|
23
|
-
return Value_ == rhs.Value_;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
private:
|
|
27
|
-
T Value_;
|
|
28
|
-
};
|
|
29
|
-
} // namespace NStlIterator
|
|
30
|
-
|
|
31
|
-
/**
|
|
32
|
-
* Range adaptor that turns a derived class with a Java-style iteration
|
|
33
|
-
* interface into an STL range.
|
|
34
|
-
*
|
|
35
|
-
* Derived class is expected to define:
|
|
36
|
-
* \code
|
|
37
|
-
* TSomething* Next();
|
|
38
|
-
* \endcode
|
|
39
|
-
*
|
|
40
|
-
* `Next()` returning `nullptr` signals end of range. Note that you can also use
|
|
41
|
-
* pointer-like types instead of actual pointers (e.g. `TAtomicSharedPtr`).
|
|
42
|
-
*
|
|
43
|
-
* Since iteration state is stored inside the derived class, the resulting range
|
|
44
|
-
* is an input range (works for single pass algorithms only). Technically speaking,
|
|
45
|
-
* if you're returning a non-const pointer from `Next`, it can also work as an output range.
|
|
46
|
-
*
|
|
47
|
-
* Example usage:
|
|
48
|
-
* \code
|
|
49
|
-
* class TSquaresGenerator: public TInputRangeAdaptor<TSquaresGenerator> {
|
|
50
|
-
* public:
|
|
51
|
-
* const double* Next() {
|
|
52
|
-
* Current_ = State_ * State_;
|
|
53
|
-
* State_ += 1.0;
|
|
54
|
-
* // Never return nullptr => we have infinite range!
|
|
55
|
-
* return &Current_;
|
|
56
|
-
* }
|
|
57
|
-
*
|
|
58
|
-
* private:
|
|
59
|
-
* double State_ = 0.0;
|
|
60
|
-
* double Current_ = 0.0;
|
|
61
|
-
* }
|
|
62
|
-
* \endcode
|
|
63
|
-
*/
|
|
64
|
-
template <class TSlave>
|
|
65
|
-
class TInputRangeAdaptor {
|
|
66
|
-
public: // TODO: private
|
|
67
|
-
class TIterator {
|
|
68
|
-
public:
|
|
69
|
-
static constexpr bool IsNoexceptNext = noexcept(std::declval<TSlave>().Next());
|
|
70
|
-
|
|
71
|
-
using difference_type = std::ptrdiff_t;
|
|
72
|
-
using pointer = decltype(std::declval<TSlave>().Next());
|
|
73
|
-
using reference = decltype(*std::declval<TSlave>().Next());
|
|
74
|
-
using value_type = std::remove_cv_t<std::remove_reference_t<reference>>;
|
|
75
|
-
using iterator_category = std::input_iterator_tag;
|
|
76
|
-
|
|
77
|
-
inline TIterator() noexcept
|
|
78
|
-
: Slave_(nullptr)
|
|
79
|
-
, Cur_()
|
|
80
|
-
{
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
inline TIterator(TSlave* slave) noexcept(IsNoexceptNext)
|
|
84
|
-
: Slave_(slave)
|
|
85
|
-
, Cur_(Slave_->Next())
|
|
86
|
-
{
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
inline bool operator==(const TIterator& it) const noexcept {
|
|
90
|
-
return Cur_ == it.Cur_;
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
inline bool operator!=(const TIterator& it) const noexcept {
|
|
94
|
-
return !(*this == it);
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
inline pointer operator->() const noexcept {
|
|
98
|
-
return Cur_;
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
inline reference operator*() const noexcept {
|
|
102
|
-
return *Cur_;
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
inline TIterator& operator++() noexcept(IsNoexceptNext) {
|
|
106
|
-
Cur_ = Slave_->Next();
|
|
107
|
-
|
|
108
|
-
return *this;
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
private:
|
|
112
|
-
TSlave* Slave_;
|
|
113
|
-
pointer Cur_;
|
|
114
|
-
};
|
|
115
|
-
|
|
116
|
-
public:
|
|
117
|
-
using const_iterator = TIterator;
|
|
118
|
-
using iterator = const_iterator;
|
|
119
|
-
|
|
120
|
-
inline iterator begin() const noexcept(TIterator::IsNoexceptNext) {
|
|
121
|
-
return TIterator(const_cast<TSlave*>(static_cast<const TSlave*>(this)));
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
inline iterator end() const noexcept {
|
|
125
|
-
return TIterator();
|
|
126
|
-
}
|
|
127
|
-
};
|
|
128
|
-
|
|
129
|
-
/**
|
|
130
|
-
* Transform given reverse iterator into forward iterator pointing to the same element.
|
|
131
|
-
*
|
|
132
|
-
* @see http://stackoverflow.com/a/1830240
|
|
133
|
-
*/
|
|
134
|
-
template <class TIterator>
|
|
135
|
-
auto ToForwardIterator(TIterator iter) {
|
|
136
|
-
return std::next(iter).base();
|
|
137
|
-
}
|
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include <util/system/yassert.h>
|
|
4
|
-
|
|
5
|
-
#include <iterator>
|
|
6
|
-
#include <utility>
|
|
7
|
-
|
|
8
|
-
template <typename TBegin, typename TEnd = TBegin>
|
|
9
|
-
struct TIteratorRange {
|
|
10
|
-
using TElement = std::remove_reference_t<decltype(*std::declval<TBegin>())>;
|
|
11
|
-
|
|
12
|
-
TIteratorRange(TBegin begin, TEnd end)
|
|
13
|
-
: Begin_(begin)
|
|
14
|
-
, End_(end)
|
|
15
|
-
{
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
TIteratorRange()
|
|
19
|
-
: TIteratorRange(TBegin{}, TEnd{})
|
|
20
|
-
{
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
TBegin begin() const {
|
|
24
|
-
return Begin_;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
TEnd end() const {
|
|
28
|
-
return End_;
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
bool empty() const {
|
|
32
|
-
// because range based for requires exactly '!='
|
|
33
|
-
return !(Begin_ != End_);
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
private:
|
|
37
|
-
TBegin Begin_;
|
|
38
|
-
TEnd End_;
|
|
39
|
-
};
|
|
40
|
-
|
|
41
|
-
template <class TIterator>
|
|
42
|
-
class TIteratorRange<TIterator, TIterator> {
|
|
43
|
-
public:
|
|
44
|
-
using iterator = TIterator;
|
|
45
|
-
using const_iterator = TIterator;
|
|
46
|
-
using value_type = typename std::iterator_traits<iterator>::value_type;
|
|
47
|
-
using reference = typename std::iterator_traits<iterator>::reference;
|
|
48
|
-
using const_reference = typename std::iterator_traits<const_iterator>::reference;
|
|
49
|
-
using difference_type = typename std::iterator_traits<iterator>::difference_type;
|
|
50
|
-
using size_type = std::size_t;
|
|
51
|
-
|
|
52
|
-
TIteratorRange()
|
|
53
|
-
: Begin_()
|
|
54
|
-
, End_()
|
|
55
|
-
{
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
TIteratorRange(TIterator begin, TIterator end)
|
|
59
|
-
: Begin_(begin)
|
|
60
|
-
, End_(end)
|
|
61
|
-
{
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
TIterator begin() const {
|
|
65
|
-
return Begin_;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
TIterator end() const {
|
|
69
|
-
return End_;
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
Y_PURE_FUNCTION
|
|
73
|
-
bool empty() const {
|
|
74
|
-
return Begin_ == End_;
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
size_type size() const {
|
|
78
|
-
return End_ - Begin_;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
reference operator[](size_t at) const {
|
|
82
|
-
Y_ASSERT(at < size());
|
|
83
|
-
|
|
84
|
-
return *(Begin_ + at);
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
private:
|
|
88
|
-
TIterator Begin_;
|
|
89
|
-
TIterator End_;
|
|
90
|
-
};
|
|
91
|
-
|
|
92
|
-
template <class TIterator>
|
|
93
|
-
TIteratorRange<TIterator> MakeIteratorRange(TIterator begin, TIterator end) {
|
|
94
|
-
return TIteratorRange<TIterator>(begin, end);
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
template <class TIterator>
|
|
98
|
-
TIteratorRange<TIterator> MakeIteratorRange(const std::pair<TIterator, TIterator>& range) {
|
|
99
|
-
return TIteratorRange<TIterator>(range.first, range.second);
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
template <class TBegin, class TEnd>
|
|
103
|
-
TIteratorRange<TBegin, TEnd> MakeIteratorRange(TBegin begin, TEnd end) {
|
|
104
|
-
return {begin, end};
|
|
105
|
-
}
|
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include "maybe.h"
|
|
4
|
-
#include "function.h"
|
|
5
|
-
|
|
6
|
-
template <class T>
|
|
7
|
-
class TLazyValueBase {
|
|
8
|
-
public:
|
|
9
|
-
using TInitializer = std::function<T()>;
|
|
10
|
-
|
|
11
|
-
TLazyValueBase() = default;
|
|
12
|
-
|
|
13
|
-
TLazyValueBase(TInitializer initializer)
|
|
14
|
-
: Initializer(std::move(initializer))
|
|
15
|
-
{
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
explicit operator bool() const noexcept {
|
|
19
|
-
return Defined();
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
bool Defined() const noexcept {
|
|
23
|
-
return ValueHolder.Defined();
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
const T& GetRef() const {
|
|
27
|
-
if (!Defined()) {
|
|
28
|
-
InitDefault();
|
|
29
|
-
}
|
|
30
|
-
return *ValueHolder;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
const T& operator*() const {
|
|
34
|
-
return GetRef();
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
const T* operator->() const {
|
|
38
|
-
return &GetRef();
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
void InitDefault() const {
|
|
42
|
-
Y_ASSERT(Initializer);
|
|
43
|
-
ValueHolder = Initializer();
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
private:
|
|
47
|
-
mutable TMaybe<T> ValueHolder;
|
|
48
|
-
TInitializer Initializer;
|
|
49
|
-
};
|
|
50
|
-
|
|
51
|
-
// we need this to get implicit construction TLazyValue from lambda
|
|
52
|
-
// and save default copy constructor and operator= for type TLazyValue
|
|
53
|
-
template <class T>
|
|
54
|
-
class TLazyValue: public TLazyValueBase<T> {
|
|
55
|
-
public:
|
|
56
|
-
template <typename... TArgs>
|
|
57
|
-
TLazyValue(TArgs&&... args)
|
|
58
|
-
: TLazyValueBase<T>(std::forward<TArgs>(args)...)
|
|
59
|
-
{
|
|
60
|
-
}
|
|
61
|
-
};
|
|
62
|
-
|
|
63
|
-
template <typename F>
|
|
64
|
-
TLazyValue<TFunctionResult<F>> MakeLazy(F&& f) {
|
|
65
|
-
return {std::forward<F>(f)};
|
|
66
|
-
}
|
package/inc/util/generic/list.h
DELETED
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include "fwd.h"
|
|
4
|
-
|
|
5
|
-
#include <util/memory/alloc.h>
|
|
6
|
-
|
|
7
|
-
#include <initializer_list>
|
|
8
|
-
#include <list>
|
|
9
|
-
#include <memory>
|
|
10
|
-
#include <utility>
|
|
11
|
-
|
|
12
|
-
template <class T, class A>
|
|
13
|
-
class TList: public std::list<T, TReboundAllocator<A, T>> {
|
|
14
|
-
using TBase = std::list<T, TReboundAllocator<A, T>>;
|
|
15
|
-
|
|
16
|
-
public:
|
|
17
|
-
using TBase::TBase;
|
|
18
|
-
|
|
19
|
-
inline explicit operator bool() const noexcept {
|
|
20
|
-
return !this->empty();
|
|
21
|
-
}
|
|
22
|
-
};
|
package/inc/util/generic/map.h
DELETED
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include "fwd.h"
|
|
4
|
-
#include "mapfindptr.h"
|
|
5
|
-
|
|
6
|
-
#include <util/str_stl.h>
|
|
7
|
-
#include <util/memory/alloc.h>
|
|
8
|
-
|
|
9
|
-
#include <utility>
|
|
10
|
-
#include <initializer_list>
|
|
11
|
-
#include <map>
|
|
12
|
-
#include <memory>
|
|
13
|
-
|
|
14
|
-
template <class K, class V, class Less, class A>
|
|
15
|
-
class TMap: public std::map<K, V, Less, TReboundAllocator<A, std::pair<const K, V>>>, public TMapOps<TMap<K, V, Less, A>> {
|
|
16
|
-
using TBase = std::map<K, V, Less, TReboundAllocator<A, std::pair<const K, V>>>;
|
|
17
|
-
|
|
18
|
-
public:
|
|
19
|
-
using TBase::TBase;
|
|
20
|
-
|
|
21
|
-
inline explicit operator bool() const noexcept {
|
|
22
|
-
return !this->empty();
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
inline bool contains(const K& key) const {
|
|
26
|
-
return this->find(key) != this->end();
|
|
27
|
-
}
|
|
28
|
-
};
|
|
29
|
-
|
|
30
|
-
template <class K, class V, class Less, class A>
|
|
31
|
-
class TMultiMap: public std::multimap<K, V, Less, TReboundAllocator<A, std::pair<const K, V>>> {
|
|
32
|
-
using TBase = std::multimap<K, V, Less, TReboundAllocator<A, std::pair<const K, V>>>;
|
|
33
|
-
|
|
34
|
-
public:
|
|
35
|
-
using TBase::TBase;
|
|
36
|
-
|
|
37
|
-
inline explicit operator bool() const noexcept {
|
|
38
|
-
return !this->empty();
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
inline bool contains(const K& key) const {
|
|
42
|
-
return this->find(key) != this->end();
|
|
43
|
-
}
|
|
44
|
-
};
|
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include <type_traits>
|
|
4
|
-
|
|
5
|
-
/** MapFindPtr usage:
|
|
6
|
-
|
|
7
|
-
if (T* value = MapFindPtr(myMap, someKey) {
|
|
8
|
-
Cout << *value;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
*/
|
|
12
|
-
|
|
13
|
-
template <class Map, class K>
|
|
14
|
-
inline auto MapFindPtr(Map& map, const K& key) {
|
|
15
|
-
auto i = map.find(key);
|
|
16
|
-
|
|
17
|
-
return (i == map.end() ? nullptr : &i->second);
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
template <class Map, class K>
|
|
21
|
-
inline auto MapFindPtr(const Map& map, const K& key) {
|
|
22
|
-
auto i = map.find(key);
|
|
23
|
-
|
|
24
|
-
return (i == map.end() ? nullptr : &i->second);
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
/** helper for THashMap/TMap */
|
|
28
|
-
template <class Derived>
|
|
29
|
-
struct TMapOps {
|
|
30
|
-
template <class K>
|
|
31
|
-
inline auto FindPtr(const K& key) {
|
|
32
|
-
return MapFindPtr(static_cast<Derived&>(*this), key);
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
template <class K>
|
|
36
|
-
inline auto FindPtr(const K& key) const {
|
|
37
|
-
return MapFindPtr(static_cast<const Derived&>(*this), key);
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
template <class K, class DefaultValue>
|
|
41
|
-
inline auto Value(const K& key, const DefaultValue& defaultValue) const -> std::remove_reference_t<decltype(*this->FindPtr(key))> {
|
|
42
|
-
if (auto found = FindPtr(key)) {
|
|
43
|
-
return *found;
|
|
44
|
-
}
|
|
45
|
-
return defaultValue;
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
template <class K, class V>
|
|
49
|
-
inline const V& ValueRef(const K& key, V& defaultValue) const {
|
|
50
|
-
static_assert(std::is_same<std::remove_const_t<V>, typename Derived::mapped_type>::value, "Passed default value must have the same type as the underlying map's mapped_type.");
|
|
51
|
-
|
|
52
|
-
if (auto found = FindPtr(key)) {
|
|
53
|
-
return *found;
|
|
54
|
-
}
|
|
55
|
-
return defaultValue;
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
template <class K, class V>
|
|
59
|
-
inline const V& ValueRef(const K& key, V&& defaultValue) const = delete;
|
|
60
|
-
};
|