From 1e9fa7caac7a5c76cda0fbedc0675e45dabd1457 Mon Sep 17 00:00:00 2001 From: StrongMods Date: Mon, 16 Oct 2023 23:25:47 +0000 Subject: [PATCH] deploy: fad41a4b7084afddee9343fc4479f13bab0fc9af --- .buildinfo | 4 + .doctrees/api.doctree | Bin 0 -> 68142 bytes .doctrees/environment.pickle | Bin 0 -> 120290 bytes .doctrees/index.doctree | Bin 0 -> 2873 bytes .nojekyll | 0 _sources/api.rst.txt | 16 + _sources/index.rst.txt | 7 + _static/basic.css | 925 +++++++++++++++++++++++++++++++ _static/doctools.js | 156 ++++++ _static/documentation_options.js | 13 + _static/file.png | Bin 0 -> 286 bytes _static/language_data.js | 199 +++++++ _static/minus.png | Bin 0 -> 90 bytes _static/plus.png | Bin 0 -> 90 bytes _static/pygments.css | 7 + _static/searchtools.js | 574 +++++++++++++++++++ _static/sphinx_highlight.js | 154 +++++ _static/traditional.css | 765 +++++++++++++++++++++++++ api.html | 474 ++++++++++++++++ genindex.html | 188 +++++++ index.html | 107 ++++ objects.inv | Bin 0 -> 532 bytes search.html | 98 ++++ searchindex.js | 1 + 24 files changed, 3688 insertions(+) create mode 100644 .buildinfo create mode 100644 .doctrees/api.doctree create mode 100644 .doctrees/environment.pickle create mode 100644 .doctrees/index.doctree create mode 100644 .nojekyll create mode 100644 _sources/api.rst.txt create mode 100644 _sources/index.rst.txt create mode 100644 _static/basic.css create mode 100644 _static/doctools.js create mode 100644 _static/documentation_options.js create mode 100644 _static/file.png create mode 100644 _static/language_data.js create mode 100644 _static/minus.png create mode 100644 _static/plus.png create mode 100644 _static/pygments.css create mode 100644 _static/searchtools.js create mode 100644 _static/sphinx_highlight.js create mode 100644 _static/traditional.css create mode 100644 api.html create mode 100644 genindex.html create mode 100644 index.html create mode 100644 objects.inv create mode 100644 search.html create mode 100644 searchindex.js diff --git a/.buildinfo b/.buildinfo new file mode 100644 index 0000000..b75924c --- /dev/null +++ b/.buildinfo @@ -0,0 +1,4 @@ +# Sphinx build info version 1 +# This file hashes the configuration used when building these files. When it is not found, a full rebuild will be done. +config: 40043e57e2d613d64e3588eb62ec59d5 +tags: 645f666f9bcd5a90fca523b33c5a78b7 diff --git a/.doctrees/api.doctree b/.doctrees/api.doctree new file mode 100644 index 0000000000000000000000000000000000000000..35402000dbc3171c57ba1fd90355dccf5b772891 GIT binary patch literal 68142 zcmdUY3z#HFappc|XLn}bFG&bV+Zt)5S!s86Phh}{(19gb386iZcnE`N^>o)vb!|^~ z(_Otgi;ykujMx<=fl%{?!v@StJp6s;vjGcXFvr8jXKWvSU|~RfXYRAXybk-0!>9Wr zGorGprne_o=rkGb1xHA~NF7$eOCVHoWotHEY+KcmO6@iZalN5l zTF_UUDxIdenJtx1w46EJ1{c*zH&~CZyPaU8Uz(?eU3W4Vt5xex_r|rsc(Vjf{jR${ zm?(x*!`-;d=-R_>W5GGx>eTB_>+q>Y>%`$({8pnre^a9pxoWGj1(cze_F+wZ7$eWL z+J3h)>rMn4+fLc9HtM0|+zswH&3GD>8~mzYb0Ss2?(3YBPOZ^&T7?_xzSEj3LBP}; zt;e44ERqP*8@;-#6yp}$E8UCT_3qShci-{OY{}gLak{(E!yf#94*ow6|DS(bx8q*q z9zgTUbaVF-ci)X;;CW53p<1svixIXo$31%rHbR=Ms#47~gjlW5V^+cLV-S2{S}Cwl ztrsAd1F#el57l(t@#B8CL~K0Ou%WpI6JxNv@)91VQL~L|itQ>C>vvi)@$IFKr>}sq zwGS4qxZ=bqx;mf)NR-JKk&5jm6mhf= zHYr?w%{36C(&Ld}gQDmf6}&jAf+)+nqsX*^wFRx;BXnhYC`WsUD=}Dms#{8GvIG&n zxHIeYR?@`cLhY!U2b9okIc=wP(ot6MBGBHV#|v(^wS2P%pxDFnkpE2c^if(5Fp2tn zp)p5_pHUTB?fY(AtITYR)&{%`S%Y{MxP~zz5UJ=JBbYmT3uZdl468VVxv3t5tu%mA zjkPa( z`6IpO9IS0DHPQz$x%VsGE7i~%E-n!=Em;|DOx>6PAI=)EzI4Ec^nkrrg_yx_qv3CX zv-j!nM)6792aD*#Va>WLLTS*Y;qI?{bLW0y$%-Xm{3V9`blCB@_E$1_xitg)_lyC) zykr2HJO;=;`Rs=MNv#C7N#(Vo^r zW7b1#?8cU5Fpg;2q3EFkxOi4~JlHhXsnwLRxc3K>MZZxdF8p@an*eTc@4vf?U{0mn zhFE%@JEd6xYsX1;5x-MzAie?wm}Mk!`D#&!P1tj<5012)c}T-)70KBZXK`0o@^Jtn zrVkXRCGr)ph}}j7!EnD6&1BKWBc->K<{Js|?oDxqr`?;SAb1jasm#u&Q<#;Ad0*Ji z1=;**mzdosG-K~TVgm8-HtoL6eS6F(WRb!*diz7#;Lha^Rhe?@a$HwU#gGrt_D#SP!#dQM|w}m(bj!T{6R!p-jj(n6<>{4 z@Cqo@j=@`xOK%K6G1YsUP@;W-H;GI4es43CT-?{LyWSQw^lqotI#vhS_W7Eww~ZQK z(zomB0}3|5yM(iXXr@4{eT=sQmtq#;RVIQ7@|yFlQqzq%o!}`qv)3q;3gk@5Srq(6 zVb&=CrdH>wPNi_lb?OD*bqZu*sDWc?hX85t4vgKLVBT}>8oVmCp87>te-Qhe5xW-= zd+_S#Ltf&wAj43$r>eCYNw-|8)q2SGV4>Y9yM-DsWSwjm@r){fFb1LnZx!aAP$7iUBn4ohG7vH?EI~9Xr!WSZS@IvB1)JihZuC zk667~6ik{#fs@Y_tQ%s%Xpxym*J>Vbpw>v@| zvCV}!m1b+sfx@9fg=Z-1qT7N-ImV(&lXIQAN(qnwX(Vtk|AJQ=;93V(|(%HU-8OzK|F-jw_av01B@tAM`2M%?a`z0P!0DrmadmLo zgaVyEaPKF+KBM^xCA;=OmSB;5C_H-C1Ci9hQsEy7Ua&j{X+)n?xQX#8X(t^(3f_DB zh@PbJZY>R3u~}OgYI?73dXH-A-G_e?G1z+`QWk7{=3;4~iLC}NkMQ2iYW=#n8TYml z8lRoZ8X}q!UkR?g_e6)iM@5mR6^_A)Odpt>tT=Njup}JH^ns(31^h>?XWDM#R1vAq zc4^+3o^qX9t#NSbU||Z0$y#L!ov2n4>{7QM)FLqiqx`sY+e!@!!k)+`QEDW#*GfVf zIEZLA!xQfWy>h=u&CONoRm#ex#}T;bJ&86&xWR>}mw0-HFmnk~&6hH>V{ovsuFvn? zwFoJziILb5D~Zj-jAq%uxjlC_ouw33Y6!0VlAjhjWK-q(wp>_ti%bp{f zXuBqoO_o7#NZ7_Hr@g;JTO^WHk|mj5;z+LBYy>#dp*z5gamH~FA=`H>*JH{GTw+_C=lKWpD0!Z^{YYL%9Y@BYl*!`=m+(s;Acj@0xJMpm^K7kAK2dym zr{Twrt$y{oYP(r0okk*uHB6_Tl(s3mC4Xje^7$^32ih$au$^g~YMZ1EGCpKA>9ms? zm&60oMcKniJnz@c7|~C8;^K7j1en!WOwiGfz$$=sY+L@z1B+KgHAD|aieu}w`PfL& zTTetfv7)CI4{6D*>kmj%Q$n>C0{NaX+Ovoo$&F9n%}_MC!uz3Uk(u5_R@37x(c_6| zN?ZYHF1jU3gRBQ-1x+Kzp;9W8&g1w=XUep!xQ$M-O?w}XOx!q0+1-iLHB)(l)l@j) zaTr7?2@ficf-~`q-9zOGO7mAwu*jqyyySMR37q%oe2zP)dP z`!n9R@avJU^}da(Si&NdOe|rM6bzv7l7vM{o5yFV+lVSjnZ0ZjCN6jf`-m!%b|Aw| z;>+Y>ml> z$@VX$54VN7hs1ucYc&bpuCO1RfJb{h=(EsCL`yXFTv`gnvk3!`!gQR^wi@29h=&!w zo=wEt6~Pk5`K4@EZUZCf+ZFHiw9=^FyPvKeqN_KAR}bLotk+e)Z&bf;QonCjzi&~$ zZ>3+z%1zr==|HmQo>S_??@vPdg8=~FMX|yWo z52aB}eA^?>#_>aG8RzUi7=)IGSf;W+6JlX?G? zph!5B`jSUS@HCkkCaLbI?~`L;JU!-pGaO*p2gpc-sSl8;3X-xMyuUJ>b=LD@-kPzv zwBmE0cF(wHV`eMU!h>OvX?c&)4E0XVJQXpf`OzLy-sr4TgX^>WD6N9#}-oV4ZD|Svg@WlI#2*nmXj7?(xU?x9_Y za$G$+;Ozh(`q_Z%=!$Od)<^&9ntUal?2E#|`6F!Iz^y4K`>~K2TzRvjo~^9=?E((; zp{ByAs*kheLZ@DRdB-VKE6D!Pv3@H&9JZn{8oL3UNBuzDvZG6tVx^9-E3`Zzv}ZAQ z5ZdzYNM2?o2Hugpgor{VC(%;cj^q$8nZk6n?uR=Pqs_t`j&o^OLhaJGB(msaOCtA1 zrEROZ@RpeJ9_NGc zEbwkRhoPbw(=xst31e!=Ova96XQC@Sw5WF_2EI;42ht!mT4Yo=y&-M}aeZVTyj&X6 z1}BC)c&U+W(*CwYRV1b>y99%o*Rce8{)LQyRXoV<8Lqu2(FBqQ82eCYg+4Xx+>8hn zY)`VP(daRB8R$(!5LJVmU!*7$)~~Rtun5L4W^w1js@IZ9D$r6|P?z+_Ixx^e<5V3F zIL@9<02(a+D{W|u1wEJ963dNSP!FuS;`Rdh-DKo95NzFevx7fMtA~L!yf?CNtYpEF zbe4#w#2E7c)?GSyz6rU?X%Ze4(l1;>kS#gs_sVRxs-vhr{iCL=GiP=Z!N+o91 z)gZY|9o&aaZ{mndp^PRTZ0vzE)bk$E5Tx1;fizS~RX__5yaa1(i83a@I$mg&!%rd3 zDC~?!i)_5{qmXvkvuOn@a^Ve@VDdo^E5u>=_STQ5Adc^0UV|cz7m@aQr(=L^wU8fA-x7C*Jn}e@`5JDCLIuBfZk_c&!zW9EhF{qJA-p0})Lp zXCOMLnvN8K+-@~H*1&BH&SyJ#8C#?u%a;*^pDJzxPmxxUFAGSXfKf8 zca8kcA}J+j>H6erx_`XOfixbok_E@PpA*rP7$cl@U!)OFX3!i%oRL;#bhTq+)@o1H zRl(Z|qJD9SgAGk3XR!I-s%d|z$8s9kd5%L?vt#LBK}1&4w?i4flAEcKq6~65sVL)` z9NJ`*@zfkmS@9%AE5+wR8M0!@j$PGI0wZWuMKHeY_BSl8VYe3 zzP)$S6q1PJZWIoRIAYL2nFjxL$VbtsV2-#l1a+h;S8#_ginw`(#hwRuq-HF%5Hpa6 zC6%$J-)GjuLFB?7L;f*T?i^Xfb|A%%8!0Xq`uK{KG&uf!nTV#uF!P{~cq&8BGQ=P0 zl}2OVu;P&e(bqwg6M@ilat5L=sHP)DAV0I39c$oUiO5O=b_itqrYx5m1$`q$Amo5j z5y)on(@&eM_)R&QG6EqfS}8soOmLn@Fi5Ex`nG8skk)TN0(l4ZRdH9TbM# z8qx;!6?(iQl;Ti0#4zr8G>0S(xdnxT;*ecSwZuT=4)iKOB%u#MBIzm?C?dQfh`xYD zp9hM}q#e1iATzLtEt#>Y-(cp%SL6aCt6@P9qJ9yK!xBv>XIOebH61A)`J&bASO=dcA}bx(;gLsj zGc{5?LVhR}kNgcP`e~CD|Fs-VS@9%AE5&C+3&ta|ZpFuB6EPkUuW6K;f=B)l{AS@1 zs@HgA$AsV!b+vkUGc{7ILS88qtNb=9`e~CD|Lz=3S@9%AE5&ES4#q07cE!_V6ERj1|7nz(f>nMW z{AOVls@GWM8+4^|C+ceTunM2v%+>G#p&mdbd3vMU4uMjl34R%PN#cah24t|<=?xbe z5A-h(=b+%^$06;Co!-c#hRT{4zP+(Y3tvb8WfpCPj8r64NLZ7B!MMy4GAVm zRjvRMVH6Sc2Q2nHfF$)CM)Q?{Ml7j}HC;sF{6&3AHDWuE;^UcBNO8Gv$P=uj!SU}1 z5lx9ufFNy z{Ra5WLLgMH5y*$=N+A$+wR#9-pUy?hH)_2eAK8=0l&Gdd;E(8;01vwaer%3#CE1Z! znQ=aU1WEP|7uk=hekP<1YAci(Vd)KpJq+94pVJJIS&>hna8T^ABa*|?ylUw2DEbuW z5z~Yqk2JLk@DMH$G9O}*=K&rE(=s87sSMmk}ias0w70Wv={*CyW5|f1E?u$Bh$Fd(vvmxk6tuyM{X~iLjo^2rN7o|A#&}4Fk zo}a0vBgGsuRA@!U9BGG;J=KSZ!{|Dhcn4HfKbbxh-1b6 z%0zQP-xALH(BLn{0w`ukWJUUW{G)|mBPdm)w|5*v;qy_3_h(&$mt*@&5D@=Ch#oWc zr#h<0IKum()j{#ky&>&N3sHSu*1VGB!b~A)1ZZCFw>#4M7z>gGXx{WU5jGM487VR1 z`#>lHix8%>OF$#M@-Bp20$_g%1(@j)-m zMEr|hR=(RLAsKaeuK~M*?s%eqoku={A5gmtBg=*->WpQ-6HU?* zS>#)oqDL@(52>`*Hx%M8%>4KJ#flSfq%U30TzxTHulc~sll(E<^g*C6@0V=m~+kGhkV>P6xfyxaeu%$sF$IQKH4 z4Ua;VQ{Gu#uh8>Brq8lzqGV(zW&va;#*)OG{6gu}ulMNJVLuCFYGiket`xFUS3@8> zo)cl5LBF)a=+134dz@$`(H*tyiSGKpaXPvX^`O1LlpZJsrc{wJgWEIBAUm1#(vWt= zz?7cQP`M<-wO6MJBy&kGLg6Spt728Bl71asCOoUEP4lc&5%H|TB39gsS=@ONNvVIs zOkJmVQbCJWG{%C?Fk7DHr&i!6ZOPWxunbfh_?Ke3t}OaDtm zWF>vO9MZRPGZlrSL%-jRTuy2Z=@C@)( z1|q!Kh;X?Ohi4@Wj(PJ$G$kep$K4lk#LuSGBtyuNT4&UChZTn$dKN*{FG_Lfp~>V7 zJr&h-q?qF^RgTx2LCjS!B2L1{?QxlWKkbiMx z*!MPVOTj2V!t@5kDChOk9;ciihXDnvq-sboOO_c3b`kCocz?nw$%9>ckwYC#E@!CwcdF?~F^*$3JJ!c65n1WO4&%HcH&Y|UIOMTX zG0sU;^wTCQzMZ2fE1slirTA>P!Wc)^uocD;pK6qvf^p7(-z;h>l$npe@h>b%N7pijXnoLAA+f>F}cD%eE0L;(Fm7I_|QlA0n> zqh??dJ0fF8KVZhhEBr#`RgBd@gx@nFTrLbUwmoZ6CC@ZC=B*{7DKSYn?!Fi#o;y*K z46#RQol)0bD-JpI>;h50D8-?NCX+Mt{9ot;lf5tHZNd*k$^wgb*j{BdJC^@pBC?Xd z9p*Teo2ijv4)Q#ynB!Wdq8#hA;5|J@Q&v1l(Ms{TFo&#J@h;g!oL3QFX_T6RIbHyM zvoHtMYs_&6T`A0=u2vs&Ag_}1EN6k5jtX<=VS8c@JyaZXs50Yxx{&0cnB(;!?aE;e zJ*A;Ahhf`$H_af4IbMsxkzfwRtHvC^i$0T>Lsh3@4yuVfIwD*mVBX6j9~^T~-`1F; z7m=}}hnO+(3ORh))GAmFMEFS~!sWsoe{LlVj(Pu;h^E9ODGa|S5^~c%XPv+mq@-S$ zL)RH~J!-`vV~%fvC@1Ei$>a<@f1;X>6mvXgH9MC7&xy!N{&tvS&yFll8wH{x#T?{$ zQZdI4@Y7G5toW@tnlk1fDOxE$8$NKJL)NT#muw=&9O5gDQd2O;6sDGiIjCM^j_c`4 zVGeb*dYEIsJ{?(b{8BCJBcN}35fKVa*DHa37>L?lTu?`Qwee&6p`E( z(gv*+I>Cv^V94_u!@Sp^c_eYkttcE6mqcIq7Ufu@le^Hfppz8c2uA6xddZFm-w3n6 z%BskNRIW-pxlwHPJ+~Qz)Y#ftW>Wl0F4VGGmIa~SZG^g9*yTT4iG*Y4+lgpO%oYKl zFLrqx{i%j>5cEeL5nYD}CZmN>;K!`E<#6_45cP|E9L{KBIm6joRMU~-n6FsPj&<>6 zBC^tj9gg{SZl*?xW5`FP;+SusqMtTd@n6r;lod}>v{HOFBw-vQ>sS0uHWA|(@uWtn zDLCc_;5Q4$P`$=6dv^+sQCF*nWB9zLSv`^Wyhb%00=q;L`#fx~+zAgA%bn;l<9ucy z$w86I6(Q}4?SgqqL*-5k+uqeQgCs`TkHSGQO7y%&^QzIwP3Tk537^;KYQZIGY86Bx zTq1a0&LYo)NK%hp)Tp+(lb%Gzj$X)&iC4&lLRRWISS@N&G(>od5#e&-j}unH;F#wU z(Uh1Z9Cu&*5zn2dNruQHwa%#Pl~x>b=s69deo=};4^1X#=y6ojkz$UwTFs8-|0W`` zlD{41_-JmXMv6Je^Q2;q522!;Hd*oS&(V|>Pg1l}d^UVw%pq%5yh}C_V-E3^MyV;7 z<00^yg*m8RV~$7ZO65+})#_mm{^C!w>f^&2Jx*+rU;N?5L*S0+``W{ymmrU=I$shF zr?E$()VQJl1DOtrKK?bNU9m6zgwq-de;CHSiCro9?_nvGA9OXiCfz4!tiHiGS0Frx~J=9<@ekH&}7WVd+^Q>KDN{EYXB=hNY`i(~;tl zIjh;R4$4Gir2{)Waz}2aMv6zs52fOfQ>f^tO;)_0qbVz%q-dr1Y-quFMAoep9uco; zl$wG^&Vt`8JVNyvk9>@-6dqAmtA|JUE&6y%O)2kN^mW@I&`9(}>oV{XFv9O>m%%g^ zi5D6V^d*S1ci6~&aP{*c?TWocUnVsa5;1&xe??PBWP2Nc=_ldX^ysNv|{-JI9Jg4n(^_)GuanAfoBy z3`CDXBbe?epJ080)$AC793dhr4cH-&>vJ4QRr&N?x@Cn;Jf zJ{JO!RVxlAn}{x^%xVPkadetQ zAi6#kfvBp;qpZRxV&{D<_Q4T|>f9QE^rSM@^l4^I97GPcHnkeI11WyWNO8Fk$X{4V zgX7#X>VP-V~c@;WMAP}xkLm;{;f=_ZIEY^;1j6FxXF^_Mq_|uN?M&Sw|j9qmNjbaXyD3$w9%# zl_BklJ&DRw8VY+Dw!Np(43gO6G87JqJ)%#dYF;(;IF3FAdc-s#$Rkaya`+-#0(eZb z$nyY?)F)9DQyI9!j>y>2iWDvWswNqNj?_A%t~;$b*!yF&W z&D2OS2YH@U%<&*9`e~CD|A8D$S@9%AE5&ES2gV$-X2rW?6EWrxUul$@f;m17ezPzK z)oaZ09lBCk4|TPAnB)9;$1hfUd_{13_@}$N)euNyt9o;%47LPhjLQHTU&yWTF+YdE z289;?E2ItPm;KLiWgtsSR$b~ff2$M zV&G3%ym?^6zGM7}u4=`p`_;Ls(~_@i)#$5^$}sRXtiJ7xWn4-EvVB-|MeP7Gx|o@S zjFt;0{IZoCI8Hr@h^EBI;B5Qi1oZ~fKHAG{V>I_{D~>sQ90O6mNWju)__n%+1tDaRWJ+RNSzLihkN;#dmTvWyO;etrVXP0T?&P8n(g> z;v9`qQ*gsQ;5Q35P`$j(jaYOdR8T&l4UOcS#7+ogzxb(rDY44r%sn8AO zTB+UcI?=O0{i!{w)>HU&I0bbz$Q0bmLw=_)FLX)q$z6c@kFTw$aP4I|FXYgU#N~7HNTck(4zkxItR*DAXbttb4B``+q zLrOZF5#urPA~KY|F{9m-Ia;u_;>?vgHNSYWRO>kLFJ%Y2+nr{!(ejJ! zg;L9Zd8gq!?e1B6s`p0fRk-RMIhN`tyKUrC&Z+imsJ%bMs*D9}dFi_pI484m{~D$^0YkKh;zWwRaze z9?1QF9)#Nc?>G-vbSv(kuEqU}eZqKNk7Du<1G|6e0PbJ9O*(?U?*AfUR=NLubfw(C zx*E>?8;MQ_yDQE~r`BjXtwZ=2z0;b*Hlyoa=!mAGEwFu&7QuS>eC+eiL-;%Ywk`?q zQn%o)*Dlq)1gm^3c$~A?bjp6Q<;*!Pr(Sj{#o5!vdTGJwzH!au8uj0uUGD(q=5A>R z=cYEVR=RhBAv8#eFX~5w@phxrBGxYn_V}$*yp}08LXf1S6 zvW+%K&0@K+umI9Fx_rDYacYh#DW0nOZc%MI!8}G}0@}-~f-NmaA;KEjO83Tf!K7OP zdgR*;!A@rpo)ok3J8e_Cq2kPT=F#7_Q>9iNQbUWDQ(8dD1jJuXwX3+kAYNH?TCGN_=$7i0n$v>BiPf^-4Yq4ZM|#pK ztT;_r3WljF!H$<3^*Kxv5~)^TtIk|?5g;nqR_gc-geEBp)?pa{ws#hq#n1#HSXH1_ zWxZ4*)ooWL%D74Wrl{F=I+aFoae+)~2Uc36?G&Sw%1W?UPgdJiZKB(Ym1?^*Tce3E zmm6hiV3}>fWZGB^YMr6et=z0QSFK@kw{?Sa=n8|hot9dQPMvzIK;@fTrBhIqzJ-bI zr1b^Msn5d@Yt;n+l$&;39&BqmP2)XiGFzx*wgld3aRleNzTa#gJ$x9&Z6F@sZPaHP zt@*>FxZ4&n#C%r_-^;cO~Hk*$%SILJVWAqSM3>+rXV)^&x-l z2hPHJ8s%zz4mKc;VHddyxYb0v>H-;Wtx?jeaZGt7*v!H#9C+J54HjI-@iEBWGFqJ| zIt!&LUIARGkfVj_&jdTEXL7%7r#7eE+Sy>eQ$N`~-kA+HX?KG43sVFpsbX>XMZeU- z*_kq&onQ*4<-@F0g4FME)FzK*P@ z_f7iQw*fzw($Dwk=STGO$#MKVOh0#T#LsK#=axhPM=$F2=xx3p zy$;W#cjkHYVj7R$UgOaphI{na;~xEimPdcZ<(ZRf@i8~HEqC%w;R=4fl>Ydtm@U>o8dQ_ zcuRs)g#ER#QuKhK%Z(Ph69~Si+i*To8bSkiL&~f4brFs~4_ps}Y|+9i=w(ru0^XV` zRNDna{6gqaaA2y@JP_+=Vb1N@#IE!lECPekJU&W!m@Ge|X|RDq``TcPmImC@4acAL wA1K_0D2v>J1EB&sc@OFSg3X~6)Y{%$t(R+^3i*OV literal 0 HcmV?d00001 diff --git a/.doctrees/environment.pickle b/.doctrees/environment.pickle new file mode 100644 index 0000000000000000000000000000000000000000..4b8b999271efbbf06a1d2f8450ab4df1b652926d GIT binary patch literal 120290 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 literal 0 HcmV?d00001 diff --git a/.doctrees/index.doctree b/.doctrees/index.doctree new file mode 100644 index 0000000000000000000000000000000000000000..e3eaa197f4f2439057d1d6646941e285c71e385c GIT binary patch literal 2873 zcmZuz&u<(x6i$=uW;fYvezZkMZJ-r|w4%F<5C_Bw32};=1E8WFD$6_euB~|N!S*zp zL!}~7L?qv84*YxkC48QloorGftulUoem}nVy=TAe{5{@TtNy~CD}>aGF=b2}#$60O zX0kHp+Q;|t>F@DPd=mPWUN}?QjK{DBjZ8?zEZ6Z>48x@ErE=ru{FdXHmqxe8MMreS z)~onL^h3u>ulUMVIR2HZ%;fx$H;;by*68_j!%p0zWfU~odK{AhoZtL~FH&IP6Bs1(|Ov8Voy8}1MyI7h@qK4{G_G&U@567A9{{^FZCS#e~@ym8hVCq^cEoH$I}80e2aTyWHe$gjn#R+-z+$I%NZ{oh%k5@aT7}gvN<~t$q+K}f zq&i>5a5yu@YvcLK=INcVo8}6LLKZV)^9achh|7Y2`)OP`n0!!6xZ;(BTu3j-vSs11 zInea*Sr}Me80(4RuQ}jb58HyOcG(FBd?A6Fr@nMcrB3KDJ}u{PH@u)$12t$^PIE~5 zC{e~!Qt_`alo}Wjt~0}+6+^%Dv(dLBC-MF8<|g6R8cPJ#Oo6p1J95i>40|=wD^@y{ zl^Bk0?c6dU{s_a`=yd?gqYrOx+&UTdQvx8G6Tn9yp%``*)$@|hIpAhkucMR0UCT3L z8A02FCUBDm#aZZPM$eEV;E)VN#h6$`(G5dddPA;7VO@e-yR6I$(((_eRssp?Sxr?k zxK~Lk_NUrkiweg}X2>E>eA?%W!Z=P=PgWGkJb5jhtogY|m~?ciQX);1Tg$#cj}4HF zLnqXY4$3rYWI5`>N9hYr9Jgu0p)koBL%nw}tJ)>_d61e5w9#|0P{~~S_w{1;2}=v12cdd}@wazCqlp!+An=L*jHo=(w1ERFPDI07Ma()MPX z0C7cP$W_>Pm)g?>5ppgRejx9r!hIgYz~vNO_FIXjb^z*bwXT;$nT*!ANI1#_MLZ~c z-E2U)f)J+@2E6 z;fbeq&M}+tUN}Hdpq9sQ1#NJ7rr8}1Z%FG`1jMj5YZu+rLU@2czLkXaw|FUDxX@1m ze_0^HH&ML2a^f-mzYqf#c2|p4o!-qPN}k-qVl7EMxzww}T$R*%2p+}Fr$)8)uT<~d z61Lj?8y5RZuhpT$8}>0$4ju%U7#SWnphXNjnNbSBA_rU tbody > tr > td > ul { + padding-left: 0em; +} + +table.indextable tr.pcap { + height: 10px; +} + +table.indextable tr.cap { + margin-top: 10px; + background-color: #f2f2f2; +} + +img.toggler { + margin-right: 3px; + margin-top: 3px; + cursor: pointer; +} + +div.modindex-jumpbox { + border-top: 1px solid #ddd; + border-bottom: 1px solid #ddd; + margin: 1em 0 1em 0; + padding: 0.4em; +} + +div.genindex-jumpbox { + border-top: 1px solid #ddd; + border-bottom: 1px solid #ddd; + margin: 1em 0 1em 0; + padding: 0.4em; +} + +/* -- domain module index --------------------------------------------------- */ + +table.modindextable td { + padding: 2px; + border-collapse: collapse; +} + +/* -- general body styles --------------------------------------------------- */ + +div.body { + min-width: 0; + max-width: none; +} + +div.body p, div.body dd, div.body li, div.body blockquote { + -moz-hyphens: auto; + -ms-hyphens: auto; + -webkit-hyphens: auto; + hyphens: auto; +} + +a.headerlink { + visibility: hidden; +} + +a:visited { + color: #551A8B; +} + +h1:hover > a.headerlink, +h2:hover > a.headerlink, +h3:hover > a.headerlink, +h4:hover > a.headerlink, +h5:hover > a.headerlink, +h6:hover > a.headerlink, +dt:hover > a.headerlink, +caption:hover > a.headerlink, +p.caption:hover > a.headerlink, +div.code-block-caption:hover > a.headerlink { + visibility: visible; +} + +div.body p.caption { + text-align: inherit; +} + +div.body td { + text-align: left; +} + +.first { + margin-top: 0 !important; +} + +p.rubric { + margin-top: 30px; + font-weight: bold; +} + +img.align-left, figure.align-left, .figure.align-left, object.align-left { + clear: left; + float: left; + margin-right: 1em; +} + +img.align-right, figure.align-right, .figure.align-right, object.align-right { + clear: right; + float: right; + margin-left: 1em; +} + +img.align-center, figure.align-center, .figure.align-center, object.align-center { + display: block; + margin-left: auto; + margin-right: auto; +} + +img.align-default, figure.align-default, .figure.align-default { + display: block; + margin-left: auto; + margin-right: auto; +} + +.align-left { + text-align: left; +} + +.align-center { + text-align: center; +} + +.align-default { + text-align: center; +} + +.align-right { + text-align: right; +} + +/* -- sidebars -------------------------------------------------------------- */ + +div.sidebar, +aside.sidebar { + margin: 0 0 0.5em 1em; + border: 1px solid #ddb; + padding: 7px; + background-color: #ffe; + width: 40%; + float: right; + clear: right; + overflow-x: auto; +} + +p.sidebar-title { + font-weight: bold; +} + +nav.contents, +aside.topic, +div.admonition, div.topic, blockquote { + clear: left; +} + +/* -- topics ---------------------------------------------------------------- */ + +nav.contents, +aside.topic, +div.topic { + border: 1px solid #ccc; + padding: 7px; + margin: 10px 0 10px 0; +} + +p.topic-title { + font-size: 1.1em; + font-weight: bold; + margin-top: 10px; +} + +/* -- admonitions ----------------------------------------------------------- */ + +div.admonition { + margin-top: 10px; + margin-bottom: 10px; + padding: 7px; +} + +div.admonition dt { + font-weight: bold; +} + +p.admonition-title { + margin: 0px 10px 5px 0px; + font-weight: bold; +} + +div.body p.centered { + text-align: center; + margin-top: 25px; +} + +/* -- content of sidebars/topics/admonitions -------------------------------- */ + +div.sidebar > :last-child, +aside.sidebar > :last-child, +nav.contents > :last-child, +aside.topic > :last-child, +div.topic > :last-child, +div.admonition > :last-child { + margin-bottom: 0; +} + +div.sidebar::after, +aside.sidebar::after, +nav.contents::after, +aside.topic::after, +div.topic::after, +div.admonition::after, +blockquote::after { + display: block; + content: ''; + clear: both; +} + +/* -- tables ---------------------------------------------------------------- */ + +table.docutils { + margin-top: 10px; + margin-bottom: 10px; + border: 0; + border-collapse: collapse; +} + +table.align-center { + margin-left: auto; + margin-right: auto; +} + +table.align-default { + margin-left: auto; + margin-right: auto; +} + +table caption span.caption-number { + font-style: italic; +} + +table caption span.caption-text { +} + +table.docutils td, table.docutils th { + padding: 1px 8px 1px 5px; + border-top: 0; + border-left: 0; + border-right: 0; + border-bottom: 1px solid #aaa; +} + +th { + text-align: left; + padding-right: 5px; +} + +table.citation { + border-left: solid 1px gray; + margin-left: 1px; +} + +table.citation td { + border-bottom: none; +} + +th > :first-child, +td > :first-child { + margin-top: 0px; +} + +th > :last-child, +td > :last-child { + margin-bottom: 0px; +} + +/* -- figures --------------------------------------------------------------- */ + +div.figure, figure { + margin: 0.5em; + padding: 0.5em; +} + +div.figure p.caption, figcaption { + padding: 0.3em; +} + +div.figure p.caption span.caption-number, +figcaption span.caption-number { + font-style: italic; +} + +div.figure p.caption span.caption-text, +figcaption span.caption-text { +} + +/* -- field list styles ----------------------------------------------------- */ + +table.field-list td, table.field-list th { + border: 0 !important; +} + +.field-list ul { + margin: 0; + padding-left: 1em; +} + +.field-list p { + margin: 0; +} + +.field-name { + -moz-hyphens: manual; + -ms-hyphens: manual; + -webkit-hyphens: manual; + hyphens: manual; +} + +/* -- hlist styles ---------------------------------------------------------- */ + +table.hlist { + margin: 1em 0; +} + +table.hlist td { + vertical-align: top; +} + +/* -- object description styles --------------------------------------------- */ + +.sig { + font-family: 'Consolas', 'Menlo', 'DejaVu Sans Mono', 'Bitstream Vera Sans Mono', monospace; +} + +.sig-name, code.descname { + background-color: transparent; + font-weight: bold; +} + +.sig-name { + font-size: 1.1em; +} + +code.descname { + font-size: 1.2em; +} + +.sig-prename, code.descclassname { + background-color: transparent; +} + +.optional { + font-size: 1.3em; +} + +.sig-paren { + font-size: larger; +} + +.sig-param.n { + font-style: italic; +} + +/* C++ specific styling */ + +.sig-inline.c-texpr, +.sig-inline.cpp-texpr { + font-family: unset; +} + +.sig.c .k, .sig.c .kt, +.sig.cpp .k, .sig.cpp .kt { + color: #0033B3; +} + +.sig.c .m, +.sig.cpp .m { + color: #1750EB; +} + +.sig.c .s, .sig.c .sc, +.sig.cpp .s, .sig.cpp .sc { + color: #067D17; +} + + +/* -- other body styles ----------------------------------------------------- */ + +ol.arabic { + list-style: decimal; +} + +ol.loweralpha { + list-style: lower-alpha; +} + +ol.upperalpha { + list-style: upper-alpha; +} + +ol.lowerroman { + list-style: lower-roman; +} + +ol.upperroman { + list-style: upper-roman; +} + +:not(li) > ol > li:first-child > :first-child, +:not(li) > ul > li:first-child > :first-child { + margin-top: 0px; +} + +:not(li) > ol > li:last-child > :last-child, +:not(li) > ul > li:last-child > :last-child { + margin-bottom: 0px; +} + +ol.simple ol p, +ol.simple ul p, +ul.simple ol p, +ul.simple ul p { + margin-top: 0; +} + +ol.simple > li:not(:first-child) > p, +ul.simple > li:not(:first-child) > p { + margin-top: 0; +} + +ol.simple p, +ul.simple p { + margin-bottom: 0; +} + +aside.footnote > span, +div.citation > span { + float: left; +} +aside.footnote > span:last-of-type, +div.citation > span:last-of-type { + padding-right: 0.5em; +} +aside.footnote > p { + margin-left: 2em; +} +div.citation > p { + margin-left: 4em; +} +aside.footnote > p:last-of-type, +div.citation > p:last-of-type { + margin-bottom: 0em; +} +aside.footnote > p:last-of-type:after, +div.citation > p:last-of-type:after { + content: ""; + clear: both; +} + +dl.field-list { + display: grid; + grid-template-columns: fit-content(30%) auto; +} + +dl.field-list > dt { + font-weight: bold; + word-break: break-word; + padding-left: 0.5em; + padding-right: 5px; +} + +dl.field-list > dd { + padding-left: 0.5em; + margin-top: 0em; + margin-left: 0em; + margin-bottom: 0em; +} + +dl { + margin-bottom: 15px; +} + +dd > :first-child { + margin-top: 0px; +} + +dd ul, dd table { + margin-bottom: 10px; +} + +dd { + margin-top: 3px; + margin-bottom: 10px; + margin-left: 30px; +} + +.sig dd { + margin-top: 0px; + margin-bottom: 0px; +} + +.sig dl { + margin-top: 0px; + margin-bottom: 0px; +} + +dl > dd:last-child, +dl > dd:last-child > :last-child { + margin-bottom: 0; +} + +dt:target, span.highlighted { + background-color: #fbe54e; +} + +rect.highlighted { + fill: #fbe54e; +} + +dl.glossary dt { + font-weight: bold; + font-size: 1.1em; +} + +.versionmodified { + font-style: italic; +} + +.system-message { + background-color: #fda; + padding: 5px; + border: 3px solid red; +} + +.footnote:target { + background-color: #ffa; +} + +.line-block { + display: block; + margin-top: 1em; + margin-bottom: 1em; +} + +.line-block .line-block { + margin-top: 0; + margin-bottom: 0; + margin-left: 1.5em; +} + +.guilabel, .menuselection { + font-family: sans-serif; +} + +.accelerator { + text-decoration: underline; +} + +.classifier { + font-style: oblique; +} + +.classifier:before { + font-style: normal; + margin: 0 0.5em; + content: ":"; + display: inline-block; +} + +abbr, acronym { + border-bottom: dotted 1px; + cursor: help; +} + +.translated { + background-color: rgba(207, 255, 207, 0.2) +} + +.untranslated { + background-color: rgba(255, 207, 207, 0.2) +} + +/* -- code displays --------------------------------------------------------- */ + +pre { + overflow: auto; + overflow-y: hidden; /* fixes display issues on Chrome browsers */ +} + +pre, div[class*="highlight-"] { + clear: both; +} + +span.pre { + -moz-hyphens: none; + -ms-hyphens: none; + -webkit-hyphens: none; + hyphens: none; + white-space: nowrap; +} + +div[class*="highlight-"] { + margin: 1em 0; +} + +td.linenos pre { + border: 0; + background-color: transparent; + color: #aaa; +} + +table.highlighttable { + display: block; +} + +table.highlighttable tbody { + display: block; +} + +table.highlighttable tr { + display: flex; +} + +table.highlighttable td { + margin: 0; + padding: 0; +} + +table.highlighttable td.linenos { + padding-right: 0.5em; +} + +table.highlighttable td.code { + flex: 1; + overflow: hidden; +} + +.highlight .hll { + display: block; +} + +div.highlight pre, +table.highlighttable pre { + margin: 0; +} + +div.code-block-caption + div { + margin-top: 0; +} + +div.code-block-caption { + margin-top: 1em; + padding: 2px 5px; + font-size: small; +} + +div.code-block-caption code { + background-color: transparent; +} + +table.highlighttable td.linenos, +span.linenos, +div.highlight span.gp { /* gp: Generic.Prompt */ + user-select: none; + -webkit-user-select: text; /* Safari fallback only */ + -webkit-user-select: none; /* Chrome/Safari */ + -moz-user-select: none; /* Firefox */ + -ms-user-select: none; /* IE10+ */ +} + +div.code-block-caption span.caption-number { + padding: 0.1em 0.3em; + font-style: italic; +} + +div.code-block-caption span.caption-text { +} + +div.literal-block-wrapper { + margin: 1em 0; +} + +code.xref, a code { + background-color: transparent; + font-weight: bold; +} + +h1 code, h2 code, h3 code, h4 code, h5 code, h6 code { + background-color: transparent; +} + +.viewcode-link { + float: right; +} + +.viewcode-back { + float: right; + font-family: sans-serif; +} + +div.viewcode-block:target { + margin: -1px -10px; + padding: 0 10px; +} + +/* -- math display ---------------------------------------------------------- */ + +img.math { + vertical-align: middle; +} + +div.body div.math p { + text-align: center; +} + +span.eqno { + float: right; +} + +span.eqno a.headerlink { + position: absolute; + z-index: 1; +} + +div.math:hover a.headerlink { + visibility: visible; +} + +/* -- printout stylesheet --------------------------------------------------- */ + +@media print { + div.document, + div.documentwrapper, + div.bodywrapper { + margin: 0 !important; + width: 100%; + } + + div.sphinxsidebar, + div.related, + div.footer, + #top-link { + display: none; + } +} \ No newline at end of file diff --git a/_static/doctools.js b/_static/doctools.js new file mode 100644 index 0000000..d06a71d --- /dev/null +++ b/_static/doctools.js @@ -0,0 +1,156 @@ +/* + * doctools.js + * ~~~~~~~~~~~ + * + * Base JavaScript utilities for all Sphinx HTML documentation. + * + * :copyright: Copyright 2007-2023 by the Sphinx team, see AUTHORS. + * :license: BSD, see LICENSE for details. + * + */ +"use strict"; + +const BLACKLISTED_KEY_CONTROL_ELEMENTS = new Set([ + "TEXTAREA", + "INPUT", + "SELECT", + "BUTTON", +]); + +const _ready = (callback) => { + if (document.readyState !== "loading") { + callback(); + } else { + document.addEventListener("DOMContentLoaded", callback); + } +}; + +/** + * Small JavaScript module for the documentation. + */ +const Documentation = { + init: () => { + Documentation.initDomainIndexTable(); + Documentation.initOnKeyListeners(); + }, + + /** + * i18n support + */ + TRANSLATIONS: {}, + PLURAL_EXPR: (n) => (n === 1 ? 0 : 1), + LOCALE: "unknown", + + // gettext and ngettext don't access this so that the functions + // can safely bound to a different name (_ = Documentation.gettext) + gettext: (string) => { + const translated = Documentation.TRANSLATIONS[string]; + switch (typeof translated) { + case "undefined": + return string; // no translation + case "string": + return translated; // translation exists + default: + return translated[0]; // (singular, plural) translation tuple exists + } + }, + + ngettext: (singular, plural, n) => { + const translated = Documentation.TRANSLATIONS[singular]; + if (typeof translated !== "undefined") + return translated[Documentation.PLURAL_EXPR(n)]; + return n === 1 ? singular : plural; + }, + + addTranslations: (catalog) => { + Object.assign(Documentation.TRANSLATIONS, catalog.messages); + Documentation.PLURAL_EXPR = new Function( + "n", + `return (${catalog.plural_expr})` + ); + Documentation.LOCALE = catalog.locale; + }, + + /** + * helper function to focus on search bar + */ + focusSearchBar: () => { + document.querySelectorAll("input[name=q]")[0]?.focus(); + }, + + /** + * Initialise the domain index toggle buttons + */ + initDomainIndexTable: () => { + const toggler = (el) => { + const idNumber = el.id.substr(7); + const toggledRows = document.querySelectorAll(`tr.cg-${idNumber}`); + if (el.src.substr(-9) === "minus.png") { + el.src = `${el.src.substr(0, el.src.length - 9)}plus.png`; + toggledRows.forEach((el) => (el.style.display = "none")); + } else { + el.src = `${el.src.substr(0, el.src.length - 8)}minus.png`; + toggledRows.forEach((el) => (el.style.display = "")); + } + }; + + const togglerElements = document.querySelectorAll("img.toggler"); + togglerElements.forEach((el) => + el.addEventListener("click", (event) => toggler(event.currentTarget)) + ); + togglerElements.forEach((el) => (el.style.display = "")); + if (DOCUMENTATION_OPTIONS.COLLAPSE_INDEX) togglerElements.forEach(toggler); + }, + + initOnKeyListeners: () => { + // only install a listener if it is really needed + if ( + !DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS && + !DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS + ) + return; + + document.addEventListener("keydown", (event) => { + // bail for input elements + if (BLACKLISTED_KEY_CONTROL_ELEMENTS.has(document.activeElement.tagName)) return; + // bail with special keys + if (event.altKey || event.ctrlKey || event.metaKey) return; + + if (!event.shiftKey) { + switch (event.key) { + case "ArrowLeft": + if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break; + + const prevLink = document.querySelector('link[rel="prev"]'); + if (prevLink && prevLink.href) { + window.location.href = prevLink.href; + event.preventDefault(); + } + break; + case "ArrowRight": + if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break; + + const nextLink = document.querySelector('link[rel="next"]'); + if (nextLink && nextLink.href) { + window.location.href = nextLink.href; + event.preventDefault(); + } + break; + } + } + + // some keyboard layouts may need Shift to get / + switch (event.key) { + case "/": + if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) break; + Documentation.focusSearchBar(); + event.preventDefault(); + } + }); + }, +}; + +// quick alias for translations +const _ = Documentation.gettext; + +_ready(Documentation.init); diff --git a/_static/documentation_options.js b/_static/documentation_options.js new file mode 100644 index 0000000..5c920ee --- /dev/null +++ b/_static/documentation_options.js @@ -0,0 +1,13 @@ +const DOCUMENTATION_OPTIONS = { + VERSION: '1.8.3', + LANGUAGE: 'en', + COLLAPSE_INDEX: false, + BUILDER: 'html', + FILE_SUFFIX: '.html', + LINK_SUFFIX: '.html', + HAS_SOURCE: true, + SOURCELINK_SUFFIX: '.txt', + NAVIGATION_WITH_KEYS: false, + SHOW_SEARCH_SUMMARY: true, + ENABLE_SEARCH_SHORTCUTS: true, +}; \ No newline at end of file diff --git a/_static/file.png b/_static/file.png new file mode 100644 index 0000000000000000000000000000000000000000..a858a410e4faa62ce324d814e4b816fff83a6fb3 GIT binary patch literal 286 zcmV+(0pb3MP)s`hMrGg#P~ix$^RISR_I47Y|r1 z_CyJOe}D1){SET-^Amu_i71Lt6eYfZjRyw@I6OQAIXXHDfiX^GbOlHe=Ae4>0m)d(f|Me07*qoM6N<$f}vM^LjV8( literal 0 HcmV?d00001 diff --git a/_static/language_data.js b/_static/language_data.js new file mode 100644 index 0000000..250f566 --- /dev/null +++ b/_static/language_data.js @@ -0,0 +1,199 @@ +/* + * language_data.js + * ~~~~~~~~~~~~~~~~ + * + * This script contains the language-specific data used by searchtools.js, + * namely the list of stopwords, stemmer, scorer and splitter. + * + * :copyright: Copyright 2007-2023 by the Sphinx team, see AUTHORS. + * :license: BSD, see LICENSE for details. + * + */ + +var stopwords = ["a", "and", "are", "as", "at", "be", "but", "by", "for", "if", "in", "into", "is", "it", "near", "no", "not", "of", "on", "or", "such", "that", "the", "their", "then", "there", "these", "they", "this", "to", "was", "will", "with"]; + + +/* Non-minified version is copied as a separate JS file, is available */ + +/** + * Porter Stemmer + */ +var Stemmer = function() { + + var step2list = { + ational: 'ate', + tional: 'tion', + enci: 'ence', + anci: 'ance', + izer: 'ize', + bli: 'ble', + alli: 'al', + entli: 'ent', + eli: 'e', + ousli: 'ous', + ization: 'ize', + ation: 'ate', + ator: 'ate', + alism: 'al', + iveness: 'ive', + fulness: 'ful', + ousness: 'ous', + aliti: 'al', + iviti: 'ive', + biliti: 'ble', + logi: 'log' + }; + + var step3list = { + icate: 'ic', + ative: '', + alize: 'al', + iciti: 'ic', + ical: 'ic', + ful: '', + ness: '' + }; + + var c = "[^aeiou]"; // consonant + var v = "[aeiouy]"; // vowel + var C = c + "[^aeiouy]*"; // consonant sequence + var V = v + "[aeiou]*"; // vowel sequence + + var mgr0 = "^(" + C + ")?" + V + C; // [C]VC... is m>0 + var meq1 = "^(" + C + ")?" + V + C + "(" + V + ")?$"; // [C]VC[V] is m=1 + var mgr1 = "^(" + C + ")?" + V + C + V + C; // [C]VCVC... is m>1 + var s_v = "^(" + C + ")?" + v; // vowel in stem + + this.stemWord = function (w) { + var stem; + var suffix; + var firstch; + var origword = w; + + if (w.length < 3) + return w; + + var re; + var re2; + var re3; + var re4; + + firstch = w.substr(0,1); + if (firstch == "y") + w = firstch.toUpperCase() + w.substr(1); + + // Step 1a + re = /^(.+?)(ss|i)es$/; + re2 = /^(.+?)([^s])s$/; + + if (re.test(w)) + w = w.replace(re,"$1$2"); + else if (re2.test(w)) + w = w.replace(re2,"$1$2"); + + // Step 1b + re = /^(.+?)eed$/; + re2 = /^(.+?)(ed|ing)$/; + if (re.test(w)) { + var fp = re.exec(w); + re = new RegExp(mgr0); + if (re.test(fp[1])) { + re = /.$/; + w = w.replace(re,""); + } + } + else if (re2.test(w)) { + var fp = re2.exec(w); + stem = fp[1]; + re2 = new RegExp(s_v); + if (re2.test(stem)) { + w = stem; + re2 = /(at|bl|iz)$/; + re3 = new RegExp("([^aeiouylsz])\\1$"); + re4 = new RegExp("^" + C + v + "[^aeiouwxy]$"); + if (re2.test(w)) + w = w + "e"; + else if (re3.test(w)) { + re = /.$/; + w = w.replace(re,""); + } + else if (re4.test(w)) + w = w + "e"; + } + } + + // Step 1c + re = /^(.+?)y$/; + if (re.test(w)) { + var fp = re.exec(w); + stem = fp[1]; + re = new RegExp(s_v); + if (re.test(stem)) + w = stem + "i"; + } + + // Step 2 + re = /^(.+?)(ational|tional|enci|anci|izer|bli|alli|entli|eli|ousli|ization|ation|ator|alism|iveness|fulness|ousness|aliti|iviti|biliti|logi)$/; + if (re.test(w)) { + var fp = re.exec(w); + stem = fp[1]; + suffix = fp[2]; + re = new RegExp(mgr0); + if (re.test(stem)) + w = stem + step2list[suffix]; + } + + // Step 3 + re = /^(.+?)(icate|ative|alize|iciti|ical|ful|ness)$/; + if (re.test(w)) { + var fp = re.exec(w); + stem = fp[1]; + suffix = fp[2]; + re = new RegExp(mgr0); + if (re.test(stem)) + w = stem + step3list[suffix]; + } + + // Step 4 + re = /^(.+?)(al|ance|ence|er|ic|able|ible|ant|ement|ment|ent|ou|ism|ate|iti|ous|ive|ize)$/; + re2 = /^(.+?)(s|t)(ion)$/; + if (re.test(w)) { + var fp = re.exec(w); + stem = fp[1]; + re = new RegExp(mgr1); + if (re.test(stem)) + w = stem; + } + else if (re2.test(w)) { + var fp = re2.exec(w); + stem = fp[1] + fp[2]; + re2 = new RegExp(mgr1); + if (re2.test(stem)) + w = stem; + } + + // Step 5 + re = /^(.+?)e$/; + if (re.test(w)) { + var fp = re.exec(w); + stem = fp[1]; + re = new RegExp(mgr1); + re2 = new RegExp(meq1); + re3 = new RegExp("^" + C + v + "[^aeiouwxy]$"); + if (re.test(stem) || (re2.test(stem) && !(re3.test(stem)))) + w = stem; + } + re = /ll$/; + re2 = new RegExp(mgr1); + if (re.test(w) && re2.test(w)) { + re = /.$/; + w = w.replace(re,""); + } + + // and turn initial Y back to y + if (firstch == "y") + w = firstch.toLowerCase() + w.substr(1); + return w; + } +} + diff --git a/_static/minus.png b/_static/minus.png new file mode 100644 index 0000000000000000000000000000000000000000..d96755fdaf8bb2214971e0db9c1fd3077d7c419d GIT binary patch literal 90 zcmeAS@N?(olHy`uVBq!ia0vp^+#t*WBp7;*Yy1LIik>cxAr*|t7R?Mi>2?kWtu=nj kDsEF_5m^0CR;1wuP-*O&G^0G}KYk!hp00i_>zopr08q^qX#fBK literal 0 HcmV?d00001 diff --git a/_static/plus.png b/_static/plus.png new file mode 100644 index 0000000000000000000000000000000000000000..7107cec93a979b9a5f64843235a16651d563ce2d GIT binary patch literal 90 zcmeAS@N?(olHy`uVBq!ia0vp^+#t*WBp7;*Yy1LIik>cxAr*|t7R?Mi>2?kWtu>-2 m3q%Vub%g%s<8sJhVPMczOq}xhg9DJoz~JfX=d#Wzp$Pyb1r*Kz literal 0 HcmV?d00001 diff --git a/_static/pygments.css b/_static/pygments.css new file mode 100644 index 0000000..348ec44 --- /dev/null +++ b/_static/pygments.css @@ -0,0 +1,7 @@ +pre { line-height: 125%; } +td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } +span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } +td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } +span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } +.highlight .hll { background-color: #ffffcc } +.highlight { background: #ffffff; } \ No newline at end of file diff --git a/_static/searchtools.js b/_static/searchtools.js new file mode 100644 index 0000000..7918c3f --- /dev/null +++ b/_static/searchtools.js @@ -0,0 +1,574 @@ +/* + * searchtools.js + * ~~~~~~~~~~~~~~~~ + * + * Sphinx JavaScript utilities for the full-text search. + * + * :copyright: Copyright 2007-2023 by the Sphinx team, see AUTHORS. + * :license: BSD, see LICENSE for details. + * + */ +"use strict"; + +/** + * Simple result scoring code. + */ +if (typeof Scorer === "undefined") { + var Scorer = { + // Implement the following function to further tweak the score for each result + // The function takes a result array [docname, title, anchor, descr, score, filename] + // and returns the new score. + /* + score: result => { + const [docname, title, anchor, descr, score, filename] = result + return score + }, + */ + + // query matches the full name of an object + objNameMatch: 11, + // or matches in the last dotted part of the object name + objPartialMatch: 6, + // Additive scores depending on the priority of the object + objPrio: { + 0: 15, // used to be importantResults + 1: 5, // used to be objectResults + 2: -5, // used to be unimportantResults + }, + // Used when the priority is not in the mapping. + objPrioDefault: 0, + + // query found in title + title: 15, + partialTitle: 7, + // query found in terms + term: 5, + partialTerm: 2, + }; +} + +const _removeChildren = (element) => { + while (element && element.lastChild) element.removeChild(element.lastChild); +}; + +/** + * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions#escaping + */ +const _escapeRegExp = (string) => + string.replace(/[.*+\-?^${}()|[\]\\]/g, "\\$&"); // $& means the whole matched string + +const _displayItem = (item, searchTerms, highlightTerms) => { + const docBuilder = DOCUMENTATION_OPTIONS.BUILDER; + const docFileSuffix = DOCUMENTATION_OPTIONS.FILE_SUFFIX; + const docLinkSuffix = DOCUMENTATION_OPTIONS.LINK_SUFFIX; + const showSearchSummary = DOCUMENTATION_OPTIONS.SHOW_SEARCH_SUMMARY; + const contentRoot = document.documentElement.dataset.content_root; + + const [docName, title, anchor, descr, score, _filename] = item; + + let listItem = document.createElement("li"); + let requestUrl; + let linkUrl; + if (docBuilder === "dirhtml") { + // dirhtml builder + let dirname = docName + "/"; + if (dirname.match(/\/index\/$/)) + dirname = dirname.substring(0, dirname.length - 6); + else if (dirname === "index/") dirname = ""; + requestUrl = contentRoot + dirname; + linkUrl = requestUrl; + } else { + // normal html builders + requestUrl = contentRoot + docName + docFileSuffix; + linkUrl = docName + docLinkSuffix; + } + let linkEl = listItem.appendChild(document.createElement("a")); + linkEl.href = linkUrl + anchor; + linkEl.dataset.score = score; + linkEl.innerHTML = title; + if (descr) { + listItem.appendChild(document.createElement("span")).innerHTML = + " (" + descr + ")"; + // highlight search terms in the description + if (SPHINX_HIGHLIGHT_ENABLED) // set in sphinx_highlight.js + highlightTerms.forEach((term) => _highlightText(listItem, term, "highlighted")); + } + else if (showSearchSummary) + fetch(requestUrl) + .then((responseData) => responseData.text()) + .then((data) => { + if (data) + listItem.appendChild( + Search.makeSearchSummary(data, searchTerms) + ); + // highlight search terms in the summary + if (SPHINX_HIGHLIGHT_ENABLED) // set in sphinx_highlight.js + highlightTerms.forEach((term) => _highlightText(listItem, term, "highlighted")); + }); + Search.output.appendChild(listItem); +}; +const _finishSearch = (resultCount) => { + Search.stopPulse(); + Search.title.innerText = _("Search Results"); + if (!resultCount) + Search.status.innerText = Documentation.gettext( + "Your search did not match any documents. Please make sure that all words are spelled correctly and that you've selected enough categories." + ); + else + Search.status.innerText = _( + `Search finished, found ${resultCount} page(s) matching the search query.` + ); +}; +const _displayNextItem = ( + results, + resultCount, + searchTerms, + highlightTerms, +) => { + // results left, load the summary and display it + // this is intended to be dynamic (don't sub resultsCount) + if (results.length) { + _displayItem(results.pop(), searchTerms, highlightTerms); + setTimeout( + () => _displayNextItem(results, resultCount, searchTerms, highlightTerms), + 5 + ); + } + // search finished, update title and status message + else _finishSearch(resultCount); +}; + +/** + * Default splitQuery function. Can be overridden in ``sphinx.search`` with a + * custom function per language. + * + * The regular expression works by splitting the string on consecutive characters + * that are not Unicode letters, numbers, underscores, or emoji characters. + * This is the same as ``\W+`` in Python, preserving the surrogate pair area. + */ +if (typeof splitQuery === "undefined") { + var splitQuery = (query) => query + .split(/[^\p{Letter}\p{Number}_\p{Emoji_Presentation}]+/gu) + .filter(term => term) // remove remaining empty strings +} + +/** + * Search Module + */ +const Search = { + _index: null, + _queued_query: null, + _pulse_status: -1, + + htmlToText: (htmlString) => { + const htmlElement = new DOMParser().parseFromString(htmlString, 'text/html'); + htmlElement.querySelectorAll(".headerlink").forEach((el) => { el.remove() }); + const docContent = htmlElement.querySelector('[role="main"]'); + if (docContent !== undefined) return docContent.textContent; + console.warn( + "Content block not found. Sphinx search tries to obtain it via '[role=main]'. Could you check your theme or template." + ); + return ""; + }, + + init: () => { + const query = new URLSearchParams(window.location.search).get("q"); + document + .querySelectorAll('input[name="q"]') + .forEach((el) => (el.value = query)); + if (query) Search.performSearch(query); + }, + + loadIndex: (url) => + (document.body.appendChild(document.createElement("script")).src = url), + + setIndex: (index) => { + Search._index = index; + if (Search._queued_query !== null) { + const query = Search._queued_query; + Search._queued_query = null; + Search.query(query); + } + }, + + hasIndex: () => Search._index !== null, + + deferQuery: (query) => (Search._queued_query = query), + + stopPulse: () => (Search._pulse_status = -1), + + startPulse: () => { + if (Search._pulse_status >= 0) return; + + const pulse = () => { + Search._pulse_status = (Search._pulse_status + 1) % 4; + Search.dots.innerText = ".".repeat(Search._pulse_status); + if (Search._pulse_status >= 0) window.setTimeout(pulse, 500); + }; + pulse(); + }, + + /** + * perform a search for something (or wait until index is loaded) + */ + performSearch: (query) => { + // create the required interface elements + const searchText = document.createElement("h2"); + searchText.textContent = _("Searching"); + const searchSummary = document.createElement("p"); + searchSummary.classList.add("search-summary"); + searchSummary.innerText = ""; + const searchList = document.createElement("ul"); + searchList.classList.add("search"); + + const out = document.getElementById("search-results"); + Search.title = out.appendChild(searchText); + Search.dots = Search.title.appendChild(document.createElement("span")); + Search.status = out.appendChild(searchSummary); + Search.output = out.appendChild(searchList); + + const searchProgress = document.getElementById("search-progress"); + // Some themes don't use the search progress node + if (searchProgress) { + searchProgress.innerText = _("Preparing search..."); + } + Search.startPulse(); + + // index already loaded, the browser was quick! + if (Search.hasIndex()) Search.query(query); + else Search.deferQuery(query); + }, + + /** + * execute search (requires search index to be loaded) + */ + query: (query) => { + const filenames = Search._index.filenames; + const docNames = Search._index.docnames; + const titles = Search._index.titles; + const allTitles = Search._index.alltitles; + const indexEntries = Search._index.indexentries; + + // stem the search terms and add them to the correct list + const stemmer = new Stemmer(); + const searchTerms = new Set(); + const excludedTerms = new Set(); + const highlightTerms = new Set(); + const objectTerms = new Set(splitQuery(query.toLowerCase().trim())); + splitQuery(query.trim()).forEach((queryTerm) => { + const queryTermLower = queryTerm.toLowerCase(); + + // maybe skip this "word" + // stopwords array is from language_data.js + if ( + stopwords.indexOf(queryTermLower) !== -1 || + queryTerm.match(/^\d+$/) + ) + return; + + // stem the word + let word = stemmer.stemWord(queryTermLower); + // select the correct list + if (word[0] === "-") excludedTerms.add(word.substr(1)); + else { + searchTerms.add(word); + highlightTerms.add(queryTermLower); + } + }); + + if (SPHINX_HIGHLIGHT_ENABLED) { // set in sphinx_highlight.js + localStorage.setItem("sphinx_highlight_terms", [...highlightTerms].join(" ")) + } + + // console.debug("SEARCH: searching for:"); + // console.info("required: ", [...searchTerms]); + // console.info("excluded: ", [...excludedTerms]); + + // array of [docname, title, anchor, descr, score, filename] + let results = []; + _removeChildren(document.getElementById("search-progress")); + + const queryLower = query.toLowerCase(); + for (const [title, foundTitles] of Object.entries(allTitles)) { + if (title.toLowerCase().includes(queryLower) && (queryLower.length >= title.length/2)) { + for (const [file, id] of foundTitles) { + let score = Math.round(100 * queryLower.length / title.length) + results.push([ + docNames[file], + titles[file] !== title ? `${titles[file]} > ${title}` : title, + id !== null ? "#" + id : "", + null, + score, + filenames[file], + ]); + } + } + } + + // search for explicit entries in index directives + for (const [entry, foundEntries] of Object.entries(indexEntries)) { + if (entry.includes(queryLower) && (queryLower.length >= entry.length/2)) { + for (const [file, id] of foundEntries) { + let score = Math.round(100 * queryLower.length / entry.length) + results.push([ + docNames[file], + titles[file], + id ? "#" + id : "", + null, + score, + filenames[file], + ]); + } + } + } + + // lookup as object + objectTerms.forEach((term) => + results.push(...Search.performObjectSearch(term, objectTerms)) + ); + + // lookup as search terms in fulltext + results.push(...Search.performTermsSearch(searchTerms, excludedTerms)); + + // let the scorer override scores with a custom scoring function + if (Scorer.score) results.forEach((item) => (item[4] = Scorer.score(item))); + + // now sort the results by score (in opposite order of appearance, since the + // display function below uses pop() to retrieve items) and then + // alphabetically + results.sort((a, b) => { + const leftScore = a[4]; + const rightScore = b[4]; + if (leftScore === rightScore) { + // same score: sort alphabetically + const leftTitle = a[1].toLowerCase(); + const rightTitle = b[1].toLowerCase(); + if (leftTitle === rightTitle) return 0; + return leftTitle > rightTitle ? -1 : 1; // inverted is intentional + } + return leftScore > rightScore ? 1 : -1; + }); + + // remove duplicate search results + // note the reversing of results, so that in the case of duplicates, the highest-scoring entry is kept + let seen = new Set(); + results = results.reverse().reduce((acc, result) => { + let resultStr = result.slice(0, 4).concat([result[5]]).map(v => String(v)).join(','); + if (!seen.has(resultStr)) { + acc.push(result); + seen.add(resultStr); + } + return acc; + }, []); + + results = results.reverse(); + + // for debugging + //Search.lastresults = results.slice(); // a copy + // console.info("search results:", Search.lastresults); + + // print the results + _displayNextItem(results, results.length, searchTerms, highlightTerms); + }, + + /** + * search for object names + */ + performObjectSearch: (object, objectTerms) => { + const filenames = Search._index.filenames; + const docNames = Search._index.docnames; + const objects = Search._index.objects; + const objNames = Search._index.objnames; + const titles = Search._index.titles; + + const results = []; + + const objectSearchCallback = (prefix, match) => { + const name = match[4] + const fullname = (prefix ? prefix + "." : "") + name; + const fullnameLower = fullname.toLowerCase(); + if (fullnameLower.indexOf(object) < 0) return; + + let score = 0; + const parts = fullnameLower.split("."); + + // check for different match types: exact matches of full name or + // "last name" (i.e. last dotted part) + if (fullnameLower === object || parts.slice(-1)[0] === object) + score += Scorer.objNameMatch; + else if (parts.slice(-1)[0].indexOf(object) > -1) + score += Scorer.objPartialMatch; // matches in last name + + const objName = objNames[match[1]][2]; + const title = titles[match[0]]; + + // If more than one term searched for, we require other words to be + // found in the name/title/description + const otherTerms = new Set(objectTerms); + otherTerms.delete(object); + if (otherTerms.size > 0) { + const haystack = `${prefix} ${name} ${objName} ${title}`.toLowerCase(); + if ( + [...otherTerms].some((otherTerm) => haystack.indexOf(otherTerm) < 0) + ) + return; + } + + let anchor = match[3]; + if (anchor === "") anchor = fullname; + else if (anchor === "-") anchor = objNames[match[1]][1] + "-" + fullname; + + const descr = objName + _(", in ") + title; + + // add custom score for some objects according to scorer + if (Scorer.objPrio.hasOwnProperty(match[2])) + score += Scorer.objPrio[match[2]]; + else score += Scorer.objPrioDefault; + + results.push([ + docNames[match[0]], + fullname, + "#" + anchor, + descr, + score, + filenames[match[0]], + ]); + }; + Object.keys(objects).forEach((prefix) => + objects[prefix].forEach((array) => + objectSearchCallback(prefix, array) + ) + ); + return results; + }, + + /** + * search for full-text terms in the index + */ + performTermsSearch: (searchTerms, excludedTerms) => { + // prepare search + const terms = Search._index.terms; + const titleTerms = Search._index.titleterms; + const filenames = Search._index.filenames; + const docNames = Search._index.docnames; + const titles = Search._index.titles; + + const scoreMap = new Map(); + const fileMap = new Map(); + + // perform the search on the required terms + searchTerms.forEach((word) => { + const files = []; + const arr = [ + { files: terms[word], score: Scorer.term }, + { files: titleTerms[word], score: Scorer.title }, + ]; + // add support for partial matches + if (word.length > 2) { + const escapedWord = _escapeRegExp(word); + Object.keys(terms).forEach((term) => { + if (term.match(escapedWord) && !terms[word]) + arr.push({ files: terms[term], score: Scorer.partialTerm }); + }); + Object.keys(titleTerms).forEach((term) => { + if (term.match(escapedWord) && !titleTerms[word]) + arr.push({ files: titleTerms[word], score: Scorer.partialTitle }); + }); + } + + // no match but word was a required one + if (arr.every((record) => record.files === undefined)) return; + + // found search word in contents + arr.forEach((record) => { + if (record.files === undefined) return; + + let recordFiles = record.files; + if (recordFiles.length === undefined) recordFiles = [recordFiles]; + files.push(...recordFiles); + + // set score for the word in each file + recordFiles.forEach((file) => { + if (!scoreMap.has(file)) scoreMap.set(file, {}); + scoreMap.get(file)[word] = record.score; + }); + }); + + // create the mapping + files.forEach((file) => { + if (fileMap.has(file) && fileMap.get(file).indexOf(word) === -1) + fileMap.get(file).push(word); + else fileMap.set(file, [word]); + }); + }); + + // now check if the files don't contain excluded terms + const results = []; + for (const [file, wordList] of fileMap) { + // check if all requirements are matched + + // as search terms with length < 3 are discarded + const filteredTermCount = [...searchTerms].filter( + (term) => term.length > 2 + ).length; + if ( + wordList.length !== searchTerms.size && + wordList.length !== filteredTermCount + ) + continue; + + // ensure that none of the excluded terms is in the search result + if ( + [...excludedTerms].some( + (term) => + terms[term] === file || + titleTerms[term] === file || + (terms[term] || []).includes(file) || + (titleTerms[term] || []).includes(file) + ) + ) + break; + + // select one (max) score for the file. + const score = Math.max(...wordList.map((w) => scoreMap.get(file)[w])); + // add result to the result list + results.push([ + docNames[file], + titles[file], + "", + null, + score, + filenames[file], + ]); + } + return results; + }, + + /** + * helper function to return a node containing the + * search summary for a given text. keywords is a list + * of stemmed words. + */ + makeSearchSummary: (htmlText, keywords) => { + const text = Search.htmlToText(htmlText); + if (text === "") return null; + + const textLower = text.toLowerCase(); + const actualStartPosition = [...keywords] + .map((k) => textLower.indexOf(k.toLowerCase())) + .filter((i) => i > -1) + .slice(-1)[0]; + const startWithContext = Math.max(actualStartPosition - 120, 0); + + const top = startWithContext === 0 ? "" : "..."; + const tail = startWithContext + 240 < text.length ? "..." : ""; + + let summary = document.createElement("p"); + summary.classList.add("context"); + summary.textContent = top + text.substr(startWithContext, 240).trim() + tail; + + return summary; + }, +}; + +_ready(Search.init); diff --git a/_static/sphinx_highlight.js b/_static/sphinx_highlight.js new file mode 100644 index 0000000..8a96c69 --- /dev/null +++ b/_static/sphinx_highlight.js @@ -0,0 +1,154 @@ +/* Highlighting utilities for Sphinx HTML documentation. */ +"use strict"; + +const SPHINX_HIGHLIGHT_ENABLED = true + +/** + * highlight a given string on a node by wrapping it in + * span elements with the given class name. + */ +const _highlight = (node, addItems, text, className) => { + if (node.nodeType === Node.TEXT_NODE) { + const val = node.nodeValue; + const parent = node.parentNode; + const pos = val.toLowerCase().indexOf(text); + if ( + pos >= 0 && + !parent.classList.contains(className) && + !parent.classList.contains("nohighlight") + ) { + let span; + + const closestNode = parent.closest("body, svg, foreignObject"); + const isInSVG = closestNode && closestNode.matches("svg"); + if (isInSVG) { + span = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); + } else { + span = document.createElement("span"); + span.classList.add(className); + } + + span.appendChild(document.createTextNode(val.substr(pos, text.length))); + const rest = document.createTextNode(val.substr(pos + text.length)); + parent.insertBefore( + span, + parent.insertBefore( + rest, + node.nextSibling + ) + ); + node.nodeValue = val.substr(0, pos); + /* There may be more occurrences of search term in this node. So call this + * function recursively on the remaining fragment. + */ + _highlight(rest, addItems, text, className); + + if (isInSVG) { + const rect = document.createElementNS( + "http://www.w3.org/2000/svg", + "rect" + ); + const bbox = parent.getBBox(); + rect.x.baseVal.value = bbox.x; + rect.y.baseVal.value = bbox.y; + rect.width.baseVal.value = bbox.width; + rect.height.baseVal.value = bbox.height; + rect.setAttribute("class", className); + addItems.push({ parent: parent, target: rect }); + } + } + } else if (node.matches && !node.matches("button, select, textarea")) { + node.childNodes.forEach((el) => _highlight(el, addItems, text, className)); + } +}; +const _highlightText = (thisNode, text, className) => { + let addItems = []; + _highlight(thisNode, addItems, text, className); + addItems.forEach((obj) => + obj.parent.insertAdjacentElement("beforebegin", obj.target) + ); +}; + +/** + * Small JavaScript module for the documentation. + */ +const SphinxHighlight = { + + /** + * highlight the search words provided in localstorage in the text + */ + highlightSearchWords: () => { + if (!SPHINX_HIGHLIGHT_ENABLED) return; // bail if no highlight + + // get and clear terms from localstorage + const url = new URL(window.location); + const highlight = + localStorage.getItem("sphinx_highlight_terms") + || url.searchParams.get("highlight") + || ""; + localStorage.removeItem("sphinx_highlight_terms") + url.searchParams.delete("highlight"); + window.history.replaceState({}, "", url); + + // get individual terms from highlight string + const terms = highlight.toLowerCase().split(/\s+/).filter(x => x); + if (terms.length === 0) return; // nothing to do + + // There should never be more than one element matching "div.body" + const divBody = document.querySelectorAll("div.body"); + const body = divBody.length ? divBody[0] : document.querySelector("body"); + window.setTimeout(() => { + terms.forEach((term) => _highlightText(body, term, "highlighted")); + }, 10); + + const searchBox = document.getElementById("searchbox"); + if (searchBox === null) return; + searchBox.appendChild( + document + .createRange() + .createContextualFragment( + '" + ) + ); + }, + + /** + * helper function to hide the search marks again + */ + hideSearchWords: () => { + document + .querySelectorAll("#searchbox .highlight-link") + .forEach((el) => el.remove()); + document + .querySelectorAll("span.highlighted") + .forEach((el) => el.classList.remove("highlighted")); + localStorage.removeItem("sphinx_highlight_terms") + }, + + initEscapeListener: () => { + // only install a listener if it is really needed + if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) return; + + document.addEventListener("keydown", (event) => { + // bail for input elements + if (BLACKLISTED_KEY_CONTROL_ELEMENTS.has(document.activeElement.tagName)) return; + // bail with special keys + if (event.shiftKey || event.altKey || event.ctrlKey || event.metaKey) return; + if (DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS && (event.key === "Escape")) { + SphinxHighlight.hideSearchWords(); + event.preventDefault(); + } + }); + }, +}; + +_ready(() => { + /* Do not call highlightSearchWords() when we are on the search page. + * It will highlight words from the *previous* search query. + */ + if (typeof Search === "undefined") SphinxHighlight.highlightSearchWords(); + SphinxHighlight.initEscapeListener(); +}); diff --git a/_static/traditional.css b/_static/traditional.css new file mode 100644 index 0000000..4c103b7 --- /dev/null +++ b/_static/traditional.css @@ -0,0 +1,765 @@ +/* + * traditional.css + * ~~~~~~~~~~~~~~~ + * + * Sphinx stylesheet -- traditional docs.python.org theme. + * + * :copyright: Copyright 2007-2023 by the Sphinx team, see AUTHORS. + * :license: BSD, see LICENSE for details. + * + */ + +body { + color: #000; + margin: 0; + padding: 0; +} + +/* :::: LAYOUT :::: */ + +div.documentwrapper { + float: left; + width: 100%; +} + +div.bodywrapper { + margin: 0 230px 0 0; +} + +div.body { + min-width: 0; + max-width: none; + background-color: white; + padding: 0 20px 30px 20px; +} + +div.sphinxsidebarwrapper { + border: 1px solid #99ccff; + padding: 10px; + margin: 10px 15px 10px 0; +} + +div.sphinxsidebar { + float: right; + margin-left: -100%; + width: 230px; +} + +div.clearer { + clear: both; +} + +div.footer { + clear: both; + width: 100%; + background-color: #99ccff; + padding: 9px 0 9px 0; + text-align: center; +} + +div.related { + background-color: #99ccff; + color: #333; + width: 100%; + height: 30px; + line-height: 30px; + border-bottom: 5px solid white; +} + +div.related h3 { + display: none; +} + +div.related ul { + margin: 0; + padding: 0 0 0 10px; + list-style: none; +} + +div.related li { + display: inline; + font-weight: bold; +} + +div.related li.right { + float: right; + margin-right: 5px; +} + +/* ::: SIDEBAR :::: */ +div.sphinxsidebar h3 { + margin: 0; +} + +div.sphinxsidebar h4 { + margin: 5px 0 0 0; +} + +div.sphinxsidebar p.topless { + margin: 5px 10px 10px 10px; +} + +div.sphinxsidebar ul { + margin: 10px; + margin-left: 15px; + padding: 0; +} + +div.sphinxsidebar ul ul { + margin-top: 0; + margin-bottom: 0; +} + +div.sphinxsidebar form { + margin-top: 10px; +} + + +/* :::: SEARCH :::: */ +ul.search { + margin: 10px 0 0 20px; + padding: 0; +} + +ul.search li { + padding: 5px 0 5px 20px; + background-image: url(file.png); + background-repeat: no-repeat; + background-position: 0 7px; +} + +ul.search li a { + font-weight: bold; +} + +ul.search li div.context { + color: #888; + margin: 2px 0 0 30px; + text-align: left; +} + +ul.keywordmatches li.goodmatch a { + font-weight: bold; +} + +/* :::: COMMON FORM STYLES :::: */ + +div.actions { + border-top: 1px solid #aaa; + background-color: #ddd; + margin: 10px 0 0 -20px; + padding: 5px 0 5px 20px; +} + +form dl { + color: #333; +} + +form dt { + clear: both; + float: left; + min-width: 110px; + margin-right: 10px; + padding-top: 2px; +} + +input#homepage { + display: none; +} + +div.error { + margin: 5px 20px 0 0; + padding: 5px; + border: 1px solid #d00; + /*border: 2px solid #05171e; + background-color: #092835; + color: white;*/ + font-weight: bold; +} + +/* :::: INLINE COMMENTS :::: */ + +div.inlinecommentswrapper { + float: right; + max-width: 40%; +} + +div.commentmarker { + float: right; + background-image: url(style/comment.png); + background-repeat: no-repeat; + width: 25px; + height: 25px; + text-align: center; + padding-top: 3px; +} + +div.nocommentmarker { + float: right; + background-image: url(style/nocomment.png); + background-repeat: no-repeat; + width: 25px; + height: 25px; +} + +div.inlinecomments { + margin-left: 10px; + margin-bottom: 5px; + background-color: #eee; + border: 1px solid #ccc; + padding: 5px; +} + +div.inlinecomment { + border-top: 1px solid #ccc; + padding-top: 5px; + margin-top: 5px; +} + +.inlinecomments p { + margin: 5px 0 5px 0; +} + +.inlinecomments .head { + font-weight: bold; +} + +.inlinecomments .meta { + font-style: italic; +} + + +/* :::: COMMENTS :::: */ + +div#comments h3 { + border-top: 1px solid #aaa; + padding: 5px 20px 5px 20px; + margin: 20px -20px 20px -20px; + background-color: #ddd; +} + +/* +div#comments { + background-color: #ccc; + margin: 40px -20px -30px -20px; + padding: 0 0 1px 0; +} + +div#comments h4 { + margin: 30px 0 20px 0; + background-color: #aaa; + border-bottom: 1px solid #09232e; + color: #333; +} + +div#comments form { + display: block; + margin: 0 0 0 20px; +} + +div#comments textarea { + width: 98%; + height: 160px; +} + +div#comments div.help { + margin: 20px 20px 10px 0; + background-color: #ccc; + color: #333; +} + +div#comments div.help p { + margin: 0; + padding: 0 0 10px 0; +} + +div#comments input, div#comments textarea { + font-family: 'Bitstream Vera Sans', 'Arial', sans-serif; + font-size: 13px; + color: black; + background-color: #aaa; + border: 1px solid #092835; +} + +div#comments input[type="reset"], +div#comments input[type="submit"] { + cursor: pointer; + font-weight: bold; + padding: 2px; + margin: 5px 5px 5px 0; + background-color: #666; + color: white; +} + +div#comments div.comment { + margin: 10px 10px 10px 20px; + padding: 10px; + border: 1px solid #0f3646; + background-color: #aaa; + color: #333; +} + +div#comments div.comment p { + margin: 5px 0 5px 0; +} + +div#comments div.comment p.meta { + font-style: italic; + color: #444; + text-align: right; + margin: -5px 0 -5px 0; +} + +div#comments div.comment h4 { + margin: -10px -10px 5px -10px; + padding: 3px; + font-size: 15px; + background-color: #888; + color: white; + border: 0; +} + +div#comments div.comment pre, +div#comments div.comment code { + background-color: #ddd; + color: #111; + border: none; +} + +div#comments div.comment a { + color: #fff; + text-decoration: underline; +} + +div#comments div.comment blockquote { + margin: 10px; + padding: 10px; + border-left: 1px solid #0f3646; + /*border: 1px solid #0f3646; + background-color: #071c25;*/ +} + +div#comments em.important { + color: #d00; + font-weight: bold; + font-style: normal; +}*/ + +/* :::: SUGGEST CHANGES :::: */ +div#suggest-changes-box input, div#suggest-changes-box textarea { + border: 1px solid #ccc; + background-color: white; + color: black; +} + +div#suggest-changes-box textarea { + width: 99%; + height: 400px; +} + + +/* :::: PREVIEW :::: */ +div.preview { + background-image: url(style/preview.png); + padding: 0 20px 20px 20px; + margin-bottom: 30px; +} + + +/* :::: INDEX PAGE :::: */ + +table.contentstable { + width: 90%; +} + +table.contentstable p.biglink { + line-height: 150%; +} + +a.biglink { + font-size: 1.5em; +} + +span.linkdescr { + font-style: italic; + padding-top: 5px; +} + +/* :::: GENINDEX STYLES :::: */ + +table.indextable td { + text-align: left; + vertical-align: top; +} + +table.indextable ul { + margin-top: 0; + margin-bottom: 0; + list-style-type: none; +} + +table.indextable > tbody > tr > td > ul { + padding-left: 0em; +} + +table.indextable tr.pcap { + height: 10px; +} + +table.indextable tr.cap { + margin-top: 10px; + background-color: #f2f2f2; +} + +img.toggler { + margin-right: 3px; + margin-top: 3px; + cursor: pointer; +} + +/* :::: DOMAIN MODULE INDEX STYLES :::: */ + +table.modindextable td { + padding: 2px; + border-collapse: collapse; +} + +/* :::: GLOBAL STYLES :::: */ + +p.subhead { + font-weight: bold; + margin-top: 20px; +} + +a:link:active { color: #ff0000; } +a:link:hover { background-color: #bbeeff; } +a:visited:hover { background-color: #bbeeff; } +a:visited { color: #551a8b; } +a:link { color: #0000bb; } + +div.body h1, +div.body h2, +div.body h3, +div.body h4, +div.body h5, +div.body h6 { + font-family: avantgarde, sans-serif; + font-weight: bold; +} + +div.body h1 { font-size: 180%; } +div.body h2 { font-size: 150%; } +div.body h3 { font-size: 120%; } +div.body h4 { font-size: 120%; } + +a.headerlink, +a.headerlink, +a.headerlink, +a.headerlink, +a.headerlink, +a.headerlink { + color: #c60f0f; + font-size: 0.8em; + padding: 0 4px 0 4px; + text-decoration: none; + visibility: hidden; +} + +*:hover > a.headerlink, +*:hover > a.headerlink, +*:hover > a.headerlink, +*:hover > a.headerlink, +*:hover > a.headerlink, +*:hover > a.headerlink { + visibility: visible; +} + +a.headerlink:hover, +a.headerlink:hover, +a.headerlink:hover, +a.headerlink:hover, +a.headerlink:hover, +a.headerlink:hover { + background-color: #c60f0f; + color: white; +} + +div.body p, div.body dd, div.body li { + text-align: justify; +} + +div.body td { + text-align: left; +} + +ul.fakelist { + list-style: none; + margin: 10px 0 10px 20px; + padding: 0; +} + +/* "Footnotes" heading */ +p.rubric { + margin-top: 30px; + font-weight: bold; +} + +/* "Topics" */ + +nav.contents, +aside.topic, +div.topic { + background-color: #eee; + border: 1px solid #ccc; + padding: 0 7px 0 7px; + margin: 10px 0 10px 0; +} + +p.topic-title { + font-size: 1.1em; + font-weight: bold; + margin-top: 10px; +} + +/* Admonitions */ + +div.admonition { + margin-top: 10px; + margin-bottom: 10px; + padding: 7px; +} + +div.admonition dt { + font-weight: bold; +} + +div.admonition dd { + margin-bottom: 10px; +} + +div.admonition dl { + margin-bottom: 0; +} + +div.admonition p { + display: inline; +} + +div.seealso { + background-color: #ffc; + border: 1px solid #ff6; +} + +div.warning { + background-color: #ffe4e4; + border: 1px solid #f66; +} + +div.note { + background-color: #eee; + border: 1px solid #ccc; +} + +p.admonition-title { + margin: 0px 10px 5px 0px; + font-weight: bold; + display: inline; +} + +p.admonition-title:after { + content: ":"; +} + +div.body p.centered { + text-align: center; + margin-top: 25px; +} + +table.docutils { + border: 0; +} + +table caption span.caption-number { + font-style: italic; +} + +table caption span.caption-text { +} + +table.docutils td, table.docutils th { + padding: 0 8px 2px 0; + border-top: 0; + border-left: 0; + border-right: 0; + border-bottom: 1px solid #aaa; +} + +table.field-list td, table.field-list th { + border: 0 !important; +} + +table.footnote td, table.footnote th { + border: 0 !important; +} + +dl { + margin-bottom: 15px; + clear: both; +} + +dd p { + margin-top: 0px; +} + +dd ul, dd table { + margin-bottom: 10px; +} + +dd { + margin-top: 3px; + margin-bottom: 10px; + margin-left: 30px; +} + +dl.glossary dt { + font-weight: bold; + font-size: 1.1em; +} + +th { + text-align: left; + padding-right: 5px; +} + +pre { + font-family: monospace; + padding: 5px; + border-left: none; + border-right: none; +} + +code { + font-family: monospace; + background-color: #ecf0f3; + padding: 0 1px 0 1px; +} + +code.descname { + background-color: transparent; + font-weight: bold; + font-size: 1.2em; +} + +code.descclassname { + background-color: transparent; +} + +code.xref, a code { + background-color: transparent; + font-weight: bold; +} + +.footnote:target { background-color: #ffa } + +.line-block { + display: block; + margin-top: 1em; + margin-bottom: 1em; +} + +.line-block .line-block { + margin-top: 0; + margin-bottom: 0; + margin-left: 1.5em; +} + +h1 code, h2 code, h3 code, h4 code, h5 code, h6 code { + background-color: transparent; +} + +.optional { + font-size: 1.3em; +} + +.sig-paren { + font-size: larger; +} + +.versionmodified { + font-style: italic; +} + +/* :::: PRINT :::: */ +@media print { + div.documentwrapper { + width: 100%; + } + + div.body { + margin: 0; + } + + div.sphinxsidebar, + div.related, + div.footer, + div#comments div.new-comment-box, + #top-link { + display: none; + } +} + +.viewcode-link { + float: right; +} + +.viewcode-back { + float: right; + font-family: serif; +} + +div.viewcode-block:target { + background-color: #f4debf; + border-top: 1px solid #ac9; + border-bottom: 1px solid #ac9; + margin: -1px -10px; + padding: 0 10px; +} + +div.code-block-caption { + background-color: #cceeff; +} + +div.code-block-caption span.caption-number { + padding: 0.1em 0.3em; + font-style: italic; +} + +div.code-block-caption span.caption-text { +} + +div.literal-block-wrapper { + padding: 1em 1em 0; +} + +div.literal-block-wrapper pre { + margin: 0; +} + +div.figure p.caption span.caption-number, +figcaption span.caption-number { + font-style: italic; +} + +div.figure p.caption span.caption-text, +figcaption span.caption-text { +} + +/* :::: MATH DISPLAY :::: */ + +div.body div.math p { + text-align: center; +} + +span.eqno { + float: right; +} \ No newline at end of file diff --git a/api.html b/api.html new file mode 100644 index 0000000..a5cfd46 --- /dev/null +++ b/api.html @@ -0,0 +1,474 @@ + + + + + + + + Developer Interface — StrongMod 1.8.3 documentation + + + + + + + + + + + +
+
+
+
+ +
+

