|
version 1.34, 2002/04/23 10:30:03
|
version 1.52, 2002/06/24 19:11:43
|
|
Line 283 odbc c:\drives\y\parser3project\odbc\
|
Line 283 odbc c:\drives\y\parser3project\odbc\
|
| !^table::load[[nameless;]путь] |
!^table::load[[nameless;]путь] |
| !если не nameless, названия колонок берутся из первой строки |
!если не nameless, названия колонок берутся из первой строки |
| !пустые строки, и строки в первой колонке содержащие '#', игнорируются |
!пустые строки, и строки в первой колонке содержащие '#', игнорируются |
| !^table::sql{query}[[$.limit(2) $.offset(4)]] |
!^table::sql{query}[[$.limit(2) $.offset(4) todo:$.default{ ^table::create[...] }]] |
| !^таблица.save[[nameless|append;]путь] |
!^таблица.save[[nameless|append;]путь] |
| !$таблица.поле |
!$таблица.поле |
| !$таблица.fields+ из named таблицы выдаёт текущую запись как Hash |
!$таблица.fields+ из named таблицы выдаёт текущую запись как Hash |
|
Line 311 odbc c:\drives\y\parser3project\odbc\
|
Line 311 odbc c:\drives\y\parser3project\odbc\
|
| !^таблица.columns[]+ таблица из одного столбца $column |
!^таблица.columns[]+ таблица из одного столбца $column |
| !$отобранное[^таблица.select(выражение)] = таблица из тех же столбцов и строк, у которых условие совпало |
!$отобранное[^таблица.select(выражение)] = таблица из тех же столбцов и строк, у которых условие совпало |
| $adults[^man.select($man.age>=18)] |
$adults[^man.select($man.age>=18)] |
| |
^таблица.color[цвет1;цвет2] |
| |
|
| |
|
| !hash |
!hash |
|
Line 331 odbc c:\drives\y\parser3project\odbc\
|
Line 331 odbc c:\drives\y\parser3project\odbc\
|
| !^a.intersection[b] = пересечение |
!^a.intersection[b] = пересечение |
| значения a |
значения a |
| !^a.intersects[b] = bool |
!^a.intersects[b] = bool |
| !^hash::sql{запрос}[[$.limit(2) $.offset(4)]] |
!^hash::sql{запрос}[[$.limit(2) $.offset(4) todo:$.default{$.field[]...}]] |
| получается hash(ключи=значения первая колонка ответа) |
получается hash(ключи=значения первая колонка ответа) |
| of hash(ключи=названия остальных колонкок ответа) |
of hash(ключи=названия остальных колонкок ответа) |
| !^hash._keys[]+ таблица из одного столбца $key |
!^hash._keys[]+ таблица из одного столбца $key |
|
Line 414 Xhashfile
|
Line 414 Xhashfile
|
| ^code.cache[заголовки новостей](35){....} |
^code.cache[заголовки новостей](35){....} |
| |
|
| !mail |
!mail |
| |
!$mail.received=MESSAGE: |
| |
.from |
| |
.reply-to |
| |
.subject |
| |
.date класса date |
| |
.message-id |
| |
.raw[ |
| |
.СЫРОЕ_ПОЛЬЗОВАТЕЛЬСКОЕ-ПОЛЕ-ЗАГОЛОВКА |
| |
] |
| |
$.{text|html|file#}[ << нумеруется как и в mail:send (text, text2, ...) (file, file2, ...) |
| |
$.content-type[ |
| |
$.value[{text|...|x-unknown}/{plain|html|...|x-unknown}] |
| |
[$.charset[windows-1251]] << в каком пришло, сейчас уже перекодировано |
| |
$.ПОЛЬЗОВАТЕЛЬСКИЙ-ПАРАМЕТР-ЗАГОЛОВКА |
| |
] |
| |
$.description |
| |
$.content-id |
| |
$.content-md5 |
| |
$.content-location |
| |
.raw[ |
| |
.СЫРОЕ_ПОЛЬЗОВАТЕЛЬСКОЕ-ПОЛЕ-ЗАГОЛОВКА |
| |
] |
| |
$.value[строка|FILE] |
| |
] |
| |
$.message#[MESSAGE] (message, message2, ...) |
| |
|
| |
!^mail:send[ |
| |
$.charset[кодировка заголовка и текстовых блоков] |
| |
$.any-header-field |
| |
$.text[string] |
| |
$.text[ |
| |
$.any-header-field |
| |
$.value[string] |
| |
] |
| |
$.html{string} |
| |
$.html[ |
| |
$.any-header-field |
| |
$.value{string} |
| |
] |
| |
$.file#[FILE] |
| |
$.file#[ |
| |
$.any-header-field |
| |
$value[FILE] |
| |
] |
| |
] |
| |
!если charset указан, письмо перекодируется в этот charset |
| |
!content-type.charset не влияет на перекодирование |
| |
!после имени части может идти # число |
| |
^mail:send[ |
| |
# по-умолчанию, совпадает с source encoding. |
| |
# задаёт кодировку body |
| |
$.charset[windows-1251] |
| |
# нет умолчания |
| |
$.content-type[$.value[text/plain] $.charset[windows-1251]] |
| |
$.from["вася" <vasya@design.ru>] |
| |
$.to["петя" <petya@design.ru>] |
| |
$.subject[пойдём пивка] |
| |
$.body[ |
| |
слова |
| |
] |
| |
] |
| !:send[$.header-field[] $.charset[кодировка письма] $.body[когда body не строка, |
!:send[$.header-field[] $.charset[кодировка письма] $.body[когда body не строка, |
| а hash, отсылается multipart письмо]] |
а hash, отсылается multipart письмо]] |
| !если charset указан, письмо перекодируется в этот charset |
!если charset указан, письмо перекодируется в этот charset |
| !content-type.charset не влияет на перекодирование |
!content-type.charset не влияет на перекодирование |
| |
!после имени части может идти целое число, части пойдут в порядке чисел. |
| !если body указан строкой, то это текст письма, никаких вложений. |
!если body указан строкой, то это текст письма, никаких вложений. |
| !если body указан hash, то это части, будут собраны текстовые блоки, затем вложения |
!если body указан hash, то это части, будут собраны текстовые блоки, затем вложения |
| |
!это старый формат, поддерживается для обратной совместимости |
| !если имя части начинается со слова text, то это текстовый блок. |
!если имя части начинается со слова text, то это текстовый блок. |
| !если имя части начинается со слова attach, то это вложение, формат задания:: |
!если имя части начинается со слова attach, то это вложение, формат задания:: |
| !$attach[$.format[!uue|Xbase64] $.value[DATA] $.file-name[user-file-name]] |
!$attach[$.format[!uue|Xbase64] $.value[DATA] $.file-name[user-file-name]] |
| !после имени части может идти целое число, части пойдут в порядке чисел. |
|
| !важно: при multipart не указывать content-type |
!важно: при multipart не указывать content-type |
| ^mail:send[ |
^mail:send[ |
| # по-умолчанию, совпадает с source encoding. |
# по-умолчанию, совпадает с source encoding. |
|
Line 537 Xhashfile
|
Line 599 Xhashfile
|
| выполняется код |
выполняется код |
| разблокируется |
разблокируется |
| Xchmod[...] НЕТ И НЕ БУДЕТ, ЧТОБЫ НЕ МОГЛИ СДЕЛАТЬ executable и запустить, даже если ftp запрещает chmod. |
Xchmod[...] НЕТ И НЕ БУДЕТ, ЧТОБЫ НЕ МОГЛИ СДЕЛАТЬ executable и запустить, даже если ftp запрещает chmod. |
| |
!^file:dirname[/a/some.tar.gz]=/a |
| |
!^file:dirname[/a/b/]=/a |
| |
!^file:basename[/a/some.tar.gz]=some.tar.gz |
| |
!^file:justname[/a/some.tar.gz]=some.tar |
| |
!^file:justext[/a/some.tar.gz]=gz |
| |
|
| !math |
math |
| !$math:PI |
!$math:PI |
| !^math:round floor ceiling |
!^math:round floor ceiling |
| !^math:trunc frac |
!^math:trunc frac |
|
Line 548 Xhashfile
|
Line 615 Xhashfile
|
| !^math:degrees radians |
!^math:degrees radians |
| !^math:pow sqrt |
!^math:pow sqrt |
| !^math:random(ширина диапазона) |
!^math:random(ширина диапазона) |
| |
^math:GUID {C2C0983C-E26E-4169-BD07-77ECE9405BA5} |
| |
!^math:crypt[password;$apr1$salt] |
| |
|
| !date |
!date |
| !время типа time можно использовать в выражениях, подставляет |
!время типа time можно использовать в выражениях, подставляет |
|
Line 558 Xhashfile
|
Line 627 Xhashfile
|
| !^date::now(смещение в днях) выдаёт сейчас+смещение |
!^date::now(смещение в днях) выдаёт сейчас+смещение |
| !^date::create(дней с epoch) // старое имя set |
!^date::create(дней с epoch) // старое имя set |
| !^date::create(year;month[;day[;hour[;minute[;second]]]]) // старое имя set |
!^date::create(year;month[;day[;hour[;minute[;second]]]]) // старое имя set |
| ^date::sql-create[дата в формате %Y-%m-%d %H:%M:%S] |
!^date::create[дата в формате %Y-%m-%d %H:%M:%S] |
| для удобного создания по значению из базы |
для удобного создания по значению из базы |
| !$date.year month day hour minute second weekday read-only |
формат1: %Y[-%m[-%d[ %H[:%M[:%S]]]]] |
| |
формат2: %H:%M[:%S] |
| |
!$date.year month day hour minute second weekday todo:yearday |
| |
read-only |
| !^date.roll[year|month|day](+-смещение) сдвигает дату |
!^date.roll[year|month|day](+-смещение) сдвигает дату |
| !^date.sql-string[] %Y-%m-%d %H:%M:%S |
!^date.sql-string[] %Y-%m-%d %H:%M:%S |
| where published='$дата.sql-string[]' |
where published='$дата.sql-string[]' |
|
Line 597 xdoc(xnode)
|
Line 669 xdoc(xnode)
|
| !равно текущей кодировке выходной страницы, |
!равно текущей кодировке выходной страницы, |
| $response:charset |
$response:charset |
| ::sql{...} |
::sql{...} |
| !::create{<string/>} старое имя 'set' |
!::create{<?xml?><string/>} старое имя 'set' |
| !::create[qualifiedName] |
!::create[qualifiedName] |
| !::load[file.xml] |
!::load[file.xml] |
| !.transform[rules.xsl][[params hash]] выдаёт dom |
!.transform[rules.xsl][[params hash]] выдаёт dom |
|
Line 618 xdoc(xnode)
|
Line 690 xdoc(xnode)
|
| !media-type = string /> |
!media-type = string /> |
| !параметры передаются как есть, не xpath выражения |
!параметры передаются как есть, не xpath выражения |
| |
|
| !.string[output options] |
!.string[[output options]] |
| !.save[file.xml;output options] с шапкой |
!.save[file.xml[;output options]] с шапкой |
| !.file[output options] = file |
!.file[[output options]] = file |
| output options идентичны атрибутам xsl:output |
output options идентичны атрибутам xsl:output |
| [исключение: игнорируется cdata-section-elements, нужно будет, сделаю] |
[исключение: игнорируется cdata-section-elements, нужно будет, сделаю] |
| выдаёт media-type при подстановке $response:body[сюда] |
выдаёт media-type при подстановке $response:body[сюда] |
|
Line 657 xdoc(xnode)
|
Line 729 xdoc(xnode)
|
| true if the attribute received its value explicitly in the XML document, |
true if the attribute received its value explicitly in the XML document, |
| or if a value was assigned programatically with the setValue function. |
or if a value was assigned programatically with the setValue function. |
| false if the attribute value came from the default value declared in the document's DTD. |
false if the attribute value came from the default value declared in the document's DTD. |
| |
!$attribute_node.name |
| |
!$attribute_node.value |
| $text_node/cdata_node/comment_node.substringData |
$text_node/cdata_node/comment_node.substringData |
| !$pi_node.target = target of this processing instruction |
!$pi_node.target = target of this processing instruction |
| XML defines this as being the first token following the markup |
XML defines this as being the first token following the markup |
| that begins the processing instruction. |
that begins the processing instruction. |
| |
!$pi_node.data = The content of this processing instruction |
| |
This is from the first non white space character after the target |
| |
to the character immediately preceding the ?>. |
| document_node. |
document_node. |
| readonly attribute DocumentType doctype |
readonly attribute DocumentType doctype |
| readonly attribute DOMImplementation implementation |
readonly attribute DOMImplementation implementation |
|
Line 687 xdoc(xnode)
|
Line 764 xdoc(xnode)
|
| !void removeAttribute(in DOMString name) raises(DOMException) |
!void removeAttribute(in DOMString name) raises(DOMException) |
| !Attr getAttributeNode(in DOMString name) |
!Attr getAttributeNode(in DOMString name) |
| !Attr setAttributeNode(in Attr newAttr) raises(DOMException) |
!Attr setAttributeNode(in Attr newAttr) raises(DOMException) |
| !/*Attr*/ removeAttributeNode(in Attr oldAttr) raises(DOMException) |
!Attr removeAttributeNode(in Attr oldAttr) raises(DOMException) |
| !NodeList getElementsByTagName(in DOMString name) |
!NodeList getElementsByTagName(in DOMString name) |
| !void normalize() |
!void normalize() |
| |
|
|
Line 700 xdoc(xnode)
|
Line 777 xdoc(xnode)
|
| !^node.select[xpath/query/expression] = array of nodes, |
!^node.select[xpath/query/expression] = array of nodes, |
| empty array if nothing found |
empty array if nothing found |
| !^node.selectSingle[xpath/query/expression] = first node if any |
!^node.selectSingle[xpath/query/expression] = first node if any |
| !^node.selectBool[xpath/query/expression] = bool if any |
!^node.selectBool[xpath/query/expression] = bool if any or die |
| !^node.selectNumber[xpath/query/expression] = double if any |
!^node.selectNumber[xpath/query/expression] = double if any or die |
| !^node.selectString[xpath/query/expression] = string if any |
!^node.selectString[xpath/query/expression] = string if any or die |
| |
|
| !error codes(пока придут как текст в случае соответствующих ошибок): |
!error codes(пока придут как текст в случае соответствующих ошибок): |
| INDEX_SIZE_ERR |
INDEX_SIZE_ERR |
|
Line 784 xdoc(xnode)
|
Line 861 xdoc(xnode)
|
| кучи auto.p и запрашиваемого документа: |
кучи auto.p и запрашиваемого документа: |
| !parser3.conf |
!parser3.conf |
| cgi: |
cgi: |
| 1. или полный путь из переменной окружения HTTP_PARSER_ROOT_CONFIG |
1. или полный путь из переменной окружения CGI_PARSER_SITE_CONFIG |
| или configure sysconfdir|windows directory |
|
| 2. или полный путь из переменной окружения HTTP_PARSER_SITE_CONFIG |
|
| или рядом с бинарником parser'а |
или рядом с бинарником parser'а |
| isapi: windows directory |
isapi: windows directory |
| apache module: |
apache module: |
| 1) ParserRootConfig [httpd.conf only] |
1) ParserConfig [can be in .htaccess] |
| 2) ParserSiteConfig [can be in .htaccess] |
|
| !auto.p вниз от DOCUMENT_ROOT/ по дереву до каталога с обрабатываемым файлом включительно |
!auto.p вниз от DOCUMENT_ROOT/ по дереву до каталога с обрабатываемым файлом включительно |
| класс собирается из всех этих файлов, последующие становятся родителями предыдущих |
класс собирается из всех этих файлов, последующие становятся родителями предыдущих |
| имя последнего загруженного MAIN, имён у предыдущих нет |
имя последнего загруженного MAIN, имён у предыдущих нет |
|
Line 816 xdoc(xnode)
|
Line 890 xdoc(xnode)
|
| !parser.runtime ^if(0). параметры (больше/меньше, чем нужно, не тех типов, ...) |
!parser.runtime ^if(0). параметры (больше/меньше, чем нужно, не тех типов, ...) |
| !number.zerodivision ^eval(1/0) ^eval(1%0) |
!number.zerodivision ^eval(1/0) ^eval(1%0) |
| !number.format ^eval(abc*5) |
!number.format ^eval(abc*5) |
| |
!file.lock shared/exclusive lock error |
| !file.missing ^file:delete[delme] not found |
!file.missing ^file:delete[delme] not found |
| !file.access ^table::load[.] no rights |
!file.access ^table::load[.] no rights |
| !image.format ^image::measure[index.html] not gif/jpg |
!image.format ^image::measure[index.html] not gif/jpg |