Annotation of parser3/www/htdocs/index.html, revision 1.142
1.104 paf 1: @USE
1.105 paf 2: /derived.p
1.15 paf 3:
1.72 paf 4: @auto[filespec]
5: $selffilespec[$filespec]
1.63 paf 6: #$form:here
1.131 paf 7: #$request:charset[UTF-8]
8: $request:charset[windows-1251]
9: $response:charset[windows-1251]
1.112 paf 10: #$response:charset[UTF-8]
1.131 paf 11: #$response:charset[empty]
1.84 paf 12: #$response:content-type[$.value[text/html]$.charset[$response:charset]]
1.15 paf 13:
1.60 paf 14: #@postprocess[body]
15: #<b>$body</b>
16: #$result[123]
1.37 paf 17:
1.15 paf 18: @main[]
1.72 paf 19: #$a(123)
20: #^a.format[%.10u]
1.71 paf 21: #$result[111]
1.70 paf 22: #^f[a]
1.133 paf 23: #^connect[mysql://mdm:4b833ljq@db-mysql/mdm]{
1.88 paf 24: # ^int:sql{select news_id from news where news_id=-1}[
25: ## $.default{2}
26: # ]<br>
1.115 paf 27: # ^hash::sql{bad}
1.88 paf 28: # ^string:sql{select news_id from news where news_id=-1}[$.default{2}]
1.109 paf 29: # ^file::load[text;^string:sql{select 'from sql server' }]
1.95 paf 30: # ^string:sql{select '^^hello[]' }] $ORIGINS(1)
1.96 paf 31: # ^process{ ^^h[]}
1.97 paf 32: # ^process{^string:sql{select '1
33: # ^^hello[]' }] }
1.131 paf 34: # ^double:sql{select '2*' ^; }
1.133 paf 35: #$card_sequence_expect_no(^double:sql{select 20020909131047 #card_sequence_expect_no from card_sequence})
36: #^card_sequence_expect_no.format[%15.f]
37: #}
1.49 paf 38: #^eval(2)
1.48 paf 39: #^tcrashlocaljunctionsv2[]
1.49 paf 40: #^tcrashlocaljunctions[]
1.50 paf 41: #^tjunctions[]
1.47 paf 42: #^replacetest[]
1.48 paf 43: #^matchoptionpp[]
1.46 paf 44: #^txdocxnodechild[]
1.44 paf 45: #^tclasses[]
1.43 paf 46: #$math:PI
47: #^b:method[]
1.42 paf 48: #^main[]
1.41 paf 49: #^errort[]
1.44 paf 50: #^tselectNumber[]
1.39 paf 51: #$result[hello]
1.36 paf 52: #^invaliddate2[]
53: #^process2[]
54: #^casehashtext[]
1.35 paf 55: #^subjvaltest[]
56: #^tableselect0[]
1.34 paf 57: #^memnotest1[]
1.32 paf 58: #^voidparams[]
1.31 paf 59: #^rolls2[]
1.30 paf 60: #^cacheexpireschanging[]
1.29 paf 61: #^cacheexpiresfixed[]
62: #^dateoffsets[]
63: #^exceptionTypes[]
1.28 paf 64: #^roll2[]
1.27 paf 65: #^rolls[]
1.25 paf 66: #^exceptions1[]
1.22 paf 67: #^locate_by_expr[]
1.18 paf 68: #^method_junction_params{...}
1.17 paf 69: #^verifyCookie[paf]
1.37 paf 70: #^execlangs[]
1.16 paf 71: #$t[^tobjeresult[]]$t.a
72: #^xmlprobs[]
1.15 paf 73: #^doubleprobs[]
74: #^math:random(-10)
75: #^divnamestop[]
76: #^arrayclone[]
77: #^operator_tricks[]
78: #^xoutputrusattr[]
79: #^xdocset1[]
80: #^regexp3[]
81: #^exec2[]
82: #^tlock[]
83: #^xmloutattrwithoutvalue[]
84: #^precisionProblem[]
85: #^xpath[]
86: #^ttablesetlang[]
87: #^ttime[]
88: #^tupper[]
89: #^treplace[]
90: #^xslt2[]
91: #^tcache2[]
92: #$ORIGINS(1)
93: #$t[^table::set{a b} ^table::set{c d}]
94: #^ttaintuntaint[]
95: #^tappend2[]
96: #^badvsnprintf[]
97: #^badoracequoting[]
98: #^badconstructors[]
99: #^xloadwrongtable[]
100: #^xsetwrongtable[]
101: #^if($form:test){y}{n}
102: #^tablecolumnerror[]
103: #^roll[]
104: #^cookie2[]
105: #^tableset[]
106: #^math:PI.format{%.30f}
107: #^xchildren[]
108: #^thashforeach3[]
109: #^thashforeach2[]
110: #^thashforeach[]
111: #^thashdelete[]
112: #^connect[mysql://user:pass@cd.rinet.ru/db]{^void:sql{z} }
113: #^tappend[]
114: #^sappend[]
115: #^eval(10\3)<br>
116: #^tform[]
117: #^formattest[]
118: #^filelist[]
119: #^connect[mysql://user:pass@host]{ }
120: #^безнадёжна_попытка_поправить_непоправимое[]
121: #^tcache[]
122: #^thashfileexp[]
123: #^tcounter[]
124: #^tablehash[]
125: #j^hashfile[]
126: #^formclass[]
127: #^hren[]
128: #^domedit[]
129: #^domxslt[]
130: #^lsplit2[]
131: #^faceesize[]
132: #^imageresize[]
133: #^ifassignhash[]
134: #^tintdefault[]
135: #$response:status[404]
136: #^ifpasshash[]
137: #^movedir[]
138: #^replace[]
139: #^set[]
140: #^hash[]<hr>
141: #$t[^methresult[]] ->$t
142: #^terror[]
143: #^ssave[]
144: #^thash[]
145: #^tdef[]
146: #^ford[]
147: #^tif[]
1.84 paf 148: #^image[]
1.15 paf 149: #^response[]
150: #^regexp2[]
151: #^ttablerem[]
152: #^pcre[]
153: #^regexp[]<hr>
154: #^mail[]
155: #^fori[]
156: #^tconnect[]
157: #^xslt[]
158: #^xml[]
159: #^header[]
1.53 paf 160: #^tablehasht[]
1.54 paf 161: #^datecreatestring[]
1.56 paf 162: #^mssqltypes1[]
163: #^badthrows[]
1.57 paf 164: #^xmlspace[]
165: #^counter[main.counter]
166: #^xpath2[]
167: #^callindirect[]
168: #^junctionprob[]
1.59 paf 169: #^datecreatestring2[]
170: #^tstoredproc[]
171: #^tstoredproc2[]
172: #^forkeys[]
1.60 paf 173: #^pngsize[]
1.61 paf 174: #^checkList[]
1.63 paf 175: #^datetest[]
1.65 paf 176: #^tserge[]
1.69 paf 177: #^envt[]
1.67 paf 178: #^selectt[]
179: #^select2[]
180: #^selectSingle2[]
181: #^selectString2[]
182: #^selectNumber2[]
183: #^selectBool2[]
184: #^xdoccreate[]
185: #^xdoccreatetag[]
1.70 paf 186: #^xdocload[]
1.67 paf 187: #^xdocstring[]
188: #^xdocsave[]
1.68 paf 189: #^div[]
190: #^datecreatestring3[]
1.73 paf 191: #^tfilespec[]
1.77 paf 192: #^tcrypt[]
1.74 paf 193: #^cryptdocsample[]
1.78 paf 194: #^tnormalize[]
1.83 paf 195: #^xmltransformbyxdoc[]
1.81 paf 196: #^sergestrandef[]
1.83 paf 197: #^tstdin[]
198: #^tfind[]
1.86 paf 199: #^mimet[]
1.92 paf 200: #^joinlimit[]
1.89 paf 201: #^tableclonelimit[]
1.91 paf 202: #^transparams[]
203: #^sendtests[]
1.93 paf 204: #^wwrapperpass[]
1.95 paf 205: #^badpos[]
1.98 paf 206: #^processtest[]
207: #^mail3[]
1.99 paf 208: #^mail4[]
1.100 paf 209: #^datesaving[]
1.101 paf 210: #^badconstructor[]
1.103 paf 211: #^calendar[]
1.104 paf 212: #^monthdays(8)
213: #^xdoctypetest[]
1.105 paf 214: #^xtabletest[]
1.117 paf 215: #^staticstest[]
1.108 paf 216: #^staticstest2[]
1.115 paf 217: #^rbodytest[]
218: #^cookie[]
1.116 paf 219: #^cookieexpirestest[]
1.119 paf 220: #^postest[]
1.120 paf 221: #^voidpostest[]
1.123 paf 222: #^virtualtest[]
1.122 paf 223: #^badcolumntest[]
1.124 paf 224: #^delimiters[]
1.125 paf 225: #^новый-split[]
1.127 paf 226: #^грязные-cookie[]
227: #^html-почта[]
228: #^badswitchtest[]
1.128 paf 229: #^okswitchtest[]
1.131 paf 230: #^cgit[]
1.132 paf 231: #^ttransformsep[]
1.133 paf 232: #^calltest[]
1.134 paf 233: #^xpath3[]
1.139 paf 234: #^doubleliterals[]
235: #^newxor[]
1.135 paf 236: #^mail2[]
1.139 paf 237: #^exec[]
1.140 paf 238: #^passpost[]
239: #^menudelim[]
1.141 paf 240: #^fordelim[]
1.142 ! paf 241: ^duplicatetable2hashkey[]
! 242: #^duplicatehashsqlkey[]
1.77 paf 243: <hr>
1.74 paf 244: OK
1.141 paf 245:
246: @duplicatehashsqlkey[]
247: ^connect[mysql://mdm:4b833ljq@db-mysql/mdm]{
248: $t[^table::sql{select * from news}]
249: $c[^t.columns[]]
250: ^c.menu{$c.column}[,]
251:
1.142 ! paf 252: $h[^hash::sql{select news_type_id, name from news}[$.distinct(1)]]
1.141 paf 253: }
254:
255: @duplicatetable2hashkey[]
256: $t[^table::create{a b
257: 1 2
258: 1 3
259: }]
1.142 ! paf 260: #^t.hash[a]
! 261: #^t.hash[a;b]
! 262: ^t.hash[a][$.distinct[1]]
1.140 paf 263:
264: @menudelim[]
265: $t[^table::create{a
266: 1
267: 2
268: 3
269: 4
270: 5
271: }]
272:
273: ^t.menu{^if($t.a<3){}{$t.a}}[,]
274:
275: @fordelim[]
276: ^for[a](0;6){^if($a<3){}{$a}}[,]
277:
1.135 paf 278:
1.139 paf 279: @passpost[]
280: <form method=post name="test" id="test">
281: <textarea name="text" cols=20 rows =6>^taint[html][1
282: 2
283:
284: 3]</textarea><br>
285: <input type=submit>
286: </form>
287:
288: ^if(def $form:text){
289: $a[^file::cgi[a.pl]]
290: $a.text|$a.status|$a.stderr<hr>
291: }
292:
293: @exec[]
294: #$a[^file::exec[a.cmd]]
295: $a[^file::cgi[a.cmd]]
296: $a.text|$a.status|$a.stderr<hr>
297:
298:
1.137 paf 299: @newxor[]
1.138 paf 300: ^eval(1!|2 #примечание()zzz
301: |0x100)<br>
1.137 paf 302: #^eval(1!||2)<br>
303: ^if(1!|1){y}{n}
304:
305: #@method[$bad]
1.136 paf 306:
1.135 paf 307: @doubleliterals[]
308: #^eval(1e-10)
309: ^eval("1e-20")
1.133 paf 310:
311: @xpath3[]
312: $constr[^xdoc::create{<?xml version="1.0" encoding="$request:charset" standalone="no"?> <constructor-data><object object_type_id="1" template_id="1" data_process_id="1" is_published="1">проверка</object> <block-list> <block name="date" type="0" label="Дата" is_hide_pub="1" data_type="1"/> <block name="content" type="0" label="Текст" is_hide_pub="1" data_type=""/> </block-list></constructor-data>}]
313: $objectData[^constr.selectSingle[/constructor-data/object]]
314: $objectData.nodeType<br>
315: $objectData.firstChild.nodeValue
316:
317: @calltest[]
318: ^calltest2[string]
319:
320: @calltest2[s]
321: $s
1.131 paf 322:
323: @ttransformsep[]
324: $input[^xdoc::load[20020909131046.xml]]
325: $output[^input.transform[generated.xsl]]
326: ^output.string[]
1.127 paf 327:
328: @okswitchtest[]
329: $local[local value]
330: ^switch[1]{
331: ^case[1]{1code $local}
332: }
333:
334: @badswitchtest[]
335: ^switch[1]{
336: ^badswitchtestcase[]
337: }
338: @badswitchtestcase[][local]
339: $local[local value]
340: ^case[1]{1code $local}
341:
342: @badjunction[]
343: ^badj1[]
344: ^badj2[]
345:
346: @html-почта[]
347: $переменная[значение]
348: ^mail:send[
349: $.from[paf@mail]
350: $.to[paf@mail]
351: $.subject[htmltest1]
352: $.html{тест$переменная= !}
353: ]
354:
1.124 paf 355:
356: @грязные-cookie[]
1.126 paf 357: $cookie:a[&]
1.125 paf 358: $cookie:a
1.124 paf 359:
360: @новый-split[]
361: $abc[a.b.c]
362: #$table[^abc.split[.]]
363: #$table[^abc.split[.;l]]
364: #$table[^abc.split[.;v]]
365: $table[^abc.split[.;lv]]
366: ^table.menu{$table.piece}[,]
367: <hr>
368: #$table[^abc.split[.;h]]
369: $table[^abc.split[.;hr]]
370: $table.0,$table.1,$table.2<br>
1.123 paf 371:
372: @delimiters[]
373: $a#1[1]<br>
374: $a#1=<br>
375:
1.121 paf 376:
377: @badcolumntest[]
378: $table[^table::load[ext.cfg]]
379: $table.b
380:
1.120 paf 381:
382: @virtualtest[]
383: $derived[^derived::create[derived create actual param]]
384: ^derived.test[]
385:
1.119 paf 386:
387: @voidpostest[]
388: $s[]
389: ^s.pos[$nothing]
1.118 paf 390:
391: @postest[]
392: $s[$nothing]
393: ^s.pos[$nothing]
1.113 paf 394:
1.115 paf 395: @cookieexpirestest[]
396: #$cookie:exptest[1]
397: #$cookie:exptest[$.value[2] $.expires(+1)]
398: $response:xxxx[^date::now(+10)]
399: $response:yyy[$.value[^date::now(+20)]]
400: $response:yyy[$.value[vvv] $.aaaa[^date::now(+20)]]
401:
1.113 paf 402: @rbodytest[]
403: $request:body=
404: <form method=post>
405: <input type=submit name=paf value=123>
406: </form>
1.107 paf 407:
408: @staticstest2[]
409: ^$derived:derived_var=$derived:derived_var<br>
410: ^$derived:a=$derived:a<br>
1.108 paf 411: $derived:a[changed] ^$derived:a=$derived:a<br>
1.107 paf 412: $derived:derived_var[changed]
413: ^$derived:derived_var=$derived:derived_var<br>
414:
1.105 paf 415: @staticstest[]
416: $derived[^derived::create[]]
417: ^derived.test[]
1.110 paf 418: <hr>
1.106 paf 419: ^$derived.a=$derived.a<br>
420: ^$derived.x=$derived.x<br>
1.110 paf 421: <hr>
422: ^if($derived is derived){derived is derived}{error: derived is not derived}<br>
423: ^if($derived is table){derived is table}{error:derived is not table}<br>
1.111 paf 424: <hr>
425: ^^eval(^$derived)=^eval($derived)<br>
426: ^^if(^$derived)=^if($derived){y}{n}<br>
1.106 paf 427:
1.105 paf 428:
1.104 paf 429: @xdoctypetest[]
430: $xdoc[^xdoc::create[x]]
431: ^if($xdoc is xdoc){y}{n}
432:
433: @xtabletest[]
434: $xtableo[^xtable::create[]]
435: ^if($xtableo is table){y}{n}
1.105 paf 436: #^xtableo.columns[]
1.100 paf 437:
1.103 paf 438: @monthdays[month]
439: $from[^date::create(2000;$month;1)]
440: $to[^date::create($from)] ^to.roll[month](+1)
441: $result($to-$from)
442:
1.100 paf 443: @badconstructor[]
444: ^date::now[]
1.99 paf 445:
446: @datesaving[]
447: $now[^date::now[]]
448: $now.daylightsaving<br>
449: $now.yearday<br>
450: #
451: $date[^date::create(2002;1;3)]
452: $date.daylightsaving<br>
453: $date.yearday
1.97 paf 454:
1.98 paf 455: @mail4[]
456: ^mail:send[
457: $.from[paf@mail.design.ru]
458: $.to[paf@mail.design.ru]
459: $.subject[^taint[uri][москва]=2]
460: $.text[^taint[uri][москва]=]
461: $.html{<a href=http://there.ru/?city=^taint[uri][Москва]>link</a>}
462: ]
1.97 paf 463: @processtest[]
464: $f[^file::load[text;piece.p]] ^process{$f.text}
465: $ORIGINS(1)
1.93 paf 466:
467:
468: @badpos[]
469: $s[123]
1.94 paf 470: ^s.mid(0;2)
1.92 paf 471:
472: @wwrapperpass[]
473: $h[^hash::create[]]
474: $h.a(1)
475: ^my_method[^if(1){$h}]
476: работает. так и должно быть?
477:
478: @my_method[p]
479: ^p._count[]
480:
1.88 paf 481:
482: @tableclonelimit[]
483: $source[^table::create{a
484: aa
485: bb
486: cc}]
487: ^source.offset(1)
488: #$dest[^table::create[$source]]
489: $dest[^table::create[$source;$.offset(2)]]
490: $dest[^table::create[$source;$.limit(2)]]
491: $dest[^table::create[$source;$.offset(1)$.limit(1)]]
492: $dest[^table::create[$source;$.offset(1)$.limit(2)]]
493: $dest[^table::create[$source;$.offset[cur]$.limit(2)]]
494:
495: ^dest.menu{$dest.a}[,]<br>
496:
497: @joinlimit[]
498: $source[^table::create{a
499: aa
500: bb
501: cc}]
502: ^source.offset(2)
503: $dest[^table::create{a
504: xx
505: }]
506: #^dest.join[$source]
507: #^dest.join[$source;$.offset(2)]
508: #^dest.join[$source;$.limit(2)]
509: #^dest.join[$source;$.offset(1)$.limit(1)]
510: #^dest.join[$source;$.offset(1)$.limit(2)]
1.91 paf 511: #^dest.join[$source;$.offset[cur]$.limit(1)]
512: ^dest.join[$source;$.limit(0)]
1.88 paf 513:
514: ^dest.menu{$dest.a}[,]<br>
1.86 paf 515:
516: @cgit[]
517: $f[^file::cgi[showenv.cmd]]
518: $f.HELLO=<br>
519: $f.CONTENT-TYPE=<br>
520: $f.content-type=<br>
521:
1.83 paf 522:
1.84 paf 523: @mimet[]
1.85 paf 524: $f[^file::stat[a.GIF]]
525: $f.content-type
1.84 paf 526:
527:
1.83 paf 528: @tfind[]
529: ^file:find[index.html]
530:
531: @tstdin[]
532: $f[^file::exec[test.pl;$.stdin[проверка stdin потока]]]
533: <pre>$f.text</pre>
1.80 paf 534:
535: @sergestrandef[]
536: $sQuantity[ ]
537: ^sQuantity.int(10)
1.78 paf 538:
539: @xmltransformbyxdoc[]
540: $xdoc[^xdoc::set{^process{<?xml version="1.0" encoding="windows-1251"?>
541: <!--DOCTYPE people SYSTEM "D:\Y\parser3project\parser3\src\www\htdocs\people.dtd"-->
542: <people>
543: <man id="1" имя="word слово">
544: <name>1 2</name>
545: </man>
546: </people>
547: }}]
548: $sheet[^xdoc::create{<?xml version="1.0"?>
1.79 paf 549: <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0"
550:
551: >
1.78 paf 552: <!--<xsl:output doctype-public ="-//W3C//DTD XHTML" indent="yes"/>-->
553:
1.79 paf 554: <!--<xsl:import href="http://localhost/html.xsl"/>-->
555: <xsl:import href="html.xsl"/>
556:
1.78 paf 557: <xsl:param name="param1">defparam1</xsl:param>
558: <xsl:param name="param2">defparam2</xsl:param>
1.79 paf 559:
1.78 paf 560:
561: <xsl:template match="doc">
562: param1=<xsl:value-of select="^$param1"/><br/>
563: param2=<xsl:value-of select="^$param2"/><br/>
564:
565: test return <something background=""/>
566: </xsl:template>
567:
568: <xsl:template name="test">
1.81 paf 569: test return3
1.78 paf 570: </xsl:template>
571:
572: <xsl:template match="people">
573: <html>
574: <head>z</head>
575: para1=<xsl:copy-of select="^$param1"/>
576: <xsl:apply-templates/>
577: <hr/>
578: <xsl:call-template name="test"/>
579: </html>
580: </xsl:template>
581:
582: <xsl:template match="name">
583: <b><xsl:value-of select="."/></b>
584: </xsl:template>
585: </xsl:stylesheet>
586: }]
587:
588:
589: $xdoc[^xdoc.transform[$sheet]]
590: $string[^xdoc.string[$.method[html]]]
591: ^string.save[a]
592: ^untaint[html]{$string}
593:
594:
1.77 paf 595:
596: @tnormalize[]
597: #s состоит из 1000 фрагментов
598: $s[^for[i](0;999){фрагмент }]
599: #это займет много ресурсов
600: ^s.match[фраг][g]{перга}
601: #это займет меньше ресурсов
602: #$normalized[^s.normalize[]]
603: #^normalized.match[фраг][g]{перга}
1.74 paf 604:
605: @sendtests[]
1.89 paf 606: ^text[]
1.74 paf 607: #^html[]
608: #^text-n-html[]
609: #^file[]
610: #^text-n-file[]
1.89 paf 611: #^text-n-html-n-file[]
1.74 paf 612: #^backwardcomp[]
613:
614: @backwardcomp[]
615: ^mail:send[
616: $.from[paf]
617: $.to[paf]
618: $.body[this is text value]
619: ]
620:
621: @text[]
622: ^mail:send[
623: $.from[paf]
1.90 paf 624: $.to[paf]
1.74 paf 625: $.text[
626: $.value[this is text value]
627: ]
628: ]
629:
630: @html[]
631: ^mail:send[
632: $.from[paf]
633: $.to[paf]
634: $.html{this is <b>html</b> value ^taint[<] 10}
635: ]
636:
637: @text-n-html[]
638: ^mail:send[
639: $.from[paf]
640: $.to[paf]
641: $.text[
642: $.value[this is text value]
643: ]
644: $.html[
645: $.value{this is <b>html</b> value ^taint[<] 10}
646: ]
647: ]
648:
649: @file[]
650: ^mail:send[
651: $.from[paf]
652: $.to[paf]
653: $.file[^file::load[binary;image.jpg]]
654: ]
655:
656: @text-n-file[]
657: ^mail:send[
658: $.from[paf]
659: $.to[paf]
660: $.text[
661: $.value[this is text value]
662: ]
663: $.file[^file::load[binary;image.jpg]]
664: ]
665:
666: @text-n-html-n-file[]
667: ^mail:send[
668: $.from[paf]
669: $.to[paf]
670: $.text[
671: $.value[this is text value]
672: ]
673: $.html[
674: $.COntent-type[$.value[text/html]$.charset[windows-1251xx]]
675: $.value{this is <b>html</b> value ^taint[<] 10}
676: ]
677: $.file[^file::load[binary;image.jpg]]
678: ]
679:
680:
681:
682: @md5salt[]
683: 1234
684:
685: @cryptdocsample[]
686: $users[^table::create{name password
687: alice ***
688: bob ***
689: }]
690:
691: $htpasswd[^table::create[nameless]{}]
692: ^users.menu{
693: ^htpasswd.append{$users.name:^math:crypt[$users.password;^$apr1^$^md5salt[]]}
694: }
695:
696: ^htpasswd.save[nameless;.htpasswd-parser-test]
697:
1.73 paf 698:
699: @tcrypt[]
1.76 paf 700: #^math:crypt[123;^$apr1^$1234567890abcdef]<br>
701: ^math:crypt[123;^$apr1^$]<br>
1.72 paf 702:
703: @tfilespec[]
704: src=$selffilespec<br>
705: dirname=^file:dirname[$selffilespec]<br>
706: basename=^file:basename[$selffilespec]<br>
707: justname=^file:justname[$selffilespec]<br>
708: justext=^file:justext[$selffilespec]<br>
1.68 paf 709:
710: @datecreatestring3[]
711: $new_after[^date::now(-3)]
712: $articles[^table::create{id title last_update
713: 1 привет 2002-07-03}]
714: ^articles.menu{
715: $last_update[^date::create[$articles.last_update]]
716: <a href=${articles.id}.html>$articles.title</a>
717: ^if($last_update > $new_after){новая}
718: <br>
719: }
1.67 paf 720:
721: @div[]
722: $var(5)
723: ^var.inc(7)
724: ^var.dec(3)
725: ^var.div(4)
726: ^var.mul(2)
727: $var
728:
729:
730: @xdocsave[]
731: $document[^xdoc::create{<?xml version="1.0" encoding="windows-1251" ?>
732: <document>
733: строка1<br/>
734: строка2<br/>
735: </document>}]
736: ^document.save[test.xml]
737:
738: @xdocstring[]
739: $document[^xdoc::create{<?xml version="1.0" encoding="windows-1251" ?>
740: <document>
741: строка1<br/>
742: строка2<br/>
743: </document>}]
744: ^document.string[
745: $.method[html]
746: ]
747:
748:
749: @xdocload[]
750: $document[^xdoc::load[article.xml]]
751: $response:body[^document.file[$.media-type[text/xml]]]
752:
753:
754: @xdoccreatetag[]
755: $document[^xdoc::create[document]]
756: $paraNode[^document.createElement[para]]
757: $dummy[^document.documentElement.appendChild[$paraNode]]
758: $response:body[^document.file[$.media-type[text/xml]]]
759:
760:
761: @xdoccreate[]
762: $document[^xdoc::create{<?xml version="1.0" encoding="windows-1251" ?>
763: <document>
764: текст
765: </document>}]
766: $response:body[^document.file[$.media-type[text/xml]]]
767:
768: @selectBool2[]
769: $d[^xdoc::set{<?xml version="1.0" encoding="windows-1251"?>
770: <t attr="привет" n="123"/>}]
771: ^if(^d.selectBool[/t/@n > 10]){
772: /t/@n больше 10
773: }{
774: не больше
775: }
776:
777:
778: @selectNumber2[]
779: $d[^xdoc::set{<?xml version="1.0" encoding="windows-1251"?>
780: <t attr="привет" n="123"/>}]
781: ^d.selectNumber[number(/t/@n)+1]<br>
782: ^d.selectNumber[2*2]<br>
783:
784:
785: @selectString2[]
786: $d[^xdoc::set{<?xml version="1.0" encoding="windows-1251"?>
787: <t attr="привет" n="123"/>}]
788: # результат=привет
789: ^d.selectString[string(t/@attr)]
790:
791:
792: @selectSingle2[]
793: $d[^xdoc::set{<?xml version="1.0" encoding="windows-1251"?>
794: <t attr="привет" n="123"/>}]
795: # результат=один элемент "t"
796: $element[^d.selectSingle[t]]
797: # результат=2 (количество атрибутов <t>)
798: Количество атрибутов: ^element.attributes._count[]<br>
799: # результат=не существует (нет <x>)
800: ^if(^d.select[x]){
801: x существует
802: }{
803: x не существует
804: }
805:
806: @select2[]
807: $d[^xdoc::set{<?xml version="1.0" encoding="windows-1251"?><t attr="привет" n="123"/>}]
808: # результат: список из одного элемента "t"
809: $list[^d.select[t]]
810: # результат: 2 = количество атрибутов <t>
811: ^list.0.attributes._count[]<br>
812: ^for[i](0;$list-1){
813: $attr[$list.$i]
814: $attr.nodeName = $attr.nodeType<br>
815: }
816:
817:
818: @selectt[]
819: $d[^xdoc::set{<?xml version="1.0" encoding="windows-1251"?><t attr="привет" n="123"/>}]
820: $list[^d.select[t]]
821: ^list.0.attributes._count[]
1.65 paf 822:
823: @envt[]
1.66 paf 824: $f[^file::exec[showenv.cmd;
825: $.bad[value]
826: $.CGI_good[value]
827: ]]
1.65 paf 828: $f.status<br>
829: $f.stderr<br>
830: <pre>$f.text</pre>
831:
1.63 paf 832:
833: @tserge[]
1.64 paf 834: ^if(" 09 "){y}
1.61 paf 835:
836: @datetest[]
837: $f[^file::stat[some.zip]]
838: Размер в байтах: $f.size<br>
839: Год создания: $f.cdate.year<br>
840: $now[^date::now[]]
841: $DAYS_CONSIDERED_NEW(3)
842: Статус: ^if($f.mdate >= $now-$DAYS_CONSIDERED_NEW){новый;старый}
843:
1.60 paf 844:
845: @checkList[]
846: ...^oneOf[a;a,b,c]...<br>
847: #...^oneOf[a;ax,b,c]...<br>
848: ...^oneWord[word]...<br>
849: #...^oneWord[wo rd]...<br>
850:
851:
852: @oneOf[s;list][t] выдаёт строку, если строка она есть в списке(разделенном запятыми)
853: $t[^list.lsplit[,]]
854: ^if(!^t.locate[piece;$s]){^throw[user;$s;unknown]}
855: $result[$s]
856:
857: @oneWord[s]
858: ^if(^s.match[\W]){^throw[user.data;$s;not word]}{$s}
1.59 paf 859:
860: @pngsize[]
861: $i[^image::measure[test.png]]
862: ^i.html[]
863:
864:
865: @forkeys[]
866: $text[^form:fields.foreach[key;val]{$key=$val
867: }]
868: ^text.save[ttt.txt]
869: =$text=
870:
871:
872: @tstoredproc2[]
873: ^connect[odbc://DSN=nestle^;UID=nestle^;PWD=mbm32]{
874: ^void:sql{exec pafvoid}
875: }
876:
877: @tstoredproc[]
878: ^connect[odbc://DSN=nestle^;UID=nestle^;PWD=mbm32]{
879: $t[^table::sql{exec pafproc}]
880: # $t[^table::sql{{call pafproc}}]
881: $c[^t.columns[]]
882: ^c.menu{$c.column}[<br>]
883: }
1.57 paf 884:
885: @datecreatestring2[]
1.58 paf 886: <table border=1>
887: ^datecreatestring2show[2000]
888: ^datecreatestring2show[2000-02]
1.59 paf 889: ^datecreatestring2show[2000-2-03]
1.58 paf 890: ^datecreatestring2show[2000-02-03 15]
891: ^datecreatestring2show[2000-02-03 15:30]
892: ^datecreatestring2show[2000-02-03 15:30:04]
893: ^datecreatestring2show[2000-02-03 15:30:04 hren]
894: ^datecreatestring2show[15:30]
895: ^datecreatestring2show[15:30:05]
896: ^datecreatestring2show[15:30:05 hren]
897: </table>
898:
899: @datecreatestring2show[s]
900: $date[^date::create[$s]]
901: <tr>
902: <td>$s</td><td align=right>^date.sql-string[]</td>
903: </tr>
904:
1.57 paf 905:
906: @junctionprob[][l]
907: $l[123]
908: $a{$l}
909: ^junctionprobnested[$a]
910: @junctionprobnested[p]
911: $p
912:
913:
914: @callindirecttarget[]
915: callindirecttarget called
916: @callindirect[]
917: $f[$callindirecttarget]
918: ^f[]
919:
920: @xpath2[]
921: $xdoc[^xdoc::create{<?xml version="1.0" encoding="windows-1251"?>
922: <doc>
923: <field-list>
924: <field name="aa"/>
925: <field name="bb"/>
926: </field-list>
927: </doc>
928: }]
929:
930: #^xdoc.string[]
931:
932: $fieldList[^xdoc.selectSingle[/doc/field-list]]
933: #^fieldList.childNodes._count[]
934: $fields[^fieldList.select[field]]
935: #^fields._count[]
936: ^fields.foreach[k;node]{
937: $node.nodeName<br>
938: }
939: @counter[filespec][f;s]
940: ^file:lock[$filespec]{
941: $f[^file::load[text;$filespec]]
942: $s[^eval($f.text+1)]
943: ^s.save[$filespec]
944: }
945: $s
1.56 paf 946:
947: @xmlspace[]
948: $xdoc[^xdoc::set{^process{<?xml version="1.0" encoding="windows-1251"?>
949: <!--DOCTYPE people SYSTEM "D:\Y\parser3project\parser3\src\www\htdocs\people.dtd"-->
950: <people>
951: <man id="1" имя="word слово">
952: <name>1 2</name>
953: </man>
954: </people>
955: }}]
956: $xdoc[^xdoc.transform[global.xsl]]
957: $string[^xdoc.string[$.method[html]]]
958: ^string.save[a]
959: ^untaint[html]{$string}
960:
961: @badthrows[]
962: #^throw[a;b;]
963: ^throw[a;]
1.54 paf 964:
965: @mssqltypes1[]
966: ^connect[odbc://DSN=nestle^;UID=nestle^;PWD=mbm32]{
1.55 paf 967: # ^string:sql{select { ts '1998-05-02 01:23:56.123' }}
968: # ^string:sql{select CAST({ ts '1998-05-02 01:23:56.123' }AS smalldatetime)}
969: # ^string:sql{select CAST({ts '2002-04-28 00:00:00.000'} AS smalldatetime)}
970: $t[^table::sql{select a from paf}]
971: ^t.count[]
1.54 paf 972: }
1.51 paf 973:
1.53 paf 974: @datecreatestring[]
1.54 paf 975: $d[^date::create[2002-04-33 01:03:04]]
1.53 paf 976: ^d.sql-string[]
1.52 paf 977:
978: @method[hash]
979: $hash.key
980: @mainZ[]
981: ^method[
982: $.key{code}
983: ]
984:
1.51 paf 985: @tablehasht[]
986: $t[^table::create{p
987: 1
988: 3
989: 2
990: 4}]
991:
992: $h[^t.hash[p]]
993:
994: =^h._count[]=
995:
996:
997: @sqldefaults[]
998: ^connect[mysql://mdm:4b833ljq@db-mysql/mdm]{
999: ^int:sql{select news_id from news where news_id=-1}[$.default{2}]<br>
1000: ^string:sql{select news_id from news where news_id=-1}[$.default{2}]
1001: }
1.60 paf 1002: =======
1003: <hr>
1004: OK
1005: >>>>>>> 1.50
1.48 paf 1006:
1007: @tcrashlocaljunctionsv2[]
1008: $a[
1009: $b{ $c[1] }
1010: ]
1011: $b
1012: $c
1013:
1014: @tcrashlocaljunctions[]
1015: $var[aaa]
1016: ^if(1){
1017: ^tcrashlocaljunctions1[]
1018: }
1019:
1020: $j
1021:
1.49 paf 1022: @tcrashlocaljunctions1[][var]
1023: $var[varvalue]
1.48 paf 1024: $j{
1025: $var
1026: }
1.49 paf 1027: $j
1.48 paf 1028:
1029: @tjunctions[][tl]
1030: $t[^t::create[]]
1031: ^tjunctionsi[]
1032:
1033: @tjunctionsi[][tl]
1034: $tl[12345]
1035: ^t.tjunctionsm[
1036: $.key{
1037: $tl
1038: }
1039: ]
1.46 paf 1040:
1.47 paf 1041: @replacetest[]
1042: $b[b]
1043: $s[
1044: aaaaaaaaaa${b}aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
1045: aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa${b}aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
1046: ]
1047: ^s.replace[^table::create{from to
1048: ba !_}]
1049:
1050:
1.46 paf 1051: @matchoptionpp[]
1.47 paf 1052: #$ORIGINS(1)
1.46 paf 1053: $s[
1054: aaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
1.47 paf 1055: aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
1056: aaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
1057: aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
1058: aaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
1059: aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
1060: aaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
1061: aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
1062: aaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
1063: aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
1.46 paf 1064: ]
1065: ^s.match[b;g']{($match.prematch|$match.match|$match.postmatch)}
1066:
1.44 paf 1067:
1068: @txdocxnodechild[]
1069: $xdoc[^xdoc::set{<?xml version="1.0" encoding="windows-1251" ?><d/>}]
1070: $xdoc.nodeName
1071: ^xdoc.selectNumber[2*2]
1.45 paf 1072: $xdoc:ELEMENT_NODE
1.44 paf 1073:
1074:
1075: @tclasses[]
1076: $t[^t::create[]]
1077: ^t.method[]
1078: <hr>
1079: ^t.base_method[]
1080:
1.40 paf 1081:
1082: @errort[]
1.42 paf 1083: ^xdoc::create[a]
1.40 paf 1084: #^throw[user;here;this]
1085:
1086: @tselectNumber[]
1087: $d[^xdoc::set{<?xml version="1.0" encoding="windows-1251"?><d attr="привет" n="123"/>}]
1088: ^d.selectString[string(d/@attr)]<br>
1089: ^d.selectNumber[2*2]<br>
1090: ^d.selectNumber[number(/d/@n)+1]<br>
1091:
1.34 paf 1092:
1.36 paf 1093: @invaliddate2[]
1094: $d[^date::create(1018946575/60/60)] ^d.sql-string[]
1095:
1096: @process2[]
1097: ^^process{
1098: ^process{
1099: ^$a[^^if(0){^$.k[y]}{^$.k[^^hren[]n]}] ^$a.k
1100: }
1101: }
1102:
1.35 paf 1103: @casehashtext[]
1104: $tt[1]
1105: $tmp[
1106: ^switch[$tt]{
1107: ^case[1]{
1108: $.aaa[123]
1109: }
1110: ^case[DEFAULT]{
1111: $.bbb[456]
1112: }
1113: }
1.36 paf 1114: shit!
1.35 paf 1115: ]
1.36 paf 1116: #$tmp
1.35 paf 1117: $tmp.aaa
1118:
1119: @subjvaltest[]
1120: $a12[val]
1121: $b[12]
1122: $a$b
1123:
1.34 paf 1124: @tableselect0[]
1125: $person[^table::create{name height
1126: paf 1.77
1127: шохин 2.07
1128: moko 1.77
1129: }]
1130: $nottoohigh[^person.select($person.height<2)]
1131: ^nottoohigh.menu{$nottoohigh.name<br>}
1.32 paf 1132:
1133: @transparams[]
1134: $idoc[^xdoc::create{<?xml version="1.0" ?><doc/>}]
1135: $odoc[^idoc.transform[global.xsl;
1136: $.param1['1']
1137: $.param2['2']
1138: ]]
1139: <pre>^taint[^odoc.string[$.method[html]]]
1140:
1141: @memnotest1[]
1142: ^for[i](0;4000){
1143:
1144: $xxxx[$i]
1145: $xxxx
1146:
1147: }
1148:
1149: @memnotest1notes[]
1150: одна итерация цикла:
1151: [Mon Apr 8 20:12:02 2002] execution-------------------------|
1.35 paf 1152: '469641+=28 wcodeframe -> 0 !optimize[3]''469669+=49 string от {} -> 0 optimize[3]'
1.32 paf 1153: [Mon Apr 8 20:12:02 2002] 12:STRING__WRITE
1154: [Mon Apr 8 20:12:02 2002] "|| "
1155: [Mon Apr 8 20:12:02 2002] 12:WITH_ROOT
1156: [Mon Apr 8 20:12:02 2002] 13:VALUE
1157: [Mon Apr 8 20:12:02 2002] "xxxx" string
1.35 paf 1158: [Mon Apr 8 20:12:02 2002] 14:CREATE_EWPOOL'469377+=24 wcodeframe -> 0 !optimize[1]''469401+=49 string -> 41 !optimize[7]'
1.32 paf 1159: [Mon Apr 8 20:12:02 2002] 16:WITH_READ
1160: [Mon Apr 8 20:12:02 2002] 17:VALUE
1161: [Mon Apr 8 20:12:02 2002] "i" string
1162: [Mon Apr 8 20:12:02 2002] 18:GET_ELEMENT
1.35 paf 1163: [Mon Apr 8 20:12:02 2002] 17:WRITE_VALUE'469452+=40 MAX_NUMBER -> !~2 actual digits''469492+=49 -> 41 !'
1164: [Mon Apr 8 20:12:02 2002] 16:REDUCE_EWPOOL'469541+=24 VString -> 0 optimize[5]'
1.32 paf 1165: [Mon Apr 8 20:12:02 2002] 15:CONSTRUCT_VALUE
1166: [Mon Apr 8 20:12:02 2002] 12:STRING__WRITE
1167: [Mon Apr 8 20:12:02 2002] "| "
1168: [Mon Apr 8 20:12:02 2002] 12:WITH_READ
1169: [Mon Apr 8 20:12:02 2002] 13:VALUE
1170: [Mon Apr 8 20:12:02 2002] "xxxx" string
1171: [Mon Apr 8 20:12:02 2002] 14:GET_ELEMENT
1172: [Mon Apr 8 20:12:02 2002] 13:WRITE_VALUE'469573+=41 string expand nothing for now'
1173: [Mon Apr 8 20:12:02 2002] 12:STRING__WRITE
1.35 paf 1174: [Mon Apr 8 20:12:02 2002] "||"'469617+=24 VString -> 0 !optimize[6]'
1.32 paf 1175: [Mon Apr 8 20:12:02 2002] <-ja returned
1176: [Mon Apr 8 20:12:02 2002] ja->
1177:
1178: 201/328=0.612804878049 %%optimized
1179:
1180: 1.
1181: CREATE_*POOL
1182: сделать
1183: *POOL_POOLED+CODE
1184: где
1185: wwrapper
1186: и(возможно) wcodeframe
1187: +string
1188: стековая переменная
1189:
1190: 2.
1191: избавиться от обёртки при возврате результата process [см. тело _for]
1192:
1193: 3.
1194: сделать callback для process, чтобы вынести invariants из _for & co.
1195:
1196: 4.
1197: @todo склеить get_element и write_value (при вставлении? write_value)
1198:
1199: 5.
1200: reduce_*pool -> вариант получить именно string, без VString обёртки [часто
1201: обёртка сразу выбрасывается = не нужна]
1202:
1203: 6.
1204: process вариант получить именно string, без VString обёртки [часто обёртка
1205: сразу выбрасывается = не нужна]
1206:
1207: 7.
1208: string head, убить 8 байт неправильной link
1.31 paf 1209:
1210: @voidparams[]
1211: ^voidparamsm[$form:field]
1212:
1213: @voidparamsm[p]
1214: ^p.int(123)
1.29 paf 1215:
1.30 paf 1216: @rolls2[]
1217: $now[^date::now[]]
1218: $d[^date::create($now.year;$now.month)] ^d.sql-string[]<br>
1219: ^for[i](1;12){
1220: ^d.roll[month](-1) ^d.sql-string[]<br>
1221: }
1222:
1.29 paf 1223: @cacheexpireschanging[]
1224: ^cache[$DB_HOME/keyключ][^date::now(+1)]{ ^rem{1 day}
1225: ^cache[^date::now(+4/24/60/60)]
1226: # ^cache(2)
1.30 paf 1227: # ^cache(0)
1.29 paf 1228: ^math:random(100)
1229: }
1230:
1231:
1232:
1233: @cacheexpiresfixed[]
1234: ^cache[$DB_HOME/keyключ][^date::now(+2/24/60/60)]{
1235: ^math:random(100)
1236: }
1237:
1238: @dateoffsets[]
1239: $d[^date::create(^date::now[]+1/24/60)]
1240: #$d[^date::now(+1/24/60)]
1241: ^d.sql-string[]
1242: #$d
1.26 paf 1243:
1.28 paf 1244: @exceptionTypes[]
1245: # parser.compile ^test[} компиляция (непарная скобка, ...)
1246: # parser.runtime ^if(0). параметры (больше/меньше, чем нужно, не тех типов, ...)
1247: # number.zerodivision ^eval(1/0) ^eval(1%0)
1248: # number.format ^eval(abc*5)
1249: # file.missing ^file:delete[delme] not found
1250: # file.access ^table::load[.] no rights
1251: # image.format ^image::measure[index.html] not gif/jpg
1252: # sql.connect ^connect[mysql://baduser:pass@host/db]{} not found/timeout
1253: # sql.execute ^connect[mysql://okuser:pass@host/db]{^void:sql{select bad}} syntax error
1254: # xml ^xdoc::create{<forgot?>} any error in xml/xslt libs
1255: # smtp.connect not found/timeout
1256: # smtp.execute communication error
1257:
1.26 paf 1258: @roll2[]
1259: $d[^date::create(2002;4;2;2;2;3)] ^d.sql-string[]<br>
1.27 paf 1260: ^d.roll[day](+365*3+1) ^d.sql-string[]<br>
1.26 paf 1261:
1.25 paf 1262:
1263: @rolls[]
1264: $d[^date::create(2002;4;4)]
1265: ^d.sql-string[]<br>
1266: ^for[i](1;7){
1267: ^d.roll[day](-1)
1268: ^d.sql-string[]<br>
1269: }
1270: <hr>
1271: $d[^date::create(2002;3;28)]
1272: ^d.sql-string[]<br>
1273: ^for[i](1;7){
1274: ^d.roll[day](+1)
1275: ^d.sql-string[]<br>
1276: }
1277: <hr>
1278: $d[^date::create(2002;12;3)]
1279: ^d.sql-string[]<br>
1280: ^for[i](1;14){
1281: ^d.roll[day](-1)
1282: ^d.sql-string[]<br>
1283: }
1284: <hr>
1285: $d[^date::create(2002;10;19)]
1286: ^d.sql-string[]<br>
1287: ^for[i](1;14){
1288: ^d.roll[day](+1)
1289: ^d.sql-string[]<br>
1290: }
1291:
1292:
1293:
1294:
1295:
1.22 paf 1296:
1297: @exceptions1[]
1298: ^try{
1299: aaa
1.24 paf 1300: ^throw[custom1;paf;is stupid]
1.22 paf 1301: }{
1.24 paf 1302: ^if($exception.type eq custom1){
1.28 paf 1303: # $exception.handled(1)
1304: ^throw[$exception]
1.24 paf 1305: type=$exception.type<br>
1306: source=$exception.source<br>
1307: file=$exception.file<br>
1308: lineno=$exception.lineno<br>
1309: comment=$exception.comment<br>
1310: }
1.22 paf 1311: }
1.21 paf 1312:
1313: @locate_by_expr[]
1314: $t[^table::create{a b
1315: 1 nok
1316: 2 ok
1317: 3 nok
1318: }]
1319: ^if(^t.locate($t.a==2)){$t.b}{n}
1.17 paf 1320:
1321: @method_junction_params[param]
1322: ^if($param is junction){junction}{ne junction}
1323:
1324: @verifyCookie[value]
1325: ^if($cookie:dummyvote eq $value){
1326: $result(1)
1327: }{
1328: $cookie:dummyvote[$value]
1329: $result(0)
1330: }
1.16 paf 1331:
1332: @execlangs[]
1.20 paf 1333: $f[^file::exec[test.pl]]
1.36 paf 1334: err:$f.stderr<br>
1.16 paf 1335: ^process{$f.text}
1336: #$c[^t.columns[]]
1337: #^c.menu{
1338: #* $c.column<br>
1339: #}
1.36 paf 1340: c:$t.c<br>
1.16 paf 1341:
1342: @tobjeresult[]
1343: ^table::create{a
1344: 12}
1.15 paf 1345:
1346: @xmlprobs[]
1347: $xmlDataType[^xdoc::load[program.xml]]
1348: #<pre>^taint[^xmlDataType.string[]]
1349: $xmlDataTypes[^xmlDataType.select[programs/program[@id=4]/data]]
1350: #=^xmlDataTypes._count[]=
1351: =^xmlDataTypes.0.getAttribute[type-id]=
1352:
1353: @doubleprobs[]
1354: $1(^math:radians(180))
1355: $2($math:PI)
1356: ^if(^1.format[%.10f]==^2.format[%.10f]){y;n}
1357: ^if($1==$2){y;n}
1358: ^if(^math:radians(180)==$math:PI){y;n}
1359:
1360:
1361: @divnamestop[]
1362: $a(10)
1363: ^eval($a\3)
1364:
1365: @arrayclone[]
1366: $t[^table::create{a b
1367: 1 11
1368: 2 22
1369: }]
1370: $c[^table::create[$t]]
1371: ^c.append{2 33}
1372: ^t.count[]
1373: ^c.count[]
1374:
1375: @operator_tricks[]
1376: ^if(1){$a[^t[]]}
1377: $a!
1378: $a($b)
1379: ^if(1){y}{n}
1380: $MAIN:a(^t[] eq OK)
1381: #$MAIN:a(1)
1382: ^if($a){y}{n}
1383: #^if(1){y}{n}
1384: $form:if
1385: $a[$.n[1]]
1386: $a.if
1387:
1388: @xoutputrusattr[]
1389: $d[^xdoc::set{<?xml version="1.0" encoding="windows-1251"?><d attr="привет"/>}]
1390: ^show_xdoc2[$d]
1391:
1392: @xdocset1[]
1393: $d[^xdoc::set{<?xml version="1.0"?><d>=^taint[&]=</d>}]
1394: ^show_xdoc2[$d]
1395:
1396: @regexp3[]
1397: $s[abcАБВ]
1398: ^if(^s.match[][i]){y}{n}
1399:
1400:
1401: @exec2[]
1402: $a[^file::exec[bin/t.cmd]]
1403: <pre>^taint[$a.text]</pre>|$a.status|$a.stderr<hr>
1404:
1405:
1406: @tlock[]
1407: ^file:lock[lockfile]{
1408: code
1409: }
1410:
1411: @xmloutattrwithoutvalue[]
1412: #$ORIGINS(1)
1413: $doc[^xdoc::set{<?xml version="1.0"?><doc background="">zz</doc>}]
1414: $doc[^doc.transform[global.xsl]]
1415: =^taint[html][^doc.string[$.method[html]]]=
1416:
1417:
1418:
1419: @precisionProblem[]
1420: $a[123456789012345678901234567890]
1421: $b(^a.double[])
1422: ^b.format{%.20E}
1423: <hr>
1424: ^eval(2*2)
1425:
1426: @xpath[]
1427: $xdoc[^xdoc::set{<?xml version="1.0" encoding="windows-1251" ?>
1428: <document><block><p>привет</p></block></document>
1429: }]
1430: #^show_xdoc2[$xdoc]
1431: $node[^xdoc.selectSingle[/document/block/p]]
1432: ^if(def $node){
1433: ^if($node is string){
1434: $node
1435: }{
1436: ^if($node is hash){
1437: ^node._count[]
1438: }{
1439: $node.nodeType
1440: }
1441: }
1442: #$node.firstChild.nodeValue
1443: }{
1444: node not found
1445: }
1446:
1447:
1448: @ttablesetlang[]
1449: $a-tab-b[a b
1450: 1 2]
1451:
1452: $t[^table::set{$a-tab-b}]
1453: =$t.a=
1454: <hr>
1455:
1456: $t[^table::set[nameless]{^taint[$a-tab-b]}]
1457: =$t.0=
1458: <hr>
1459:
1460: $t[^table::set{^untaint{^taint[$a-tab-b]}}]
1461: =$t.a=
1462:
1463: #^t.append{1 2}
1464:
1465: @mail3[]
1466: ^mail:send[
1.98 paf 1467: $.from[Александр Петросян <paf@mail.design.ru>]
1468: $.to[Александр Петросян <paf@mail.design.ru>]
1469: $.subject[проверка2]
1.15 paf 1470: $.body[
1471: $.text[
1472: $.content-type[$.value[text/plain] $.charset[windows-1251]]
1.98 paf 1473: $.body[проверка^taint[uri][москва]=]
1.15 paf 1474: ]
1475: $.attachment[
1476: $.value[^file::load[text;index.html]]
1477: $.file-name[привет всем.html]
1478: ]
1479: ]
1480: ]
1481:
1482:
1483: @ttime[]
1484: $now[^date::now[]]
1485: $now.hour:$now.minute
1486:
1487: @tupper[]
1488: $t[abcABCабвАБВ]
1489: $t<br>
1490: ^t.upper[]
1491:
1492: @treplace[]
1493: $copy-paste-clean[^table::set{a b
1494: . _
1495: , _
1496: + _
1497: & _
1498: ? _
1499: = _}]
1500:
1501: $cache_key[^taint[в.а,с+я]&был?тут=недавно.cache]
1502: # почему-то этот replace роняет апач в 500 ошибку :(
1503: #^cache_key.replace[$copy-paste-clean]
1504: $test[abc]
1505: ^test.save[$cache_key]saved<br>
1506: $cache[^file:list[.;\.cache^$]]
1507: ^file:delete[$cache_key]deleted($cache.name)<br>
1508:
1509:
1510:
1511: @xslt2[]
1512: $xdoc[^xdoc::set{<?xml version="1.0" encoding="windows-1251" ?>
1513: <document><block><p>привет</p></block></document>
1514: }]
1515: ^show_xdoc2[$xdoc]
1516: ^show_xdoc2[^xdoc.transform[templates/_document.xslt]]
1517: <hr>
1518:
1519:
1520: @tcache2[]
1521: ^cache[$DB_HOME/keyключ](2){
1522: ^math:random(100)
1523: }
1524:
1525: @ttaintuntaint[]
1526: <!-- некий панковский заголовок с буковкой C в круглых скобках -->^taint[html][
1527:
1528: ]zz
1529: <hr>
1530: ^untaint[html]{1^taint[ ]2 3}
1531:
1532:
1533: @tappend2[]
1534: $t[^table::set{a b}]^t.append{1 2}$t.a
1535:
1536: @badvsnprintf[]
1537: ^connect[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz]{
1538: }
1539:
1540:
1541: @badoracequoting[]
1542: $SQL.connect-string[oracle://webspb:webpwd@mts?NLS_LANG=RUSSIAN_AMERICA.CL8MSWIN1251&NLS_DATE_FORMAT=YYYY-MM-DD HH24:MI:SS]
1543: ^connect[$SQL.connect-string]{
1544: ^void:sql{delete from paf}
1545: ^void:sql{insert into paf values (1, '$form:text')}
1546: $paf[^table::sql{select * from paf}]
1547: ^paf.menu{
1548: $paf.id: ^untaint{$paf.block}<hr>
1549:
1550: }
1551: <hr>
1552:
1553:
1554: ^rem{
1555: $news[^table::sql{select description from news}[$.limit(3)]]
1556: ^news.menu{
1557: ^untaint{$news.description}<hr>
1558:
1559: }
1560: <hr>
1561: }
1562:
1563: $tables[^table::sql{select table_name from user_tables}]
1564: ^tables.menu{
1565: $tables.table_name<br>
1566: }
1567:
1568: }
1569: <hr>
1570: $env:PATH
1571:
1572: @badconstructors[]
1573: $bred[^string::length[]]
1574: $bred[^response::clear[]]
1575: $bred[^int::int[]]
1576:
1577:
1578: @xloadwrongtable[]
1579: $constr[^xdoc::load[wrongtable.xml]]
1580: ^show_xdoc2[$constr]
1581:
1582: @xsetwrongtable[]
1583: $constr[^xdoc::set{<?xml version="1.0" encoding="windows-1251z" ?>
1584: <block-list>^untaint[as-is]{$constructor}</block-list>}]
1585:
1586:
1587: @tablecolumnerror[]
1588: $t[^table::set{a}]
1589: $t.$a
1590:
1591: @roll[]
1592: #$date[^date::set(1970;1;2)]
1593: #^date.roll[month](-1)
1594: $date[^date::set(2038;1;1)]
1595: ^date.roll[month](+1)
1596: $date.year $date.month $date.day
1597:
1598: @cookie2[]
1599: #=$cookie:clientType[$.value[test]]=<br>
1600: =$cookie:clientType=<br>
1601:
1602:
1603: @tableset[]
1604: $a[^table::set{a
1605: 1
1606: 2}]
1607: ^eval(100\$a)
1608:
1609:
1610:
1611: @zzz[]
1612:
1613:
1614: $constructor[
1615: <block1 name="main_srvr" type="0" label="Основное тело" />
1616: <block2 name="main_srvr2" type="0" label="Основное тело" />
1617: ]
1618:
1619: $constr[^xdoc::set{<?xml version="1.0" encoding="windows-1251" ?>
1620: <block-list>^untaint[as-is]{$constructor}</block-list>}]
1621:
1622: $children[$constr.documentElement.childNodes]
1623: ^if($children){
1624: ^for[i](1;^children._count[]){
1625: $node[$children.$i]
1626: $node.nodeName<br>
1627: }
1628: }
1629:
1630:
1631: @thashforeach3[]
1632: $h[
1633: $.a[1]
1634: $.b[2]
1635: ]
1636: $c[^table::set{a
1637: ^h.foreach[key;value]{$value
1638: }}]
1639: $c.a
1640:
1641: @thashforeach2[]
1642: $h[
1643: $.a[1]
1644: $.b[2]
1645: ]
1646: $c[
1647: ^h.foreach[key;value]{
1648: $.$key[$value]
1649: }
1650: ]
1651: $c.b
1652:
1653: @thashforeach[]
1654: $h[
1655: $.a[1]
1656: $.b[2]
1657: ]
1658: ^h.foreach[key;value]{
1659: $key=$value<br>
1660: }
1661:
1662: @thashdelete[]
1663: $h[$.a[1] $.b[2]]
1664: was:<br>
1665: count=^h._count[] <br>
1666: b='$h.b' <br>
1667:
1668: ^h.delete[b]
1669:
1670: now:<br>
1671: count=^h._count[] <br>
1672: b='$h.b'
1673:
1674: @sappend[]
1675: $test[123]
1676: ^test.save[test]
1677: ^test.save[append;test]
1678:
1679: @tappend[]
1680: $test[^table::set{a b
1681: a1 b1}]
1682: ^test.save[test]
1683: $test[^table::set{a b
1684: a2 b2}]
1685: ^test.save[append;test]
1686:
1687:
1688: @tform[]
1689: ^if(def $form:new_file){y}{n}
1690: <form method="post" enctype="multipart/form-data">
1691: <input type="file" name="new_file" />
1692: <input type=submit>
1693: </input>
1694:
1695: @formattest[]
1696: $size(15.124)
1697:
1698: ^size.format{%.2f}
1699:
1700: @filelist[]
1701: $html[^file:list[.;\.html^$]]
1702: ^html.menu{
1703: $html.name<br>
1704: }
1705: <hr>
1706:
1707: @безнадёжна_попытка_поправить_непоправимое[]
1708: $dom_from_disk[^xdoc::load[input.xml]]
1709: $dom_created_in_air[^xdoc::create[doc]]
1710: ^dom_created_in_air.documentElement.appendChild[^dom_from_disk.documentElement.cloneNode(1)]
1711: ^show_xdoc2[$dom_created_in_air]
1712:
1713:
1714: @tcache[]
1715: #^hashfile:clear[cache]
1716: $code[^hashfile::open[$DB_HOME;cache]]
1717: ^code.cache[key](2){
1718: ^math:random(100)
1719: # ^code.delete[]
1720: }
1721:
1722: @thashfileexp[]
1723: $hf[^hashfile::open[$DB_HOME;hashfile]]
1724: $hf.paf[$.value[крут] $.expires(3)]
1725: paf=$hf.paf
1726: <hr>
1727: ^hf.foreach[key;value]{
1728: $key=$value<br>
1729: }
1730: <hr>
1731: $hash[^hf.hash[]]
1732: =$hash.paf=
1733: <hr>
1734:
1735: @tcounter[]
1736: ^tcounterone[$DB_HOME]
1737: other root:
1738: ^tcounterone[${DB_HOME}2]
1739: again, first:
1740: ^tcounterone[$DB_HOME]
1741:
1742: @tcounterone[DB_HOME]
1743: $counter[^hashfile::open[$DB_HOME;counter]]
1744: #^counter.clear[]
1745: ^counter.transaction{
1746: # $counter.value(10)
1747: $counter.value($counter.value+1)
1748: # ^counter.delete[value]
1749: $counter.value
1750: }
1751: <hr>
1752: ^rem{
1753: $hash[^counter.hash[]]
1754: =$hash.value=
1755: <hr>
1756: }
1757:
1758: @tablehash[]
1759: $productList[^table::set{id name
1760: 1 носки
1761: 2 валенки
1762: 3 ушанка
1763: }]
1764:
1765: #скажем, у первого дилера
1766: $firstPriceList[^table::set{id price
1767: 1 0.3
1768: 3 1000
1769: }]
1770:
1771: $firstPriceHash[^firstPriceList.hash[id]]
1772:
1773: ^productList.menu{
1774: продукт "$productList.name" | цена у first: $firstPriceHash.[$productList.id].price<br>
1775: }
1776:
1777:
1778: @hashfile[]
1779: $hf[^hashfile::assign[hashfile]]
1780: #$hf.paf[крут5]
1781: paf=$hf.paf
1782:
1783: @formclass[]
1784: ^$form:CLASS.a=$form:CLASS.a
1785:
1786: @domdata[]
1787: ^if(1){
1788: # $a{^hren[]}
1789: }
1790: $a
1791: $xdoc[^xdoc::create[doc]]
1792: $doc[$xdoc.documentElement]
1793: $name[^doc.appendChild[^xdoc.createElement[name]]]
1794: $text[^name.appendChild[^xdoc.createTextNode[петросян&coz]]]
1795: ^untaint[as-is]{=$text.nodeValue=}
1796:
1797: @domedit[]
1798: ^domdata[]
1799: #$paf.nodeName<br>
1800: #$doc.documentElement.nodeName<br>
1801:
1802: ^show_xnode1[$xdoc.documentElement;0;1]
1803: <hr>
1804: ^show_xdoc2[$xdoc]
1805: <hr>
1806:
1807: @domxslt[]
1808: ^domdata[]
1809: ^show_xdoc2[^xdoc.transform[global.xsl;$.param1[123/]]]
1810: <hr>
1811:
1812: @lsplit2[]
1813: $path[/optics/]
1814: $pathTable[^path.lsplit[/]]
1815: ^pathTable.menu{
1816: ^if(def $pathTable.piece){
1817: =$pathTable.piece=
1818: }
1819: }
1820:
1821:
1822: @faceesize[]
1823: $k(2)
1824: $pict[^image::load[paf.gif]]
1825: $small[^image::create($pict.width/$k;$pict.height/$k)]
1826: ^small.copy[$pict](0;0;$pict.width;$pict.height;0;0;$small.width;$small.height;250)
1827: $response:body[^small.gif[]]
1828:
1829: @imageresize[]
1830: $k(2)
1831: $pict[^image::create(400*$k;200*$k)]
1832: $pict.line-width(2)
1833: ^pict.arc($pict.width/2;$pict.height/2;$pict.width-1;$pict.height-1;0;360;0x000000)
1834: ^pict.arc($pict.width/2;$pict.height/2;$pict.width-20;$pict.height-20;0+20;360-20;0xff0000)
1835: #^pict.arc($pict.width/2;$pict.height/2;$pict.width;$pict.height;0;360;0xff0000)
1836: ^pict.circle($pict.width/2;$pict.height/2;$pict.height/2-20;0x0000ff)
1837: ^pict.arc($pict.width/2;$pict.height/2;$pict.height-26;$pict.height-26;0+20;360-20;0xff0000)
1838: $response:body[^pict.gif[]]
1839:
1840: #$small[^image::create($pict.width/$k;$pict.height/$k)]
1841: #^small.copy[$pict](0;0;$pict.width;$pict.height;0;0)
1842: #^small.copy[$pict](0;0;$pict.width;$pict.height;0;0;$small.width;$small.height;0)
1843:
1844: #$response:body[^small.gif[]]
1845:
1846:
1847: @tintdefault[]
1848: #$abc[abc]
1849: $abc[33]
1850: ^abc.int[z]
1851: #^abc.int(123)
1852:
1853: @ifassignhash[]
1854: $h[^if(1){$.a(1);$.a(2)}]
1855: $h.a
1856:
1857: @ifpasshash[]
1858: $a[$.e[a]]
1859: $b[$.e[b]]
1860: ^ifpasshashdest[^if(1){$a;$b}]
1861: #$x[^if(1){$a}{$b}]
1862: #^ifpasshashdest[$x]
1863:
1864: @ifpasshashdest[p]
1865: $p.e
1866:
1867: @movedir[]
1868: ^file:move[a;deeper/a]
1869:
1870: @replace[]
1871: $a[12^;3]
1872: ^a.replace[^table::set{from to
1873: 2^; !
1874: }]
1875:
1876:
1877: @set[]
1878: ^setdata[]
1879: ^a.add[$b]
1880: add:$a.3<br>
1881:
1882: ^setdata[]
1883: ^a.sub[$b]
1884: sub2:$a.2<br>
1885: sub1:$a.1<br>
1886:
1887: ^setdata[]
1888: $c[^a.union[$b]]
1889: union3:$c.3<br>
1890: union2:$c.2<br>
1891:
1892: ^setdata[]
1893: $c[^a.intersection[$b]]
1894: intersection3:$c.3<br>
1895: intersection2:$c.2<br>
1896:
1897: ^setdata[]
1898: intersects:^if(^a.intersects[$b]){y;n}<br>
1899: intersects2:^if(^a.intersects[ ]){y;n}<br>
1900:
1901:
1902: <hr>
1903:
1904: @setdata[]
1905: $a[$.1[a1] $.2[a2]]
1906: $b[ $.2[b2] $.3[b3]]
1907:
1908:
1909: @hash[]
1910: $h[^hash::create[$._default[123]]]
1911: $h.paf[not kretin]
1912: $h.paf<br>
1913: =$h.that=<br>
1914:
1915: @methresult[]
1916: $result[^table::set{1}]
1917:
1918: @terror[]
1919: ^error[method z must be called with z]
1920:
1921: @syntax1[]
1922: #^a[^b]
1923:
1924: @syntax2[]
1925: #^a[
1926:
1927: @ssave[]
1928: $abc[abc]
1929: ^abc.save[abc]
1930:
1931: @calendar[]
1.103 paf 1932: $year(2002)
1933: $month(12)
1.84 paf 1934: ${year}-${month}:<br>
1935: $week_days[^date:calendar[rus]($year;$month)]
1.15 paf 1936: <pre>
1.101 paf 1937: ^week_days.menu{^for[wday](0;6){^if($week_days.$wday){$week_days.$wday; ^; ^;} }=$week_days.week,$week_days.year=<br>}
1.15 paf 1938: </pre>
1939:
1940: @thash[]
1941: $table[^table::set{id name age
1942: 1 paf 278
1943: 2 пиф 234
1944: }]
1945: $hash[^table.hash[id;^table::set[nameless]{id
1946: name}]]
1947: $hash.2.id $hash.2.name $hash.2.age
1948:
1949: @tdef[]
1950: $s[0]
1951: if 0=^if($s){}{n}<br>
1952: if def 0=^if(def $s){y}{}<br>
1953: <hr>
1954:
1955: @ford[]
1956: ^for[i](0;5){$i}{($i)}
1957:
1958: @tif[]
1959: ^if[def]{y;n}
1960:
1961: @image[]
1962: $pict[^image::create(400;200)]
1963: ^pict.arc($pict.width/2;$pict.height/2;$pict.width-1;$pict.height-1;0;360;0x000000)
1964: ^pict.arc($pict.width/2;$pict.height/2;$pict.width-10;$pict.height-10;0+10;360-10;0xff0000)
1965: #^pict.arc($pict.width/2;$pict.height/2;$pict.width;$pict.height;0;360;0xff0000)
1966: ^pict.circle($pict.width/2;$pict.height/2;$pict.height/2-10;0x0000ff)
1967: ^pict.arc($pict.width/2;$pict.height/2;$pict.height-26;$pict.height-26;0+10;360-10;0xff0000)
1968: $response:body[^pict.gif[]]
1969:
1970:
1971:
1972: @mail2[]
1973: ^mail:send[
1.139 paf 1974: $.message-id[<6615%1@parser.ru>]
1.15 paf 1975: $.content-type[$.value[text/plain] $.charset[windows-1251]]
1976: $.from[Александр Петросян <paf@design.ru>]
1977: $.to[Александр Петросян <paf@design.ru>]
1.134 paf 1978: $.subject[проверка проверка]
1979: $.text[проверка]
1.15 paf 1980: ]
1981:
1982: @cookie[]
1.115 paf 1983: #$env:HTTP_COOKIE<br>
1.15 paf 1984:
1985: #$cookie:переменная[test тест ТЕСТ2]
1986: =$cookie:переменная=<br>
1987: #$cookie:переменная2[test тест ТЕСТ3]
1988: =$cookie:переменная2=<br>
1989: =$cookie:CLASS.переменная2=<br>
1990:
1991: @response[]
1992: #^if($form:reload){
1993: $response:refresh[$.value[0] $.url[./t.html?uri=$env:SERVER_NAME]]
1994: #}
1995:
1996: @xslt[]
1997: ^xdata[]
1998: $transformed[^xdoc.transform[global.xsl;$.param1[123/]]]
1999: ^show_xdoc2[$transformed]
2000:
2001: @regexp2[]
2002: $s[ select]
2003: $s[^s.match[^^\s*][]{!}]
2004: $s
2005:
2006: @header[]
2007: $response:refresh[
2008: $.value[0]
2009: $.url[http://design.ru?a=^taint[123]]
2010: ]
2011:
2012: @ttablerem[]
2013: $table[^table::load[a.cfg]]
2014: ^table.menu{$table.a}
2015:
2016: @tconnect[]
2017: ^connect[mysql://test:test@paf/test?charset=cp1251_koi8&compress=1&timeout=1&named_pipe=1]{
2018: $tables[^table::sql{show tables}]
2019: #$cols[^tables.columns[]]
2020: #$cols.column
2021: ^tables.menu{
2022: $tables.[Tables_in_test]<br>
2023: }
2024: }
2025:
2026: @pcre[]
2027: $s[1 2]
2028: ^s.match[\s;ig]{!}
2029: #^s.match[\d;ig]{!}
2030:
2031:
2032: @regexp[]
2033: $s[abcАБВ]
2034: ^if(^s.match[б][i]){y}{n}
2035:
2036: @mail[]
2037: #$ORIGINS(1)
2038: ^mail:send[
2039: $.from[paf@design.ru]
2040: $.to[paf@design.ru]
2041: $.body[1
2042:
2043: 2
2044:
2045:
2046: 3]
2047: ]
2048:
2049: @fori[][i]
2050: ^for[i](1;3){... =$i= ...}
2051:
2052: @xdata0[]
2053: #$response:content-type[$.value[text/html] $.charset[windows-1251]]
2054: $xdoc[^xdoc::set{<?xml version="1.0" encoding="windows-1251"?>
2055: <!--DOCTYPE people SYSTEM "D:\Y\parser3project\parser3\src\www\htdocs\people.dtd"-->
2056: <people>
2057: <man id="1" имя="word слово">
2058: <name>P«^;AF B</name>
2059: </man>
2060: <man id="2">
2061: <name>ПИФ^taint[&]</name>
2062: </man>
2063: </people>
2064: }]
2065:
2066: @xdata[]
2067: #$response:content-type[$.value[text/html] $.charset[windows-1251]]
2068: $xdoc[^xdoc::set{^process{<?xml version="1.0" encoding="windows-1251"?>
2069: <!--DOCTYPE people SYSTEM "D:\Y\parser3project\parser3\src\www\htdocs\people.dtd"-->
2070: <people>
2071: <man id="1" имя="word слово">
2072: <name>P«^;AF B</name>
2073: </man>
2074: <man id="2">
2075: <name>ПИФ^taint[&]</name>
2076: </man>
2077: </people>
2078: }}]
2079:
2080: @xml[]
2081: ^xdata[]
2082:
2083: ^show_xdoc2[$xdoc]<hr>
2084: #^show_xnode1[$xdoc]<hr>
2085: $people[^xdoc.select[*/man]]
2086: #^show1[]
2087: ^show_xnodes1[$people]<hr>
2088: #^people.0.owner.hren[]
2089:
2090: ^show_xnode1[^xdoc.selectSingle[*/man[2]/name];0;1]<hr>
2091:
2092: by id:
2093: ^show_xnode1[^xdoc.getElementById[1];0;1]
2094: <hr>
2095:
2096: @show1[array]
2097: ^for[i](0;^array._count[]-1){
2098: $x[$array.$i]
2099: $x.firstChild.nodeValue:
2100: $pattributes[$x.parentNode.attributes]
2101: ^if(^pattributes._count[]){
2102: $pattributes.id.name=$pattributes.id.nodeValue
2103: }
2104: <br>
2105: }
2106:
2107: @show_xnodes1[array][i]
2108: ^for[i](0;^array._count[]-1){
2109: ^show_xnode1[$array.$i;0;1]
2110: }
2111:
2112: @show_xnode1[x;level;single][l]
2113: ^if(def $x){
2114: ^for[l](0;$level-1){ ^; ^; ^; ^;}
2115: ^if($x.nodeType == $xnode:ELEMENT_NODE){
2116: <^;$x.nodeName
2117: $pairs[$x.attributes]
2118: ^if(def $pairs){
2119: $names[^pairs._keys[]]
2120: ^names.menu{ $names.key="$pairs.[$names.key].nodeValue"}
2121: }
2122: >^;
2123: }{
2124: [$x.nodeType]
2125: }
2126:
2127: ^if(def $x.nodeValue){$x.nodeValue}<br>
2128: ^show_xnode1[$x.firstChild]($level+1)
2129: ^if(!$single){
2130: ^show_xnode1[$x.nextSibling]($level)
2131: }
2132:
2133: ^if($x.nodeType == $xnode:ELEMENT_NODE){
2134: ^for[l](0;$level-1){ ^; ^; ^; ^;}<^;/$x.nodeName>^;<br>
2135: }
2136: }
2137:
2138: @show_xdoc2[xdoc]
2139: ^xdoc.save[out/save.xml;
2140: # $.encoding[utf-8]
2141: $.method[xml]
2142: ]
2143: $file[^xdoc.file[
2144: $.encoding[utf-8]
2145: $.method[html]
2146: ]]
2147: ^file.save[text;out/save_file.html]
2148: #$response:body[^xdoc.file[ $.media-type[text/paf] ]]
2149: <pre>^taint[html][^xdoc.string[
2150: $.method[html]
2151: # $.encoding[utF-8]
2152: # $.omit-xml-declaration[yes]
2153: # $.standalone[no]
2154: # -$.doctype-public[-//W3C//DTD XHTML]
2155: # -$.doctype-system[/a/b/c/]
2156: # $.indent[yes]
2157: # $.media-type[text/paf]
2158: ]]
2159: </pre>
E-mail: