jk.c 87 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610
  1. /* jk intepreter, by @txlyre,www:txlyre.website, in the public domain */
  2. #include<ctype.h>
  3. #include<limits.h>
  4. #include<math.h>
  5. #include<setjmp.h>
  6. #include<stdbool.h>
  7. #include<stdint.h>
  8. #include<stdio.h>
  9. #include<stdlib.h>
  10. #include<string.h>
  11. #include<time.h>
  12. #include<unistd.h>
  13. #include<sys/wait.h>
  14. #include<errno.h>
  15. #include<gc.h>
  16. #define R return
  17. #define BR break
  18. #define CN continue
  19. #define WH while
  20. #define SW switch
  21. #define CS case
  22. #define T true
  23. #define F false
  24. #define N NULL
  25. #define LOOP for(;;)
  26. #define elif else if
  27. #define FR(p) GC_FREE(p)
  28. #define xt ((x)->tag)
  29. #define yt ((y)->tag)
  30. #define xa ((x)->val.array)
  31. #define ya ((y)->val.array)
  32. #define xn ((x)->val.number)
  33. #define yn ((y)->val.number)
  34. #define vn ((v)->val.number)
  35. #define xV ((x)->val.verb)
  36. #define yV ((y)->val.verb)
  37. #define xY ((x)->val.symbol)
  38. #define yY ((y)->val.symbol)
  39. typedef uint32_t U32;
  40. typedef uint64_t U64;
  41. typedef double D;
  42. typedef unsigned char UC;
  43. typedef char C;
  44. typedef char *S;
  45. typedef ssize_t SZ;
  46. typedef size_t Z;
  47. typedef bool B;
  48. typedef unsigned int UI;
  49. typedef int I;
  50. typedef void *P;
  51. typedef void V;
  52. typedef const char *cS;
  53. #define SO(t) (sizeof(t))
  54. #define AE(x)(SO(x)/SO((x)[0]))
  55. #define ROTL32(x, r) ((x << r) | (x >> (32 - r)))
  56. #define FMIX32(h) \
  57. h ^= h >> 16; \
  58. h *= 0x85ebca6b; \
  59. h ^= h >> 13; \
  60. h *= 0xc2b2ae35; \
  61. h ^= h >> 16;
  62. #define TABLE_MIN_SIZE 32
  63. jmp_buf Icp;
  64. B Iin;
  65. P ma(Z size){P p;
  66. if(!(p=GC_MALLOC(size)))abort();R p;}
  67. P maa(Z size){P p;
  68. if(!(p=GC_malloc_atomic(size)))abort();
  69. memset(p,0,size);R p;}
  70. P mau(Z size){P p;
  71. if(!(p=GC_malloc_uncollectable(size)))abort();
  72. memset(p,0,size);R p;}
  73. P mrea(P p,Z size){if(!(p=GC_REALLOC(p,size)))abort();R p;}
  74. S sdup(S s){S p=GC_strdup(s);
  75. if(!p)abort();R p;}
  76. typedef struct _Lst Lst;
  77. struct _Lst{P value;
  78. Lst*next;};
  79. Lst*ln(void){Lst*list=ma(SO(Lst));
  80. list->value=N;
  81. list->next=N;R list;}
  82. B le(Lst*list){R(!(list)->value);}
  83. Z ll(Lst*list){Z length=0;
  84. if(le(list))R length;
  85. do{list=list->next,length++;}WH(list);R length;}
  86. P li(Lst*list,SZ index){Z length;
  87. if(le(list))R N;
  88. if(index==0)R list->value;
  89. length=ll(list);
  90. if(index<0)index+=((SZ)length);
  91. if(index<0||index>=length)R N;
  92. for(Z i=0;i<((Z)index);i++)list=list->next;R list->value;}
  93. Lst*lp(Lst*list,P value){Lst*head=list;
  94. if(le(list)){list->value=value;R head;}
  95. WH(list->next)list=list->next;
  96. list=list->next=ln();
  97. list->value=value;R head;}
  98. Lst*lc(Lst*l){Lst*r=ln();
  99. if(!le(l))WH(l){lp(r,l->value);
  100. l=l->next;}
  101. R r;}
  102. P lP(Lst*list){if(le(list))R N;
  103. if(!list->next){P value=list->value;
  104. list->value=N;R value;}
  105. Lst*head=list;
  106. WH(list){if(!list->next){P value=list->value;
  107. list->value=N;
  108. head->next=N;R value;}
  109. head=list;
  110. list=list->next;}
  111. R N;}
  112. P ls(Lst*list,SZ index,P value){Z length=ll(list);
  113. if(index<0)index+=((SZ)length);
  114. if(index==((SZ)length)){lp(list,value);R value;}
  115. if(index<0||index>=length)R N;
  116. for(Z i=0;i<((Z)index);i++)list=list->next;
  117. list->value=value;R value;}
  118. Lst*lI(Lst**list,SZ index,P value){Lst*head=*list;
  119. if(index==-1)R lp(head,value);
  120. Z length=ll(head);
  121. if(index<0)index+=(SZ)length;
  122. if(index<0||index>length)R N;
  123. if(index==-1)R lp(head,value);
  124. if(index==0){if(le(head))R lp(head,value);
  125. Lst*temp=ln();
  126. temp->value=value;
  127. temp->next=head;
  128. *list=temp;R temp;}
  129. Lst*temp0=*list;
  130. for(Z i=0;i<((Z)index)-1;i++)temp0=temp0->next;
  131. Lst*temp=temp0->next;
  132. temp0->next=ln();
  133. temp0->next->value=value;
  134. temp0->next->next=temp;R head;}
  135. Lst*ld(Lst**list,SZ index){Lst*head=*list;
  136. if(le(head))R N;
  137. Z length=ll(head);
  138. if(index<0)index+=(SZ)length;
  139. if(index<0||index>=length)R N;
  140. if(index==0){head->value=N;
  141. if(!head->next)R head;
  142. *list=head->next;
  143. return*list;}
  144. Lst*temp0=*list;
  145. for(Z i=0;i<((Z)index)-1;i++)temp0=temp0->next;
  146. Lst*temp=temp0->next;
  147. temp->value=N;
  148. temp0->next=temp->next;R head;}
  149. Lst*lS(Lst*list,bool(*cmp)(P ,P )){Z l=ll(list);
  150. B s;
  151. for(Z i=0;i<l;i++){Lst*t=list;
  152. Lst*p=list;
  153. s=F;
  154. WH(t->next){Lst*n=t->next;
  155. if(cmp(t->value,n->value)){s=T;
  156. if(t==list){t->next=n->next;
  157. n->next=t;
  158. p=n;
  159. list=p;}else{t->next=n->next;
  160. n->next=t;
  161. p->next=n;
  162. p=n;}
  163. CN;}
  164. p=t;
  165. t=t->next;}
  166. if(!s)BR;}
  167. R list;}
  168. typedef struct{S str;
  169. Z used;
  170. Z allocated;}Bt;
  171. Bt*Bnew(void){Bt*buf=ma(SO(Bt));
  172. buf->str=N;
  173. buf->used=buf->allocated=0;R buf;}
  174. V Bappend(Bt*buf,C c){buf->used++;
  175. if(buf->used>buf->allocated){buf->allocated++;
  176. buf->str=mrea(buf->str,SO(char)*buf->allocated);}
  177. buf->str[buf->used-1]=c;}
  178. S Bread(Bt*buf){if(buf->used==0||buf->str[buf->used-1])Bappend(buf,0);
  179. S str=buf->str;
  180. FR(buf);R str;}
  181. V BappendS(Bt*buf,S s){WH(*s)Bappend(buf,*s++);}
  182. typedef struct{enum Tkt{T_PUNCT,T_LPAR,T_RPAR,T_NAME,T_NUM,T_QUOTE}tag;
  183. S text;}Tkt;
  184. typedef struct{S source;
  185. Z len;
  186. Z pos;
  187. Lst*tokens;}Lt;
  188. Lt*Lnew(void){Lt*lexer=ma(SO(Lt));R lexer;}
  189. C Llook(Lt*lexer,Z offset){Z pos=lexer->pos+offset;
  190. if(pos>=lexer->len)R 0;R lexer->source[pos];}
  191. C Leat(Lt*lexer){if(lexer->pos>=lexer->len)R 0;R lexer->source[lexer->pos++];}
  192. V LpT(Lt*lexer,enum Tkt tag,S text){Tkt*token=ma(SO(Tkt));
  193. token->tag=tag;
  194. token->text=text;
  195. lp(lexer->tokens,token);}
  196. Lst*guards;
  197. jmp_buf*guard(){jmp_buf*lb=maa(SO(jmp_buf));
  198. lp(guards,lb);R lb;}
  199. jmp_buf*guarding(){R li(guards,-1);}
  200. V unguard(){jmp_buf*lb=lP(guards);
  201. FR(lb);}
  202. V fatal(S s){jmp_buf*lb;
  203. if((lb=guarding()))longjmp(*lb,1);
  204. fprintf(stderr,"|%s error\n",s);
  205. if(Iin)longjmp(Icp,1);
  206. exit(1);}
  207. V Lerror(Lt*lexer,S s){fatal(s);}
  208. V Llnum(Lt*lexer,B is_negative){Bt*buf=Bnew();
  209. if(is_negative)Bappend(buf,'-');
  210. if(Llook(lexer,0)=='.'){Bappend(buf,Leat(lexer));
  211. if(!(isdigit(Llook(lexer,0))))Lerror(lexer,"trailing-dot");}
  212. do{Bappend(buf,Leat(lexer));}WH(isdigit(Llook(lexer,0)));
  213. if(Llook(lexer,0)=='.'){Bappend(buf,Leat(lexer));
  214. if(!(isdigit(Llook(lexer,0))))Lerror(lexer,"trailing-dot");
  215. do{Bappend(buf,Leat(lexer));}WH(isdigit(Llook(lexer,0)));}
  216. LpT(lexer,T_NUM,Bread(buf));}
  217. V Llex(Lt*lexer,S s){lexer->source=s;
  218. lexer->len=strlen(s);
  219. lexer->pos=0;
  220. lexer->tokens=ln();
  221. WH(lexer->pos<lexer->len){C c=Llook(lexer,0);
  222. if(c=='/'&&le(lexer->tokens))BR;
  223. if(isspace(c)){Leat(lexer);
  224. if(Llook(lexer,0)=='/')BR;}elif(isdigit(c)||c=='.'){Llnum(lexer,F);}elif(isalpha(c)){Bt*buf=Bnew();
  225. do{Bappend(buf,Leat(lexer));}WH(isalpha(Llook(lexer,0)));
  226. if(buf->used==1&&Llook(lexer,0)=='.'){Bappend(buf,Leat(lexer));
  227. LpT(lexer,T_PUNCT,Bread(buf));}else LpT(lexer,T_NAME,Bread(buf));}elif(c=='('||c==')'){Leat(lexer);
  228. LpT(lexer,c=='('?T_LPAR:T_RPAR,N);}elif(c=='\''){Bt*buf=Bnew();
  229. Leat(lexer);
  230. LOOP{if(lexer->pos>=lexer->len)Lerror(lexer,"unmatched-quote");
  231. if(Llook(lexer,0)=='\''){if(Llook(lexer,1)=='\''){Bappend(buf,Leat(lexer));
  232. Leat(lexer);CN;}
  233. Leat(lexer);BR;}
  234. Bappend(buf,Leat(lexer));}
  235. LpT(lexer,T_QUOTE,Bread(buf));}elif(ispunct(c)){C buf[3];
  236. buf[0]=Leat(lexer);
  237. buf[1]=0;
  238. if(Llook(lexer,0)=='.'||Llook(lexer,0)==':'){buf[1]=Leat(lexer);
  239. buf[2]=0;}
  240. if(strcmp(buf,"-")==0&&isdigit(Llook(lexer,0))){Llnum(lexer,T);CN;}
  241. LpT(lexer,T_PUNCT,sdup(buf));}else Lerror(lexer,"lex");}}
  242. typedef struct _Tt Tt;
  243. typedef struct _Tentry_t Tentry_t;
  244. struct _Tentry_t{S key;
  245. P value;
  246. B is_deleted;};
  247. struct _Tt{Tentry_t*entries;
  248. Z used;
  249. Z capacity;};
  250. Tt*Tnew(void){Tt*table=ma(SO(Tt));
  251. table->used=0;
  252. table->capacity=TABLE_MIN_SIZE;
  253. table->entries=ma(table->capacity*SO(Tentry_t));R table;}
  254. Z Tlength(Tt*table){R table->used;}
  255. B Tempty(Tt*table){R table->used==0;}
  256. static U64 MM86128(P key,const I len,U32 seed){const uint8_t*data=(const uint8_t*)key;
  257. const I nblocks=len/16;
  258. U32 h1=seed;
  259. U32 h2=seed;
  260. U32 h3=seed;
  261. U32 h4=seed;
  262. U32 c1=0x239b961b;
  263. U32 c2=0xab0e9789;
  264. U32 c3=0x38b34ae5;
  265. U32 c4=0xa1e38b93;
  266. const uint32_t*blocks=(const uint32_t*)(data+nblocks*16);
  267. for(I i=-nblocks;i;i++){U32 k1=blocks[i*4+0];
  268. U32 k2=blocks[i*4+1];
  269. U32 k3=blocks[i*4+2];
  270. U32 k4=blocks[i*4+3];
  271. k1*=c1;
  272. k1=ROTL32(k1,15);
  273. k1*=c2;
  274. h1^=k1;
  275. h1=ROTL32(h1,19);
  276. h1+=h2;
  277. h1=h1*5+0x561ccd1b;
  278. k2*=c2;
  279. k2=ROTL32(k2,16);
  280. k2*=c3;
  281. h2^=k2;
  282. h2=ROTL32(h2,17);
  283. h2+=h3;
  284. h2=h2*5+0x0bcaa747;
  285. k3*=c3;
  286. k3=ROTL32(k3,17);
  287. k3*=c4;
  288. h3^=k3;
  289. h3=ROTL32(h3,15);
  290. h3+=h4;
  291. h3=h3*5+0x96cd1c35;
  292. k4*=c4;
  293. k4=ROTL32(k4,18);
  294. k4*=c1;
  295. h4^=k4;
  296. h4=ROTL32(h4,13);
  297. h4+=h1;
  298. h4=h4*5+0x32ac3b17;}
  299. const uint8_t*tail=(const uint8_t*)(data+nblocks*16);
  300. U32 k1=0;
  301. U32 k2=0;
  302. U32 k3=0;
  303. U32 k4=0;
  304. SW(len & 15){CS 15:k4^=tail[14]<<16;
  305. CS 14:k4^=tail[13]<<8;
  306. CS 13:k4^=tail[12]<<0;
  307. k4*=c4;
  308. k4=ROTL32(k4,18);
  309. k4*=c1;
  310. h4^=k4;
  311. CS 12:k3^=tail[11]<<24;
  312. CS 11:k3^=tail[10]<<16;
  313. CS 10:k3^=tail[9]<<8;
  314. CS 9:k3^=tail[8]<<0;
  315. k3*=c3;
  316. k3=ROTL32(k3,17);
  317. k3*=c4;
  318. h3^=k3;
  319. CS 8:k2^=tail[7]<<24;
  320. CS 7:k2^=tail[6]<<16;
  321. CS 6:k2^=tail[5]<<8;
  322. CS 5:k2^=tail[4]<<0;
  323. k2*=c2;
  324. k2=ROTL32(k2,16);
  325. k2*=c3;
  326. h2^=k2;
  327. CS 4:k1^=tail[3]<<24;
  328. CS 3:k1^=tail[2]<<16;
  329. CS 2:k1^=tail[1]<<8;
  330. CS 1:k1^=tail[0]<<0;
  331. k1*=c1;
  332. k1=ROTL32(k1,15);
  333. k1*=c2;
  334. h1^=k1;}
  335. h1^=len;
  336. h2^=len;
  337. h3^=len;
  338. h4^=len;
  339. h1+=h2;
  340. h1+=h3;
  341. h1+=h4;
  342. h2+=h1;
  343. h3+=h1;
  344. h4+=h1;
  345. FMIX32(h1);
  346. FMIX32(h2);
  347. FMIX32(h3);
  348. FMIX32(h4);
  349. h1+=h2;
  350. h1+=h3;
  351. h1+=h4;
  352. h2+=h1;
  353. h3+=h1;
  354. h4+=h1;R(((U64)h2)<<32)| h1;}
  355. static U32 HASH_SEED=0;
  356. P Tget(Tt*table,S key){if(Tempty(table))R N;
  357. U64 hash=MM86128(key,strlen(key),HASH_SEED);
  358. Z index=hash%table->capacity;
  359. Z i=index;
  360. WH(table->entries[i].key){if(!table->entries[i].is_deleted&&strcmp(table->entries[i].key,key)==0)R table->entries[i].value;
  361. i++;
  362. if(i>=table->capacity)i=0;
  363. if(i==index)BR;}
  364. R N;}
  365. B Thas(Tt*table,S key){if(Tempty(table))R F;
  366. U64 hash=MM86128(key,strlen(key),HASH_SEED);
  367. Z index=hash%table->capacity;
  368. Z i=index;
  369. WH(table->entries[i].key){if(!table->entries[i].is_deleted&&strcmp(table->entries[i].key,key)==0)R T;
  370. i++;
  371. if(i>=table->capacity)i=0;
  372. if(i==index)BR;}
  373. R F;}
  374. static V Tentry_set(Tentry_t*entries,S key,P value,Z capacity,Z*used){U64 hash=MM86128(key,strlen(key),HASH_SEED);
  375. Z index=hash%capacity;
  376. Z i=index;
  377. WH(entries[i].key){if(strcmp(entries[i].key,key)==0){entries[i].value=value;
  378. if(entries[i].is_deleted){if(used)(*used)++;
  379. entries[i].is_deleted=F;}
  380. R;}elif(entries[i].is_deleted)BR;
  381. i++;
  382. if(i>=capacity)i=0;
  383. if(i==index)BR;}
  384. if(used)(*used)++;
  385. entries[i].key=key;
  386. entries[i].value=value;
  387. entries[i].is_deleted=F;}
  388. Tt*Tset(Tt*table,S key,P value){if(table->used>=table->capacity){Z capacity=table->capacity+TABLE_MIN_SIZE;
  389. Tentry_t*entries=ma(capacity*SO(Tentry_t));
  390. for(Z i=0;i<table->capacity;i++){Tentry_t entry=table->entries[i];
  391. if(entry.key&&!entry.is_deleted)Tentry_set(entries,entry.key,entry.value,capacity,N);}
  392. FR(table->entries);
  393. table->entries=entries;
  394. table->capacity=capacity;}
  395. Tentry_set(table->entries,key,value,table->capacity,&table->used);R table;}
  396. typedef struct _Vt Vt;
  397. typedef struct _St St;
  398. typedef struct _vt vt;
  399. struct _St{Tt*env;
  400. Lst*args;
  401. Lst*selfrefs;
  402. Vt*nil;
  403. Vt*udf;
  404. Vt*unit;
  405. vt*at;};
  406. struct _vt{S name;
  407. UI rank[3];
  408. Lst*bonds;
  409. B mark;
  410. B is_fun;
  411. Vt*(*monad)(St*,vt*,Vt*);
  412. Vt*(*dyad)(St*,vt*,Vt*,Vt*);};
  413. typedef struct{S name;
  414. vt*(*adverb)(St*,Vt*);
  415. vt*(*conjunction)(St*,Vt*,Vt*);}advt;
  416. struct _Vt{enum Vtag_t{ARRAY,VERB,SYM,NUM,CHAR,NIL,UDF}tag;
  417. union{Lst*array;
  418. vt*verb;
  419. S symbol;
  420. D number;
  421. UC _char;}val;};
  422. vt*vnew(){vt*verb=ma(SO(vt));R verb;}
  423. Vt*Vnew(enum Vtag_t tag){Vt*val;
  424. if(tag>SYM)val=maa(SO(Vt));
  425. else val=ma(SO(Vt));
  426. val->tag=tag;R val;}
  427. Vt*VnC(enum Vtag_t tag){Vt*val=mau(SO(Vt));
  428. val->tag=tag;R val;}
  429. Vt*_UNIT;
  430. Vt*Vna(Lst*array){if(le(array)){FR(array);R _UNIT;}
  431. Vt*val=Vnew(ARRAY);
  432. val->val.array=array;R val;}
  433. Tt*VCACHE;
  434. Vt*Vnv(vt*verb){Vt*val;
  435. if((val=Tget(VCACHE,verb->name)))R val;
  436. val=Vnew(VERB);
  437. val->val.verb=verb;R val;}
  438. Tt*SCACHE;
  439. Vt*Vny(S symbol){Vt*val;
  440. if((val=Tget(SCACHE,symbol)))R val;
  441. val=VnC(SYM);
  442. val->val.symbol=symbol;
  443. Tset(SCACHE,symbol,val);R val;}
  444. Vt*_NAN,*INF,*NINF;
  445. Vt*NNUMS[8];
  446. Vt*NUMS[256];
  447. Vt*CHARS[256];
  448. Vt*Vnn(D number){if(isnan(number))R _NAN;
  449. elif(number==INFINITY)R INF;
  450. elif(number==-INFINITY)R NINF;
  451. elif(number>=0&&number<256&&number==(D)((Z)number))R NUMS[(Z)number];
  452. elif(number<0&&number>=-8&&fabs(number)==(D)((Z)fabs(number)))R NNUMS[((Z)fabs(number))-1];
  453. Vt*val=Vnew(NUM);
  454. val->val.number=number;R val;}
  455. Vt*Vnc(UC _char){R CHARS[_char];}
  456. B Veq(Vt*x,Vt*y){if(xt!=yt)R F;
  457. SW(xt){CS ARRAY:{Lst*tx=xa;
  458. Lst*ty=ya;
  459. if(le(tx)&&le(ty))BR;
  460. if(le(tx)&&!le(ty))R F;
  461. if(!le(tx)&&le(ty))R F;
  462. WH(tx){if(!ty)R F;
  463. if(!Veq(tx->value,ty->value))R F;
  464. tx=tx->next;
  465. ty=ty->next;}
  466. if(ty)R F;}
  467. CS VERB:R strcmp(xV->name,xV->name)==0;
  468. CS SYM:R strcmp(xY,yY)==0;
  469. CS NUM:if(isnan(xn)&&isnan(yn))BR;R xn==yn;
  470. CS CHAR:R x==y;
  471. CS NIL:CS UDF:BR;}
  472. R T;}
  473. B Cap(Lst*a){if(le(a))R F;
  474. WH(a){Vt*v=a->value;
  475. if(v->tag!=CHAR||!isprint(v->val._char))R F;
  476. a=a->next;}
  477. R T;}
  478. B Aap(Lst*a){if(le(a))R F;
  479. WH(a){Vt*v=a->value;
  480. if(v->tag!=ARRAY)R F;
  481. a=a->next;}
  482. R T;}
  483. S Vshow(Vt*v);
  484. S show_array(Vt*v){if(v->tag!=ARRAY)R Vshow(v);
  485. Lst*t=v->val.array;
  486. if(le(t))R sdup("()");
  487. Bt*buf=Bnew();
  488. if(!t->next){Bappend(buf,',');
  489. S ts=Vshow(t->value);
  490. BappendS(buf,ts);
  491. FR(ts);R Bread(buf);}
  492. if(Cap(t)){WH(t){Vt*c=t->value;
  493. Bappend(buf,c->val._char);
  494. t=t->next;}
  495. R Bread(buf);}
  496. if(!Aap(t)){WH(t){S ts=Vshow(t->value);
  497. BappendS(buf,ts);
  498. FR(ts);
  499. t=t->next;
  500. if(t)Bappend(buf,' ');}}else{UI rwk=0;
  501. UI rwl=ll(t->value);
  502. WH(t){S ts=show_array(t->value);
  503. BappendS(buf,ts);
  504. FR(ts);
  505. t=t->next;
  506. if(t)Bappend(buf,' ');
  507. rwk++;
  508. if(rwk>=rwl&&t){rwk=0;
  509. Bappend(buf,'\n');}}}
  510. R Bread(buf);}
  511. S Vshow(Vt*v){SW(v->tag){CS ARRAY:R show_array(v);
  512. CS VERB:R sdup(v->val.verb->name);
  513. CS SYM:R sdup(v->val.symbol);
  514. CS NUM:{C buf[128];
  515. snprintf(buf,SO(buf),"%.15g",vn);R sdup(buf);}
  516. CS CHAR:{if(!isprint(v->val._char)){C buf[16];
  517. snprintf(buf,SO(buf),"4t.%d",v->val._char);R sdup(buf);}
  518. C buf[2];
  519. buf[0]=v->val._char;
  520. buf[1]=0;R sdup(buf);}
  521. CS NIL:R sdup("nil");
  522. CS UDF:R sdup("udf");}
  523. R sdup("<?>");}
  524. D Vnum(Vt*v){if(v->tag==CHAR)R v->val._char;R vn;}
  525. B VTp(Vt*x){SW(xt){CS ARRAY:R !le(xa);
  526. CS NUM:CS CHAR:R Vnum(x)!=0;
  527. CS NIL:CS UDF:R F;
  528. default:R T;}}
  529. vt*Gv(S s);
  530. St*Sn(void){St*st=ma(SO(St));
  531. st->env=Tnew();
  532. st->args=ln();
  533. st->selfrefs=ln();
  534. st->nil=Vnew(NIL);
  535. st->udf=Vnew(UDF);
  536. st->unit=_UNIT;
  537. st->at=Gv("@");R st;}
  538. V Serror(St*st,S e){fprintf(stderr,"%s error\n",e);
  539. exit(1);}
  540. Vt*eR(St*st,vt*f,Vt*x,UI d,UI rm){if(!f->monad)R st->udf;
  541. if(d>=rm||xt!=ARRAY){if(f->mark)lp(st->selfrefs,f);
  542. Vt*r=f->monad(st,f,x);
  543. if(f->mark)lP(st->selfrefs);R r;}
  544. Lst*t=xa;
  545. if(le(t))R x;
  546. Lst*l=ln();
  547. WH(t){lp(l,eR(st,f,t->value,d+1,rm));
  548. t=t->next;}
  549. R Vna(l);}
  550. Vt*apM(St*st,Vt*f,Vt*x){if(f->tag!=VERB)R st->udf;
  551. if(!f->val.verb->monad)R st->udf;R eR(st,f->val.verb,x,0,f->val.verb->rank[0]);}
  552. Vt*tgth(St*st,vt*f,Vt*x,Vt*y,UI dl,UI dr,UI rl,UI rr){if(!f->dyad)R st->udf;
  553. if(dl>=rl&&dr>=rr){if(f->mark)lp(st->selfrefs,f);
  554. Vt*r=f->dyad(st,f,x,y);
  555. if(f->mark)lP(st->selfrefs);R r;}
  556. if(dl<rl&&dr<rr&&xt==ARRAY&&yt==ARRAY){Lst*tx=xa;
  557. Lst*ty=ya;
  558. if(!tx->value||!ty->value)R !tx->value?x:y;
  559. Lst*t=ln();
  560. WH(tx){if(!ty)BR;
  561. lp(
  562. t,tgth(st,f,tx->value,ty->value,dl+1,dr+1,rl,rr));
  563. tx=tx->next;
  564. ty=ty->next;}
  565. R Vna(t);}elif((xt!=ARRAY||dl>=rl)&&yt==ARRAY&&dr<rr){Lst*ty=ya;
  566. if(!ty->value)R y;
  567. Lst*t=ln();
  568. WH(ty){lp(t,tgth(st,f,x,ty->value,dl,dr+1,rl,rr));
  569. ty=ty->next;}
  570. R Vna(t);}elif((yt!=ARRAY||dr>=rr)&&xt==ARRAY&&dl<rl){Lst*tx=xa;
  571. if(!tx->value)R x;
  572. Lst*t=ln();
  573. WH(tx){lp(t,tgth(st,f,tx->value,y,dl+1,dr,rl,rr));
  574. tx=tx->next;}
  575. R Vna(t);}
  576. if(f->mark)lp(st->selfrefs,f);
  577. Vt*r=f->dyad(st,f,x,y);
  578. if(f->mark)lP(st->selfrefs);R r;}
  579. Vt*apD(St*st,Vt*f,Vt*x,Vt*y){if(f->tag!=VERB)R st->nil;R tgth(st,f->val.verb,x,y,0,0,f->val.verb->rank[1],f->val.verb->rank[2]);}
  580. typedef struct _Nt Nt;
  581. struct _Nt{enum Ntag_t{N_STRAND,N_LITERAL,N_INDEX1,N_INDEX2,N_FUN,N_MONAD,N_DYAD,N_ADV,N_CONJ,N_PARTIAL_CONJ,N_FORK,N_HOOK,N_BOND,N_OVER,N_BIND}tag;
  582. advt*av;
  583. Vt*v;
  584. Lst*l;
  585. Nt*a;
  586. Nt*b;
  587. Nt*c;};
  588. Vt*_fork_m(St*st,vt*self,Vt*x){vt*f=li(self->bonds,0);
  589. vt*g=li(self->bonds,1);
  590. vt*h=li(self->bonds,2);
  591. Vt*l=eR(st,f,x,0,f->rank[0]);
  592. Vt*r=eR(st,h,x,0,f->rank[0]);R tgth(st,g,l,r,0,0,g->rank[1],g->rank[2]);}
  593. Vt*_fork_d(St*st,vt*self,Vt*x,Vt*y){vt*f=li(self->bonds,0);
  594. vt*g=li(self->bonds,1);
  595. vt*h=li(self->bonds,2);
  596. Vt*l=eR(st,f,x,0,f->rank[0]);
  597. Vt*r=eR(st,h,y,0,f->rank[0]);R tgth(st,g,l,r,0,0,g->rank[1],g->rank[2]);}
  598. Vt*_hook_m(St*st,vt*self,Vt*x){vt*f=li(self->bonds,0);
  599. vt*g=li(self->bonds,1);
  600. Vt*r=eR(st,g,x,0,g->rank[0]);R eR(st,f,r,0,f->rank[0]);}
  601. Vt*_hook_d(St*st,vt*self,Vt*x,Vt*y){vt*f=li(self->bonds,0);
  602. vt*g=li(self->bonds,1);
  603. Vt*r=tgth(st,g,x,y,0,0,g->rank[1],g->rank[2]);R eR(st,f,r,0,f->rank[0]);}
  604. Vt*_bond_m(St*st,vt*self,Vt*x){vt*f=li(self->bonds,0);
  605. Vt*g=li(self->bonds,1);R tgth(st,f,g,x,0,0,f->rank[1],f->rank[2]);}
  606. Vt*_bond_d(St*st,vt*self,Vt*x,Vt*y){vt*f=li(self->bonds,0);
  607. Vt*g=li(self->bonds,1);
  608. Vt*r=tgth(st,f,x,y,0,0,f->rank[1],f->rank[2]);R tgth(st,f,x,r,0,0,f->rank[1],f->rank[2]);}
  609. Vt*_over_m(St*st,vt*self,Vt*x){Vt*f=li(self->bonds,0);
  610. vt*g=li(self->bonds,1);
  611. vt*h=li(self->bonds,2);
  612. Vt*l=eR(st,h,x,0,h->rank[0]);R tgth(st,g,f,l,0,0,g->rank[1],g->rank[2]);}
  613. Vt*_over_d(St*st,vt*self,Vt*x,Vt*y){Vt*f=li(self->bonds,0);
  614. vt*g=li(self->bonds,1);
  615. vt*h=li(self->bonds,2);
  616. Vt*l=tgth(st,h,x,y,0,0,h->rank[1],h->rank[2]);R tgth(st,g,f,l,0,0,g->rank[1],g->rank[2]);}
  617. B nca(Nt*node,unsigned int*argc){if(!node)R F;
  618. if(node->tag==N_LITERAL&&node->v->tag==SYM&&strcmp(node->v->val.symbol,"y")==0){*argc=2;R T;}elif(node->tag==N_LITERAL&&node->v->tag==SYM&&strcmp(node->v->val.symbol,"x")==0){if(*argc<2)*argc=1;}elif(node->tag==N_MONAD||node->tag==N_CONJ||node->tag==N_HOOK||node->tag==N_BOND||node->tag==N_INDEX1){if(nca(node->a,argc))R T;
  619. if(nca(node->b,argc))R T;}elif(node->tag==N_DYAD||node->tag==N_FORK||node->tag==N_OVER||node->tag==N_INDEX2){if(nca(node->a,argc))R T;
  620. if(nca(node->b,argc))R T;
  621. if(nca(node->c,argc))R T;}elif(node->tag==N_ADV){if(nca(node->a,argc))R T;}elif(node->tag==N_STRAND){Lst*t=node->l;
  622. WH(t){if(nca(t->value,argc))R T;
  623. t=t->next;}}
  624. R F;}
  625. Vt*Swalk(St*st,Nt*node);
  626. Vt*_const_m(St*st,vt*self,Vt*x){R self->bonds->value;}
  627. Vt*_const_d(St*st,vt*self,Vt*x,Vt*y){R self->bonds->value;}
  628. Vt*_fun_m(St*st,vt*self,Vt*x){Lst*args=ln();
  629. lp(args,x);
  630. lp(args,self);
  631. lp(st->args,args);
  632. Vt*r=Swalk(st,self->bonds->value);
  633. lP(st->args);
  634. FR(args);R r;}
  635. Vt*_fun_d(St*st,vt*self,Vt*x,Vt*y){Lst*args=ln();
  636. lp(args,x);
  637. lp(args,y);
  638. lp(args,self);
  639. lp(st->args,args);
  640. Vt*r=Swalk(st,self->bonds->next->value);
  641. lP(st->args);
  642. FR(args);R r;}
  643. Vt*_partial_conjunction(St*st,vt*self,Vt*x){advt*av=self->bonds->value;
  644. Vt*a=self->bonds->next->value;R Vnv(av->conjunction(st,a,x));}
  645. Nt*Nn1(enum Ntag_t tag,Nt*a);
  646. Vt*Swalk(St*st,Nt*node){if(!node)R st->nil;
  647. SW(node->tag){CS N_STRAND:{Lst*t=node->l;
  648. WH(t){t->value=Swalk(st,t->value);
  649. t=t->next;}
  650. R Vna(node->l);}
  651. CS N_LITERAL:{Vt*v=node->v;
  652. Vt*t=N;
  653. if(v->tag==SYM){S n=v->val.symbol;
  654. if(!le(st->args)){Lst*args=li(st->args,-1);
  655. Z argc=ll(args)-1;
  656. if(argc==2&&strcmp(n,"y")==0)R args->next->value;
  657. elif(strcmp(n,"x")==0)R args->value;}
  658. if((t=Tget(st->env,n)))R t;}
  659. R v;}
  660. CS N_INDEX1:R tgth(st,st->at,Swalk(st,node->a),Swalk(st,node->b),0,0,st->at->rank[1],st->at->rank[2]);
  661. CS N_INDEX2:R tgth(st,st->at,tgth(st,st->at,Swalk(st,node->a),Swalk(st,node->b),0,0,st->at->rank[1],st->at->rank[2]),Swalk(st,node->c),0,0,st->at->rank[1],st->at->rank[2]);
  662. CS N_FUN:{UI argc=0;
  663. nca(node->a,&argc);
  664. vt*nv=vnew();
  665. if(argc>0)nv->is_fun=T;
  666. nv->bonds=ln();
  667. nv->name=sdup(argc==0?":...":argc==1?":x":":xy");
  668. nv->rank[0]=0;
  669. nv->rank[1]=0;
  670. nv->rank[2]=0;
  671. if(argc==0){lp(nv->bonds,Swalk(st,node->a));
  672. nv->monad=_const_m;
  673. nv->dyad=_const_d;}elif(argc==1){lp(nv->bonds,node->a);
  674. nv->monad=_fun_m;
  675. nv->dyad=N;}else{nv->monad=N;
  676. lp(nv->bonds,st->udf);
  677. lp(nv->bonds,node->a);
  678. nv->dyad=_fun_d;}
  679. R Vnv(nv);}
  680. CS N_MONAD:R apM(st,Swalk(st,node->a),Swalk(st,node->b));
  681. CS N_DYAD:R apD(st,Swalk(st,node->a),Swalk(st,node->b),Swalk(st,node->c));
  682. CS N_ADV:{Vt*v=Swalk(st,node->a);R Vnv(node->av->adverb(st,v));}
  683. CS N_CONJ:{Vt*v1=Swalk(st,node->a);
  684. Vt*v2=Swalk(st,node->b);R Vnv(node->av->conjunction(st,v1,v2));}
  685. CS N_PARTIAL_CONJ:{vt*nv=vnew();
  686. Vt*a=Swalk(st,node->a);
  687. S r=Vshow(a);
  688. Z l=strlen(r)+strlen(node->av->name)+1;
  689. nv->name=ma(l);
  690. snprintf(nv->name,l,"%s%s",r,node->av->name);
  691. FR(r);
  692. nv->bonds=ln();
  693. lp(nv->bonds,node->av);
  694. lp(nv->bonds,a);
  695. nv->rank[0]=0;
  696. nv->rank[1]=0;
  697. nv->rank[2]=0;
  698. nv->monad=_partial_conjunction;
  699. nv->dyad=N;R Vnv(nv);}
  700. CS N_FORK:{Vt*_f=Swalk(st,node->a);
  701. if(_f->tag!=VERB)R st->udf;
  702. Vt*_g=Swalk(st,node->b);
  703. if(_g->tag!=VERB)R st->udf;
  704. Vt*_h=Swalk(st,node->c);
  705. if(_h->tag!=VERB)R st->udf;
  706. vt*f=_f->val.verb;
  707. vt*g=_g->val.verb;
  708. vt*h=_h->val.verb;
  709. vt*nv=vnew();
  710. nv->bonds=ln();
  711. lp(nv->bonds,f);
  712. lp(nv->bonds,g);
  713. lp(nv->bonds,h);
  714. Z l=strlen(f->name)+strlen(g->name)+strlen(h->name)+1;
  715. nv->name=ma(l);
  716. snprintf(nv->name,l,"%s%s%s",f->name,g->name,h->name);
  717. nv->rank[0]=0;
  718. nv->rank[1]=0;
  719. nv->rank[2]=0;
  720. nv->monad=_fork_m;
  721. nv->dyad=_fork_d;R Vnv(nv);}
  722. CS N_HOOK:{Vt*_f=Swalk(st,node->a);
  723. if(_f->tag!=VERB)R st->udf;
  724. Vt*_g=Swalk(st,node->b);
  725. if(_g->tag!=VERB)R st->udf;
  726. vt*f=_f->val.verb;
  727. vt*g=_g->val.verb;
  728. vt*nv=vnew();
  729. nv->bonds=ln();
  730. lp(nv->bonds,f);
  731. lp(nv->bonds,g);
  732. Z l=strlen(f->name)+strlen(g->name)+1;
  733. nv->name=ma(l);
  734. snprintf(nv->name,l,"%s%s",f->name,g->name);
  735. nv->rank[0]=0;
  736. nv->rank[1]=0;
  737. nv->rank[2]=0;
  738. nv->monad=_hook_m;
  739. nv->dyad=_hook_d;R Vnv(nv);}
  740. CS N_BOND:{Vt*_f=Swalk(st,node->a);
  741. if(_f->tag!=VERB)R st->udf;
  742. Vt*g=Swalk(st,node->b);
  743. vt*f=_f->val.verb;
  744. vt*nv=vnew();
  745. nv->bonds=ln();
  746. lp(nv->bonds,f);
  747. lp(nv->bonds,g);
  748. S r=Vshow(g);
  749. Z l=strlen(r)+strlen(f->name)+1;
  750. nv->name=ma(l);
  751. snprintf(nv->name,l,"%s%s",r,f->name);
  752. FR(r);
  753. nv->rank[0]=0;
  754. nv->rank[1]=0;
  755. nv->rank[2]=0;
  756. nv->monad=_bond_m;
  757. nv->dyad=_bond_d;R Vnv(nv);}
  758. CS N_OVER:{Vt*f=Swalk(st,node->a);
  759. Vt*_g=Swalk(st,node->b);
  760. if(_g->tag!=VERB)R st->udf;
  761. Vt*_h=Swalk(st,node->c);
  762. if(_h->tag!=VERB)R st->udf;
  763. vt*g=_g->val.verb;
  764. vt*h=_h->val.verb;
  765. vt*nv=vnew();
  766. nv->bonds=ln();
  767. lp(nv->bonds,f);
  768. lp(nv->bonds,g);
  769. lp(nv->bonds,h);
  770. S r=Vshow(f);
  771. Z l=strlen(r)+strlen(g->name)+strlen(h->name)+1;
  772. nv->name=ma(l);
  773. snprintf(nv->name,l,"%s%s%s",r,g->name,h->name);
  774. FR(r);
  775. nv->rank[0]=0;
  776. nv->rank[1]=0;
  777. nv->rank[2]=0;
  778. nv->monad=_over_m;
  779. nv->dyad=_over_d;R Vnv(nv);}
  780. CS N_BIND:{Vt*l=node->a->v;
  781. Nt*b=node->b;
  782. UI argc=0;
  783. nca(b,&argc);
  784. if(argc!=0)b=Nn1(N_FUN,b);
  785. Vt*r=Swalk(st,b);
  786. if(r->tag==VERB&&argc==0)r->val.verb->mark=T;
  787. Vt*ov=Tget(st->env,l->val.symbol);
  788. if(ov&&ov->tag==VERB&&ov->val.verb->is_fun&&r->tag==VERB&&r->val.verb->is_fun){if(!ov->val.verb->monad&&r->val.verb->monad){ls(ov->val.verb->bonds,0,r->val.verb->bonds->value);
  789. ov->val.verb->monad=r->val.verb->monad;BR;}
  790. if(!ov->val.verb->dyad&&r->val.verb->dyad){lp(ov->val.verb->bonds,r->val.verb->bonds->next->value);
  791. ov->val.verb->dyad=r->val.verb->dyad;BR;}}
  792. Tset(st->env,l->val.symbol,r);}}
  793. R st->nil;}
  794. Vt*vconst(St*st,vt*self,Vt*x){vt*nv=vnew();
  795. nv->bonds=ln();
  796. lp(nv->bonds,x);
  797. S r=Vshow(x);
  798. Z l=strlen(r)+2;
  799. nv->name=ma(l);
  800. snprintf(nv->name,l,":%s",r);
  801. nv->rank[0]=0;
  802. nv->rank[1]=0;
  803. nv->rank[2]=0;
  804. nv->monad=_const_m;
  805. nv->dyad=_const_d;R Vnv(nv);}
  806. Vt*vbind(St*st,vt*self,Vt*x,Vt*y){if(xt==SYM){if(yt==VERB)yV->mark=T;
  807. Tset(st->env,xY,y);}
  808. R st->udf;}
  809. Tt*Inverses;
  810. Vt*vobverse(St*st,vt*self,Vt*x,Vt*y){if(xt==VERB&&yt==VERB){vt*vx=xV;
  811. if(!yV->monad)
  812. R st->udf;
  813. if(strcmp(vx->name,":...")==0||strcmp(vx->name,":x")==0||strcmp(vx->name,":xy")==0)R st->udf;
  814. if(Thas(Inverses,vx->name))R st->udf;
  815. Tset(Inverses,vx->name,yV);R st->nil;}
  816. R st->udf;}
  817. Vt*vflip(St*st,vt*self,Vt*x){if(xt!=ARRAY||le(xa))R st->udf;
  818. Lst*t=xa;
  819. if(!Aap(t))R st->udf;
  820. Lst*r=ln();
  821. Vt*c0=t->value;
  822. Lst*c0t=c0->val.array;
  823. Z c0l=ll(c0t);
  824. for(Z i=0;i<c0l;i++){Lst*nc=ln();
  825. Lst*t2=t;
  826. WH(t2){Vt*rw=t2->value;
  827. Lst*rwt=rw->val.array;
  828. if(le(rwt))R st->udf;
  829. Vt*v=li(rwt,i);
  830. if(!v)v=rwt->value;
  831. lp(nc,v);
  832. t2=t2->next;}
  833. lp(r,Vna(nc));}
  834. R Vna(r);}
  835. Vt*vplus(St*st,vt*self,Vt*x,Vt*y){if((xt==NUM||xt==CHAR)&&(yt==NUM||yt==CHAR)){if(xt==CHAR||yt==CHAR)R Vnc(Vnum(x)+Vnum(y));R Vnn(Vnum(x)+Vnum(y));}
  836. R _NAN;}
  837. Vt*vsign(St*st,vt*self,Vt*x){if(xt==NUM)R xn<0?NNUMS[0]:xn>0?NUMS[1]:NUMS[0];R _NAN;}
  838. D gcd(D a,D b){if(b!=0)R gcd(b,fmod(a,b));
  839. else R fabs(a);}
  840. Vt*vgcd(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM&&yt==NUM)R Vnn(gcd(xn,yn));R _NAN;}
  841. Vt*vsin(St*st,vt*self,Vt*x){if(xt==NUM)R Vnn(sin(xn));R _NAN;}
  842. Vt*vsquare(St*st,vt*self,Vt*x){if(xt==NUM)R Vnn(xn*xn);R _NAN;}
  843. Vt*vnegate(St*st,vt*self,Vt*x){if(xt==NUM)R Vnn(-xn);R _NAN;}
  844. Vt*vminus(St*st,vt*self,Vt*x,Vt*y){if((xt==NUM||xt==CHAR)&&(yt==NUM||yt==CHAR)){if(xt==CHAR||yt==CHAR)R Vnc(Vnum(x)-Vnum(y));R Vnn(Vnum(x)-Vnum(y));}
  845. R _NAN;}
  846. Vt*vatan(St*st,vt*self,Vt*x){if(xt==NUM)R Vnn(atan(xn));R _NAN;}
  847. Vt*vatan2(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM&&yt==NUM)R Vnn(atan2(xn,yn));R _NAN;}
  848. Vt*vfirst(St*st,vt*self,Vt*x){if(xt!=ARRAY)R x;
  849. if(le(xa))R st->udf;R xa->value;}
  850. Vt*vtimes(St*st,vt*self,Vt*x,Vt*y){if((xt==NUM||xt==CHAR)&&(yt==NUM||yt==CHAR)){if(xt==CHAR||yt==CHAR)R Vnc(Vnum(x)*Vnum(y));R Vnn(Vnum(x)*Vnum(y));}
  851. R _NAN;}
  852. D lcm(D a,D b){R(a*b)/gcd(a,b);}
  853. U64 factorial(U64 n){U64 r=1;
  854. WH(n>0)r*=n--;R r;}
  855. Vt*vfactorial(St*st,vt*self,Vt*x){if(xt==NUM)R Vnn(factorial((U64)fabs(xn)));R _NAN;}
  856. Vt*vlcm(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM&&yt==NUM)R Vnn(lcm(xn,yn));R _NAN;}
  857. Vt*vdouble(St*st,vt*self,Vt*x){if(xt==NUM)R Vnn(xn*2);R _NAN;}
  858. Vt*vreplicate(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM){Z k=fabs(xn);
  859. Lst*r=ln();
  860. WH(k--)lp(r,y);R Vna(r);}
  861. R st->udf;}
  862. Vt*vreciprocal(St*st,vt*self,Vt*x){if(xt==NUM)R Vnn(1/xn);R _NAN;}
  863. Vt*vdivide(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM&&yt==NUM){D ny=yn;
  864. if(ny==0)R INF;R Vnn(xn/ny);}
  865. R _NAN;}
  866. D npower(D base,I n){if(n<0)R npower(1/base,-n);
  867. elif(n==0)R 1.0;
  868. elif(n==1)R base;
  869. elif(n%2)R base*npower(base*base,n/2);
  870. else R npower(base*base,n/2);}
  871. D nroot(D base,I n){if(n==1)R base;
  872. elif(n<=0||base<0)R NAN;
  873. else{D delta,x=base/n;
  874. do{delta=(base/npower(x,n-1)-x)/n;
  875. x+=delta;}WH(fabs(delta)>=1e-8);R x;}}
  876. Vt*vsqrt(St*st,vt*self,Vt*x){if(xt==NUM)R Vnn(sqrt(xn));R _NAN;}
  877. Vt*vroot(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM&&yt==NUM)R Vnn(nroot(yn,xn));R _NAN;}
  878. Vt*vhalve(St*st,vt*self,Vt*x){if(xt==NUM)R Vnn(xn/2);R _NAN;}
  879. Vt*vidivide(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM&&yt==NUM){D ny=yn;
  880. if(ny==0)R INF;R Vnn(trunc(xn/ny));}
  881. R _NAN;}
  882. Vt*venlist(St*st,vt*self,Vt*x);
  883. Vt*vpred(St*st,vt*self,Vt*x);
  884. Vt*vrange(St*st,vt*self,Vt*x,Vt*y);
  885. Vt*venum(St*st,vt*self,Vt*x){if(Veq(x,NUMS[1]))R venlist(st,N,NUMS[0]);
  886. elif(Veq(x,NUMS[0]))R st->unit;R vrange(st,self,NUMS[0],vpred(st,self,x));}
  887. Vt*vmod(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM&&yt==NUM){D ny=yn;
  888. if(ny==0)R _NAN;R Vnn(fmod(xn,ny));}
  889. R _NAN;}
  890. Vt*vtake(St*st,vt*self,Vt*x,Vt*y);
  891. Vt*vdrop(St*st,vt*self,Vt*x,Vt*y);
  892. B spnp(D v){R isnan(v)||v==INFINITY||v==-INFINITY;}
  893. Vt*vodometer(St*st,vt*self,Vt*x){if(xt!=ARRAY)x=venlist(st,N,x);
  894. elif(le(xa)||!xa->next)R st->udf;
  895. Z p=1;
  896. Z xl=0;
  897. Lst*t=xa;
  898. WH(t){Vt*it=t->value;
  899. if(it->tag!=NUM||spnp(it->val.number))R st->udf;
  900. p*=(Z)(it->val.number);
  901. t=t->next;xl++;}
  902. if(p<1)R st->unit;
  903. t=xa;
  904. uint64_t*lims=maa(SO(U64)*xl);
  905. for(Z i=0;i<xl;i++){lims[i]=(Z)(((Vt*)t->value)->val.number);
  906. t=t->next;}
  907. uint64_t**z=ma(SO(uint64_t*)*p);
  908. for(Z i=0;i<p;i++)z[i]=maa(SO(U64)*xl);
  909. for(Z i=0;i<p-1;i++){uint64_t*r=z[i];
  910. uint64_t*s=z[i+1];
  911. B carry=T;
  912. for(Z j=0;j<xl;j++){U64 a=xl-1-j;
  913. s[a]=r[a];
  914. if(carry){s[a]++;carry=F;}
  915. if(s[a]>=lims[a]){s[a]=0;carry=T;}}}
  916. FR(lims);
  917. Lst*r=ln();
  918. for(Z i=0;i<p;i++){Lst*rw=ln();
  919. for(Z j=0;j<xl;j++)lp(rw,Vnn(z[i][j]));
  920. lp(r,Vna(rw));
  921. FR(z[i]);}
  922. FR(z);R Vna(r);}
  923. Vt*vchunks(St*st,vt*self,Vt*x,Vt*y){if(xt!=NUM)R st->udf;
  924. if(yt!=ARRAY)y=venlist(st,N,y);
  925. elif(le(ya))R y;
  926. Lst*r=ln();
  927. Z l=ll(ya);
  928. Z cl=fabs(xn);
  929. for(Z i=0;i<l;i+=cl)lp(r,vtake(st,N,Vnn(cl),vdrop(st,N,Vnn(i),y)));R Vna(r);}
  930. Vt*vexp(St*st,vt*self,Vt*x){if(xt==NUM)R Vnn(exp(xn));R _NAN;}
  931. Vt*vpower(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM&&yt==NUM)R Vnn(pow(xn,yn));R _NAN;}
  932. Vt*vnlog(St*st,vt*self,Vt*x){if(xt==NUM)R Vnn(log(xn));R _NAN;}
  933. Vt*vlog(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM&&yt==NUM)R Vnn(log(yn)/log(xn));R _NAN;}
  934. I bits_needed(U32 value){I bits=0;
  935. for(I bit_test=16;bit_test>0;bit_test>>=1){if(value>>bit_test!=0){bits+=bit_test;
  936. value>>=bit_test;}}
  937. R bits+value;}
  938. Vt*vbits(St*st,vt*self,Vt*x){if(xt==NUM){I n=xn;
  939. I bk=bits_needed(n);
  940. Lst*r=ln();
  941. for(I i=0;i<bk;i++)if((n &(1<<i))>>i)lp(r,NUMS[1]);
  942. else lp(r,NUMS[0]);R Vna(r);}
  943. R st->udf;}
  944. Vt*vbase(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM&&yt==NUM){Z v=fabs(yn);
  945. Z b=fabs(xn);
  946. if(b<2)R st->udf;
  947. Lst*r=ln();
  948. WH(v>0){r=lI(&r,0,Vnn(v%b));
  949. v/=b;}
  950. R Vna(r);}
  951. R st->udf;}
  952. SZ indexOf(Lst*l,Vt*x){if(le(l))return-1;
  953. Z i=0;
  954. WH(l){if(Veq(l->value,x))R i;
  955. l=l->next;
  956. i++;}
  957. return-1;}
  958. Vt*vgroup(St*st,vt*self,Vt*x){if(xt!=ARRAY)x=venlist(st,N,x);
  959. elif(le(xa))R x;
  960. Lst*r=ln();
  961. Lst*is=ln();
  962. Z i=0;
  963. Lst*t=xa;
  964. WH(t){Vt*v=t->value;
  965. SZ n=indexOf(is,v);
  966. if(n<0){lp(r,venlist(st,N,Vnn(i)));
  967. lp(is,v);}else{Vt*tmp=li(r,n);
  968. lp(tmp->val.array,Vnn(i));}
  969. t=t->next;
  970. i++;}
  971. WH(is){Lst*tmp=is->next;
  972. FR(is);
  973. is=tmp;}
  974. R Vna(r);}
  975. Vt*vbuckets(St*st,vt*self,Vt*x,Vt*y){if(xt!=ARRAY)x=venlist(st,N,x);
  976. elif(le(xa))R y;
  977. if(yt!=ARRAY)y=venlist(st,N,x);
  978. elif(le(ya))R y;
  979. Lst*r=ln();
  980. Lst*t=xa;
  981. Z mx=0;
  982. WH(t){Vt*v=t->value;
  983. if(v->tag!=NUM)BR;
  984. SZ i=vn;
  985. if(i>=0&&i>mx)mx=i;
  986. t=t->next;}
  987. for(Z i=0;i<mx+1;i++)lp(r,ln());
  988. if(le(r)){FR(r);R st->unit;}
  989. Lst*ty=ya;
  990. t=xa;
  991. WH(t&&ty){Vt*v=t->value;
  992. if(v->tag!=NUM)BR;
  993. SZ i=vn;
  994. if(i>=0){Lst*b=li(r,i);
  995. if(b)lp(b,ty->value);}
  996. t=t->next;ty=ty->next;}
  997. if(ty){Lst*lb=ln();
  998. WH(ty){lp(lb,ty->value);
  999. ty=ty->next;}
  1000. lp(r,lb);}
  1001. t=r;
  1002. WH(t){t->value=Vna(t->value);
  1003. t=t->next;}
  1004. R Vna(r);}
  1005. Vt*vequals(St*st,vt*self,Vt*x,Vt*y){R Veq(x,y)?NUMS[1]:NUMS[0];}
  1006. Vt*vpermute(St*st,vt*self,Vt*x){if(xt!=ARRAY||le(xa)||!xa->next)R x;
  1007. Lst*permutation=lc(xa);
  1008. Z length=ll(permutation);
  1009. Lst*result=ln();
  1010. lp(result,lc(permutation));
  1011. Lst*c=ln();
  1012. for(Z i=0;i<length;i++){Z*n=maa(SO(Z));
  1013. lp(c,n);}
  1014. Z k;
  1015. Lst*p;
  1016. Z i=0;
  1017. WH(i<length){Z*n=li(c,i);
  1018. if((*n)<i){k=i%2&&(*n);
  1019. p=li(permutation,i);
  1020. ls(permutation,i,li(permutation,k));
  1021. ls(permutation,k,p);
  1022. *n=(*n)+1;
  1023. i=1;
  1024. lp(result,lc(permutation));}else{*n=0;
  1025. i++;}}
  1026. WH(c){Lst*tmp=c->next;
  1027. FR(c->value);
  1028. FR(c);
  1029. c=tmp;}
  1030. WH(permutation){Lst*tmp=permutation->next;
  1031. FR(permutation);
  1032. permutation=tmp;}
  1033. Lst*t=result;
  1034. WH(t){t->value=Vna(t->value);
  1035. t=t->next;}
  1036. R Vna(result);}
  1037. Vt*voccurences(St*st,vt*self,Vt*x){if(xt!=ARRAY)x=venlist(st,N,x);
  1038. elif(le(xa))R x;
  1039. Lst*table=ln();
  1040. Lst*r=ln();
  1041. Lst*t=xa;
  1042. WH(t){B f=F;
  1043. Vt*it=t->value;
  1044. Lst*tt=table;
  1045. if(!le(tt))WH(tt){Lst*p=tt->value;
  1046. if(Veq(p->value,it)){Z*n=p->next->value;
  1047. *n=(*n)+1;
  1048. lp(r,Vnn(*n));
  1049. f=T;BR;}
  1050. tt=tt->next;}
  1051. if(!f){Lst*p=ln();
  1052. lp(p,it);
  1053. Z*n=maa(SO(Z));
  1054. lp(p,n);
  1055. lp(table,p);
  1056. lp(r,NUMS[0]);}
  1057. t=t->next;}
  1058. if(!le(table)){t=table;
  1059. WH(t){Lst*tmp=t->next;
  1060. Lst*p=t->value;
  1061. FR(p->next->value);
  1062. FR(p->next);
  1063. FR(p);
  1064. FR(t);
  1065. t=tmp;}}
  1066. R Vna(r);}
  1067. Vt*vmask(St*st,vt*self,Vt*x,Vt*y){if(xt!=ARRAY)x=venlist(st,N,x);
  1068. elif(le(xa))R x;
  1069. if(yt!=ARRAY)y=venlist(st,N,y);
  1070. Lst*r=ln();
  1071. Vt*l=Vnn(ll(ya));
  1072. Z n=0;
  1073. Z k=ll(xa);
  1074. for(Z i=0;i<k;i++){Vt*s=vtake(st,N,l,vdrop(st,N,Vnn(i),x));
  1075. if(Veq(s,y)){n++;
  1076. for(Z j=0;j<l->val.number;j++,i++)lp(r,Vnn(n));
  1077. i--;}else lp(r,NUMS[0]);}
  1078. R Vna(r);}
  1079. Vt*vclassify(St*st,vt*self,Vt*x){if(xt!=ARRAY)x=venlist(st,N,x);
  1080. elif(le(xa))R x;
  1081. Lst*table=ln();
  1082. Lst*r=ln();
  1083. Lst*t=xa;
  1084. Z i=0;
  1085. WH(t){B f=F;
  1086. Vt*it=t->value;
  1087. Lst*tt=table;
  1088. if(!le(tt))WH(tt){Lst*p=tt->value;
  1089. if(Veq(p->value,it)){Z*n=p->next->value;
  1090. lp(r,Vnn(*n));
  1091. f=T;BR;}
  1092. tt=tt->next;}
  1093. if(!f){Lst*p=ln();
  1094. lp(p,it);
  1095. Z*n=maa(SO(Z));
  1096. *n=i++;
  1097. lp(p,n);
  1098. lp(table,p);
  1099. lp(r,Vnn(*n));}
  1100. t=t->next;}
  1101. if(!le(table)){t=table;
  1102. WH(t){Lst*tmp=t->next;
  1103. Lst*p=t->value;
  1104. FR(p->next->value);
  1105. FR(p->next);
  1106. FR(p);
  1107. FR(t);
  1108. t=tmp;}}
  1109. R Vna(r);}
  1110. Vt*vunbits(St*st,vt*self,Vt*x){if(xt!=ARRAY)x=venlist(st,N,x);
  1111. I n=0;
  1112. I i=0;
  1113. Lst*t=xa;
  1114. WH(t){if(VTp(t->value))n|=(int)1<<i;
  1115. else n &=~((int)1<<i);
  1116. t=t->next;
  1117. i++;}
  1118. R Vnn(n);}
  1119. Vt*vunbase(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM){Z b=fabs(xn);
  1120. if(b<2)R st->udf;
  1121. if(yt!=ARRAY)y=venlist(st,N,y);
  1122. Z n=0;
  1123. Lst*t=ya;
  1124. if(le(t))R st->udf;
  1125. WH(t){Vt*v=t->value;
  1126. if(v->tag!=NUM)BR;
  1127. Z k=fabs(vn);
  1128. n=n*b+k;
  1129. t=t->next;}
  1130. R Vnn(n);}
  1131. R st->udf;}
  1132. Vt*vnot(St*st,vt*self,Vt*x){R VTp(x)?NUMS[0]:NUMS[1];}
  1133. Vt*vnot_equals(St*st,vt*self,Vt*x,Vt*y){R !Veq(x,y)?NUMS[1]:NUMS[0];}
  1134. Vt*vpred(St*st,vt*self,Vt*x){if(xt==NUM)R Vnn(xn-1);
  1135. elif(xt==CHAR)R Vnc(x->val._char-1);R _NAN;}
  1136. Vt*vless(St*st,vt*self,Vt*x,Vt*y){if((xt==NUM||xt==CHAR)&&(yt==NUM||yt==CHAR)){if(Vnum(x)<Vnum(y))R NUMS[1];R NUMS[0];}
  1137. R _NAN;}
  1138. Vt*vfloor(St*st,vt*self,Vt*x){if(xt==NUM)R Vnn(floor(xn));R _NAN;}
  1139. B _compare_up(P a,P b){Vt*x=((Lst*)a)->value;
  1140. Vt*y=((Lst*)b)->value;
  1141. if((xt==NUM||xt==CHAR)&&(yt==NUM||yt==CHAR)){if(Vnum(x)>Vnum(y))R T;R F;}
  1142. R F;}
  1143. B _compare_down(P a,P b){Vt*x=((Lst*)a)->value;
  1144. Vt*y=((Lst*)b)->value;
  1145. if((xt==NUM||xt==CHAR)&&(yt==NUM||yt==CHAR)){if(Vnum(x)<Vnum(y))R T;R F;}
  1146. R F;}
  1147. Vt*_grade(Vt*x,B down){if(xt!=ARRAY||le(xa)||!xa->next)R x;
  1148. Z i=0;
  1149. Lst*ps=ln();
  1150. Lst*t=xa;
  1151. WH(t){Lst*p=ln();
  1152. lp(p,t->value);
  1153. lp(p,Vnn(i++));
  1154. lp(ps,p);
  1155. t=t->next;}
  1156. ps=lS(ps,down?_compare_down:_compare_up);
  1157. t=ps;
  1158. WH(t){Lst*p=t->value;
  1159. t->value=p->next->value;
  1160. FR(p->next);
  1161. FR(p);
  1162. t=t->next;}
  1163. R Vna(ps);}
  1164. Vt*vgradedown(St*st,vt*self,Vt*x){R _grade(x,T);}
  1165. Vt*vnudge_left(St*st,vt*self,Vt*x,Vt*y){if(xt!=ARRAY)R venlist(st,N,y);
  1166. elif(le(xa))R x;
  1167. elif(!xa->next)R venlist(st,N,y);
  1168. Lst*r=ln();
  1169. Lst*t=xa->next;
  1170. WH(t){lp(r,t->value);
  1171. t=t->next;}
  1172. lp(r,y);R Vna(r);}
  1173. Vt*vlesseq(St*st,vt*self,Vt*x,Vt*y){if(Veq(x,y))R NUMS[1];
  1174. if((xt==NUM||xt==CHAR)&&(yt==NUM||yt==CHAR)){if(Vnum(x)<Vnum(y))R NUMS[1];R NUMS[0];}
  1175. R _NAN;}
  1176. Vt*vsucc(St*st,vt*self,Vt*x){if(xt==NUM)R Vnn(xn+1);
  1177. elif(xt==CHAR)R Vnc(x->val._char+1);R _NAN;}
  1178. Vt*vceil(St*st,vt*self,Vt*x){if(xt==NUM)R Vnn(ceil(xn));R _NAN;}
  1179. Vt*vgreater(St*st,vt*self,Vt*x,Vt*y){if((xt==NUM||xt==CHAR)&&(yt==NUM||yt==CHAR)){if(Vnum(x)>Vnum(y))R NUMS[1];R NUMS[0];}
  1180. R _NAN;}
  1181. Vt*vgreatereq(St*st,vt*self,Vt*x,Vt*y){if(Veq(x,y))R NUMS[1];
  1182. if((xt==NUM||xt==CHAR)&&(yt==NUM||yt==CHAR)){if(Vnum(x)>Vnum(y))R NUMS[1];R NUMS[0];}
  1183. R _NAN;}
  1184. Vt*vgradeup(St*st,vt*self,Vt*x){R _grade(x,F);}
  1185. Vt*vnudge_right(St*st,vt*self,Vt*x,Vt*y){if(xt!=ARRAY)R venlist(st,N,y);
  1186. elif(le(xa))R x;
  1187. elif(!xa->next)R venlist(st,N,y);
  1188. Lst*r=ln();
  1189. lp(r,y);
  1190. Lst*t=xa;
  1191. WH(t->next){lp(r,t->value);
  1192. t=t->next;}
  1193. R Vna(r);}
  1194. Vt*venlist(St*st,vt*self,Vt*x){Lst*l=ln();
  1195. lp(l,x);R Vna(l);}
  1196. Vt*vjoin(St*st,vt*self,Vt*x,Vt*y){Lst*l=ln();
  1197. if(xt==ARRAY&&!le(xa)){Lst*t=xa;
  1198. WH(t){lp(l,t->value);
  1199. t=t->next;}}else lp(l,x);
  1200. if(yt==ARRAY&&!le(ya)){Lst*t=ya;
  1201. WH(t){lp(l,t->value);
  1202. t=t->next;}}else lp(l,y);R Vna(l);}
  1203. Vt*venpair(St*st,vt*self,Vt*x,Vt*y){Lst*l=ln();
  1204. lp(l,x);
  1205. lp(l,y);R Vna(l);}
  1206. Vt*vselfref1(St*st,vt*self,Vt*x){vt*v;
  1207. if(!le(st->args))v=li(li(st->args,-1),-1);
  1208. elif(!le(st->selfrefs))v=li(st->selfrefs,-1);
  1209. else R st->udf;R eR(st,v,x,0,v->rank[0]);}
  1210. Vt*vselfref2(St*st,vt*self,Vt*x,Vt*y){vt*v;
  1211. if(!le(st->args))v=li(li(st->args,-1),-1);
  1212. elif(!le(st->selfrefs))v=li(st->selfrefs,-1);
  1213. else R st->udf;R tgth(st,v,x,y,0,0,v->rank[1],v->rank[2]);}
  1214. Vt*vtake(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM){if(yt!=ARRAY){if(xn==0)R st->unit;
  1215. else R x;}
  1216. if(xn==0||le(ya))R st->unit;
  1217. B rev=xn<0;
  1218. Z k=(Z)fabs(xn);
  1219. Lst*t=ya;
  1220. Lst*r=ln();
  1221. if(rev)for(SZ i=k;i>0;i--){Vt*v=li(t,-i);
  1222. if(!v)CN;
  1223. lp(r,v);}
  1224. else WH(t&&k){lp(r,t->value);
  1225. t=t->next;
  1226. k--;}
  1227. R Vna(r);}
  1228. R st->udf;}
  1229. Vt*vwhere(St*st,vt*self,Vt*x){if(xt!=ARRAY)x=venlist(st,N,x);
  1230. elif(le(xa))R x;
  1231. Lst*r=ln();
  1232. Lst*t=xa;
  1233. Z i=0;
  1234. WH(t){Vt*a=t->value;
  1235. if(a->tag!=NUM)BR;
  1236. Z k=fabs(a->val.number);
  1237. for(Z j=0;j<k;j++)lp(r,Vnn(i));
  1238. t=t->next;
  1239. i++;}
  1240. R Vna(r);}
  1241. Vt*vcopy(St*st,vt*self,Vt*x,Vt*y){if(xt!=ARRAY)x=venlist(st,N,x);
  1242. if(yt!=ARRAY)y=venlist(st,N,y);
  1243. Lst*tx=xa;
  1244. Lst*ty=ya;
  1245. if(le(tx)||le(ty))R st->unit;
  1246. Lst*r=ln();
  1247. WH(tx){Vt*a=tx->value;
  1248. Vt*b=ty->value;
  1249. if(b->tag!=NUM)BR;
  1250. Z k=fabs(b->val.number);
  1251. for(Z i=0;i<k;i++)lp(r,a);
  1252. tx=tx->next;
  1253. if(ty->next)ty=ty->next;}
  1254. R Vna(r);}
  1255. Vt*vnub(St*st,vt*self,Vt*x){if(xt!=ARRAY||le(xa))R x;
  1256. Lst*n=ln();
  1257. Lst*r=ln();
  1258. Lst*t=xa;
  1259. WH(t){B u=T;
  1260. Lst*t2=r;
  1261. if(!le(t2))WH(t2){if(Veq(t->value,t2->value)){u=F;BR;}
  1262. t2=t2->next;}
  1263. if(u)lp(r,t->value);
  1264. lp(n,u?NUMS[1]:NUMS[0]);
  1265. t=t->next;}
  1266. WH(r){Lst*tmp=r->next;
  1267. FR(r);
  1268. r=tmp;}
  1269. R Vna(n);}
  1270. Vt*vdrop(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM){if(yt!=ARRAY){if(xn==0)R y;
  1271. else R st->unit;}
  1272. if(xn==0)R y;
  1273. if(le(ya))R st->unit;
  1274. B rev=xn<0;
  1275. Z k=(Z)fabs(xn);
  1276. Lst*t=ya;
  1277. if(rev){Z l=ll(t);
  1278. if(k>=l)R st->unit;R vtake(st,N,Vnn(l-k),y);}
  1279. Lst*r=ln();
  1280. WH(t&&k){t=t->next;
  1281. k--;}
  1282. WH(t){lp(r,t->value);
  1283. t=t->next;}
  1284. R Vna(r);}
  1285. R st->udf;}
  1286. Vt*vunique(St*st,vt*self,Vt*x){if(xt!=ARRAY||le(xa))R x;
  1287. Lst*r=ln();
  1288. Lst*t=xa;
  1289. WH(t){B u=T;
  1290. Lst*t2=r;
  1291. if(!le(t2))WH(t2){if(Veq(t->value,t2->value)){u=F;BR;}
  1292. t2=t2->next;}
  1293. if(u)lp(r,t->value);
  1294. t=t->next;}
  1295. R Vna(r);}
  1296. Vt*vfind(St*st,vt*self,Vt*x,Vt*y){if(yt!=ARRAY)y=venlist(st,self,y);
  1297. elif(le(ya))R st->unit;
  1298. Z i=0;
  1299. Lst*r=ln();
  1300. Lst*t=ya;
  1301. WH(t){if(Veq(t->value,x))lp(r,Vnn(i));
  1302. t=t->next;
  1303. i++;}
  1304. R Vna(r);}
  1305. Vt*vcount(St*st,vt*self,Vt*x){if(xt!=ARRAY)R NUMS[1];R Vnn(ll(xa));}
  1306. V flatten(Vt*v,Lst*r){if(v->tag==ARRAY){Lst*t=v->val.array;
  1307. WH(t){flatten(t->value,r);
  1308. t=t->next;}}else lp(r,v);}
  1309. Vt*vflatten(St*st,vt*self,Vt*x){if(xt!=ARRAY||le(xa))R x;
  1310. Lst*r=ln();
  1311. flatten(x,r);R Vna(r);}
  1312. Vt*vminand(St*st,vt*self,Vt*x,Vt*y){if((xt==NUM||xt==CHAR)&&(yt==NUM||yt==CHAR)){if(Vnum(x)<Vnum(y))R x;R y;}
  1313. R _NAN;}
  1314. Vt*vreverse(St*st,vt*self,Vt*x){if(xt!=ARRAY)R x;
  1315. Lst*t=xa;
  1316. if(le(t))R x;
  1317. Lst*r=ln();
  1318. for(SZ i=ll(t)-1;i>=0;i--)lp(r,li(t,i));R Vna(r);}
  1319. Vt*vmaxor(St*st,vt*self,Vt*x,Vt*y){if((xt==NUM||xt==CHAR)&&(yt==NUM||yt==CHAR)){if(Vnum(x)>Vnum(y))R x;R y;}
  1320. R _NAN;}
  1321. Vt*vrotate(St*st,vt*self,Vt*x,Vt*y){if(xt!=ARRAY||le(xa)||!xa->next)R x;
  1322. if(yt!=NUM)R st->udf;
  1323. B rev=yn<0;
  1324. Z k=fabs(yn);
  1325. Lst*r=ln();
  1326. Lst*t=xa;
  1327. WH(t){lp(r,t->value);
  1328. t=t->next;}
  1329. for(Z i=0;i<k;i++){Vt*v;
  1330. if(rev){v=r->value;
  1331. r=r->next;
  1332. lp(r,v);}else{v=lP(r);
  1333. r=lI(&r,0,v);}}
  1334. R Vna(r);}
  1335. Vt*vwindows(St*st,vt*self,Vt*x,Vt*y){if(yt!=ARRAY)y=venlist(st,N,y);
  1336. elif(le(ya))R y;
  1337. Z k=fabs(xn);
  1338. Z l=ll(ya);
  1339. Lst*r=ln();
  1340. for(Z i=0;i<l;i++){if(i+k>l)BR;
  1341. lp(r,vtake(st,N,Vnn(k),vdrop(st,N,Vnn(i),y)));}
  1342. R Vna(r);}
  1343. Z depthOf(Vt*x,Z d){if(xt==ARRAY){Lst*t=xa;
  1344. if(le(t))R 0;
  1345. WH(t){Z d2=depthOf(t->value,d+1);
  1346. if(d2>d)d=d2;
  1347. t=t->next;}
  1348. R d;}
  1349. R 0;}
  1350. Vt*vdepth(St*st,vt*self,Vt*x){R Vnn(depthOf(x,1));}
  1351. Vt*vround(St*st,vt*self,Vt*x){if(xt==NUM)R Vnn(round(xn));R _NAN;}
  1352. Vt*vabs(St*st,vt*self,Vt*x){if(xt==NUM)R Vnn(fabs(xn));R _NAN;}
  1353. Vt*vtail(St*st,vt*self,Vt*x);
  1354. Vt*vat(St*st,vt*self,Vt*x,Vt*y){if(yt!=NUM)R st->udf;
  1355. if(xt!=ARRAY){if(yn>-1&&yn<1)R x;
  1356. else R st->udf;}
  1357. if(le(xa))R st->nil;
  1358. Vt*v=li(xa,(SZ)yn);
  1359. if(!v)R st->udf;R v;}
  1360. Vt*vmember(St*st,vt*self,Vt*x,Vt*y){if(xt!=ARRAY)x=venlist(st,self,x);
  1361. elif(le(xa))R NUMS[0];
  1362. Lst*t=xa;
  1363. WH(t){if(Veq(t->value,y))R NUMS[1];
  1364. t=t->next;}
  1365. R NUMS[0];}
  1366. Vt*vshuffle(St*st,vt*self,Vt*x){if(xt!=ARRAY)x=venlist(st,self,x);
  1367. elif(le(xa))R x;
  1368. Lst*t=xa;
  1369. Z l=0;
  1370. Lst*r=ln();
  1371. WH(t){lp(r,t->value);
  1372. t=t->next;l++;}
  1373. for(Z i=0;i<l;i++){Z j=rand()%l;
  1374. Vt*tmp=li(r,i);
  1375. ls(r,i,li(r,j));
  1376. ls(r,j,tmp);}
  1377. R Vna(r);}
  1378. Vt*vhead(St*st,vt*self,Vt*x){R vtake(st,N,NUMS[2],x);}
  1379. Vt*vbin(St*st,vt*self,Vt*x,Vt*y){if(xt!=ARRAY)x=venlist(st,self,x);
  1380. elif(le(xa))R x;
  1381. if(yt!=ARRAY)y=venlist(st,self,x);
  1382. elif(le(ya))R y;
  1383. Z xl=ll(xa);
  1384. Lst*bins=ln();
  1385. for(Z i=0;i<xl;i++){D s;
  1386. D e;
  1387. Vt*vs=li(xa,i);
  1388. if(vs->tag==NUM)s=vs->val.number;
  1389. elif(vs->tag==CHAR)s=vs->val._char;
  1390. else R st->udf;
  1391. Vt*ve=i==xl-1?Vnn(s+1):li(xa,i+1);
  1392. if(ve->tag==NUM)e=fabs(ve->val.number);
  1393. elif(ve->tag==CHAR)e=ve->val._char;
  1394. else R st->udf;
  1395. if(ll(bins)>0){Lst*pp=li(bins,-1);
  1396. D*pe=pp->value;
  1397. if(s<=(*pe))R st->udf;}
  1398. D*sn=ma(SO(D));
  1399. *sn=s;
  1400. D*en=ma(SO(D));
  1401. *en=e;
  1402. Lst*p=ln();
  1403. lp(p,sn);
  1404. lp(p,en);
  1405. lp(bins,p);}
  1406. Z bl=ll(bins);
  1407. Lst*r=ln();
  1408. Z yl=ll(ya);
  1409. for(Z i=0;i<yl;i++){Vt*it=li(ya,i);
  1410. D itv;
  1411. if(it->tag==NUM)itv=it->val.number;
  1412. elif(it->tag==CHAR)itv=it->val._char;
  1413. else R st->udf;
  1414. Lst*b=bins->value;
  1415. D*s=b->value;
  1416. if(itv<(*s)){lp(r,NNUMS[0]);CN;}
  1417. b=li(bins,-1);
  1418. s=b->next->value;
  1419. if(itv>=(*s)){lp(r,Vnn(bl-1));CN;}
  1420. D v=NAN;
  1421. for(Z j=0;j<bl;j++){b=li(bins,j);
  1422. D*s=b->value;
  1423. D*e=b->next->value;
  1424. if(itv>=(*s)&&itv<(*e)){v=j;BR;}}
  1425. if(!isnan(v))lp(r,Vnn(v));}
  1426. WH(bins){Lst*tmp=bins->next;
  1427. Lst*b=bins->value;
  1428. FR(b->next->value);
  1429. FR(b->next);
  1430. FR(b->value);
  1431. FR(b);
  1432. FR(bins);
  1433. bins=tmp;}
  1434. R Vna(r);}
  1435. Vt*vtail(St*st,vt*self,Vt*x){if(xt!=ARRAY)R x;
  1436. if(le(xa))R st->udf;R li(xa,-1);}
  1437. Vt*vcut(St*st,vt*self,Vt*x,Vt*y){if(xt!=ARRAY)x=venlist(st,self,x);
  1438. elif(le(xa))R x;
  1439. if(yt!=ARRAY)y=venlist(st,self,x);
  1440. elif(le(ya))R x;
  1441. if(ll(xa)!=2)R st->udf;
  1442. Vt*vs=xa->value;
  1443. Vt*ve=xa->next->value;
  1444. if(vs->tag!=NUM||ve->tag!=NUM)R st->udf;
  1445. Z s=fabs(vs->val.number);
  1446. Z e=fabs(ve->val.number);
  1447. Lst*r=ln();
  1448. Z l=ll(ya);
  1449. Lst*pa=ln();
  1450. for(Z i=s;i<e&&i<l;i++){Vt*v=li(ya,i);
  1451. if(!v)BR;
  1452. lp(pa,v);}
  1453. Lst*pb=ln();
  1454. for(Z i=e;i<l;i++){Vt*v=li(ya,i);
  1455. if(!v)BR;
  1456. lp(pb,v);}
  1457. lp(r,Vna(pa));
  1458. lp(r,Vna(pb));R Vna(r);}
  1459. Vt*vprefixes(St*st,vt*self,Vt*x){if(xt!=ARRAY)x=venlist(st,N,x);
  1460. Lst*r=ln();
  1461. Z i=0;
  1462. Lst*t=xa;
  1463. WH(t){lp(r,vtake(st,N,Vnn(i),x));
  1464. t=t->next;
  1465. i++;}
  1466. lp(r,x);R Vna(r);}
  1467. Vt*vbehead(St*st,vt*self,Vt*x){R vdrop(st,N,NUMS[1],x);}
  1468. Vt*vcurtail(St*st,vt*self,Vt*x){R vdrop(st,N,NNUMS[0],x);}
  1469. Vt*vsuffixes(St*st,vt*self,Vt*x){if(xt!=ARRAY)x=venlist(st,N,x);
  1470. Lst*r=ln();
  1471. Z i=0;
  1472. Lst*t=xa;
  1473. WH(t){lp(r,vdrop(st,N,Vnn(i),x));
  1474. t=t->next;
  1475. i++;}
  1476. lp(r,st->unit);R Vna(r);}
  1477. Vt*vleft(St*st,vt*self,Vt*x,Vt*y){R x;}
  1478. Vt*vsame(St*st,vt*self,Vt*x){R x;}
  1479. Vt*vright(St*st,vt*self,Vt*x,Vt*y){R y;}
  1480. Vt*vsymbol(St*st,vt*self,Vt*x){S s=Vshow(x);R Vny(s);}
  1481. Vt*vapply1(St*st,vt*self,Vt*x,Vt*y){R apM(st,x,y);}
  1482. Vt*vapply2(St*st,vt*self,Vt*x,Vt*y){if(yt!=ARRAY||le(ya)||!ya->next)R st->udf;R apD(st,x,ya->value,ya->next->value);}
  1483. Vt*vshape(St*st,vt*self,Vt*x){if(xt!=ARRAY||le(xa))R st->unit;
  1484. if(!Aap(xa))R venlist(st,N,vcount(st,N,x));
  1485. if(!xa->next)R venlist(st,N,vshape(st,N,xa->value));R venpair(st,N,vcount(st,N,x),vcount(st,N,xa->value));}
  1486. Vt*vreshape(St*st,vt*self,Vt*x,Vt*y){if(yt!=ARRAY)y=venlist(st,N,y);
  1487. elif(le(ya))R y;
  1488. if(xt!=ARRAY)x=venlist(st,N,x);
  1489. elif(le(xa))R st->unit;
  1490. Lst*r;
  1491. if(!xa->next){Vt*a=xa->value;
  1492. if(a->tag!=NUM)R st->udf;
  1493. Z k=fabs(a->val.number);
  1494. Lst*t=ln();
  1495. flatten(y,t);
  1496. r=ln();
  1497. WH(k){lp(r,t->value);
  1498. if(t->next)t=t->next;
  1499. k--;}}elif(xa->next){Vt*a=xa->value;
  1500. if(a->tag!=NUM)R st->udf;
  1501. Vt*b=xa->next->value;
  1502. if(a->tag!=NUM)R st->udf;
  1503. Z k=fabs(a->val.number);
  1504. Z l=fabs(b->val.number);
  1505. y=vreshape(st,self,venlist(st,N,Vnn(k*l)),y);
  1506. Lst*t=ya;
  1507. r=ln();
  1508. WH(k--){Lst*rw=ln();
  1509. for(Z i=0;i<l;i++){lp(rw,t->value);
  1510. t=t->next;}
  1511. lp(r,Vna(rw));}}else R st->udf;R Vna(r);}
  1512. Vt*vrepr(St*st,vt*self,Vt*x){S s=Vshow(x);
  1513. Lst*r=ln();
  1514. for(Z i=0;i<strlen(s);i++)lp(r,Vnc(s[i]));
  1515. FR(s);R Vna(r);}
  1516. S format(S template,Lst*replaces){Bt*text=Bnew();
  1517. B skip=F;
  1518. Z ri=0;
  1519. Z tl=strlen(template);
  1520. Z rl=ll(replaces);
  1521. for(Z i=0;i<tl;i++){C c=template[i];
  1522. if(skip){Bappend(text,c);
  1523. skip=F;CN;}
  1524. if(c=='_'){S s=Vshow(li(replaces,ri));
  1525. BappendS(text,s);
  1526. FR(s);
  1527. if(ri<rl-1)ri++;CN;}elif(c=='{'){Z bi=i;
  1528. Bt*n=Bnew();
  1529. i++;
  1530. WH(i<tl&&template[i]!='}')Bappend(n,template[i++]);
  1531. if(i>=tl||template[i]!='}'){FR(Bread(n));
  1532. Bappend(text,'{');
  1533. i=bi;CN;}
  1534. S s=Bread(n);
  1535. SZ ind=atoi(s);
  1536. FR(s);
  1537. Vt*v=li(replaces,ind);
  1538. if(!v)CN;
  1539. s=Vshow(v);
  1540. BappendS(text,s);
  1541. FR(s);CN;}elif(c=='~'){skip=T;CN;}
  1542. Bappend(text,c);}
  1543. R Bread(text);}
  1544. Vt*vformat(St*st,vt*self,Vt*x,Vt*y){if(xt!=ARRAY)x=venlist(st,N,x);
  1545. elif(le(xa))R x;
  1546. S fmt=Vshow(y);
  1547. S s=format(fmt,xa);
  1548. FR(fmt);
  1549. Lst*r=ln();
  1550. WH(*s)lp(r,Vnc(*s++));R Vna(r);}
  1551. Vt*vinsert(St*st,vt*self,Vt*x,Vt*y){if(yt!=ARRAY)y=venlist(st,N,y);
  1552. Lst*r=ln();
  1553. Lst*t=ya;
  1554. WH(t){lp(r,t->value);
  1555. if(t->next)lp(r,x);
  1556. t=t->next;}
  1557. R Vna(r);}
  1558. U64 fibonacci(U64 n){U64 a=0;
  1559. U64 b=1;
  1560. WH(n-->1){U64 t=a;
  1561. a=b;
  1562. b+=t;}
  1563. R b;}
  1564. Vt*vfibonacci(St*st,vt*self,Vt*x){if(xt==NUM)R Vnn(fibonacci((U64)fabs(xn)));R _NAN;}
  1565. Vt*viota(St*st,vt*self,Vt*x){if(Veq(x,NUMS[1]))R venlist(st,N,NUMS[1]);
  1566. elif(Veq(x,NUMS[0]))R st->unit;R vrange(st,self,NUMS[1],x);}
  1567. Vt*vrange(St*st,vt*self,Vt*x,Vt*y){if((xt==NUM||xt==CHAR)&&(yt==NUM||yt==CHAR)){if(xt==NUM&&spnp(xn))R st->udf;
  1568. if(yt==NUM&&spnp(yn))R st->udf;
  1569. SZ s=Vnum(x);
  1570. SZ e=Vnum(y);
  1571. if(s==e)R venlist(st,N,x);
  1572. Lst*r=ln();
  1573. if(s>e)for(SZ i=s;i>=e;i--){if(xt==CHAR||yt==CHAR)lp(r,Vnc(i));
  1574. else lp(r,Vnn(i));}
  1575. else for(SZ i=s;i<=e;i++){if(xt==CHAR||yt==CHAR)lp(r,Vnc(i));
  1576. else lp(r,Vnn(i));}
  1577. R Vna(r);}
  1578. R _NAN;}
  1579. Vt*vdeal(St*st,vt*self,Vt*x){if(xt!=ARRAY)R x;
  1580. Lst*t=xa;
  1581. if(le(t))R st->udf;
  1582. Z i=rand()%ll(t);R li(t,i);}
  1583. Vt*vroll(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM&&yt==NUM){Lst*r=ln();
  1584. Z k=fabs(xn);
  1585. Z d=fabs(yn);
  1586. for(Z i=0;i<k;i++)lp(r,Vnn(rand()%d));R Vna(r);}
  1587. R st->udf;}
  1588. Vt*vtype(St*st,vt*self,Vt*x){R NUMS[xt];}
  1589. Vt*vcast(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM){I t=fabs(xn);
  1590. if(yt==t)R y;
  1591. SW(t){CS ARRAY:if(yt==SYM){S s=yY;
  1592. Lst*r=ln();
  1593. WH(*s)lp(r,Vnc(*s++));R Vna(r);}BR;
  1594. CS NUM:if(yt==CHAR)R Vnn(y->val._char);
  1595. elif(yt==ARRAY&&Cap(ya)){Bt*buf=Bnew();
  1596. Lst*t=ya;
  1597. WH(t){Bappend(buf,((Vt*)t->value)->val._char);
  1598. t=t->next;}
  1599. S s=Bread(buf);
  1600. D r=strtod(s,N);
  1601. FR(s);R Vnn(r);}BR;
  1602. CS CHAR:if(yt==NUM)R Vnc(yn);BR;}}
  1603. R st->udf;}
  1604. Vt*vprint(St*st,vt*self,Vt*x){S s=Vshow(x);
  1605. fprintf(stdout,"%s",s);
  1606. FR(s);R st->nil;}
  1607. Vt*vprintln(St*st,vt*self,Vt*x){S s=Vshow(x);
  1608. fprintf(stdout,"%s\n",s);
  1609. FR(s);R st->nil;}
  1610. Vt*vexit(St*st,vt*self,Vt*x){if(xt!=NUM)R st->udf;
  1611. I code=xn;
  1612. exit(code);R st->nil;}
  1613. Vt*vread(St*st,vt*self,Vt*x){if(x==NUMS[0]){Bt*buf=Bnew();
  1614. Z size=0;
  1615. LOOP{I c=fgetc(stdin);
  1616. if(c<0)BR;
  1617. Bappend(buf,c);size++;}
  1618. S s=Bread(buf);
  1619. Lst*r=ln();
  1620. for(Z i=0;i<size;i++)lp(r,Vnc(s[i]));
  1621. FR(s);R Vna(r);}
  1622. elif(x==NUMS[1]){C line[512];
  1623. if(!fgets(line,SO(line),stdin))R st->udf;
  1624. Lst*r=ln();
  1625. for(Z i=0;i<strlen(line);i++)lp(r,Vnc(line[i]));R Vna(r);}
  1626. S path=Vshow(x);
  1627. FILE*fd=fopen(path,"rb");
  1628. if(!fd){FR(path);R st->udf;}
  1629. fseek(fd,0,SEEK_END);
  1630. Z size=ftell(fd);
  1631. fseek(fd,0,SEEK_SET);
  1632. UC*buf=ma(size+1);
  1633. if(!buf)R st->udf;
  1634. size=fread(buf,SO(UC),size,fd);
  1635. fclose(fd);
  1636. FR(path);
  1637. Lst*r=ln();
  1638. for(Z i=0;i<size;i++)lp(r,Vnc(buf[i]));
  1639. FR(buf);R Vna(r);}
  1640. Vt*vwrite(St*st,vt*self,Vt*x,Vt*y){if(xt!=ARRAY)x=venlist(st,N,x);
  1641. S path=Vshow(y);
  1642. FILE*fd=fopen(path,"wb");
  1643. if(!fd){FR(path);R NNUMS[0];}
  1644. Z k=0;
  1645. Lst*t=xa;
  1646. WH(t){UC c;
  1647. Vt*v=t->value;
  1648. if(v->tag==NUM)c=fabs(vn);
  1649. elif(v->tag==CHAR)c=v->val._char;
  1650. else BR;
  1651. fputc(c,fd);
  1652. t=t->next;k++;}
  1653. fclose(fd);
  1654. FR(path);R Vnn(k);}
  1655. Vt*vsystem(St*st,vt*self,Vt*x){S cmd=Vshow(x);
  1656. FILE*pd;
  1657. pd=popen(cmd,"r");
  1658. if(!pd){FR(cmd);R st->udf;}
  1659. UC*buffer=N;
  1660. Z Bsize=0;
  1661. Z Ballocated=0;
  1662. Z bytes_received;
  1663. UC chunk[1024];
  1664. LOOP{bytes_received=fread(chunk,1,1024,pd);
  1665. if(bytes_received==0)BR;
  1666. Z head=Bsize;
  1667. Bsize+=bytes_received;
  1668. if(Bsize>Ballocated){Ballocated=Bsize;
  1669. if(!buffer)buffer=ma(Ballocated);
  1670. else buffer=mrea(buffer,Ballocated);
  1671. if(!buffer){FR(cmd);
  1672. pclose(pd);R st->udf;}}
  1673. for(Z i=0;i<bytes_received;i++)buffer[head+i]=chunk[i];
  1674. if(feof(pd))BR;}
  1675. pclose(pd);
  1676. FR(cmd);
  1677. Lst*r=ln();
  1678. for(Z i=0;i<Bsize;i++)lp(r,Vnc(buffer[i]));
  1679. FR(buffer);R Vna(r);}
  1680. struct files_t{FILE*in;
  1681. FILE*out;};
  1682. typedef struct files_t files_t;
  1683. struct files_chain_t{files_t files;
  1684. pid_t pid;
  1685. struct files_chain_t*next;};
  1686. typedef struct files_chain_t files_chain_t;
  1687. static files_chain_t*files_chain;
  1688. V _cleanup_pipe(int*pipe){close(pipe[0]);
  1689. close(pipe[1]);}
  1690. static I _do_popen2(files_chain_t*link,const S command){I child_in[2];
  1691. I child_out[2];
  1692. if(0!=pipe(child_in))return-1;
  1693. if(0!=pipe(child_out)){_cleanup_pipe(child_in);
  1694. return-1;}
  1695. pid_t cpid=link->pid=fork();
  1696. if(0>cpid){_cleanup_pipe(child_in);
  1697. _cleanup_pipe(child_out);
  1698. return-1;}
  1699. if(0==cpid){if(0>dup2(child_in[0],0)||0>dup2(child_out[1],1))_Exit(127);
  1700. _cleanup_pipe(child_in);
  1701. _cleanup_pipe(child_out);
  1702. for(files_chain_t*p=files_chain;p;p=p->next){I fd_in=fileno(p->files.in);
  1703. if(fd_in!=0)close(fd_in);
  1704. I fd_out=fileno(p->files.out);
  1705. if(fd_out!=1)close(fd_out);}
  1706. execl("/bin/sh","sh","-c",command,(S )N);
  1707. _Exit(127);}
  1708. close(child_in[0]);
  1709. close(child_out[1]);
  1710. link->files.in=fdopen(child_in[1],"w");
  1711. link->files.out=fdopen(child_out[0],"r");R 0;}
  1712. files_t*popen2(const S command){files_chain_t*link=(files_chain_t*)malloc(SO(files_chain_t));
  1713. if(N==link)R N;
  1714. if(0>_do_popen2(link,command)){free(link);R N;}
  1715. link->next=files_chain;
  1716. files_chain=link;R(files_t*)link;}
  1717. I pclose2(files_t*fp){files_chain_t**p=&files_chain;
  1718. I found=0;
  1719. WH(*p){if(*p==(files_chain_t*)fp){*p=(*p)->next;
  1720. found=1;BR;}
  1721. p=&(*p)->next;}
  1722. if(!found)return-1;
  1723. if(0>fclose(fp->out)){free((files_chain_t*)fp);
  1724. return-1;}
  1725. I status=-1;
  1726. pid_t wait_pid;
  1727. do{wait_pid=waitpid(((files_chain_t*)fp)->pid,&status,0);}WH(-1==wait_pid&&EINTR==errno);
  1728. free((files_chain_t*)fp);
  1729. if(wait_pid==-1)return-1;R status;}
  1730. Vt*vsystem2(St*st,vt*self,Vt*x,Vt*y){S cmd=Vshow(y);
  1731. files_t*pd;
  1732. pd=popen2(cmd);
  1733. if(pd==N){FR(cmd);R st->udf;}
  1734. Lst*t=xa;
  1735. WH(t){UC c;
  1736. Vt*v=t->value;
  1737. if(v->tag==NUM)c=fabs(vn);
  1738. elif(v->tag==CHAR)c=v->val._char;
  1739. else BR;
  1740. fputc(c,pd->in);
  1741. t=t->next;}
  1742. fflush(pd->in);
  1743. fclose(pd->in);
  1744. UC*buffer=N;
  1745. Z Bsize=0;
  1746. Z Ballocated=0;
  1747. Z bytes_received;
  1748. UC chunk[1024];
  1749. LOOP{bytes_received=fread(chunk,1,1024,pd->out);
  1750. if(bytes_received==0)BR;
  1751. Z head=Bsize;
  1752. Bsize+=bytes_received;
  1753. if(Bsize>Ballocated){Ballocated=Bsize;
  1754. if(!buffer)buffer=ma(Ballocated);
  1755. else buffer=mrea(buffer,Ballocated);
  1756. if(!buffer){FR(cmd);
  1757. pclose2(pd);R st->udf;}}
  1758. for(Z i=0;i<bytes_received;i++)buffer[head+i]=chunk[i];
  1759. if(feof(pd->out))BR;}
  1760. pclose2(pd);
  1761. FR(cmd);
  1762. Lst*r=ln();
  1763. for(Z i=0;i<Bsize;i++)lp(r,Vnc(buffer[i]));
  1764. FR(buffer);R Vna(r);}
  1765. Vt*vshl(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM&&yt==NUM)R Vnn(((int)xn)<<((int)yn));R _NAN;}
  1766. Vt*vshr(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM&&yt==NUM)R Vnn(((int)xn)>>((int)yn));R _NAN;}
  1767. Vt*vxor(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM&&yt==NUM)R Vnn(((int)xn)^((int)yn));R _NAN;}
  1768. Vt*vband(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM&&yt==NUM)R Vnn(((int)xn)&((int)yn));R _NAN;}
  1769. Vt*vbor(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM&&yt==NUM)R Vnn(((int)xn)|((int)yn));R _NAN;}
  1770. Vt*vbnot(St*st,vt*self,Vt*x){if(xt==NUM)R Vnn(~(int)xn);R _NAN;}
  1771. Lst*prime_factors(D n){Lst*factors=ln();
  1772. D divisor=2;
  1773. WH(n>=2){if(fmod(n,divisor)==0){lp(factors,Vnn(divisor));
  1774. n/=divisor;}else divisor++;}
  1775. R factors;}
  1776. Vt*vfactors(St*st,vt*self,Vt*x){if(xt==NUM&&!spnp(xn))R Vna(prime_factors(xn));R st->udf;}
  1777. Vt*vcombine(St*st,vt*self,Vt*x,Vt*y){if(xt==NUM&&yt==NUM&&!spnp(xn)&&!spnp(yn)){Vt*n=venpair(st,N,x,y);R vunbase(st,N,NUMS[10],n);}
  1778. R _NAN;}
  1779. Vt*Srun(St*st,S program);
  1780. Vt*veval(St*st,vt*self,Vt*x){S s=Vshow(x);
  1781. jmp_buf*lb=guard();
  1782. if(setjmp(*lb)){unguard();
  1783. FR(s);R st->udf;}
  1784. Vt*v=Srun(st,s);
  1785. FR(s);
  1786. unguard();R v;}
  1787. Vt*vimport(St*st,vt*self,Vt*x){S path=Vshow(x);
  1788. FILE*fd=fopen(path,"rb");
  1789. if(!fd){FR(path);R st->udf;}
  1790. fseek(fd,0,SEEK_END);
  1791. Z size=ftell(fd);
  1792. fseek(fd,0,SEEK_SET);
  1793. UC*buf=ma(size+1);
  1794. if(!buf)R st->udf;
  1795. size=fread(buf,SO(UC),size,fd);
  1796. fclose(fd);
  1797. FR(path);
  1798. Vt*v=Srun(st,(S )buf);
  1799. FR(buf);R v;}
  1800. Vt*vudf1(St*st,vt*self,Vt*x){R st->udf;}
  1801. Vt*vudf2(St*st,vt*self,Vt*x,Vt*y){R st->udf;}
  1802. #define X UINT_MAX
  1803. #define DEFVERB(__symb,__rm,__rl,__rr,__m,__d)\
  1804. {__symb,{__rm,__rl,__rr},N,F,F,v##__m,v##__d}
  1805. #define DEFVERBD(__symb,__rm,__rl,__rr,__m,__d)\
  1806. {__symb ".",{__rm,__rl,__rr},N,F,F,v##__m,v##__d}
  1807. #define DEFVERBC(__symb,__rm,__rl,__rr,__m,__d)\
  1808. {__symb ":",{__rm,__rl,__rr},N,F,F,v##__m,v##__d}
  1809. vt VERBS[]={DEFVERB(":",0,0,0,const,bind),DEFVERBC(":",0,0,0,udf1,obverse),DEFVERB("+",0,X,X,flip,plus),DEFVERBD("+",X,X,X,fibonacci,gcd),DEFVERBC("+",X,X,X,sin,combine),DEFVERB("-",X,X,X,negate,minus),DEFVERBD("-",X,X,X,atan,atan2),DEFVERB("*",0,X,X,first,times),DEFVERBD("*",X,X,X,factorial,lcm),DEFVERBC("*",X,X,0,double,replicate),DEFVERB("%",X,X,X,reciprocal,divide),DEFVERBD("%",X,X,X,sqrt,root),DEFVERBC("%",X,X,X,halve,idivide),DEFVERB("!",X,X,X,enum,mod),DEFVERBD("!",X,X,X,iota,range),DEFVERBC("!",0,X,0,odometer,chunks),DEFVERB("^",X,X,X,exp,power),DEFVERBD("^",X,X,X,nlog,log),DEFVERB("=",0,X,X,permute,equals),DEFVERBD("=",0,0,0,occurences,mask),DEFVERBC("=",0,0,0,classify,equals),DEFVERB("~",X,X,X,not,not_equals),DEFVERBD("~",X,0,0,sign,insert),DEFVERBC("~",0,0,0,not,not_equals),DEFVERB("<",X,X,X,pred,less),DEFVERBD("<",X,X,X,floor,lesseq),DEFVERBC("<",0,0,X,gradedown,nudge_left),DEFVERB(">",X,X,X,succ,greater),DEFVERBD(">",X,X,X,ceil,greatereq),DEFVERBC(">",0,0,X,gradeup,nudge_right),DEFVERB(",",0,0,0,enlist,join),DEFVERBD(",",X,0,0,enlist,enpair),DEFVERB("#",0,X,0,count,take),DEFVERBD("#",0,0,0,where,copy),DEFVERBC("#",0,0,0,group,buckets),DEFVERB("_",0,X,0,nub,drop),DEFVERBD("_",0,X,0,unbits,unbase),DEFVERBC("_",X,X,X,bits,base),DEFVERB("?",0,0,0,unique,find),DEFVERB("&",0,X,X,flatten,minand),DEFVERB("|",0,X,X,reverse,maxor),DEFVERBD("|",X,0,0,round,rotate),DEFVERBC("|",0,X,0,depth,windows),DEFVERB("@",X,0,X,abs,at),DEFVERBD("@",0,0,0,shuffle,member),DEFVERB("{",0,0,0,head,bin),DEFVERBD("{",0,0,0,tail,cut),DEFVERBC("{",0,X,X,prefixes,shl),DEFVERB("}",0,X,X,behead,xor),DEFVERBD("}",0,0,0,curtail,band),DEFVERBC("}",0,X,X,suffixes,shr),DEFVERB("[",X,0,0,factors,left),DEFVERBD("[",X,X,X,bnot,bor),DEFVERB("]",0,0,0,same,right),DEFVERBD("`",0,0,0,symbol,apply1),DEFVERBC("`",0,0,0,square,apply2),DEFVERB("$",0,0,0,shape,reshape),DEFVERBD("$",0,0,0,repr,format),DEFVERBD("p",0,0,0,print,udf2),DEFVERBD("P",0,0,0,println,udf2),DEFVERBD("f",0,0,0,selfref1,selfref2),DEFVERBD("F",0,0,0,read,write),DEFVERBD("r",0,X,X,deal,roll),DEFVERBD("t",0,0,0,type,cast),DEFVERBD("E",0,0,0,exit,udf2),DEFVERBD("y",0,0,0,system,system2),DEFVERBD("e",0,0,0,eval,udf2),DEFVERBD("i",0,0,0,import,udf2)};
  1810. Vt*_advfold_m(St*st,vt*self,Vt*x){if(xt!=ARRAY||le(xa))R x;
  1811. Vt*_v=self->bonds->value;
  1812. if(_v->tag!=VERB)R st->udf;
  1813. vt*v=_v->val.verb;
  1814. Vt*t=xa->value;
  1815. Lst*tx=xa->next;
  1816. WH(tx){t=tgth(st,v,t,tx->value,0,0,v->rank[1],v->rank[2]);
  1817. tx=tx->next;}
  1818. R t;}
  1819. Vt*_advfold_d(St*st,vt*self,Vt*x,Vt*y){if(yt!=ARRAY||le(ya))R y;
  1820. Vt*_v=self->bonds->value;
  1821. if(_v->tag!=VERB)R st->udf;
  1822. vt*v=_v->val.verb;
  1823. Vt*t=x;
  1824. Lst*ty=ya;
  1825. WH(ty){t=tgth(st,v,t,ty->value,0,0,v->rank[1],v->rank[2]);
  1826. ty=ty->next;}
  1827. R t;}
  1828. Vt*_advscan_m(St*st,vt*self,Vt*x){if(xt!=ARRAY||le(xa))R x;
  1829. Vt*_v=self->bonds->value;
  1830. if(_v->tag!=VERB)R st->udf;
  1831. vt*v=_v->val.verb;
  1832. Lst*r=ln();
  1833. Vt*t=xa->value;
  1834. Lst*tx=xa->next;
  1835. lp(r,t);
  1836. WH(tx){t=tgth(st,v,t,tx->value,0,0,v->rank[1],v->rank[2]);
  1837. lp(r,t);
  1838. tx=tx->next;}
  1839. R Vna(r);}
  1840. Vt*_advscan_d(St*st,vt*self,Vt*x,Vt*y){if(yt!=ARRAY||le(ya))R y;
  1841. Vt*_v=self->bonds->value;
  1842. if(_v->tag!=VERB)R st->udf;
  1843. vt*v=_v->val.verb;
  1844. Lst*r=ln();
  1845. Vt*t=x;
  1846. Lst*ty=ya;
  1847. lp(r,t);
  1848. WH(ty){t=tgth(st,v,t,ty->value,0,0,v->rank[1],v->rank[2]);
  1849. lp(r,t);
  1850. ty=ty->next;}
  1851. R Vna(r);}
  1852. Vt*_adveach_m(St*st,vt*self,Vt*x){Vt*_v=self->bonds->value;
  1853. if(_v->tag!=VERB)R st->udf;
  1854. vt*v=_v->val.verb;
  1855. if(xt!=ARRAY)R eR(st,v,x,0,1);
  1856. if(le(xa))R x;R eR(st,v,x,0,1);}
  1857. Vt*_adveach_d(St*st,vt*self,Vt*x,Vt*y){Vt*_v=self->bonds->value;
  1858. if(_v->tag!=VERB)R st->udf;
  1859. vt*v=_v->val.verb;
  1860. if(xt!=ARRAY)x=venlist(st,N,x);
  1861. if(yt!=ARRAY)y=venlist(st,N,y);
  1862. Lst*r=ln();
  1863. Lst*tx=xa;
  1864. Lst*ty=ya;
  1865. WH(tx&&ty){lp(r,tgth(st,v,tx->value,ty->value,0,0,v->rank[1],v->rank[2]));
  1866. tx=tx->next;
  1867. ty=ty->next;}
  1868. R Vna(r);}
  1869. Vt*_advconverge_m(St*st,vt*self,Vt*x){Vt*_v=self->bonds->value;
  1870. if(_v->tag!=VERB)R st->udf;
  1871. vt*v=_v->val.verb;
  1872. Vt*t;
  1873. LOOP{t=x;
  1874. x=eR(st,v,x,0,v->rank[0]);
  1875. if(Veq(x,t))BR;}
  1876. R x;}
  1877. vt*cnjbond(St*st,Vt*x,Vt*y);
  1878. Vt*_advconverge_d(St*st,vt*self,Vt*x,Vt*y){Vt*_v=self->bonds->value;
  1879. if(_v->tag!=VERB)R st->udf;
  1880. vt*v=_v->val.verb;
  1881. if(yt!=ARRAY)R tgth(st,v,y,x,0,0,v->rank[1],v->rank[2]);
  1882. if(le(ya))R x;
  1883. v=cnjbond(st,Vnv(v),x);R eR(st,v,y,0,1);}
  1884. Vt*_advconverges_m(St*st,vt*self,Vt*x){Vt*_v=self->bonds->value;
  1885. if(_v->tag!=VERB)R st->udf;
  1886. Lst*r=ln();
  1887. Vt*t;
  1888. lp(r,x);
  1889. LOOP{t=x;
  1890. x=apM(st,_v,x);
  1891. if(Veq(x,t))BR;
  1892. lp(r,x);}
  1893. R Vna(r);}
  1894. Vt*_advconverges_d(St*st,vt*self,Vt*x,Vt*y){Vt*_v=self->bonds->value;
  1895. if(_v->tag!=VERB)R st->udf;
  1896. vt*v=_v->val.verb;
  1897. if(yt!=ARRAY)R tgth(st,v,y,x,0,0,v->rank[1],v->rank[2]);
  1898. if(le(ya))R x;
  1899. v=cnjbond(st,x,Vnv(v));R eR(st,v,y,0,1);}
  1900. Vt*_adveachprior_m(St*st,vt*self,Vt*x){if(xt!=ARRAY||le(xa)||!xa->next)R x;
  1901. Vt*_v=self->bonds->value;
  1902. if(_v->tag!=VERB)R st->udf;
  1903. vt*v=_v->val.verb;
  1904. Lst*r=ln();
  1905. Lst*p=xa;
  1906. Lst*t=xa->next;
  1907. WH(t){lp(r,tgth(st,v,t->value,p->value,0,0,v->rank[1],v->rank[2]));
  1908. p=t;
  1909. t=t->next;}
  1910. R Vna(r);}
  1911. Vt*_adveachprior_d(St*st,vt*self,Vt*x,Vt*y){if(yt!=ARRAY||le(ya))R y;
  1912. Vt*_v=self->bonds->value;
  1913. if(_v->tag!=VERB)R st->udf;
  1914. vt*v=_v->val.verb;
  1915. Lst*r=ln();
  1916. Lst*p=N;
  1917. Lst*t=ya;
  1918. WH(t){lp(r,tgth(st,v,t->value,!p?x:p->value,0,0,v->rank[1],v->rank[2]));
  1919. p=t;
  1920. t=t->next;}
  1921. R Vna(r);}
  1922. Vt*_advreflex_m(St*st,vt*self,Vt*x){Vt*_v=self->bonds->value;
  1923. if(_v->tag!=VERB)R st->udf;
  1924. vt*v=_v->val.verb;R tgth(st,v,x,x,0,0,v->rank[1],v->rank[2]);}
  1925. Vt*_advreflex_d(St*st,vt*self,Vt*x,Vt*y){Vt*_v=self->bonds->value;
  1926. if(_v->tag!=VERB)R st->udf;
  1927. vt*v=_v->val.verb;R tgth(st,v,y,x,0,0,v->rank[1],v->rank[2]);}
  1928. Vt*_advamend_m(St*st,vt*self,Vt*x){R st->udf;}
  1929. Vt*_advamend_d(St*st,vt*self,Vt*x,Vt*y){if(xt!=ARRAY)x=venlist(st,N,x);
  1930. Vt*v=self->bonds->value;
  1931. if(v->tag!=ARRAY)v=venlist(st,N,v);
  1932. if(yt!=ARRAY)y=venlist(st,N,y);
  1933. Lst*r=lc(ya);
  1934. Z i=0;
  1935. Z l=ll(xa);
  1936. Lst*t=v->val.array;
  1937. WH(t){Vt*n=t->value;
  1938. if(n->tag!=NUM)BR;
  1939. ls(r,n->val.number,li(xa,i<l?i:l-1));
  1940. t=t->next;
  1941. i++;}
  1942. R Vna(r);}
  1943. Vt*_advfilter_m(St*st,vt*self,Vt*x){Vt*_v=self->bonds->value;
  1944. if(_v->tag!=VERB)R st->udf;
  1945. if(xt!=ARRAY)x=venlist(st,N,x);
  1946. elif(le(xa))R x;
  1947. vt*v=_v->val.verb;
  1948. Lst*r=ln();
  1949. Lst*t=xa;
  1950. WH(t){Vt*b=eR(st,v,t->value,0,v->rank[0]);
  1951. if(VTp(b))lp(r,t->value);
  1952. t=t->next;}
  1953. R Vna(r);}
  1954. Vt*_advfilter_d(St*st,vt*self,Vt*x,Vt*y){R st->udf;}
  1955. Vt*_advspan_m(St*st,vt*self,Vt*x){Vt*v=self->bonds->value;
  1956. if(v->tag!=VERB)R st->udf;
  1957. if(xt!=ARRAY)x=venlist(st,N,x);
  1958. elif(le(xa))R x;
  1959. Lst*r=ln();
  1960. Lst*t=xa;
  1961. Lst*p=ln();
  1962. WH(t){Vt*b=apM(st,v,t->value);
  1963. if(VTp(b)){lp(r,Vna(p));
  1964. p=ln();}else lp(p,t->value);
  1965. t=t->next;}
  1966. lp(r,Vna(p));R Vna(r);}
  1967. Vt*_advspan_d(St*st,vt*self,Vt*x,Vt*y){Vt*_v=self->bonds->value;
  1968. if(_v->tag!=VERB)R st->udf;
  1969. vt*v=_v->val.verb;
  1970. Vt*r=vwindows(st,N,x,y);R eR(st,v,r,0,1);}
  1971. Vt*_advinverse_m(St*st,vt*self,Vt*x){Vt*_v=self->bonds->value;
  1972. if(_v->tag!=VERB)R st->udf;
  1973. vt*v=_v->val.verb;
  1974. vt*iv=Tget(Inverses,v->name);
  1975. if(!iv)R st->udf;R eR(st,iv,x,0,iv->rank[0]);}
  1976. Vt*_advinverse_d(St*st,vt*self,Vt*x,Vt*y){Vt*_v=self->bonds->value;
  1977. if(_v->tag!=VERB)R st->udf;
  1978. vt*v=_v->val.verb;
  1979. vt*iv=Tget(Inverses,v->name);
  1980. if(!iv)R st->udf;
  1981. Vt*a=eR(st,iv,x,0,iv->rank[0]);
  1982. Vt*b=eR(st,iv,y,0,iv->rank[0]);R apD(st,_v,a,b);}
  1983. Vt*_advlaminate_m(St*st,vt*self,Vt*x){Vt*_v=self->bonds->value;
  1984. if(_v->tag!=VERB)R st->udf;
  1985. if(xt!=ARRAY)x=venlist(st,N,x);
  1986. elif(le(xa))R st->udf;
  1987. Vt*r=xa->value;
  1988. Lst*t=xa;
  1989. WH(t){r=apD(st,_v,r,t->value);
  1990. t=t->next;}
  1991. R r;}
  1992. Vt*_advlaminate_d(St*st,vt*self,Vt*x,Vt*y){Vt*_v=self->bonds->value;
  1993. if(_v->tag!=VERB)R st->udf;
  1994. if(yt!=ARRAY)y=venlist(st,N,y);
  1995. elif(le(ya))R st->udf;
  1996. Vt*r=x;
  1997. Lst*t=ya;
  1998. WH(t){r=apD(st,_v,r,t->value);
  1999. t=t->next;}
  2000. R r;}
  2001. #define ADVERB(__name,__symb)\
  2002. vt*adv##__name(St*st,Vt*v){\
  2003. vt*nv=vnew();\
  2004. nv->bonds=ln();\
  2005. lp(nv->bonds,v);\
  2006. S r=Vshow(v);\
  2007. Z l=strlen(r)+strlen(__symb)+1;\
  2008. nv->name=ma(l);\
  2009. snprintf(nv->name,l,"%s" __symb,r);\
  2010. FR(r);\
  2011. nv->rank[0]=0;\
  2012. nv->monad=_adv##__name##_m;\
  2013. nv->dyad=_adv##__name##_d;\
  2014. R nv;}
  2015. ADVERB(fold,"/");
  2016. ADVERB(converge,"/.");
  2017. ADVERB(scan,"\\");
  2018. ADVERB(converges,"\\.");
  2019. ADVERB(each,"\"");
  2020. ADVERB(eachprior,"\".");
  2021. ADVERB(reflex,";.");
  2022. ADVERB(amend,"`");
  2023. ADVERB(filter,"&.");
  2024. ADVERB(span,"/:");
  2025. ADVERB(inverse,"-:");
  2026. ADVERB(laminate,"@:");
  2027. advt ADVERBS[]={{"/",advfold,N}, {"/.",advconverge,N},{"\\",advscan,N}, {"\\.",advconverges,N},{"\"",adveach,N}, {"\".",adveachprior,N},{";.",advreflex,N},{"`",advamend,N},{"&.",advfilter,N},{"/:",advspan,N},{"-:",advinverse,N},{"@:",advlaminate,N}};
  2028. Vt*_cnjbond_m(St*st,vt*self,Vt*x){Vt*v1=self->bonds->value;
  2029. Vt*v2=self->bonds->next->value;
  2030. if(v1->tag==VERB&&v2->tag==VERB)R apM(st,v1,apM(st,v2,x));
  2031. elif(v1->tag==VERB)R apD(st,v1,x,v2);
  2032. elif(v2->tag==VERB)R apD(st,v2,v1,x);
  2033. else R st->nil;}
  2034. Vt*_cnjbond_d(St*st,vt*self,Vt*x,Vt*y){Vt*v1=self->bonds->value;
  2035. Vt*v2=self->bonds->next->value;
  2036. if(v1->tag==VERB&&v2->tag==VERB)R apM(st,v1,apD(st,v2,x,y));
  2037. elif(v1->tag==VERB)R apD(st,v1,apD(st,v1,x,y),v2);
  2038. elif(v2->tag==VERB)R apD(st,v2,v1,apD(st,v2,x,y));
  2039. else R st->nil;}
  2040. Vt*_cnjpick_m(St*st,vt*self,Vt*x){Vt*v1=self->bonds->value;
  2041. Vt*v2=self->bonds->next->value;
  2042. if(v1->tag!=VERB||v2->tag!=ARRAY)R st->nil;
  2043. Vt*n=apM(st,v1,x);
  2044. Vt*f=vat(st,N,v2,n);R apM(st,f,x);}
  2045. Vt*_cnjpick_d(St*st,vt*self,Vt*x,Vt*y){Vt*v1=self->bonds->value;
  2046. Vt*v2=self->bonds->next->value;
  2047. if(v1->tag!=VERB||v2->tag!=ARRAY)R st->nil;
  2048. Vt*n=apD(st,v1,x,y);
  2049. Vt*f=vat(st,N,v2,n);R apD(st,f,x,y);}
  2050. Vt*_cnjwhile_m(St*st,vt*self,Vt*x){Vt*v1=self->bonds->value;
  2051. Vt*v2=self->bonds->next->value;
  2052. if(v1->tag==VERB){LOOP{if(!VTp(apM(st,v1,x)))BR;
  2053. x=apM(st,v2,x);}}elif(v1->tag==NUM){Z k=(Z)fabs(v1->val.number);
  2054. for(Z i=0;i<k;i++)x=apM(st,v2,x);}
  2055. R x;}
  2056. Vt*_cnjwhile_d(St*st,vt*self,Vt*x,Vt*y){Vt*v1=self->bonds->value;
  2057. Vt*v2=self->bonds->next->value;
  2058. if(v1->tag==VERB){LOOP{if(!VTp(apD(st,v1,x,y)))BR;
  2059. x=apD(st,v2,x,y);}}elif(v1->tag==NUM){Z k=(Z)fabs(v1->val.number);
  2060. for(Z i=0;i<k;i++)x=apD(st,v2,x,y);}
  2061. R x;}
  2062. Vt*_cnjrank_m(St*st,vt*self,Vt*x){Vt*v1=self->bonds->value;
  2063. Vt*v2=self->bonds->next->value;
  2064. if(v1->tag!=VERB||v2->tag!=NUM)R st->udf;
  2065. UI rank=
  2066. v2->val.number==INFINITY?UINT_MAX:fabs(v2->val.number);R eR(st,v1->val.verb,x,0,rank);}
  2067. Vt*_cnjrank_d(St*st,vt*self,Vt*x,Vt*y){Vt*v1=self->bonds->value;
  2068. Vt*v2=self->bonds->next->value;
  2069. if(v1->tag!=VERB||v2->tag!=NUM)R st->udf;
  2070. UI rank=
  2071. v2->val.number==INFINITY?UINT_MAX:fabs(v2->val.number);R tgth(st,v1->val.verb,x,y,0,0,rank,rank);}
  2072. Vt*_cnjmonaddyad_m(St*st,vt*self,Vt*x){Vt*v=self->bonds->value;
  2073. if(v->tag!=VERB)R st->udf;R eR(st,v->val.verb,x,0,v->val.verb->rank[0]);}
  2074. Vt*_cnjmonaddyad_d(St*st,vt*self,Vt*x,Vt*y){Vt*v=self->bonds->next->value;
  2075. if(v->tag!=VERB)R st->udf;R tgth(st,v->val.verb,x,y,0,0,v->val.verb->rank[1],v->val.verb->rank[2]);}
  2076. Vt*_cnjif_m(St*st,vt*self,Vt*x){Vt*v1=self->bonds->value;
  2077. Vt*v2=self->bonds->next->value;
  2078. if(v1->tag!=VERB||v2->tag!=VERB)R st->udf;
  2079. Vt*b=apM(st,v2,x);
  2080. if(VTp(b))R x;R apM(st,v1,x);}
  2081. Vt*_cnjif_d(St*st,vt*self,Vt*x,Vt*y){Vt*v1=self->bonds->value;
  2082. Vt*v2=self->bonds->next->value;
  2083. if(v1->tag!=VERB||v2->tag!=VERB)R st->udf;
  2084. Vt*b=apD(st,v2,x,y);
  2085. if(VTp(b))R y;R apD(st,v1,x,y);}
  2086. Vt*_cnjunder_m(St*st,vt*self,Vt*x){Vt*v1=self->bonds->value;
  2087. Vt*v2=self->bonds->next->value;
  2088. if(v1->tag!=VERB||v2->tag!=VERB)R st->udf;
  2089. vt*iv=Tget(Inverses,v2->val.verb->name);
  2090. if(!iv)R st->udf;
  2091. Vt*v=apM(st,v2,x);
  2092. v=apM(st,v1,v);R eR(st,iv,v,0,iv->rank[0]);}
  2093. Vt*_cnjunder_d(St*st,vt*self,Vt*x,Vt*y){Vt*v1=self->bonds->value;
  2094. Vt*v2=self->bonds->next->value;
  2095. if(v1->tag!=VERB||v2->tag!=VERB)R st->udf;
  2096. vt*iv=Tget(Inverses,v2->val.verb->name);
  2097. if(!iv)R st->udf;
  2098. Vt*a=apM(st,v2,x);
  2099. Vt*b=apM(st,v2,y);
  2100. Vt*v=apD(st,v1,a,b);R eR(st,iv,v,0,iv->rank[0]);}
  2101. #define CONJUNCTION(__name,__symb)\
  2102. vt*cnj##__name(St*st,Vt*x,Vt*y){\
  2103. vt*nv=vnew();\
  2104. nv->bonds=ln();\
  2105. lp(nv->bonds,x);\
  2106. lp(nv->bonds,y);\
  2107. S rx=Vshow(x);\
  2108. S ry=Vshow(y);\
  2109. Z l=strlen(rx)+strlen(ry)+strlen(__symb)+1;\
  2110. nv->name=ma(l);\
  2111. snprintf(nv->name,l,"%s"__symb"%s",rx,ry);\
  2112. FR(rx);\
  2113. FR(ry);\
  2114. nv->rank[0]=0;\
  2115. nv->rank[1]=0;\
  2116. nv->rank[1]=0;\
  2117. nv->monad=_cnj##__name##_m;\
  2118. nv->dyad=_cnj##__name##_d;\
  2119. R nv;}
  2120. CONJUNCTION(bond,";");
  2121. CONJUNCTION(pick,"?.");
  2122. CONJUNCTION(while,"?:");
  2123. CONJUNCTION(rank,"\":");
  2124. CONJUNCTION(monaddyad,";:");
  2125. CONJUNCTION(if,"&:");
  2126. CONJUNCTION(under,"^:");
  2127. advt CONJUNCTIONS[]={{";",N,cnjbond},{"?.",N,cnjpick},{"?:",N,cnjwhile},{"\":",N,cnjrank},{";:",N,cnjmonaddyad},{"&:",N,cnjif},{"^:",N,cnjunder}};
  2128. #define FINDER(kind,rname,table)\
  2129. kind*G##rname(S s){\
  2130. for(Z i=0;i<AE(table);i++){\
  2131. if(strcmp(table[i].name,s)==0)\
  2132. R &table[i];}\
  2133. R N;}
  2134. FINDER(vt,v,VERBS);
  2135. FINDER(advt,adv,ADVERBS);
  2136. FINDER(advt,cnj,CONJUNCTIONS);
  2137. Nt*Nn(enum Ntag_t tag){Nt*node=ma(SO(Nt));
  2138. node->tag=tag;R node;}
  2139. Nt*Nns(Lst*l){Nt*node=ma(SO(Nt));
  2140. node->tag=N_STRAND;
  2141. node->l=l;R node;}
  2142. Nt*Nnl(Vt*v){Nt*node=ma(SO(Nt));
  2143. node->tag=N_LITERAL;
  2144. node->v=v;R node;}
  2145. Nt*Nn1(enum Ntag_t tag,Nt*a){Nt*node=ma(SO(Nt));
  2146. node->tag=tag;
  2147. node->a=a;R node;}
  2148. Nt*Nn2(enum Ntag_t tag,Nt*a,Nt*b){Nt*node=ma(SO(Nt));
  2149. node->tag=tag;
  2150. node->a=a;
  2151. node->b=b;R node;}
  2152. Nt*Nn3(enum Ntag_t tag,Nt*a,Nt*b,Nt*c){Nt*node=ma(SO(Nt));
  2153. node->tag=tag;
  2154. node->a=a;
  2155. node->b=b;
  2156. node->c=c;R node;}
  2157. typedef struct{Lt*lexer;
  2158. St*st;
  2159. Z pos;
  2160. Z end;}Pt;
  2161. Pt*Pnew(St*state){Pt*parser=ma(SO(Pt));
  2162. parser->st=state;R parser;}
  2163. V Perror(Pt*parser,S s){fatal(s);}
  2164. B Pdone(Pt*parser){R parser->pos>=parser->end;}
  2165. Tkt*Plook(Pt*parser,Z offset){Z pos=parser->pos+offset;
  2166. if(pos>=parser->end)R N;R li(parser->lexer->tokens,pos);}
  2167. B Pstop(Pt*parser){Tkt*tok=Plook(parser,0);
  2168. if(!tok)R T;R tok->tag==T_RPAR;}
  2169. V Peat(Pt*parser){if(!Pdone(parser))parser->pos++;}
  2170. Nt*PPexpr(Pt*parser);
  2171. Nt*PPverb(Pt*parser){Tkt*tok=Plook(parser,0);
  2172. if(!tok||tok->tag!=T_PUNCT)R N;
  2173. vt*verb=Gv(tok->text);
  2174. if(!verb)R N;R Nnl(Vnv(verb));}
  2175. Vt*_advwrapper_m(St*st,vt*self,Vt*x){advt*av=self->bonds->value;
  2176. if(xt!=VERB)R st->nil;R Vnv(av->adverb(st,x));}
  2177. Vt*_advwrapper_d(St*st,vt*self,Vt*x,Vt*y){advt*av=self->bonds->value;
  2178. if(xt!=VERB)R st->nil;
  2179. vt*v=av->adverb(st,x);R eR(st,v,y,0,v->rank[0]);}
  2180. Nt*PPadvatom(Pt*parser){Tkt*tok=Plook(parser,0);
  2181. if(!tok||tok->tag!=T_PUNCT)R N;
  2182. advt*adverb=Gadv(tok->text);
  2183. if(!adverb)R N;
  2184. vt*nv=vnew();
  2185. nv->name=sdup(tok->text);
  2186. nv->bonds=ln();
  2187. lp(nv->bonds,adverb);
  2188. nv->rank[0]=0;
  2189. nv->rank[1]=0;
  2190. nv->rank[2]=0;
  2191. nv->monad=_advwrapper_m;
  2192. nv->dyad=_advwrapper_d;R Nnl(Vnv(nv));}
  2193. Vt*_cnjwrapper_d(St*st,vt*self,Vt*x,Vt*y){advt*av=self->bonds->value;R Vnv(av->conjunction(st,x,y));}
  2194. Nt*PPcnjatom(Pt*parser){Tkt*tok=Plook(parser,0);
  2195. if(!tok||tok->tag!=T_PUNCT)R N;
  2196. advt*adverb=Gcnj(tok->text);
  2197. if(!adverb)R N;
  2198. vt*nv=vnew();
  2199. nv->name=sdup(tok->text);
  2200. nv->bonds=ln();
  2201. lp(nv->bonds,adverb);
  2202. nv->rank[0]=0;
  2203. nv->rank[1]=0;
  2204. nv->rank[2]=0;
  2205. nv->monad=N;
  2206. nv->dyad=_cnjwrapper_d;R Nnl(Vnv(nv));}
  2207. Nt*PPatom(Pt*parser){Tkt*tok=Plook(parser,0);
  2208. Nt*node=N;
  2209. SW(tok->tag){CS T_RPAR:Perror(parser,"unmatched");
  2210. CS T_LPAR:Peat(parser);
  2211. tok=Plook(parser,0);
  2212. if(tok&&tok->tag==T_RPAR){node=Nnl(parser->st->unit);BR;}
  2213. node=PPexpr(parser);
  2214. tok=Plook(parser,0);
  2215. if(!tok||tok->tag!=T_RPAR)Perror(parser,"unmatched");BR;
  2216. CS T_PUNCT:node=PPverb(parser);
  2217. if(!node)node=PPadvatom(parser);
  2218. if(!node)node=PPcnjatom(parser);
  2219. if(!node)Perror(parser,"parse");BR;
  2220. CS T_NUM:node=Nnl(Vnn(strtod(tok->text,N)));BR;
  2221. CS T_NAME:node=Nnl(Vny(sdup(tok->text)));BR;
  2222. CS T_QUOTE:if(!*tok->text)node=Nnl(parser->st->unit);
  2223. elif(!*(tok->text+1))node=Nnl(Vnc(tok->text[0]));
  2224. else{Lst*list=ln();
  2225. for(Z i=0;i<strlen(tok->text);i++)lp(list,Vnc(tok->text[i]));
  2226. node=Nnl(Vna(list));}BR;}
  2227. if(!node)Perror(parser,"parse");
  2228. Peat(parser);R node;}
  2229. Nt*PPa(Pt*parser,Nt*a,enum Tkt tag){Tkt*tok;
  2230. if((tok=Plook(parser,0))&&tok->tag==tag){Lst*as=ln();
  2231. lp(as,a->v);
  2232. do{a=PPatom(parser);
  2233. lp(as,a->v);}WH((tok=Plook(parser,0))&&tok->tag==tag);R Nnl(Vna(as));}
  2234. R N;}
  2235. Nt*_PPnoun(Pt*parser){Nt*n;
  2236. Nt*a=PPatom(parser);
  2237. if(a->tag==N_LITERAL&&a->v->tag==NUM&&(n=PPa(parser,a,T_NUM)))R n;
  2238. elif(a->tag==N_LITERAL&&a->v->tag==SYM&&(n=PPa(parser,a,T_NAME)))R n;
  2239. elif(a->tag==N_LITERAL&&a->v->tag==ARRAY&&Cap(a->v->val.array)&&(n=PPa(parser,a,T_QUOTE)))R n;R a;}
  2240. Nt*PPnoun(Pt*parser,B flat){Nt*a=flat?PPatom(parser):_PPnoun(parser);
  2241. Tkt*tok;
  2242. if((tok=Plook(parser,0))&&tok->tag==T_PUNCT&&strcmp(tok->text,",:")==0){Peat(parser);
  2243. Lst*l=ln();
  2244. lp(l,a);
  2245. LOOP{a=flat?PPatom(parser):_PPnoun(parser);
  2246. lp(l,a);
  2247. if(!((tok=Plook(parser,0))&&tok->tag==T_PUNCT&&strcmp(tok->text,",:")==0))BR;
  2248. Peat(parser);}
  2249. R Nns(l);}
  2250. R a;}
  2251. B Nisv(Pt*parser,Nt*n){Vt*v;
  2252. if(n->tag==N_FUN)R T;
  2253. elif(n->tag==N_ADV||n->tag==N_CONJ||n->tag==N_PARTIAL_CONJ)R T;
  2254. elif(n->tag==N_FORK||n->tag==N_HOOK||n->tag==N_BOND||n->tag==N_OVER)R T;
  2255. elif(n->tag==N_LITERAL&&n->v->tag==VERB)R T;
  2256. elif(n->tag==N_LITERAL&&n->v->tag==SYM&&(v=Tget(parser->st->env,n->v->val.symbol))&&v->tag==VERB)R T;R F;}
  2257. Nt*PPadv(Pt*parser,Nt*v,bool*flag){Tkt*tok;
  2258. advt*adv;
  2259. Nt*t;
  2260. LOOP{tok=Plook(parser,0);
  2261. if(!tok||tok->tag!=T_PUNCT)BR;
  2262. if((adv=Gadv(tok->text))){if(flag)*flag=T;
  2263. Peat(parser);
  2264. t=Nn(N_ADV);
  2265. t->av=adv;
  2266. t->a=v;
  2267. v=t;}else BR;}
  2268. R v;}
  2269. Nt*PPcnj(Pt*parser,Nt*v,bool*flag){Tkt*tok;
  2270. advt*adv;
  2271. Nt*t;
  2272. LOOP{tok=Plook(parser,0);
  2273. if(!tok||tok->tag!=T_PUNCT)BR;
  2274. if((adv=Gcnj(tok->text))){if(flag)*flag=T;
  2275. Peat(parser);
  2276. if(Pstop(parser)){t=Nn(N_PARTIAL_CONJ);
  2277. t->av=adv;
  2278. t->a=v;}else{t=Nn(N_CONJ);
  2279. t->av=adv;
  2280. t->a=v;
  2281. t->b=PPnoun(parser,T);}
  2282. v=t;}else BR;}
  2283. R v;}
  2284. B is_apply(Nt*n){R n->tag==N_LITERAL&&n->v->tag==VERB&&(strcmp(n->v->val.verb->name,"`.")==0||strcmp(n->v->val.verb->name,"`:")==0);}
  2285. B is_obverse(Nt*n){R n->tag==N_LITERAL&&n->v->tag==VERB&&strcmp(n->v->val.verb->name,"::")==0;}
  2286. Nt*PPexpr(Pt*parser){Tkt*tmp;
  2287. Lst*ns=ln();
  2288. WH(!Pstop(parser)){if(le(ns)&&(tmp=Plook(parser,0))&&tmp->tag==T_PUNCT&&strcmp(tmp->text,":")==0&&(Plook(parser,1))){Peat(parser);R Nn1(N_FUN,PPexpr(parser));}
  2289. Nt*n=PPnoun(parser,F);
  2290. if(le(ns)&&n->tag==N_LITERAL&&n->v->tag==SYM&&(tmp=Plook(parser,0))&&tmp->tag==T_PUNCT&&strcmp(tmp->text,":")==0){Peat(parser);R Nn2(N_BIND,n,PPexpr(parser));}
  2291. LOOP{B flag=F;
  2292. n=PPadv(parser,n,&flag);
  2293. n=PPcnj(parser,n,&flag);
  2294. if(!flag)BR;}
  2295. lp(ns,n);}
  2296. Z len;
  2297. Nt*l,*m,*r;
  2298. LOOP{len=ll(ns);
  2299. if(len<2)BR;
  2300. if(len>=3&&is_apply(li(ns,-2))||is_obverse(li(ns,-2))){r=lP(ns);
  2301. m=lP(ns);
  2302. l=lP(ns);
  2303. lp(ns,Nn3(N_DYAD,m,l,r));}elif(len>=3&&!Nisv(parser,li(ns,-1))&&Nisv(parser,li(ns,-2))&&!Nisv(parser,li(ns,-3))){r=lP(ns);
  2304. m=lP(ns);
  2305. l=lP(ns);
  2306. lp(ns,Nn3(N_DYAD,m,l,r));}elif(len>=3&&Nisv(parser,li(ns,-1))&&Nisv(parser,li(ns,-2))&&Nisv(parser,li(ns,-3))){r=lP(ns);
  2307. m=lP(ns);
  2308. l=lP(ns);
  2309. lp(ns,Nn3(N_FORK,l,m,r));}elif(len>=3&&Nisv(parser,li(ns,-1))&&Nisv(parser,li(ns,-2))&&!Nisv(parser,li(ns,-3))){r=lP(ns);
  2310. m=lP(ns);
  2311. l=lP(ns);
  2312. lp(ns,Nn3(N_OVER,l,m,r));}elif(len>=2&&is_apply(li(ns,-1))){r=lP(ns);
  2313. l=lP(ns);
  2314. lp(ns,Nn2(N_BOND,r,l));}elif(len>=2&&!Nisv(parser,li(ns,-1))&&Nisv(parser,li(ns,-2))){r=lP(ns);
  2315. l=lP(ns);
  2316. lp(ns,Nn2(N_MONAD,l,r));}elif(len>=2&&Nisv(parser,li(ns,-1))&&Nisv(parser,li(ns,-2))){r=lP(ns);
  2317. l=lP(ns);
  2318. lp(ns,Nn2(N_HOOK,l,r));}elif(len>=2&&Nisv(parser,li(ns,-1))&&!Nisv(parser,li(ns,-2))){r=lP(ns);
  2319. l=lP(ns);
  2320. lp(ns,Nn2(N_BOND,r,l));}elif(len>=3){r=lP(ns);
  2321. m=lP(ns);
  2322. l=lP(ns);
  2323. lp(ns,Nn3(N_INDEX2,m,l,r));}elif(len>=2){r=lP(ns);
  2324. l=lP(ns);
  2325. lp(ns,Nn2(N_INDEX1,l,r));}}
  2326. R ns->value;}
  2327. Nt*Pparse(Pt*parser,Lt*lexer){parser->lexer=lexer;
  2328. parser->pos=0;
  2329. parser->end=ll(parser->lexer->tokens);
  2330. Nt*node=PPexpr(parser);
  2331. if(!Pdone(parser)){Tkt*tok=Plook(parser,0);
  2332. if(tok&&tok->tag==T_RPAR)Perror(parser,"unmatched");
  2333. Perror(parser,"parse");}
  2334. R node;}
  2335. Vt*Srun(St*st,S program){Lt*lexer=Lnew();
  2336. Llex(lexer,program);
  2337. Pt*parser=Pnew(st);
  2338. Nt*node=Pparse(parser,lexer);
  2339. Lst*t=lexer->tokens;
  2340. if(t->value)WH(t){Lst*tmp=t->next;
  2341. Tkt*tok=t->value;
  2342. if(tok->text)FR(tok->text);
  2343. FR(tok);
  2344. FR(t);
  2345. t=tmp;}
  2346. Vt*r=Swalk(st,node);
  2347. FR(parser);R r;}
  2348. cS VHELP =\
  2349. ": monadic const create a function that always yields x" "\n"\
  2350. ": dyadic bind bind y to symbol x" "\n"\
  2351. "+ monadic flip transpose matrix" "\n"\
  2352. "+ dyadic plus add numbers" "\n"\
  2353. "+. monadic fibonacci compute xth fibonacci number" "\n"\
  2354. "+. dyadic gcd compute gcd(x, y)" "\n"\
  2355. "+: monadic sin compute sin(x)" "\n"\
  2356. "+: dyadic combine combine digits of x and y, same as 10_.(10_:),(10_:)" "\n"\
  2357. "- monadic negate negate number" "\n"\
  2358. "- dyadic minus subtract numbers" "\n"\
  2359. "* monadic first yield first element of x" "\n"\
  2360. "* dyadic times multiply numbers" "\n"\
  2361. "% monadic reciprocal 1 / x" "\n"\
  2362. "% dyadic divide divide numbers" "\n"\
  2363. "%: dyadic idivide same as % divide, but result is always integer" "\n"\
  2364. "! monadic enum [0, x)" "\n"\
  2365. "! dyadic mod modulo of numbers" "\n"\
  2366. "!. monadic iota [1, x]" "\n"\
  2367. "!. dyadic range [x, y] (also works for chars and even if x > y)" "\n"\
  2368. "^ monadic exp e^x" "\n"\
  2369. "^ dyadic power raise number to a power" "\n"\
  2370. "= monadic permute generate permutations of x" "\n"\
  2371. "= dyadic equals test whether x and y are equal" "\n"\
  2372. "=. monadic occurences count occurences of elts, =.'Hello World!' is 0 0 0 1 0 0 0 1 0 2 0 0" "\n"\
  2373. "=. dyadic mask mask one array in another, 'abxyzabayxxyabxyk'=.'xy' is 0 0 1 1 0 0 0 0 0 0 2 2 0 0 3 3 0" "\n"\
  2374. "=: monadic classify assign unique index to each unique elt, =:'Hello World!' is 0 1 2 2 3 4 5 3 6 2 7 8" "\n"\
  2375. "=: dyadic match same as = equals, but rank 0, so compares x and y as whole" "\n"\
  2376. "~ monadic not logical not, nil udf () 0 4t.0 are not truthy, everything else is truthy" "\n"\
  2377. "~ dyadic notequals test whether x and y are not equal" "\n"\
  2378. "~: dyadic notmatch rank 0 version of ~ notequals" "\n"\
  2379. "< monadic pred x - 1" "\n"\
  2380. "< dyadic less test whether x is lesser than y" "\n"\
  2381. "<. monadic floor round x down" "\n"\
  2382. "<. dyadic lesseq test whether x is equal or lesser than y" "\n"\
  2383. "<: monadic gradedown indices of array sorted descending" "\n"\
  2384. "> monadic succ x + 1" "\n"\
  2385. "> dyadic greater test whether x is greater than y" "\n"\
  2386. ">. monadic ceil round x up" "\n"\
  2387. ">. dyadic greatereq test whether x is equal or greater than y" "\n"\
  2388. ">: monadic gradeup indices of array sorted ascending" "\n"\
  2389. ", monadic enlist put x into 1-elt array" "\n"\
  2390. ", dyadic join concat x and y" "\n"\
  2391. ",. monadic enfile ame as , enlist but with infinite rank, ,.1 2 3 is (,1),:(,2),:(,3)" "\n"\
  2392. "# monadic count yield count of elts of x" "\n"\
  2393. "# dyadic take take x first elts of y (or last if x < 0)" "\n"\
  2394. "#. monadic where #.0 0 1 0 1 0 is 2 4" "\n"\
  2395. "#. dyadic copy repeat each elt of x by corresponding number in y, 5 2 3 3#.0 2 2 1 is 2 2 3 3 3" "\n"\
  2396. "#: monadic group #:'mississippi' is (,0),:1 4 7 10,:2 3 5 6,:8 9" "\n"\
  2397. "#: dyadic buckets group elts of y into buckets according to x, e.g. 0 -1 -1 2 0#:a b c d e is (a,.e),:(),:(,d)" "\n"\
  2398. "_ monadic nub mark all unique elts of x, e.g. _'abracadabra' yields 1 1 1 0 1 0 1 0 0 0 0" "\n"\
  2399. "_ dyadic drop remove first x elts of y (or last if x < 0)" "\n"\
  2400. "_. monadic unbits _.1 0 1 is 5" "\n"\
  2401. "_: monadic bits _:5 is 1 0 1" "\n"\
  2402. "? monadic unique distinct elts of x, same as ]#._" "\n"\
  2403. "? dyadic find find all indices of x in y" "\n"\
  2404. "& monadic flatten flatten an array, same as ,//." "\n"\
  2405. "& dyadic minand get min of two numbers (logical and for 0/1s)" "\n"\
  2406. "| monadic reverse reverse an array" "\n"\
  2407. "| dyadic maxor get max of two numbers (for 0/1s is same as logical or)" "\n"\
  2408. "|. monadic round round x" "\n"\
  2409. "@ monadic abs |x|" "\n"\
  2410. "@ dyadic at pick elts from x by indices from y" "\n"\
  2411. "{ monadic head all elts of x except last, same as -1_" "\n"\
  2412. "{ dyadic bin bin search, e.g. 1 3 5 7 9{8 9 0 yields 3 4 -1" "\n"\
  2413. "} monadic behead all elts of x except first, same as 1_" "\n"\
  2414. "[ monadic factors compute prime factors of x" "\n"\
  2415. "[ dyadic left yield x" "\n"
  2416. "] monadic same yield x (i.e. identity)" "\n"
  2417. "] dyadic right yield y (i.e. right argument)" "\n"
  2418. "$ monadic shape yield shape of x" "\n"
  2419. "$ dyadic reshape reshape y to shape x" "\n"
  2420. "";
  2421. cS V2HELP =\
  2422. "p. monadic print print x" "\n"\
  2423. "P. monadic println print x and a \\n" "\n"\
  2424. "f. monadic selfref1 monadic reference to current function or rhs of bind" "\n"\
  2425. "f. dyadic selfref2 dyadic reference to current function or rhs of bind" "\n"\
  2426. "t. monadic type type of x, array=0, verb=1, symbol=2, number=3, char=4, nil=5, udf=6" "\n"\
  2427. "r. monadic deal yield random elt of x" "\n"\
  2428. "r. dyadic roll roll xdy (note: y is 0-based, so >xr.y for 1-based)" "\n"\
  2429. "i. monadic import load and eval source file" "\n"\
  2430. "y. monadic system exec system command (yields output)" "\n"\
  2431. "y. dyadic system2 exec system command with input" "\n"\
  2432. "";
  2433. cS AHELP =\
  2434. "f\" each >\"1 2 3 yields 2 3 4" "\n"\
  2435. "xf\" merge 1 2 3,\"a b c yields (1,.a),:(2,.b),:(3,.c)" "\n"\
  2436. "f\". eachprior -\".1 2 2 3 5 6 yields 1 0 1 2 1" "\n"\
  2437. "xf\". eachpriorwith 0-\".1 2 2 3 5 6 yields 1 1 0 1 2 1" "\n"\
  2438. "f/ fold +/1 2 3 yields 6" "\n"\
  2439. "xf/ foldwith 1+/1 2 3 yields 7" "\n"\
  2440. "f\\ scan +/1 2 3 yields 1 3 6" "\n"\
  2441. "xf\\ scanwith 1+\\1 2 3 yields 1 2 4 7" "\n"\
  2442. "f/. converge 1;_/.1 2 3 yields ()" "\n"\
  2443. "f\\. converges 1;_\\.1 2 3 yields 1 2 3,:2 3,:(,3),:()" "\n"\
  2444. "xf/. eachright 1-/.1 2 3 yields 0 1 2" "\n"\
  2445. "xf\\. eachleft 1-\\.1 2 3 yields 0 -1 -2" "\n"\
  2446. "f\": rank #\":1 2 3$1 yields 3 3, #\":inf 2 3$1 yields 1 1 1,:1 1 1" "\n"\
  2447. "xf\": rank 1 2 3 *:\":1 1 2 3 yields (,1),:2 2,:3 3 3" "\n"\
  2448. "f@: laminate 1 2 3,:1 2 3@@:0 1 yields 2" "\n"\
  2449. "n` amend 'gw'0 3`'cross' yields 'grows'" "\n"\
  2450. "f&. filter >;0&.-2!.2 yields 1 2, basically shortcut for ]#.f" "\n"\
  2451. "f/: span =;' '/:'x y z' yields (,'x'),:(,'y'),:(,'z')" "\n"\
  2452. "xf/: stencil 3+//:!10 yields 3 6 9 12 15 18 21 24, shortcut for f\"x|:" "\n"\
  2453. "f;. reflex *;.5 yields 25, 5%;.2 yields 0.4" "\n"\
  2454. "";
  2455. cS CHELP =\
  2456. "f;g bond */;!.5 yields 120, +;1 5 yields 6, 5;- 1 yields 4" "\n"\
  2457. "f?.x pick >;5?.((2*),:<)\"3 6 yields 6 5" "\n"\
  2458. "f?:F while <;5?:>0 yields 5" "\n"\
  2459. "n?:f repeat 5?:*;2 1 yields 32" "\n"\
  2460. "f&:F if 1+&:+2 yields 2" "\n"\
  2461. "f;:F monaddyad -;:+5 yields -5, 1-;:+5 yields 6" "\n"\
  2462. "";
  2463. cS IHELP =\
  2464. "inverse of a function f is a function ~f that undoes the effect of f" "\n"\
  2465. "\n"\
  2466. "f::~f obverse define inverse ~f for f" "\n"\
  2467. "\n"\
  2468. "f-:x inverse ~fx" "\n"\
  2469. "xf-:y inverse (~fx)~f~fx" "\n"\
  2470. "f^:Fx under ~FfFx" "\n"\
  2471. "xf^:Fx under ~F(Fx)f(Fx)" "\n"\
  2472. "";
  2473. cS SHELP =\
  2474. "/ comment" "\n"\
  2475. "5+5 / also comment" "\n"\
  2476. "5+5/not comment (no whitespace before /)" "\n\n"\
  2477. "nil udf / special, nil and undefined" "\n"\
  2478. "'a'%2 / = nan, nan used to denote illegal numeric operation" "\n"\
  2479. "+1 2 3 / = udf, attempt to transpose flat vector, udf/undefined used to denote illegal operation" "\n"\
  2480. "5 5.5 -5 42 / number (double-precision floats)" "\n"\
  2481. "nan inf /" "\n"\
  2482. "'a' 'b' 'g' / chars (bytes)" "\n"\
  2483. "4t.0 / 0 NUL byte" "\n"\
  2484. "(4t.0),:(4t.16),:(4t.22) /" "\n"\
  2485. "1 2 3 / numbers array" "\n"\
  2486. "'hello world!' 'bla''bla' / quote, array of chars" "\n"\
  2487. ",'a' / 1-char string" "\n"\
  2488. "() / unit, empty array" "\n"\
  2489. "1,:(5+5),:1 2 3 / strand, mixed array literal" "\n"\
  2490. "-1 / negative num literal" "\n"\
  2491. "- 1 / application of - negate to 1" "\n"\
  2492. "-1 -2 -3 / array of negative nums" "\n"\
  2493. "- 1 2 3 / application of - negate to an array of nums" "\n"\
  2494. "5-5 / array of numbers 5 and -5" "\n"\
  2495. "5- 5 / 5 minus 5" "\n"\
  2496. "+ / verb" "\n"\
  2497. "5+5 / dyadic expr" "\n"\
  2498. "#1 2 3 / monadic expr (no left side)" "\n"\
  2499. "+/ *;. / adverb" "\n"\
  2500. "+;1 -;* +^:^. / conjunction" "\n"\
  2501. ":x+y / function literal" "\n"\
  2502. ":1 / function that always yields 1" "\n"\
  2503. "x:123 / bind name" "\n"\
  2504. "sq:*;. /" "\n"\
  2505. "fac:*/1+! / bind function" "\n"\
  2506. "f:x+y /" "\n"\
  2507. "f:-x / overload function by arity" "\n"\
  2508. "f 5 / = -5" "\n"\
  2509. "5 f 5 / = 10" "\n"\
  2510. "*/!. / hook, fgx -> f(g(x)), xfgy -> f(g(x, y))" "\n"\
  2511. "+/%# / fork, fghx -> g(f(x), h(x)), xfghy -> g(f(x), h(y))" "\n"\
  2512. "1+! / over, nfgx -> f(n, g(x)), xnfgy -> f(n, g(x, y))" "\n"\
  2513. "1+ / bond, nfx -> f(n, x), xnfy -> f(n, f(x, y))" "\n";
  2514. cS HELP = "\\0\thelp on syntax\n"\
  2515. "\\+\thelp on verbs\n"\
  2516. "\\a\thelp on additional verbs\n"\
  2517. "\\\"\thelp on adverbs\n"\
  2518. "\\;\thelp on conjunctions\n"\
  2519. "\\-:\thelp on inverses\n";
  2520. I main(I argc,S*argv){GC_INIT();
  2521. GC_enable_incremental();
  2522. guards=ln();
  2523. Iin=isatty(0);
  2524. HASH_SEED=time(N);
  2525. srand(HASH_SEED);
  2526. VCACHE=Tnew();
  2527. SCACHE=Tnew();
  2528. for(Z i=0;i<AE(VERBS);i++){Vt*v=VnC(VERB);
  2529. v->val.verb=&VERBS[i];
  2530. Tset(VCACHE,VERBS[i].name,v);}
  2531. _UNIT=Vnew(ARRAY);
  2532. _UNIT->val.array=ln();
  2533. St*st=Sn();
  2534. for(I i=1;i<=8;i++){NNUMS[i-1]=VnC(NUM);
  2535. NNUMS[i-1]->val.number=-i;}
  2536. for(I i=0;i<256;i++){NUMS[i]=VnC(NUM);
  2537. NUMS[i]->val.number=i;}
  2538. for(I i=0;i<256;i++){CHARS[i]=VnC(CHAR);
  2539. CHARS[i]->val._char=i;}
  2540. _NAN=VnC(NUM);
  2541. _NAN->val.number=NAN;
  2542. INF=VnC(NUM);
  2543. INF->val.number=INFINITY;
  2544. NINF=VnC(NUM);
  2545. NINF->val.number=-INFINITY;
  2546. Tset(st->env,"E",Vnn(exp(1)));
  2547. Tset(st->env,"pi",Vnn(M_PI));
  2548. Tset(st->env,"tau",Vnn(M_PI*2));
  2549. Tset(st->env,"nan",_NAN);
  2550. Tset(st->env,"inf",INF);
  2551. Tset(st->env,"nil",st->nil);
  2552. Tset(st->env,"udf",st->udf);
  2553. Inverses=Tnew();
  2554. Tset(Inverses,"+",Gv("+"));
  2555. Tset(Inverses,"-",Gv("-"));
  2556. Tset(Inverses,"|",Gv("|"));
  2557. Tset(Inverses,"~",Gv("~"));
  2558. Tset(Inverses,"%",Gv("%"));
  2559. Tset(Inverses,"]",Gv("]"));
  2560. Tset(Inverses,"*:",Gv("%:"));
  2561. Tset(Inverses,"%:",Gv("*:"));
  2562. Tset(Inverses,">",Gv("<"));
  2563. Tset(Inverses,"<",Gv(">"));
  2564. Tset(Inverses,"_.",Gv("_:"));
  2565. Tset(Inverses,"_:",Gv("_."));
  2566. Tset(Inverses,"^.",Gv("^"));
  2567. Tset(Inverses,"^",Gv("^."));
  2568. Tset(Inverses,"+;.",Gv("%:"));
  2569. Tset(Inverses,"*/",Gv("["));
  2570. Tset(Inverses,"[",Srun(st,"*/")->val.verb);
  2571. Tset(Inverses,"!",Srun(st,">|/")->val.verb);
  2572. Tset(Inverses,"!.",Srun(st,"|/")->val.verb);
  2573. Tset(Inverses,"]@>:",Srun(st,"]@<:")->val.verb);
  2574. Tset(Inverses,"]@<:",Srun(st,"]@>:")->val.verb);
  2575. Lst*args=ln();
  2576. for(I i=1;i<argc;i++){Lst*arg=ln();
  2577. S s=argv[i];
  2578. WH(*s)lp(arg,CHARS[*s++]);
  2579. lp(args,Vna(arg));}
  2580. Tset(st->env,"args",Vna(args));
  2581. if(Iin)printf("jk\t\\\\ to exit \\ for help\n");
  2582. S s=N;
  2583. if(Iin)setjmp(Icp);
  2584. if(s){FR(s);s=N;}
  2585. LOOP{Bt*buffer;
  2586. C line[256];
  2587. buffer=Bnew();
  2588. if(Iin)putc('\t',stdout);
  2589. if(!fgets(line,SO(line),stdin))BR;
  2590. if(Iin){if(strcmp(line,"\\\\\n")==0)BR;
  2591. elif(strcmp(line,"\\\n")==0){printf("%s",HELP);CN;}
  2592. elif(strcmp(line,"\\0\n")==0){printf("%s",SHELP);CN;}
  2593. elif(strcmp(line,"\\+\n")==0){printf("%s",VHELP);CN;}
  2594. elif(strcmp(line,"\\a\n")==0){printf("%s",V2HELP);CN;}
  2595. elif(strcmp(line,"\\\"\n")==0){printf("%s",AHELP);CN;}
  2596. elif(strcmp(line,"\\;\n")==0){printf("%s",CHELP);CN;}
  2597. elif(strcmp(line,"\\-:\n")==0){printf("%s",IHELP);CN;}}
  2598. WH(strlen(line)>2&&strcmp(line+strlen(line)-3,"..\n")==0){line[strlen(line)-3]=0;
  2599. BappendS(buffer,line);
  2600. if(Iin)putc('\t',stdout);
  2601. if(!fgets(line,SO(line),stdin))R 0;}
  2602. BappendS(buffer,line);
  2603. s=Bread(buffer);
  2604. Vt*v=Srun(st,s);
  2605. FR(s);s=N;
  2606. if(v->tag!=NIL){Tset(st->env,"it",v);
  2607. S s=Vshow(v);
  2608. fputs(s,stdout);
  2609. if(Iin)putc('\n',stdout);}}}