Developer Interface

+
+
+class api.Game(*args, **kwargs)
+
+
+register_game_begin_listener(game_begin_listener)
+

Register a listener to be notified when the game begins.

+

The registered listener will be called when the game begins, such as when +a saved game is loaded or when the game editor starts, etc.

+
+
Parameters:
+

game_begin_listener (callable) – A callable object, such as a +function or method, to be notified when the game begins.

+
+
Example:
+

game = Game()

+
+
def game_begin_listener():

game.show_message(“hello,”, “world”)

+
+
+

game.register_game_begin_listener(game_begin_listener)

+
+
+
+ +
+
+show_message(message)
+
+

Display a message in the chat.

+

This method allows the game to show a message in the chat

+
+
+
Parameters:
+

message (str) – The content of the message.

+
+
Example:
+

game.show_message(“hello, world”)

+
+
+
+ +
+ +
+
+class api.Lord(lord_id)
+

Represents a lord with a unique identifier.

+
+
Parameters:
+

lord_id (int) – The identifier for the lord.

+
+
Raises:
+

LordDoesNotExistException – If the lord with the given ID does not exist.

+
+
+
+
+count_ales()
+

Count the amount of ales owned by the lord.

+
+
Returns:
+

The count of ales.

+
+
Return type:
+

int

