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