If you see this page, you have sucessfully installed Parser and trying to test it.
To see full paths to configuration files and DOCUMENT_ROOT comment out postprocess[] method.
If something is marked as red, then something is configured the wrong way or automatic detection is impossible (related to library files and codepages search with relative paths).
| koi8-r | $charsetsdir/koi8-r.cfg (5104 Bytes) |
| windows-1251 | $charsetsdir/windows-1251.cfg (5128 Bytes) |
| protocol | parser driver | sql client library |
|---|---|---|
| mysql | $sqldriversdir/libparser3mysql.so (50008 Bytes) | libmysqlclient.so (relative path. checkout is impossible) |
DOCUMENT_ROOT: equal with test script directory (comment postprocess method for view)
Путь к скрипту: comment postprocess method for view
$response:charset: UTF-8
$request:charset: UTF-8
$request:uri: /_test_eng.html?a=321&b=%D0%90
$request:query: a=321&b=%D0%90 (for get values use $form class)
$SQL.connect-string: defined
$MAIL.SMTP: undefined
$CLASS_PATH:
| /../data/classes/sql | directory exist |
| /../data/classes/auth | directory exist |
| /../data/classes/io | directory exist |
| /../data/classes/utils | directory exist |
| /../data/classes/engine | directory exist |
| /../data/classes | directory exist |
Read $cookie:test: undefined
Write to cookie value ABC $cookie:test[ABC] (press Reload)
^eval(4+2): 6
^math:random(1000): 270
^math:log(1000): 6.90775527898214
^math:log10(1000): 3
^math:uuid[]: 23B97E02-CAAC-4002-A901-BA313A43E9F1
^math:uid64[]: 15AB8477C919889B
^math:md5[StRiNg]: ed4577017f40ccb66fcf09dda2fe2a3c
^math:crypt[StRiNg;$apr1$]: $apr1$Q7XbfUPB$MIyIQe1/BKzg9ThrLQf7N.
^math:crc32[StRiNg]: 2896444419
Definition $str[АбвГде]
String length ^str.length[]: 6
Uppercase string ^str.upper[]: АБВГДЕ
Lowercase string ^str.lower[]: абвгде
First 2 chars ^str.left(2): Аб
Last 3 chars ^str.right(3): Где
Substring ^str.mid(1;3): бвГ
Position of 'б' char ^str.pos[б]: 1
Position of 'б' char starting from position 2 ^str.pos[б](2): -1
Position of 'X' char ^str.pos[X]: -1
Replacement substring 'вГ' to XX using match ^str.match[вГ][]{XX}: АбXXде
Replacement chars 'в' to 'Y', 'Г' to 'Z' using ^str.replace[$repl]: АбYZде
^str.trim[both;е]: АбвГд
^str.trim[start;е]: АбвГде
^str.trim[end;е]: АбвГд
^str.trim[left;е]: АбвГде
^str.trim[right;е]: АбвГд
^str.base64[]: 0JDQsdCy0JPQtNC1
^str.js-escape[]: %u0410%u0431%u0432%u0413%u0434%u0435
^str:js-unescape[%u0410%u0431%u0432%u0413%u0434%u0435]: АбвГде
$form:a: 321
Safe conversion $form:a to integer: ^form:a.int(1): 321
1 value $form:b: А
$form:qtail: undefined
$hash1[
$.a[1]
$.b[2]
$.c[3]
]
^hash1.foreach[key;value]{
$key=$value
}[<br />]
a=1
$tbl1[^table::create{name col1 col2
Vasya 3 5
Dima 4 14}]
$tbl1 rows quantity: 2| string | column |
|---|---|
| 1 | name |
| 2 | col1 |
| 3 | col2 |
Print content $tbl1:
| string | name | col1 | col2 |
|---|---|---|---|
| 1 | Vasya | 3 | 5 |
| 2 | Dima | 4 | 14 |
$tbl2[^table::create{name col1 col2
Vova 3 44}]
$tbl2 rows quantity: 1
join $tbl1 to $tbl2 [^tbl2.join[$tbl1]]
$tbl2 rows quantity ^tbl2.count[]: 3
Print table:
| string | name | col1 | col2 |
|---|---|---|---|
| 1 | Vova | 3 | 44 |
| 2 | Vasya | 3 | 5 |
| 3 | Dima | 4 | 14 |
select table rows where col1 values are equal 3: ^tbl2.select($tbl2.col1 == 3)
| string | name | col1 | col2 |
|---|---|---|---|
| 1 | Vova | 3 | 44 |
| 2 | Vasya | 3 | 5 |
Making hash with tables (where hash keys are col1 values): $hData[^tbl2.hash[col1][$.distinct[tables]]]
Print hash data:
| Key | Value | ||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 3 |
|
||||||||||||
| 4 |
|
Making hash with strings (where hash keys are col2 values and values are name values): $hData[^tbl2.hash[col2;name][$.type[string]]]
Print hash data:
| Key | Value |
|---|---|
| 44 | Vova |
| 5 | Vasya |
| 14 | Dima |
$now[^date::now[]]
$now.day/$now.month/$now.year ${now.hour}:${now.minute}:$now.second: 29/10/2025 10:33:36
$now.week: 44
$now.weekyear: 2025
Print now in sql format ^now.sql-string[]: 2025-10-29 10:33:36
Print now in UNIX timestamp format ^now.unix-timestamp[]: 1761723216
Print now in GMT format ^now.gmt-string[]: Wed, 29 Oct 2025 07:33:36 GMT
Number of last day in current month ^now.last-day[]: 31
Roll date to 5 days ahead ^now.roll[day](-5): 24/10/2025
Roll date to 30 days behind ^now.roll[day](30): 23/11/2025
Write table $tbl1 to file _test.cfg (^tbl1.save[_test.cfg]):
File created successfully
^file:dirname[/_test.cfg]: /
^file:basename[/_test.cfg]: _test.cfg
^file:justname[/_test.cfg]: _test
^file:justext[/_test.cfg]: cfg
Get saved file information $fstat[^file::stat[_test.cfg]]:
File size [$fstat.size]: 35
cdate: 29/10/2025
adate: 29/10/2025
mdate: 29/10/2025
Loading data into $tbl3 from file DOCUMENT_ROOT/_test.cfg and out table content ($tbl3[^table::load[_test.cfg]]):
| string | name | col1 | col2 |
|---|---|---|---|
| 1 | Vasya | 3 | 5 |
| 2 | Dima | 4 | 14 |
File copy (^file:copy[_test.cfg;_copy.cfg]): ok
File delete (^file:delete[_test.cfg]): ok
Create object: $hf [$hf[^hashfile::open[_test]]]: object was created sucessfully
Number of records: 31
Adding record (C2AE74FE-2E37-46B2-91F9-ADFCFEDABCCD) for 3 days:
$hf.[C2AE74FE-2E37-46B2-91F9-ADFCFEDABCCD][ $.value[616516520] $.expires(3) ]Cleanup hashfile from expired records (^hf.cleanup[]): ok
| Variable | Value | Comment |
|---|---|---|
| SERVER_NAME | www.parser.ru | DNS Server name |
| QUERY_STRING | a=321&b=%D0%90 | For get values use $form class |
| HTTP_REFERER | ||
| HTTP_USER_AGENT | Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com) | Browser USER_AGENT string |
| HTTP_X_FORWARDED_FOR | Filled if visitor come through proxy server | |
| REMOTE_HOST | ||
| REMOTE_ADDR | 216.73.216.146 | Visitors' IP address |
| PARSER_VERSION | 3.5.0 (compiled on amd64-unknown-freebsd13.4) | Parser3 version (if not defined - parser3 before 3.1.5) |
^int:sql{SELECT 2+2}:
4
Create xdoc:
$document[^xdoc::create{<?xml version="1.0" encoding="UTF-8" ?>
<document>
<t attr="Hello" n="123"/>
<t attr="Bye" n="234" n2="xxx"/>
<text>Text</text>
</document>}]
Object xdoc created successfully.
| Field | Description | Value | ||
|---|---|---|---|---|
| on start | now | after ^memory:compact[] | ||
| $status:rusage.utime (secs) | process time | 0.008773 | 0.016668 | 0.018802 |
| $status:rusage.stime (secs) | time for reading files | 0.010924 | 0.010924 | 0.010924 |
| $status:rusage.maxrss (blocks) | memory, used by process | 8836 | 10412 | 10412 |
| $status:memory.used (KB) | user | 2256 | 2512 | 2312 |
| $status:memory.free (KB) | free (fragmentated) | 428 | 172 | 372 |
| $status:memory.ever_allocated_since_compact (KB) | allocated since last garbage collection | 3032.234375 | 3978.828125 | 0 |
| $status:memory.ever_allocated_since_start (KB) | allocated since start | 3032.234375 | 3978.828125 | 3978.90625 |