+
+
+
+ +
+
+count_apples()
+

Count the amount of apples owned by the lord.

+
+
Returns:
+

The count of apples.

+
+
Return type:
+

int

+
+
+
+ +
+
+count_bows()
+

Count the amount of bows owned by the lord.

+
+
Returns:
+

The count of bows.

+
+
Return type:
+

int

+
+
+
+ +
+
+count_breads()
+

Count the amount of breads owned by the lord.

+
+
Returns:
+

The count of breads.

+
+
Return type:
+

int

+
+
+
+ +
+
+count_cheeses()
+

Count the amount of cheeses owned by the lord.

+
+
Returns:
+

The count of cheeses.

+
+
Return type:
+

int

+
+
+
+ +
+
+count_crossbows()
+

Count the amount of crossbows owned by the lord.

+
+
Returns:
+

The count of crossbows.

+
+
Return type:
+

int

+
+
+
+ +
+
+count_flours()
+

Count the amount of flours owned by the lord.

+
+
Returns:
+

The count of flours.

+
+
Return type:
+

int

+
+
+
+ +
+
+count_golds()
+

Count the amount of golds owned by the lord.

+
+
Returns:
+

The count of golds.

+
+
Return type:
+

int

+
+
+
+ +
+
+count_good(good_type: GoodType) int
+

