Annotation of parser3/www/htdocs/index.html, revision 1.52
1.42 paf 1: @USE
2: t.p
1.15 paf 3:
4: @autoz[]
5: $request:charset[windows-1251]
6: $response:charset[windows-1251]
7: $response:content-type[$.value[text/html]$.charset[$response:charset]]
8:
1.51 paf 9: @postprocess[body]
10: $body
11: <hr>
12: OK
1.37 paf 13:
1.15 paf 14: @main[]
1.51 paf 15: #^sqldefaults[]
1.49 paf 16: #^eval(2)
1.48 paf 17: #^tcrashlocaljunctionsv2[]
1.49 paf 18: #^tcrashlocaljunctions[]
1.50 paf 19: #^tjunctions[]
1.47 paf 20: #^replacetest[]
1.48 paf 21: #^matchoptionpp[]
1.46 paf 22: #^txdocxnodechild[]
1.44 paf 23: #^tclasses[]
1.43 paf 24: #$math:PI
25: #^b:method[]
1.42 paf 26: #^main[]
1.41 paf 27: #^errort[]
1.44 paf 28: #^tselectNumber[]
1.39 paf 29: #$result[hello]
1.36 paf 30: #^invaliddate2[]
31: #^process2[]
32: #^casehashtext[]
1.35 paf 33: #^subjvaltest[]
34: #^tableselect0[]
1.34 paf 35: #^memnotest1[]
1.33 paf 36: #^transparams[]
1.32 paf 37: #^voidparams[]
1.31 paf 38: #^rolls2[]
1.30 paf 39: #^cacheexpireschanging[]
1.29 paf 40: #^cacheexpiresfixed[]
41: #^dateoffsets[]
42: #^exceptionTypes[]
1.28 paf 43: #^roll2[]
1.27 paf 44: #^rolls[]
1.25 paf 45: #^exceptions1[]
1.22 paf 46: #^locate_by_expr[]
1.18 paf 47: #^method_junction_params{...}
1.17 paf 48: #^verifyCookie[paf]
1.37 paf 49: #^execlangs[]
1.16 paf 50: #$t[^tobjeresult[]]$t.a
51: #^xmlprobs[]
1.15 paf 52: #^doubleprobs[]
53: #^math:random(-10)
54: #^divnamestop[]
55: #^arrayclone[]
56: #^operator_tricks[]
57: #^xoutputrusattr[]
58: #^xdocset1[]
59: #^regexp3[]
60: #^exec2[]
61: #^tlock[]
62: #^xmloutattrwithoutvalue[]
63: #^precisionProblem[]
64: #^xpath[]
65: #^ttablesetlang[]
66: #^mail3[]
67: #^ttime[]
68: #^tupper[]
69: #^treplace[]
70: #^xslt2[]
71: #^tcache2[]
72: #$ORIGINS(1)
73: #$t[^table::set{a b} ^table::set{c d}]
74: #^ttaintuntaint[]
75: #^tappend2[]
76: #^badvsnprintf[]
77: #^badoracequoting[]
78: #^badconstructors[]
79: #^xloadwrongtable[]
80: #^xsetwrongtable[]
81: #^if($form:test){y}{n}
82: #^tablecolumnerror[]
83: #^roll[]
84: #^cookie2[]
85: #^tableset[]
86: #^math:PI.format{%.30f}
87: #^xchildren[]
88: #^thashforeach3[]
89: #^thashforeach2[]
90: #^thashforeach[]
91: #^thashdelete[]
92: #^connect[mysql://user:pass@cd.rinet.ru/db]{^void:sql{z} }
93: #^tappend[]
94: #^sappend[]
95: #^eval(10\3)<br>
96: #^tform[]
97: #^formattest[]
98: #^filelist[]
99: #^connect[mysql://user:pass@host]{ }
100: #^безнадёжна_попытка_поправить_непоправимое[]
101: #^tcache[]
102: #^thashfileexp[]
103: #^tcounter[]
104: #^tablehash[]
105: #j^hashfile[]
106: #^formclass[]
107: #^hren[]
108: #^domedit[]
109: #^domxslt[]
110: #^lsplit2[]
111: #^faceesize[]
112: #^imageresize[]
113: #^ifassignhash[]
114: #^tintdefault[]
115: #$response:status[404]
116: #^ifpasshash[]
117: #^movedir[]
118: #^replace[]
119: #^set[]
120: #^hash[]<hr>
121: #$t[^methresult[]] ->$t
122: #^terror[]
123: #^ssave[]
124: #^calendar[]
125: #^thash[]
126: #^tdef[]
127: #^ford[]
128: #^tif[]
129: #^image[]
130: #^mail2[]
131: #^cookie[]
132: #^response[]
133: #^regexp2[]
134: #^ttablerem[]
135: #^pcre[]
136: #^regexp[]<hr>
137: #^mail[]
138: #^exec[]
139: #^fori[]
140: #^tconnect[]
141: #^xslt[]
142: #^xml[]
143: #^header[]
1.51 paf 144: ^tablehasht[]
145:
1.52 ! paf 146:
! 147: @method[hash]
! 148: $hash.key
! 149: @mainZ[]
! 150: ^method[
! 151: $.key{code}
! 152: ]
! 153:
1.51 paf 154: @tablehasht[]
155: $t[^table::create{p
156: 1
157: 3
158: 2
159: 4}]
160:
161: $h[^t.hash[p]]
162:
163: =^h._count[]=
164:
165:
166: @sqldefaults[]
167: ^connect[mysql://mdm:4b833ljq@db-mysql/mdm]{
168: ^int:sql{select news_id from news where news_id=-1}[$.default{2}]<br>
169: ^string:sql{select news_id from news where news_id=-1}[$.default{2}]
170: }
1.48 paf 171:
172: @tcrashlocaljunctionsv2[]
173: $a[
174: $b{ $c[1] }
175: ]
176: $b
177: $c
178:
179: @tcrashlocaljunctions[]
180: $var[aaa]
181: ^if(1){
182: ^tcrashlocaljunctions1[]
183: }
184:
185: $j
186:
1.49 paf 187: @tcrashlocaljunctions1[][var]
188: $var[varvalue]
1.48 paf 189: $j{
190: $var
191: }
1.49 paf 192: $j
1.48 paf 193:
194: @tjunctions[][tl]
195: $t[^t::create[]]
196: ^tjunctionsi[]
197:
198: @tjunctionsi[][tl]
199: $tl[12345]
200: ^t.tjunctionsm[
201: $.key{
202: $tl
203: }
204: ]
1.46 paf 205:
1.47 paf 206: @replacetest[]
207: $b[b]
208: $s[
209: aaaaaaaaaa${b}aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
210: aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa${b}aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
211: ]
212: ^s.replace[^table::create{from to
213: ba !_}]
214:
215:
1.46 paf 216: @matchoptionpp[]
1.47 paf 217: #$ORIGINS(1)
1.46 paf 218: $s[
219: aaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
1.47 paf 220: aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
221: aaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
222: aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
223: aaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
224: aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
225: aaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
226: aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
227: aaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
228: aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
1.46 paf 229: ]
230: ^s.match[b;g']{($match.prematch|$match.match|$match.postmatch)}
231:
1.44 paf 232:
233: @txdocxnodechild[]
234: $xdoc[^xdoc::set{<?xml version="1.0" encoding="windows-1251" ?><d/>}]
235: $xdoc.nodeName
236: ^xdoc.selectNumber[2*2]
1.45 paf 237: $xdoc:ELEMENT_NODE
1.44 paf 238:
239:
240: @tclasses[]
241: $t[^t::create[]]
242: ^t.method[]
243: <hr>
244: ^t.base_method[]
245:
1.40 paf 246:
247: @errort[]
1.42 paf 248: ^xdoc::create[a]
1.40 paf 249: #^throw[user;here;this]
250:
251: @tselectNumber[]
252: $d[^xdoc::set{<?xml version="1.0" encoding="windows-1251"?><d attr="привет" n="123"/>}]
253: ^d.selectString[string(d/@attr)]<br>
254: ^d.selectNumber[2*2]<br>
255: ^d.selectNumber[number(/d/@n)+1]<br>
256:
1.34 paf 257:
1.36 paf 258: @invaliddate2[]
259: $d[^date::create(1018946575/60/60)] ^d.sql-string[]
260:
261: @process2[]
262: ^^process{
263: ^process{
264: ^$a[^^if(0){^$.k[y]}{^$.k[^^hren[]n]}] ^$a.k
265: }
266: }
267:
1.35 paf 268: @casehashtext[]
269: $tt[1]
270: $tmp[
271: ^switch[$tt]{
272: ^case[1]{
273: $.aaa[123]
274: }
275: ^case[DEFAULT]{
276: $.bbb[456]
277: }
278: }
1.36 paf 279: shit!
1.35 paf 280: ]
1.36 paf 281: #$tmp
1.35 paf 282: $tmp.aaa
283:
284: @subjvaltest[]
285: $a12[val]
286: $b[12]
287: $a$b
288:
1.34 paf 289: @tableselect0[]
290: $person[^table::create{name height
291: paf 1.77
292: шохин 2.07
293: moko 1.77
294: }]
295: $nottoohigh[^person.select($person.height<2)]
296: ^nottoohigh.menu{$nottoohigh.name<br>}
1.32 paf 297:
298: @transparams[]
299: $idoc[^xdoc::create{<?xml version="1.0" ?><doc/>}]
300: $odoc[^idoc.transform[global.xsl;
301: $.param1['1']
302: $.param2['2']
303: ]]
304: <pre>^taint[^odoc.string[$.method[html]]]
305:
306: @memnotest1[]
307: ^for[i](0;4000){
308:
309: $xxxx[$i]
310: $xxxx
311:
312: }
313:
314: @memnotest1notes[]
315: одна итерация цикла:
316: [Mon Apr 8 20:12:02 2002] execution-------------------------|
1.35 paf 317: '469641+=28 wcodeframe -> 0 !optimize[3]''469669+=49 string от {} -> 0 optimize[3]'
1.32 paf 318: [Mon Apr 8 20:12:02 2002] 12:STRING__WRITE
319: [Mon Apr 8 20:12:02 2002] "|| "
320: [Mon Apr 8 20:12:02 2002] 12:WITH_ROOT
321: [Mon Apr 8 20:12:02 2002] 13:VALUE
322: [Mon Apr 8 20:12:02 2002] "xxxx" string
1.35 paf 323: [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 324: [Mon Apr 8 20:12:02 2002] 16:WITH_READ
325: [Mon Apr 8 20:12:02 2002] 17:VALUE
326: [Mon Apr 8 20:12:02 2002] "i" string
327: [Mon Apr 8 20:12:02 2002] 18:GET_ELEMENT
1.35 paf 328: [Mon Apr 8 20:12:02 2002] 17:WRITE_VALUE'469452+=40 MAX_NUMBER -> !~2 actual digits''469492+=49 -> 41 !'
329: [Mon Apr 8 20:12:02 2002] 16:REDUCE_EWPOOL'469541+=24 VString -> 0 optimize[5]'
1.32 paf 330: [Mon Apr 8 20:12:02 2002] 15:CONSTRUCT_VALUE
331: [Mon Apr 8 20:12:02 2002] 12:STRING__WRITE
332: [Mon Apr 8 20:12:02 2002] "| "
333: [Mon Apr 8 20:12:02 2002] 12:WITH_READ
334: [Mon Apr 8 20:12:02 2002] 13:VALUE
335: [Mon Apr 8 20:12:02 2002] "xxxx" string
336: [Mon Apr 8 20:12:02 2002] 14:GET_ELEMENT
337: [Mon Apr 8 20:12:02 2002] 13:WRITE_VALUE'469573+=41 string expand nothing for now'
338: [Mon Apr 8 20:12:02 2002] 12:STRING__WRITE
1.35 paf 339: [Mon Apr 8 20:12:02 2002] "||"'469617+=24 VString -> 0 !optimize[6]'
1.32 paf 340: [Mon Apr 8 20:12:02 2002] <-ja returned
341: [Mon Apr 8 20:12:02 2002] ja->
342:
343: 201/328=0.612804878049 %%optimized
344:
345: 1.
346: CREATE_*POOL
347: сделать
348: *POOL_POOLED+CODE
349: где
350: wwrapper
351: и(возможно) wcodeframe
352: +string
353: стековая переменная
354:
355: 2.
356: избавиться от обёртки при возврате результата process [см. тело _for]
357:
358: 3.
359: сделать callback для process, чтобы вынести invariants из _for & co.
360:
361: 4.
362: @todo склеить get_element и write_value (при вставлении? write_value)
363:
364: 5.
365: reduce_*pool -> вариант получить именно string, без VString обёртки [часто
366: обёртка сразу выбрасывается = не нужна]
367:
368: 6.
369: process вариант получить именно string, без VString обёртки [часто обёртка
370: сразу выбрасывается = не нужна]
371:
372: 7.
373: string head, убить 8 байт неправильной link
1.31 paf 374:
375: @voidparams[]
376: ^voidparamsm[$form:field]
377:
378: @voidparamsm[p]
379: ^p.int(123)
1.29 paf 380:
1.30 paf 381: @rolls2[]
382: $now[^date::now[]]
383: $d[^date::create($now.year;$now.month)] ^d.sql-string[]<br>
384: ^for[i](1;12){
385: ^d.roll[month](-1) ^d.sql-string[]<br>
386: }
387:
1.29 paf 388: @cacheexpireschanging[]
389: ^cache[$DB_HOME/keyключ][^date::now(+1)]{ ^rem{1 day}
390: ^cache[^date::now(+4/24/60/60)]
391: # ^cache(2)
1.30 paf 392: # ^cache(0)
1.29 paf 393: ^math:random(100)
394: }
395:
396:
397:
398: @cacheexpiresfixed[]
399: ^cache[$DB_HOME/keyключ][^date::now(+2/24/60/60)]{
400: ^math:random(100)
401: }
402:
403: @dateoffsets[]
404: $d[^date::create(^date::now[]+1/24/60)]
405: #$d[^date::now(+1/24/60)]
406: ^d.sql-string[]
407: #$d
1.26 paf 408:
1.28 paf 409: @exceptionTypes[]
410: # parser.compile ^test[} компиляция (непарная скобка, ...)
411: # parser.runtime ^if(0). параметры (больше/меньше, чем нужно, не тех типов, ...)
412: # number.zerodivision ^eval(1/0) ^eval(1%0)
413: # number.format ^eval(abc*5)
414: # file.missing ^file:delete[delme] not found
415: # file.access ^table::load[.] no rights
416: # image.format ^image::measure[index.html] not gif/jpg
417: # sql.connect ^connect[mysql://baduser:pass@host/db]{} not found/timeout
418: # sql.execute ^connect[mysql://okuser:pass@host/db]{^void:sql{select bad}} syntax error
419: # xml ^xdoc::create{<forgot?>} any error in xml/xslt libs
420: # smtp.connect not found/timeout
421: # smtp.execute communication error
422:
1.26 paf 423: @roll2[]
424: $d[^date::create(2002;4;2;2;2;3)] ^d.sql-string[]<br>
1.27 paf 425: ^d.roll[day](+365*3+1) ^d.sql-string[]<br>
1.26 paf 426:
1.25 paf 427:
428: @rolls[]
429: $d[^date::create(2002;4;4)]
430: ^d.sql-string[]<br>
431: ^for[i](1;7){
432: ^d.roll[day](-1)
433: ^d.sql-string[]<br>
434: }
435: <hr>
436: $d[^date::create(2002;3;28)]
437: ^d.sql-string[]<br>
438: ^for[i](1;7){
439: ^d.roll[day](+1)
440: ^d.sql-string[]<br>
441: }
442: <hr>
443: $d[^date::create(2002;12;3)]
444: ^d.sql-string[]<br>
445: ^for[i](1;14){
446: ^d.roll[day](-1)
447: ^d.sql-string[]<br>
448: }
449: <hr>
450: $d[^date::create(2002;10;19)]
451: ^d.sql-string[]<br>
452: ^for[i](1;14){
453: ^d.roll[day](+1)
454: ^d.sql-string[]<br>
455: }
456:
457:
458:
459:
460:
1.22 paf 461:
462: @exceptions1[]
463: ^try{
464: aaa
1.24 paf 465: ^throw[custom1;paf;is stupid]
1.22 paf 466: }{
1.24 paf 467: ^if($exception.type eq custom1){
1.28 paf 468: # $exception.handled(1)
469: ^throw[$exception]
1.24 paf 470: type=$exception.type<br>
471: source=$exception.source<br>
472: file=$exception.file<br>
473: lineno=$exception.lineno<br>
474: comment=$exception.comment<br>
475: }
1.22 paf 476: }
1.21 paf 477:
478: @locate_by_expr[]
479: $t[^table::create{a b
480: 1 nok
481: 2 ok
482: 3 nok
483: }]
484: ^if(^t.locate($t.a==2)){$t.b}{n}
1.17 paf 485:
486: @method_junction_params[param]
487: ^if($param is junction){junction}{ne junction}
488:
489: @verifyCookie[value]
490: ^if($cookie:dummyvote eq $value){
491: $result(1)
492: }{
493: $cookie:dummyvote[$value]
494: $result(0)
495: }
1.16 paf 496:
497: @execlangs[]
1.20 paf 498: $f[^file::exec[test.pl]]
1.36 paf 499: err:$f.stderr<br>
1.16 paf 500: ^process{$f.text}
501: #$c[^t.columns[]]
502: #^c.menu{
503: #* $c.column<br>
504: #}
1.36 paf 505: c:$t.c<br>
1.16 paf 506:
507: @tobjeresult[]
508: ^table::create{a
509: 12}
1.15 paf 510:
511: @xmlprobs[]
512: $xmlDataType[^xdoc::load[program.xml]]
513: #<pre>^taint[^xmlDataType.string[]]
514: $xmlDataTypes[^xmlDataType.select[programs/program[@id=4]/data]]
515: #=^xmlDataTypes._count[]=
516: =^xmlDataTypes.0.getAttribute[type-id]=
517:
518: @doubleprobs[]
519: $1(^math:radians(180))
520: $2($math:PI)
521: ^if(^1.format[%.10f]==^2.format[%.10f]){y;n}
522: ^if($1==$2){y;n}
523: ^if(^math:radians(180)==$math:PI){y;n}
524:
525:
526: @divnamestop[]
527: $a(10)
528: ^eval($a\3)
529:
530: @arrayclone[]
531: $t[^table::create{a b
532: 1 11
533: 2 22
534: }]
535: $c[^table::create[$t]]
536: ^c.append{2 33}
537: ^t.count[]
538: ^c.count[]
539:
540: @operator_tricks[]
541: ^if(1){$a[^t[]]}
542: $a!
543: $a($b)
544: ^if(1){y}{n}
545: $MAIN:a(^t[] eq OK)
546: #$MAIN:a(1)
547: ^if($a){y}{n}
548: #^if(1){y}{n}
549: $form:if
550: $a[$.n[1]]
551: $a.if
552:
553: @xoutputrusattr[]
554: $d[^xdoc::set{<?xml version="1.0" encoding="windows-1251"?><d attr="привет"/>}]
555: ^show_xdoc2[$d]
556:
557: @xdocset1[]
558: $d[^xdoc::set{<?xml version="1.0"?><d>=^taint[&]=</d>}]
559: ^show_xdoc2[$d]
560:
561: @regexp3[]
562: $s[abcАБВ]
563: ^if(^s.match[][i]){y}{n}
564:
565:
566: @exec2[]
567: $a[^file::exec[bin/t.cmd]]
568: <pre>^taint[$a.text]</pre>|$a.status|$a.stderr<hr>
569:
570:
571: @tlock[]
572: ^file:lock[lockfile]{
573: code
574: }
575:
576: @xmloutattrwithoutvalue[]
577: #$ORIGINS(1)
578: $doc[^xdoc::set{<?xml version="1.0"?><doc background="">zz</doc>}]
579: $doc[^doc.transform[global.xsl]]
580: =^taint[html][^doc.string[$.method[html]]]=
581:
582:
583:
584: @precisionProblem[]
585: $a[123456789012345678901234567890]
586: $b(^a.double[])
587: ^b.format{%.20E}
588: <hr>
589: ^eval(2*2)
590:
591: @xpath[]
592: $xdoc[^xdoc::set{<?xml version="1.0" encoding="windows-1251" ?>
593: <document><block><p>привет</p></block></document>
594: }]
595: #^show_xdoc2[$xdoc]
596: $node[^xdoc.selectSingle[/document/block/p]]
597: ^if(def $node){
598: ^if($node is string){
599: $node
600: }{
601: ^if($node is hash){
602: ^node._count[]
603: }{
604: $node.nodeType
605: }
606: }
607: #$node.firstChild.nodeValue
608: }{
609: node not found
610: }
611:
612:
613: @ttablesetlang[]
614: $a-tab-b[a b
615: 1 2]
616:
617: $t[^table::set{$a-tab-b}]
618: =$t.a=
619: <hr>
620:
621: $t[^table::set[nameless]{^taint[$a-tab-b]}]
622: =$t.0=
623: <hr>
624:
625: $t[^table::set{^untaint{^taint[$a-tab-b]}}]
626: =$t.a=
627:
628: #^t.append{1 2}
629:
630: @mail3[]
631: ^mail:send[
632: $.from[Александр Петросян <paf@design.ru>]
633: $.to[Александр Петросян <paf@design.ru>]
634: $.subject[проверка4]
635: $.body[
636: $.text[
637: $.content-type[$.value[text/plain] $.charset[windows-1251]]
638: $.body[проверка]
639: ]
640: $.attachment[
641: $.value[^file::load[text;index.html]]
642: $.file-name[привет всем.html]
643: ]
644: ]
645: ]
646:
647:
648: @ttime[]
649: $now[^date::now[]]
650: $now.hour:$now.minute
651:
652: @tupper[]
653: $t[abcABCабвАБВ]
654: $t<br>
655: ^t.upper[]
656:
657: @treplace[]
658: $copy-paste-clean[^table::set{a b
659: . _
660: , _
661: + _
662: & _
663: ? _
664: = _}]
665:
666: $cache_key[^taint[в.а,с+я]&был?тут=недавно.cache]
667: # почему-то этот replace роняет апач в 500 ошибку :(
668: #^cache_key.replace[$copy-paste-clean]
669: $test[abc]
670: ^test.save[$cache_key]saved<br>
671: $cache[^file:list[.;\.cache^$]]
672: ^file:delete[$cache_key]deleted($cache.name)<br>
673:
674:
675:
676: @xslt2[]
677: $xdoc[^xdoc::set{<?xml version="1.0" encoding="windows-1251" ?>
678: <document><block><p>привет</p></block></document>
679: }]
680: ^show_xdoc2[$xdoc]
681: ^show_xdoc2[^xdoc.transform[templates/_document.xslt]]
682: <hr>
683:
684:
685: @tcache2[]
686: ^cache[$DB_HOME/keyключ](2){
687: ^math:random(100)
688: }
689:
690: @ttaintuntaint[]
691: <!-- некий панковский заголовок с буковкой C в круглых скобках -->^taint[html][
692:
693: ]zz
694: <hr>
695: ^untaint[html]{1^taint[ ]2 3}
696:
697:
698: @tappend2[]
699: $t[^table::set{a b}]^t.append{1 2}$t.a
700:
701: @badvsnprintf[]
702: ^connect[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz]{
703: }
704:
705:
706: @badoracequoting[]
707: $SQL.connect-string[oracle://webspb:webpwd@mts?NLS_LANG=RUSSIAN_AMERICA.CL8MSWIN1251&NLS_DATE_FORMAT=YYYY-MM-DD HH24:MI:SS]
708: ^connect[$SQL.connect-string]{
709: ^void:sql{delete from paf}
710: ^void:sql{insert into paf values (1, '$form:text')}
711: $paf[^table::sql{select * from paf}]
712: ^paf.menu{
713: $paf.id: ^untaint{$paf.block}<hr>
714:
715: }
716: <hr>
717:
718:
719: ^rem{
720: $news[^table::sql{select description from news}[$.limit(3)]]
721: ^news.menu{
722: ^untaint{$news.description}<hr>
723:
724: }
725: <hr>
726: }
727:
728: $tables[^table::sql{select table_name from user_tables}]
729: ^tables.menu{
730: $tables.table_name<br>
731: }
732:
733: }
734: <hr>
735: $env:PATH
736:
737: @badconstructors[]
738: $bred[^string::length[]]
739: $bred[^response::clear[]]
740: $bred[^int::int[]]
741:
742:
743: @xloadwrongtable[]
744: $constr[^xdoc::load[wrongtable.xml]]
745: ^show_xdoc2[$constr]
746:
747: @xsetwrongtable[]
748: $constr[^xdoc::set{<?xml version="1.0" encoding="windows-1251z" ?>
749: <block-list>^untaint[as-is]{$constructor}</block-list>}]
750:
751:
752: @tablecolumnerror[]
753: $t[^table::set{a}]
754: $t.$a
755:
756: @roll[]
757: #$date[^date::set(1970;1;2)]
758: #^date.roll[month](-1)
759: $date[^date::set(2038;1;1)]
760: ^date.roll[month](+1)
761: $date.year $date.month $date.day
762:
763: @cookie2[]
764: #=$cookie:clientType[$.value[test]]=<br>
765: =$cookie:clientType=<br>
766:
767:
768: @tableset[]
769: $a[^table::set{a
770: 1
771: 2}]
772: ^eval(100\$a)
773:
774:
775:
776: @zzz[]
777:
778:
779: $constructor[
780: <block1 name="main_srvr" type="0" label="Основное тело" />
781: <block2 name="main_srvr2" type="0" label="Основное тело" />
782: ]
783:
784: $constr[^xdoc::set{<?xml version="1.0" encoding="windows-1251" ?>
785: <block-list>^untaint[as-is]{$constructor}</block-list>}]
786:
787: $children[$constr.documentElement.childNodes]
788: ^if($children){
789: ^for[i](1;^children._count[]){
790: $node[$children.$i]
791: $node.nodeName<br>
792: }
793: }
794:
795:
796: @thashforeach3[]
797: $h[
798: $.a[1]
799: $.b[2]
800: ]
801: $c[^table::set{a
802: ^h.foreach[key;value]{$value
803: }}]
804: $c.a
805:
806: @thashforeach2[]
807: $h[
808: $.a[1]
809: $.b[2]
810: ]
811: $c[
812: ^h.foreach[key;value]{
813: $.$key[$value]
814: }
815: ]
816: $c.b
817:
818: @thashforeach[]
819: $h[
820: $.a[1]
821: $.b[2]
822: ]
823: ^h.foreach[key;value]{
824: $key=$value<br>
825: }
826:
827: @thashdelete[]
828: $h[$.a[1] $.b[2]]
829: was:<br>
830: count=^h._count[] <br>
831: b='$h.b' <br>
832:
833: ^h.delete[b]
834:
835: now:<br>
836: count=^h._count[] <br>
837: b='$h.b'
838:
839: @sappend[]
840: $test[123]
841: ^test.save[test]
842: ^test.save[append;test]
843:
844: @tappend[]
845: $test[^table::set{a b
846: a1 b1}]
847: ^test.save[test]
848: $test[^table::set{a b
849: a2 b2}]
850: ^test.save[append;test]
851:
852:
853: @tform[]
854: ^if(def $form:new_file){y}{n}
855: <form method="post" enctype="multipart/form-data">
856: <input type="file" name="new_file" />
857: <input type=submit>
858: </input>
859:
860: @formattest[]
861: $size(15.124)
862:
863: ^size.format{%.2f}
864:
865: @filelist[]
866: $html[^file:list[.;\.html^$]]
867: ^html.menu{
868: $html.name<br>
869: }
870: <hr>
871:
872: @безнадёжна_попытка_поправить_непоправимое[]
873: $dom_from_disk[^xdoc::load[input.xml]]
874: $dom_created_in_air[^xdoc::create[doc]]
875: ^dom_created_in_air.documentElement.appendChild[^dom_from_disk.documentElement.cloneNode(1)]
876: ^show_xdoc2[$dom_created_in_air]
877:
878:
879: @tcache[]
880: #^hashfile:clear[cache]
881: $code[^hashfile::open[$DB_HOME;cache]]
882: ^code.cache[key](2){
883: ^math:random(100)
884: # ^code.delete[]
885: }
886:
887: @thashfileexp[]
888: $hf[^hashfile::open[$DB_HOME;hashfile]]
889: $hf.paf[$.value[крут] $.expires(3)]
890: paf=$hf.paf
891: <hr>
892: ^hf.foreach[key;value]{
893: $key=$value<br>
894: }
895: <hr>
896: $hash[^hf.hash[]]
897: =$hash.paf=
898: <hr>
899:
900: @tcounter[]
901: ^tcounterone[$DB_HOME]
902: other root:
903: ^tcounterone[${DB_HOME}2]
904: again, first:
905: ^tcounterone[$DB_HOME]
906:
907: @tcounterone[DB_HOME]
908: $counter[^hashfile::open[$DB_HOME;counter]]
909: #^counter.clear[]
910: ^counter.transaction{
911: # $counter.value(10)
912: $counter.value($counter.value+1)
913: # ^counter.delete[value]
914: $counter.value
915: }
916: <hr>
917: ^rem{
918: $hash[^counter.hash[]]
919: =$hash.value=
920: <hr>
921: }
922:
923: @tablehash[]
924: $productList[^table::set{id name
925: 1 носки
926: 2 валенки
927: 3 ушанка
928: }]
929:
930: #скажем, у первого дилера
931: $firstPriceList[^table::set{id price
932: 1 0.3
933: 3 1000
934: }]
935:
936: $firstPriceHash[^firstPriceList.hash[id]]
937:
938: ^productList.menu{
939: продукт "$productList.name" | цена у first: $firstPriceHash.[$productList.id].price<br>
940: }
941:
942:
943: @hashfile[]
944: $hf[^hashfile::assign[hashfile]]
945: #$hf.paf[крут5]
946: paf=$hf.paf
947:
948: @formclass[]
949: ^$form:CLASS.a=$form:CLASS.a
950:
951: @domdata[]
952: ^if(1){
953: # $a{^hren[]}
954: }
955: $a
956: $xdoc[^xdoc::create[doc]]
957: $doc[$xdoc.documentElement]
958: $name[^doc.appendChild[^xdoc.createElement[name]]]
959: $text[^name.appendChild[^xdoc.createTextNode[петросян&coz]]]
960: ^untaint[as-is]{=$text.nodeValue=}
961:
962: @domedit[]
963: ^domdata[]
964: #$paf.nodeName<br>
965: #$doc.documentElement.nodeName<br>
966:
967: ^show_xnode1[$xdoc.documentElement;0;1]
968: <hr>
969: ^show_xdoc2[$xdoc]
970: <hr>
971:
972: @domxslt[]
973: ^domdata[]
974: ^show_xdoc2[^xdoc.transform[global.xsl;$.param1[123/]]]
975: <hr>
976:
977: @lsplit2[]
978: $path[/optics/]
979: $pathTable[^path.lsplit[/]]
980: ^pathTable.menu{
981: ^if(def $pathTable.piece){
982: =$pathTable.piece=
983: }
984: }
985:
986:
987: @faceesize[]
988: $k(2)
989: $pict[^image::load[paf.gif]]
990: $small[^image::create($pict.width/$k;$pict.height/$k)]
991: ^small.copy[$pict](0;0;$pict.width;$pict.height;0;0;$small.width;$small.height;250)
992: $response:body[^small.gif[]]
993:
994: @imageresize[]
995: $k(2)
996: $pict[^image::create(400*$k;200*$k)]
997: $pict.line-width(2)
998: ^pict.arc($pict.width/2;$pict.height/2;$pict.width-1;$pict.height-1;0;360;0x000000)
999: ^pict.arc($pict.width/2;$pict.height/2;$pict.width-20;$pict.height-20;0+20;360-20;0xff0000)
1000: #^pict.arc($pict.width/2;$pict.height/2;$pict.width;$pict.height;0;360;0xff0000)
1001: ^pict.circle($pict.width/2;$pict.height/2;$pict.height/2-20;0x0000ff)
1002: ^pict.arc($pict.width/2;$pict.height/2;$pict.height-26;$pict.height-26;0+20;360-20;0xff0000)
1003: $response:body[^pict.gif[]]
1004:
1005: #$small[^image::create($pict.width/$k;$pict.height/$k)]
1006: #^small.copy[$pict](0;0;$pict.width;$pict.height;0;0)
1007: #^small.copy[$pict](0;0;$pict.width;$pict.height;0;0;$small.width;$small.height;0)
1008:
1009: #$response:body[^small.gif[]]
1010:
1011:
1012: @tintdefault[]
1013: #$abc[abc]
1014: $abc[33]
1015: ^abc.int[z]
1016: #^abc.int(123)
1017:
1018: @ifassignhash[]
1019: $h[^if(1){$.a(1);$.a(2)}]
1020: $h.a
1021:
1022: @ifpasshash[]
1023: $a[$.e[a]]
1024: $b[$.e[b]]
1025: ^ifpasshashdest[^if(1){$a;$b}]
1026: #$x[^if(1){$a}{$b}]
1027: #^ifpasshashdest[$x]
1028:
1029: @ifpasshashdest[p]
1030: $p.e
1031:
1032: @movedir[]
1033: ^file:move[a;deeper/a]
1034:
1035: @replace[]
1036: $a[12^;3]
1037: ^a.replace[^table::set{from to
1038: 2^; !
1039: }]
1040:
1041:
1042: @set[]
1043: ^setdata[]
1044: ^a.add[$b]
1045: add:$a.3<br>
1046:
1047: ^setdata[]
1048: ^a.sub[$b]
1049: sub2:$a.2<br>
1050: sub1:$a.1<br>
1051:
1052: ^setdata[]
1053: $c[^a.union[$b]]
1054: union3:$c.3<br>
1055: union2:$c.2<br>
1056:
1057: ^setdata[]
1058: $c[^a.intersection[$b]]
1059: intersection3:$c.3<br>
1060: intersection2:$c.2<br>
1061:
1062: ^setdata[]
1063: intersects:^if(^a.intersects[$b]){y;n}<br>
1064: intersects2:^if(^a.intersects[ ]){y;n}<br>
1065:
1066:
1067: <hr>
1068:
1069: @setdata[]
1070: $a[$.1[a1] $.2[a2]]
1071: $b[ $.2[b2] $.3[b3]]
1072:
1073:
1074: @hash[]
1075: $h[^hash::create[$._default[123]]]
1076: $h.paf[not kretin]
1077: $h.paf<br>
1078: =$h.that=<br>
1079:
1080: @methresult[]
1081: $result[^table::set{1}]
1082:
1083: @terror[]
1084: ^error[method z must be called with z]
1085:
1086: @syntax1[]
1087: #^a[^b]
1088:
1089: @syntax2[]
1090: #^a[
1091:
1092: @ssave[]
1093: $abc[abc]
1094: ^abc.save[abc]
1095:
1096: @calendar[]
1097: 2001;11:<br>
1098: $week_days[^date:calendar[rus](2001;11)]
1099: <pre>
1100: ^week_days.menu{^for[wday](0;7){^if($week_days.$wday){$week_days.$wday; ^; ^;} }<br>}
1101: </pre>
1102:
1103: @thash[]
1104: $table[^table::set{id name age
1105: 1 paf 278
1106: 2 пиф 234
1107: }]
1108: $hash[^table.hash[id;^table::set[nameless]{id
1109: name}]]
1110: $hash.2.id $hash.2.name $hash.2.age
1111:
1112: @tdef[]
1113: $s[0]
1114: if 0=^if($s){}{n}<br>
1115: if def 0=^if(def $s){y}{}<br>
1116: <hr>
1117:
1118: @ford[]
1119: ^for[i](0;5){$i}{($i)}
1120:
1121: @tif[]
1122: ^if[def]{y;n}
1123:
1124: @image[]
1125: $pict[^image::create(400;200)]
1126: ^pict.arc($pict.width/2;$pict.height/2;$pict.width-1;$pict.height-1;0;360;0x000000)
1127: ^pict.arc($pict.width/2;$pict.height/2;$pict.width-10;$pict.height-10;0+10;360-10;0xff0000)
1128: #^pict.arc($pict.width/2;$pict.height/2;$pict.width;$pict.height;0;360;0xff0000)
1129: ^pict.circle($pict.width/2;$pict.height/2;$pict.height/2-10;0x0000ff)
1130: ^pict.arc($pict.width/2;$pict.height/2;$pict.height-26;$pict.height-26;0+10;360-10;0xff0000)
1131: $response:body[^pict.gif[]]
1132:
1133:
1134:
1135: @mail2[]
1136: ^mail:send[
1137: $.content-type[$.value[text/plain] $.charset[windows-1251]]
1138: $.from[Александр Петросян <paf@design.ru>]
1139: $.to[Александр Петросян <paf@design.ru>]
1140: $.subject[проверка]
1141: $.body[проверка]
1142: ]
1143:
1144: @cookie[]
1145: $env:HTTP_COOKIE<br>
1146:
1147: #$cookie:переменная[test тест ТЕСТ2]
1148: =$cookie:переменная=<br>
1149: #$cookie:переменная2[test тест ТЕСТ3]
1150: =$cookie:переменная2=<br>
1151: =$cookie:CLASS.переменная2=<br>
1152:
1153: @response[]
1154: #^if($form:reload){
1155: $response:refresh[$.value[0] $.url[./t.html?uri=$env:SERVER_NAME]]
1156: #}
1157:
1158: @xslt[]
1159: ^xdata[]
1160: $transformed[^xdoc.transform[global.xsl;$.param1[123/]]]
1161: ^show_xdoc2[$transformed]
1162:
1163: @regexp2[]
1164: $s[ select]
1165: $s[^s.match[^^\s*][]{!}]
1166: $s
1167:
1168: @header[]
1169: $response:refresh[
1170: $.value[0]
1171: $.url[http://design.ru?a=^taint[123]]
1172: ]
1173:
1174: @ttablerem[]
1175: $table[^table::load[a.cfg]]
1176: ^table.menu{$table.a}
1177:
1178: @tconnect[]
1179: ^connect[mysql://test:test@paf/test?charset=cp1251_koi8&compress=1&timeout=1&named_pipe=1]{
1180: $tables[^table::sql{show tables}]
1181: #$cols[^tables.columns[]]
1182: #$cols.column
1183: ^tables.menu{
1184: $tables.[Tables_in_test]<br>
1185: }
1186: }
1187:
1188: @pcre[]
1189: $s[1 2]
1190: ^s.match[\s;ig]{!}
1191: #^s.match[\d;ig]{!}
1192:
1193:
1194: @regexp[]
1195: $s[abcАБВ]
1196: ^if(^s.match[б][i]){y}{n}
1197:
1198: @mail[]
1199: #$ORIGINS(1)
1200: ^mail:send[
1201: $.from[paf@design.ru]
1202: $.to[paf@design.ru]
1203: $.body[1
1204:
1205: 2
1206:
1207:
1208: 3]
1209: ]
1210:
1211: @exec[]
1212: $a[^file::exec[fc.exe;;a;b]]
1213: $a.status|$a.stderr<hr>
1214:
1215: @fori[][i]
1216: ^for[i](1;3){... =$i= ...}
1217:
1218: @xdata0[]
1219: #$response:content-type[$.value[text/html] $.charset[windows-1251]]
1220: $xdoc[^xdoc::set{<?xml version="1.0" encoding="windows-1251"?>
1221: <!--DOCTYPE people SYSTEM "D:\Y\parser3project\parser3\src\www\htdocs\people.dtd"-->
1222: <people>
1223: <man id="1" имя="word слово">
1224: <name>P«^;AF B</name>
1225: </man>
1226: <man id="2">
1227: <name>ПИФ^taint[&]</name>
1228: </man>
1229: </people>
1230: }]
1231:
1232: @xdata[]
1233: #$response:content-type[$.value[text/html] $.charset[windows-1251]]
1234: $xdoc[^xdoc::set{^process{<?xml version="1.0" encoding="windows-1251"?>
1235: <!--DOCTYPE people SYSTEM "D:\Y\parser3project\parser3\src\www\htdocs\people.dtd"-->
1236: <people>
1237: <man id="1" имя="word слово">
1238: <name>P«^;AF B</name>
1239: </man>
1240: <man id="2">
1241: <name>ПИФ^taint[&]</name>
1242: </man>
1243: </people>
1244: }}]
1245:
1246: @xml[]
1247: ^xdata[]
1248:
1249: ^show_xdoc2[$xdoc]<hr>
1250: #^show_xnode1[$xdoc]<hr>
1251: $people[^xdoc.select[*/man]]
1252: #^show1[]
1253: ^show_xnodes1[$people]<hr>
1254: #^people.0.owner.hren[]
1255:
1256: ^show_xnode1[^xdoc.selectSingle[*/man[2]/name];0;1]<hr>
1257:
1258: by id:
1259: ^show_xnode1[^xdoc.getElementById[1];0;1]
1260: <hr>
1261:
1262: @show1[array]
1263: ^for[i](0;^array._count[]-1){
1264: $x[$array.$i]
1265: $x.firstChild.nodeValue:
1266: $pattributes[$x.parentNode.attributes]
1267: ^if(^pattributes._count[]){
1268: $pattributes.id.name=$pattributes.id.nodeValue
1269: }
1270: <br>
1271: }
1272:
1273: @show_xnodes1[array][i]
1274: ^for[i](0;^array._count[]-1){
1275: ^show_xnode1[$array.$i;0;1]
1276: }
1277:
1278: @show_xnode1[x;level;single][l]
1279: ^if(def $x){
1280: ^for[l](0;$level-1){ ^; ^; ^; ^;}
1281: ^if($x.nodeType == $xnode:ELEMENT_NODE){
1282: <^;$x.nodeName
1283: $pairs[$x.attributes]
1284: ^if(def $pairs){
1285: $names[^pairs._keys[]]
1286: ^names.menu{ $names.key="$pairs.[$names.key].nodeValue"}
1287: }
1288: >^;
1289: }{
1290: [$x.nodeType]
1291: }
1292:
1293: ^if(def $x.nodeValue){$x.nodeValue}<br>
1294: ^show_xnode1[$x.firstChild]($level+1)
1295: ^if(!$single){
1296: ^show_xnode1[$x.nextSibling]($level)
1297: }
1298:
1299: ^if($x.nodeType == $xnode:ELEMENT_NODE){
1300: ^for[l](0;$level-1){ ^; ^; ^; ^;}<^;/$x.nodeName>^;<br>
1301: }
1302: }
1303:
1304: @show_xdoc2[xdoc]
1305: ^xdoc.save[out/save.xml;
1306: # $.encoding[utf-8]
1307: $.method[xml]
1308: ]
1309: $file[^xdoc.file[
1310: $.encoding[utf-8]
1311: $.method[html]
1312: ]]
1313: ^file.save[text;out/save_file.html]
1314: #$response:body[^xdoc.file[ $.media-type[text/paf] ]]
1315: <pre>^taint[html][^xdoc.string[
1316: $.method[html]
1317: # $.encoding[utF-8]
1318: # $.omit-xml-declaration[yes]
1319: # $.standalone[no]
1320: # -$.doctype-public[-//W3C//DTD XHTML]
1321: # -$.doctype-system[/a/b/c/]
1322: # $.indent[yes]
1323: # $.media-type[text/paf]
1324: ]]
1325: </pre>
E-mail: