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