Get the amount of a specific type of good owned by the lord. +:param good_type: The type of the good. +:type good_type: GoodType +:return: The amount of the specified good. +:rtype int

+
+ +
+
+count_hops()
+

Count the amount of hops owned by the lord.

+
+
Returns:
+

The count of hops.

+
+
Return type:
+

int

+
+
+
+ +
+
+count_irons()
+

Count the amount of irons owned by the lord.

+
+
Returns:
+

The count of irons.

+
+
Return type:
+

int

+
+
+
+ +
+
+count_leather_armor()
+

Count the amount of leather armor owned by the lord.

+
+
Returns:
+

The count of leather_armor.

+
+
Return type:
+

int

+
+
+
+ +
+
+count_maces()
+

Count the amount of maces owned by the lord.

+
+
Returns:
+

The count of maces.

+
+
Return type:
+

int

+
+
+
+ +
+
+count_meats()
+

Count the amount of meats owned by the lord.

+
+
Returns:
+

The count of meats.

+
+
Return type:
+

int

+
+
+
+ +
+
+count_metal_armor()
+

Count the amount of metal armor owned by the lord.

+
+
Returns:
+

The count of metal armor.

+
+
Return type:
+

int

+
+
+
+ +
+
+count_pikes()
+

Count the amount of pikes owned by the lord.

