--- parser3/operators.ru.txt 2009/08/11 12:37:28 1.223 +++ parser3/operators.ru.txt 2010/08/04 15:20:31 1.230 @@ -56,6 +56,7 @@ Xне сделано, видимо, не будет сделано !^if(условие){когда да}{когда нет} + !^if(условие1){да}[(условие2){да}[(условие2){да}[...]]]{нет} -- количество доп. условий не ограничено (в общем elseif это :) !^switch[значение]{^case[вариант1[;вариант2...]]{действие}^case[DEFAULT]{действие по умолчанию}} !^while(условие){тело}[[разделитель]|{разделитель который выполняется перед непустым очередным не первым телом}] !^for[i](0;4){тело}[[разделитель]|{разделитель который выполняется перед непустым очередным не первым телом}] @@ -140,8 +141,8 @@ Xне сделано, видимо, не будет сделано ClientCharset << charset in which parser thinks client works !sqlite://DBfile? - ClientCharset=parser-charset& << charset in which parser thinks client works - autocommit=1 + ClientCharset=parser-charset& << charset in which parser thinks client works + autocommit=1 для работы connect нужно, чтобы заранее(рекомендуется в системном конфигурационном auto.p) была определена таблица @@ -296,7 +297,7 @@ odbc c:\drives\y\parser3project\odbc\deb пример: ^if(def $form:name) не пуста? ^if($user.isAlive) истина? [автопреобразование к числу, не ноль?] - !^string::sql{query}[[$.limit(1) $.offset(4) $.default{n/a} $.bind[см. table::sql]]] + !^string:sql{query}[[$.limit(1) $.offset(4) $.default{n/a} $.bind[см. table::sql]]] результат запроса должен быть один столбец/одна строка !^строка.int[] .int(default) целочисленное значение строки. если ломается преобразование, берётся default @@ -336,6 +337,7 @@ odbc c:\drives\y\parser3project\odbc\deb <0 = не найдено !^строка.replace[$таблица_подстановок_строка_на_строку] !^строка.save[[append;]путь] + !^строка.save[путь[;$.charset[в какой кодировке сохраняем] $.append(true)]] !^строка.normalize[] выдает другую строку, в которой фрагменты на одном языке объединены полезно делать перед сложными match операциями, если вы знаете, что входная строка состоит из большого числа фрагментов @@ -359,10 +361,10 @@ odbc c:\drives\y\parser3project\odbc\deb !$.separator[^#09] !$.encloser["] по-умолчанию, нет. !^table::sql{query}[[$.limit(2) $.offset(4) $.bind[hash] todo:$.default{ ^table::create[...] }]] - bind привязывает переменные в запросе к их значениям - пока реализован только для oracle - в запросе надо написать ":имя" - в параметре bind передать hash, из которого возьмётся(или куда запишется) значение + bind привязывает переменные в запросе к их значениям + пока реализован только для oracle + в запросе надо написать ":имя" + в параметре bind передать hash, из которого возьмётся(или куда запишется) значение !^таблица.save[[nameless|append;]путь[;опции, см. load]] !$таблица.поле !$таблица.fields из named таблицы выдаёт текущую запись как Hash @@ -424,6 +426,9 @@ odbc c:\drives\y\parser3project\odbc\deb !^хеш.foreach[key;value]{тело}[[разделитель]|{разделитель который выполняется перед непустым очередным не первым телом}] !^хеш.delete[ключ] удалить ключ !^хеш.contain[ключ] - существует ли в хеше ключ (bool) + !^хэш._at[first|last] + !^хэш._at([-]N) + доступ к заданным элементам упорядоченного хеша !hashfile !^hashfile::open[filename] @@ -508,7 +513,7 @@ odbc c:\drives\y\parser3project\odbc\deb !$response:headers накопленные поля !$response:body[DATA] замещает стандартный ответ !$response:download[DATA] замещает стандартный ответ, - выставляет флаг, заставляющий browser предложить download + выставляет флаг, заставляющий browser предложить download !$response:status !^response:clear[] забыть все заданные response поля !$response:charset @@ -538,9 +543,10 @@ odbc c:\drives\y\parser3project\odbc\deb !^reflection:classes[] хеш со всеми классами. ключ -- имя класса, значение бывает methoded (класс с методами) или void !^reflection:class[объект] класс переданного объекта !^reflection:class_name[объект] имя класса переданного объекта - !^reflection:base[объект] класс переданного объекта - !^reflection:base_name[объект] имя класса переданного объекта + !^reflection:base[объект] родительский класс переданного объекта + !^reflection:base_name[объект] имя родительского класса переданного объекта !^reflection:methods[класс] хеш со списком методов указанного класса, значения -- строки 'native' или 'parser' + !^reflection:fields[класс или объект] хеш со списком статических полей указанного класса или динамических полей указанного объекта !^reflection:method_info[класс;метод] хеш с параметрами указанного метода класса $.inherited[класс] имя класса, где метод был определён (возвращается только если метод был определён в предке) для native классов возвращается хеш: @@ -549,6 +555,9 @@ odbc c:\drives\y\parser3project\odbc\deb .call_type[dynamic|static|any] для parser классов возвращается хеш: ключ -- номер параметра (0, 1, ...), значение - имя параметра + !^reflection:dynamical[[object or class, caller if absent]] возвращает true, если метод был вызван из динамического контекста + при передаче параметра возвращает true, если передан динамический объект, + false если класс !mail @@ -579,10 +588,10 @@ odbc c:\drives\y\parser3project\odbc\deb $.message#[MESSAGE] (message, message2, ...) !^mail:send[ - $.options[-odd] - unix: строка, которая будет добавлена к команде запуска sendmail - -odd означает "быстро поставь в очередь без проверки email" - win32: игнорируется + $.options[-odd] + unix: строка, которая будет добавлена к команде запуска sendmail + -odd означает "быстро поставь в очередь без проверки email" + win32: игнорируется $.charset[кодировка заголовка и текстовых блоков] $.any-header-field $.text[string] @@ -734,12 +743,13 @@ odbc c:\drives\y\parser3project\odbc\deb !$файл_из_post.name !$файл_из_post.size !$файлtиз_post.text - !^файл.save[text|binary;имя файла] + !^файл.save[text|binary;имя файла[;$.charset[в какой кодировке сохраняем]]] !^file:delete[имя файла] !^file:find[имя файла][{когда не нашли}] !^file:list[путь[;шаблон-строка|шаблон-regex]] = table с колонкой name !^file::load[text|binary;!big.zip[;!domain_press_release_2001_03_01.zip][;опции]] - !^file::create[text;имя;^untaint[xml]{data}] + !^file::create[text;имя;data] + !^file::create[text;имя;data[;$.charset[кодировка букв в создаваемом файле]]] !$файл_который_был_loaded.size !$файл_который_был_loaded_или_created.mode = text/binary !^file::stat[имя файла] @@ -772,23 +782,26 @@ odbc c:\drives\y\parser3project\odbc\deb !^файл.sql-string[] внутри ^connect даст правильно escaped строку, которую можно в запрос отдать X^file::sql[[имя_файла_для_download]]{} !^file::sql{}[[ - $.name[имя_файла_для_download] - $.content-type[пользовательский content-type] + $.name[имя_файла_для_download] + $.content-type[пользовательский content-type] ]] - результат запроса должен быть "одна строка". - колонки: - первая колонка - данные - если есть вторая - это имя файла - если есть третья - это content-type + результат запроса должен быть "одна строка". + колонки: + первая колонка - данные + если есть вторая - это имя файла + если есть третья - это content-type !^файл.base64[] encode - !^file:base64[имя файла] encode - !^file::base64[encoded string] decode + !^file:base64[имя файла] + encode + !^file::base64[encoded string] + !^file::base64[mode;имя файла;encoded string[;$.content-type[...]]] + decode !^file:crc32[имя файла] - вычисляет crc32 файла с указанным именем + вычисляет crc32 файла с указанным именем !^файл.crc32[] - вычисляет crc32 объекта - !^файл.md5[] - !^file:md5[имя файла] + вычисляет crc32 объекта + !^файл.md5[] + !^file:md5[имя файла] выдает digest файла, длиной 16 байт в виде строки, где байты digest выданы в hex виде, впритык, в нижнем регистре @@ -1094,7 +1107,7 @@ xdoc(xnode) !$status:memory hash !used - Includes some pages that were allocated but never written. + Includes some pages that were allocated but never written. !free @@ -1102,8 +1115,8 @@ xdoc(xnode) Return the number of bytes allocated since the last collection. !ever_allocated_since_start - Return the total number of bytes [EVER(c)PAF] allocated in this process. - Never decreases. + Return the total number of bytes [EVER(c)PAF] allocated in this process. + Never decreases. !$status:pid process id !$status:tid thread id