| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446 |
- #define CB_GET(%0) new _cb[E_CALLBACK_DATA]; Callback_Get(cb, _cb, (%0))
- #define CB_CALL(%0) Callback_Call(_cb,%0)
- #define CB_REL() Callback_Release(_cb)
- stock Map(callback:cb, const arr[], dest[], al = sizeof (arr), dl = sizeof (dest))
- {
- CB_GET("i");
- for (new len = min(al, dl), i; i != len; ++i)
- {
- dest[i] = CB_CALL(arr[i]);
- }
- return CB_REL();
- }
- #define Map({%0}%1)%8; LAMBDA_i<Map>{%0}(%1)%8;
- stock Map_(callback:cb, const arr[], len = sizeof (arr))
- {
- CB_GET("i");
- for (new i; i != len; ++i)
- {
- CB_CALL(arr[i]);
- }
- return CB_REL();
- }
- #define Map_({%0}%1)%8; LAMBDA_i<Map_>{%0}(%1)%8;
- stock MapIdx(callback:cb, const arr[], dest[], al = sizeof (arr), dl = sizeof (dest))
- {
- CB_GET("ii");
- for (new len = min(al, dl), i; i != len; ++i)
- {
- dest[i] = CB_CALL(i, arr[i]);
- }
- return CB_REL();
- }
- #define MapIdx({%0}%1)%8; LAMBDA_ii<IdxMap>{%0}(%1)%8;
- stock MapIdx_(callback:cb, const arr[], len = sizeof (arr))
- {
- CB_GET("ii");
- for (new i; i != len; ++i)
- {
- CB_CALL(i, arr[i]);
- }
- return CB_REL();
- }
- #define MapIdx_({%0}%1)%8; LAMBDA_ii<IdxMap_>{%0}(%1)%8;
- stock ZipWith(callback:cb, const l[], const r[], dest[], ls = sizeof (l), rs = sizeof (r), ds = sizeof (dest))
- {
- CB_GET("ii");
- for (new len = min(ds, min(ls, rs)), i; i != len; ++i)
- {
- dest[i] = CB_CALL(l[i], r[i]);
- }
- return CB_REL();
- }
- #define ZipWith({%0}%1)%8; LAMBDA_ii<ZipWith>{%0}(%1)%8;
- stock ZipWith_(callback:cb, const l[], const r[], ls = sizeof (l), rs = sizeof (r))
- {
- CB_GET("ii");
- for (new len = min(ls, rs), i; i != len; ++i)
- {
- CB_CALL(l[i], r[i]);
- }
- return CB_REL();
- }
- #define ZipWith_({%0}%1)%8; LAMBDA_ii<ZipWith_>{%0}(%1)%8;
- stock ZipWith3(callback:cb, const l[], const m[], const r[], dest[], ls = sizeof (l), ms = sizeof (m), rs = sizeof (r), ds = sizeof (dest))
- {
- CB_GET("iii");
- for (new len = min(min(ms, ds), min(ls, rs)), i; i != len; ++i)
- {
- dest[i] = CB_CALL(l[i], m[i], r[i]);
- }
- return CB_REL();
- }
- #define ZipWith3({%0}%1)%8; LAMBDA_iii<ZipWith3>{%0}(%1)%8;
- stock ZipWith3_(callback:cb, const l[], const m[], const r[], ls = sizeof (l), ms = sizeof (m), rs = sizeof (r))
- {
- CB_GET("iii");
- for (new len = min(ms, min(ls, rs)), i; i != len; ++i)
- {
- CB_CALL(l[i], m[i], r[i]);
- }
- return CB_REL();
- }
- #define ZipWith3_({%0}%1)%8; LAMBDA_iii<ZipWith3_>{%0}(%1)%8;
- stock ZipWithIdx(callback:cb, const l[], const r[], dest[], ls = sizeof (l), rs = sizeof (r), ds = sizeof (dest))
- {
- CB_GET("iii");
- for (new len = min(ds, min(ls, rs)), i; i != len; ++i)
- {
- dest[i] = CB_CALL(i, l[i], r[i]);
- }
- return CB_REL();
- }
- #define ZipWithIdx({%0}%1)%8; LAMBDA_ii<ZipWith>{%0}(%1)%8;
- stock ZipWithIdx_(callback:cb, const l[], const r[], ls = sizeof (l), rs = sizeof (r))
- {
- CB_GET("iii");
- for (new len = min(ls, rs), i; i != len; ++i)
- {
- CB_CALL(i, l[i], r[i]);
- }
- return CB_REL();
- }
- #define ZipWithIdx_({%0}%1)%8; LAMBDA_ii<ZipWith_>{%0}(%1)%8;
- stock ZipWith3Idx(callback:cb, const l[], const m[], const r[], dest[], ls = sizeof (l), ms = sizeof (m), rs = sizeof (r), ds = sizeof (dest))
- {
- CB_GET("iiii");
- for (new len = min(min(ms, ds), min(ls, rs)), i; i != len; ++i)
- {
- dest[i] = CB_CALL(i, l[i], m[i], r[i]);
- }
- return CB_REL();
- }
- #define ZipWith3Idx({%0}%1)%8; LAMBDA_iii<ZipWith3>{%0}(%1)%8;
- stock ZipWith3Idx_(callback:cb, const l[], const m[], const r[], ls = sizeof (l), ms = sizeof (m), rs = sizeof (r))
- {
- CB_GET("iiii");
- for (new len = min(ms, min(ls, rs)), i; i != len; ++i)
- {
- CB_CALL(i, l[i], m[i], r[i]);
- }
- return CB_REL();
- }
- #define ZipWith3Idx_({%0}%1)%8; LAMBDA_iii<ZipWith3_>{%0}(%1)%8;
- stock FoldLIdx(callback:cb, n, const arr[], len = sizeof (arr))
- {
- CB_GET("iii");
- new
- cur = n;
- for (new i = 0; i != len; ++i)
- {
- cur = CB_CALL(i, cur, arr[i]);
- }
- return
- CB_REL(),
- cur;
- }
- #define FoldLIdx({%0}%1)%8; LAMBDA_ii<FoldL>{%0}(%1)%8;
- stock ScanLIdx(callback:cb, n, const arr[], dest[], al = sizeof (arr), dl = sizeof (dest))
- {
- if (!dl) return 0;
- CB_GET("iii");
- new
- len = min(al, dl - 1),
- i = -1,
- cur = n;
- while (++i != len)
- {
- dest[i] = cur,
- cur = CB_CALL(i, cur, arr[i]);
- }
- dest[i] = cur;
- return
- CB_REL(),
- 1;
- }
- #define ScanLIdx({%0}%1)%8; LAMBDA_ii<ScanL>{%0}(%1)%8;
- stock FoldRIdx(callback:cb, const arr[], n, len = sizeof (arr))
- {
- CB_GET("iii");
- new
- cur = n;
- while (len--)
- {
- cur = CB_CALL(i, arr[len], cur);
- }
- return
- CB_REL(),
- cur;
- }
- #define FoldRIdx({%0}%1)%8; LAMBDA_ii<FoldR>{%0}(%1)%8;
- stock ScanRIdx(callback:cb, n, const arr[], dest[], al = sizeof (arr), dl = sizeof (dest))
- {
- if (!dl) return 0;
- CB_GET("iii");
- new
- len = min(al, dl - 1),
- cur = n;
- dest[len] = cur;
- while (len--)
- {
- dest[len] = cur = CB_CALL(i, arr[len], cur);
- }
- return
- CB_REL(),
- 1;
- }
- #define ScanRIdx({%0}%1)%8; LAMBDA_ii<ScanR>{%0}(%1)%8;
- stock FoldL1Idx(callback:cb, const arr[], len = sizeof (arr))
- {
- assert(len > 0);
- CB_GET("iii");
- new
- cur = arr[0];
- for (new i = 1; i != len; ++i)
- {
- cur = CB_CALL(i, cur, arr[i]);
- }
- return
- CB_REL(),
- cur;
- }
- #define FoldL1Idx({%0}%1)%8; LAMBDA_ii<FoldL1>{%0}(%1)%8;
- stock FoldR1Idx(callback:cb, const arr[], len = sizeof (arr))
- {
- assert(len > 0);
- CB_GET("iii");
- new
- cur = arr[--len];
- while (len--)
- {
- cur = CB_CALL(i, arr[len], cur);
- }
- return
- CB_REL(),
- cur;
- }
- #define FoldR1Idx({%0}%1)%8; LAMBDA_ii<FoldR1>{%0}(%1)%8;
- stock FoldL(callback:cb, n, const arr[], len = sizeof (arr))
- {
- CB_GET("ii");
- new
- cur = n;
- for (new i = 0; i != len; ++i)
- {
- cur = CB_CALL(cur, arr[i]);
- }
- return
- CB_REL(),
- cur;
- }
- #define FoldL({%0}%1)%8; LAMBDA_ii<FoldL>{%0}(%1)%8;
- stock ScanL(callback:cb, n, const arr[], dest[], al = sizeof (arr), dl = sizeof (dest))
- {
- if (!dl) return 0;
- CB_GET("ii");
- new
- len = min(al, dl - 1),
- i = -1,
- cur = n;
- while (++i != len)
- {
- dest[i] = cur,
- cur = CB_CALL(cur, arr[i]);
- }
- dest[i] = cur;
- return
- CB_REL(),
- 1;
- }
- #define ScanL({%0}%1)%8; LAMBDA_ii<ScanL>{%0}(%1)%8;
- stock FoldR(callback:cb, const arr[], n, len = sizeof (arr))
- {
- CB_GET("ii");
- new
- cur = n;
- while (len--)
- {
- cur = CB_CALL(arr[len], cur);
- }
- return
- CB_REL(),
- cur;
- }
- #define FoldR({%0}%1)%8; LAMBDA_ii<FoldR>{%0}(%1)%8;
- stock ScanR(callback:cb, n, const arr[], dest[], al = sizeof (arr), dl = sizeof (dest))
- {
- if (!dl) return 0;
- CB_GET("ii");
- new
- len = min(al, dl - 1),
- cur = n;
- dest[len] = cur;
- while (len--)
- {
- dest[len] = cur = CB_CALL(arr[len], cur);
- }
- return
- CB_REL(),
- 1;
- }
- #define ScanR({%0}%1)%8; LAMBDA_ii<ScanR>{%0}(%1)%8;
- stock FoldL1(callback:cb, const arr[], len = sizeof (arr))
- {
- assert(len > 0);
- CB_GET("ii");
- new
- cur = arr[0];
- for (new i = 1; i != len; ++i)
- {
- cur = CB_CALL(cur, arr[i]);
- }
- return
- CB_REL(),
- cur;
- }
- #define FoldL1({%0}%1)%8; LAMBDA_ii<FoldL1>{%0}(%1)%8;
- stock FoldR1(callback:cb, const arr[], len = sizeof (arr))
- {
- assert(len > 0);
- CB_GET("ii");
- new
- cur = arr[--len];
- while (len--)
- {
- cur = CB_CALL(arr[len], cur);
- }
- return
- CB_REL(),
- cur;
- }
- #define FoldR1({%0}%1)%8; LAMBDA_ii<FoldR1>{%0}(%1)%8;
- stock bool:And(bool:arr[], len = sizeof (arr))
- {
- while (len--)
- {
- if (!arr[len]) return false;
- }
- return true;
- }
- stock bool:Or(bool:arr[], len = sizeof (arr))
- {
- while (len--)
- {
- if (arr[len]) return true;
- }
- return false;
- }
- stock bool:All(callback:cb, const arr[], len = sizeof (arr))
- {
- CB_GET("i");
- for (new i; i != len; ++i)
- {
- if (!CB_CALL(arr[i])) return CB_REL(), false;
- }
- return
- CB_REL(),
- true;
- }
- #define All({%0}%1)%8; LAMBDA_i<All>{%0}(%1)%8;
- stock bool:Any(callback:cb, const arr[], len = sizeof (arr))
- {
- CB_GET("i");
- for (new i; i != len; ++i)
- {
- if (CB_CALL(arr[i])) return CB_REL(), true;
- }
- return
- CB_REL(),
- false;
- }
- #define Any({%0}%1)%8; LAMBDA_i<Any>{%0}(%1)%8;
- stock bool:AllIdx(callback:cb, const arr[], len = sizeof (arr))
- {
- CB_GET("ii");
- for (new i; i != len; ++i)
- {
- if (!CB_CALL(i, arr[i])) return CB_REL(), false;
- }
- return
- CB_REL(),
- true;
- }
- #define AllIdx({%0}%1)%8; LAMBDA_i<All>{%0}(%1)%8;
- stock bool:AnyIdx(callback:cb, const arr[], len = sizeof (arr))
- {
- CB_GET("ii");
- for (new i; i != len; ++i)
- {
- if (CB_CALL(i, arr[i])) return CB_REL(), true;
- }
- return
- CB_REL(),
- false;
- }
- #define AnyIdx({%0}%1)%8; LAMBDA_i<Any>{%0}(%1)%8;
- stock Reverse(const arr[], len = sizeof (arr))
- {
- new
- temp;
- for (new i = 0; j = len - 1; i < j; ++i, --j)
- {
- temp = arr[i],
- arr[i] = arr[j],
- arr[j] = temp;
- }
- return 1;
- }
- stock bool:Elem(n, const arr[], len = sizeof (arr))
- {
- while (len--)
- {
- if (arr[len] == n) return true;
- }
- return false;
- }
- stock bool:NotElem(n, const arr[], len = sizeof (arr))
- {
- while (len--)
- {
- if (arr[len] == n) return false;
- }
- return true;
- }
- #undef CB_GET
- #undef CB_CALL
- #undef CB_REL
- #define Just(%0) (YSI_gJust=_:%0,1)
- #define Nothing (0)
|