+
+
Returns:
+

The count of pikes.

+
+
Return type:
+

int

+
+
+
+ +
+
+count_pitches()
+

Count the amount of pitches owned by the lord.

+
+
Returns:
+

The count of pitches.

+
+
Return type:
+

int

+
+
+
+ +
+
+count_spears()
+

Count the amount of spears owned by the lord.

+
+
Returns:
+

The count of spears.

+
+
Return type:
+

int

+
+
+
+ +
+
+count_stones()
+

Count the amount of stones owned by the lord.

+
+
Returns:
+

The count of stones.

+
+
Return type:
+

int

+
+
+
+ +
+
+count_wheats()
+

Count the amount of wheats owned by the lord.

+
+
Returns:
+

The count of wheats.

+
+
Return type:
+

int

+
+
+
+ +
+
+count_woods()
+

Count the amount of woods owned by the lord.

+
+
Returns:
+

The count of woods.

+
+
Return type:
+

int

+
+
+
+ +
+
+get_id()
+

Get the identifier of the lord.

+
+
Returns:
+

The identifier of the lord.

+
+
Return type:
+

int

+
+
+
+ +
+ +
+
+class api.Building(building_id, index=None)
+
+ +
+
+class api.Unit(unit_id, index)
+
+ +
+ + +
+
+
+
+ +
+
+ + + + \ No newline at end of file diff --git a/genindex.html b/genindex.html new file mode 100644 index 0000000..f114806 --- /dev/null +++ b/genindex.html @@ -0,0 +1,188 @@ + + + + + + + Index — StrongMod 1.8.3 documentation + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/index.html b/index.html new file mode 100644 index 0000000..3a6c8e6 --- /dev/null +++ b/index.html @@ -0,0 +1,107 @@ + + + + + + + + Welcome to StrongMod’s documentation! — StrongMod 1.8.3 documentation + + + + + + + + + + + +
+
+
+
+ +
+

Welcome to StrongMod’s documentation!

+ +
+ + +
+
+
+
+ +
+
+ + + + \ No newline at end of file diff --git a/objects.inv b/objects.inv new file mode 100644 index 0000000000000000000000000000000000000000..e817e1f6b8eb0dfa43d2a6bfb3145f9d57cbc8db GIT binary patch literal 532 zcmV+v0_*)FAX9K?X>NERX>N99Zgg*Qc_4OWa&u{KZXhxWBOp+6Z)#;@bUGkYbaHQQ zXH9Qp3L_v^WpZMd?av*PJAarPHb0B7EY-J#6 zb0A}HZE$jBb8}^6Aa!$TZf78RY-wUH3V7O;l|gF5Fc3xeK7~rNO`zK>OQ8f>2!zt5 zk*$d>Drtly*Uhfi==FM%j;*A%O`2G{Nb~;8M|@AXm8<(kDj`k9>|tFh?mfF>obKzO z)$M{Uv+nT7HCzQ&4l3ybxV)lMUeL+ps=G1ZI< zKvB37u@@u5#XV6Rm*1H!xE$boxF@5sTXB=MI92r3NUP5Acxz4Rz8dLAu?2 z%m=X+SPl{P0PmpC(%Rh^TF85f^DnD-0czB6ah9*ZNF(55EIQrBIh*ch_JGoT!FGWD68GZ( literal 0 HcmV?d00001 diff --git a/search.html b/search.html new file mode 100644 index 0000000..03c0154 --- /dev/null +++ b/search.html @@ -0,0 +1,98 @@ + + + + + + + Search — StrongMod 1.8.3 documentation + + + + + + + + + + + + + + + + +
+
+
+
+ +

