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