Search

+ + + + +

+ Searching for multiple words only shows matches that contain + all words. +

+ + +
+ + + +
+ + + +
+ +
+ + +
+
+
+
+ +
+
+ + + + \ No newline at end of file diff --git a/searchindex.js b/searchindex.js new file mode 100644 index 0000000..2e00f45 --- /dev/null +++ b/searchindex.js @@ -0,0 +1 @@ +Search.setIndex({"docnames": ["api", "index"], "filenames": ["api.rst", "index.rst"], "titles": ["Developer Interface", "Welcome to StrongMod\u2019s documentation!"], "terms": {"class": 0, "api": 0, "game": [0, 1], "arg": 0, "kwarg": 0, "register_game_begin_listen": 0, "game_begin_listen": 0, "regist": 0, "listen": 0, "notifi": 0, "when": 0, "begin": 0, "The": 0, "call": 0, "save": 0, "i": 0, "load": 0, "editor": 0, "start": 0, "etc": 0, "paramet": 0, "callabl": 0, "A": 0, "object": 0, "function": 0, "method": 0, "exampl": 0, "def": 0, "show_messag": 0, "hello": 0, "world": 0, "messag": 0, "displai": 0, "chat": 0, "thi": 0, "allow": 0, "show": 0, "str": 0, "content": 0, "lord": [0, 1], "lord_id": 0, "repres": 0, "uniqu": 0, "identifi": 0, "int": 0, "rais": 0, "lorddoesnotexistexcept": 0, "If": 0, "given": 0, "id": 0, "doe": 0, "exist": 0, "count_al": 0, "count": 0, "amount": 0, "al": 0, "own": 0, "return": 0, "type": 0, "count_appl": 0, "appl": 0, "count_bow": 0, "bow": 0, "count_bread": 0, "bread": 0, "count_chees": 0, "chees": 0, "count_crossbow": 0, "crossbow": 0, "count_flour": 0, "flour": 0, "count_gold": 0, "gold": 0, "count_good": 0, "good_typ": 0, "goodtyp": 0, "get": 0, "specif": 0, "good": 0, "param": 0, "specifi": 0, "rtype": 0, "count_hop": 0, "hop": 0, "count_iron": 0, "iron": 0, "count_leather_armor": 0, "leather": 0, "armor": 0, "leather_armor": 0, "count_mac": 0, "mace": 0, "count_meat": 0, "meat": 0, "count_metal_armor": 0, "metal": 0, "count_pik": 0, "pike": 0, "count_pitch": 0, "pitch": 0, "count_spear": 0, "spear": 0, "count_ston": 0, "stone": 0, "count_wheat": 0, "wheat": 0, "count_wood": 0, "wood": 0, "get_id": 0, "build": [0, 1], "building_id": 0, "index": 0, "none": 0, "unit": [0, 1], "unit_id": 0, "develop": 1, "interfac": 1}, "objects": {"api": [[0, 0, 1, "", "Building"], [0, 0, 1, "", "Game"], [0, 0, 1, "", "Lord"], [0, 0, 1, "", "Unit"]], "api.Game": [[0, 1, 1, "", "register_game_begin_listener"], [0, 1, 1, "", "show_message"]], "api.Lord": [[0, 1, 1, "", "count_ales"], [0, 1, 1, "", "count_apples"], [0, 1, 1, "", "count_bows"], [0, 1, 1, "", "count_breads"], [0, 1, 1, "", "count_cheeses"], [0, 1, 1, "", "count_crossbows"], [0, 1, 1, "", "count_flours"], [0, 1, 1, "", "count_golds"], [0, 1, 1, "", "count_good"], [0, 1, 1, "", "count_hops"], [0, 1, 1, "", "count_irons"], [0, 1, 1, "", "count_leather_armor"], [0, 1, 1, "", "count_maces"], [0, 1, 1, "", "count_meats"], [0, 1, 1, "", "count_metal_armor"], [0, 1, 1, "", "count_pikes"], [0, 1, 1, "", "count_pitches"], [0, 1, 1, "", "count_spears"], [0, 1, 1, "", "count_stones"], [0, 1, 1, "", "count_wheats"], [0, 1, 1, "", "count_woods"], [0, 1, 1, "", "get_id"]]}, "objtypes": {"0": "py:class", "1": "py:method"}, "objnames": {"0": ["py", "class", "Python class"], "1": ["py", "method", "Python method"]}, "titleterms": {"develop": 0, "interfac": 0, "welcom": 1, "strongmod": 1, "": 1, "document": 1}, "envversion": {"sphinx.domains.c": 3, "sphinx.domains.changeset": 1, "sphinx.domains.citation": 1, "sphinx.domains.cpp": 9, "sphinx.domains.index": 1, "sphinx.domains.javascript": 3, "sphinx.domains.math": 2, "sphinx.domains.python": 4, "sphinx.domains.rst": 2, "sphinx.domains.std": 2, "sphinx": 60}, "alltitles": {"Developer Interface": [[0, "developer-interface"]], "Welcome to StrongMod\u2019s documentation!": [[1, "welcome-to-strongmod-s-documentation"]]}, "indexentries": {"building (class in api)": [[0, "api.Building"]], "game (class in api)": [[0, "api.Game"]], "lord (class in api)": [[0, "api.Lord"]], "unit (class in api)": [[0, "api.Unit"]], "count_ales() (api.lord method)": [[0, "api.Lord.count_ales"]], "count_apples() (api.lord method)": [[0, "api.Lord.count_apples"]], "count_bows() (api.lord method)": [[0, "api.Lord.count_bows"]], "count_breads() (api.lord method)": [[0, "api.Lord.count_breads"]], "count_cheeses() (api.lord method)": [[0, "api.Lord.count_cheeses"]], "count_crossbows() (api.lord method)": [[0, "api.Lord.count_crossbows"]], "count_flours() (api.lord method)": [[0, "api.Lord.count_flours"]], "count_golds() (api.lord method)": [[0, "api.Lord.count_golds"]], "count_good() (api.lord method)": [[0, "api.Lord.count_good"]], "count_hops() (api.lord method)": [[0, "api.Lord.count_hops"]], "count_irons() (api.lord method)": [[0, "api.Lord.count_irons"]], "count_leather_armor() (api.lord method)": [[0, "api.Lord.count_leather_armor"]], "count_maces() (api.lord method)": [[0, "api.Lord.count_maces"]], "count_meats() (api.lord method)": [[0, "api.Lord.count_meats"]], "count_metal_armor() (api.lord method)": [[0, "api.Lord.count_metal_armor"]], "count_pikes() (api.lord method)": [[0, "api.Lord.count_pikes"]], "count_pitches() (api.lord method)": [[0, "api.Lord.count_pitches"]], "count_spears() (api.lord method)": [[0, "api.Lord.count_spears"]], "count_stones() (api.lord method)": [[0, "api.Lord.count_stones"]], "count_wheats() (api.lord method)": [[0, "api.Lord.count_wheats"]], "count_woods() (api.lord method)": [[0, "api.Lord.count_woods"]], "get_id() (api.lord method)": [[0, "api.Lord.get_id"]], "register_game_begin_listener() (api.game method)": [[0, "api.Game.register_game_begin_listener"]], "show_message() (api.game method)": [[0, "api.Game.show_message"]]}}) \ No newline at end of file