File: INSTALL

package info (click to toggle)
parser 3.5.1-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 7,520 kB
  • sloc: cpp: 35,302; sh: 15,643; ansic: 10,375; yacc: 1,378; makefile: 242
file content (103 lines) | stat: -rw-r--r-- 4,985 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
$Id: INSTALL,v 1.58 2024/11/04 04:37:43 moko Exp $

1. What is the process to compile Parser3?

  Just start ./buildall script and you would get $HOME/parser3install/bin/parser3 binary.

  NOTE:
  In case you do not need XML support, use ./buildall --without-xml

  NOTE:
  In case you need apache parser module (DSO), use ./buildall --with-apache

  NOTE:
  If you have gc, prce, libxml and libxslt installed, you can use ./configure --with-xml

  NOTE:
  In case you later would experience problems with gcc runtime exception handling 
  (most notable when reporting sql-related problems), pass this to buildall script:
  --with-sjlj-exceptions (HPUX is reported to have such problems)

  NOTE:
  On some systems there are no "make" and you should run 'gmake', change buildall script accordingly then.

2. What is the process to install Parser3?

  Copy files from $HOME/parser3install directory into your cgi-bin directory.

  Then install Parser3 to handle documents, step-by-step instructions:
    http://www.parser.ru/en/docs/lang/install4apachecgi.htm" in English
    http://www.parser.ru/docs/lang/install4apachecgi.htm" in Russian

  Directory layout:
    bin/
      parser3               -- CGI and command line Parser3 interpreter
      auto.p.dist           -- configuration file sample,
                               copy it to auto.p and adjust to your needs
    share/
      charsets/
        parser3.charsets/   -- charset definition files
          koi8-r.cfg        -- cyrillic charset [KOI8-R encoding]
          windows-1251.cfg  -- cyrillic charset [windows-1251 encoding]
          ...

3. I have heard about $mail:receive experimental support, how do I use it?

  Just start ./buildall --with-mailreceive.
  If you have glib and gmime installed, you can run ./configure --with-mailreceive.

4. Safety features
  You can disable any exec operations by setting --disable-execs option.
  file::exec, file::cgi and mail:send (unix version) methods would be disabled.

  You can enable reading and executing files, not belonging to group+user 
  other than effective by setting --disable-safe-mode option.

  You can disable user-configured sendmail commands by forcing it, setting
  "--with=sendmail=COMMAND" option.

5. Since Parser 3.4.0 several optimizations were implemented.
  If you experience problems you can try to disable them by commenting corresponding
  defines and recompiling parser3.

  src/include/pa_opcode.h
    #define OPTIMIZE_BYTECODE_GET_CLASS               -- $a:
    #define OPTIMIZE_BYTECODE_GET_ELEMENT             -- $a ^a
    #define OPTIMIZE_BYTECODE_GET_OBJECT_ELEMENT      -- $a.b ^a.b
    #define OPTIMIZE_BYTECODE_GET_OBJECT_VAR_ELEMENT  -- $a.$b ^a.$b
    #define OPTIMIZE_BYTECODE_GET_SELF_ELEMENT        -- $self.a ^self.a
    #define OPTIMIZE_BYTECODE_CONSTRUCT               -- $a(expr),  $a[value]
                                                         $.a(expr), $.a[value]
                                                         $self.a(expr), $self.a[value]
    #define OPTIMIZE_BYTECODE_CUT_REM_OPERATOR        -- cut rem operator with any number of params during compilation
    #define OPTIMIZE_BYTECODE_STRING_POOL             -- simplifying string's bytecode into expression
    #define OPTIMIZE_BYTECODE_GET_SELF_ELEMENT        -- bytecode for $self.a ^self.a
    #define OPTIMIZE_BYTECODE_GET_ELEMENT__SPECIAL    -- bytecode for .CLASS, .CLASS_NAME
    #define FEATURE_GET_ELEMENT4CALL                  -- ^o.m[] calls get_element4call("m"), not get_element("m")

  src/include/pa_string.h
    #define HASH_CODE_CACHING  -- calculated hash codes are cached and used for sequential hash lookups

  src/include/pa_memory.h
    #define USE_DESTRUCTORS    -- destructors are used to decrease memory consumption during code
                                  processing and make ^memory:compact[] calls non-essential.

  src/types/pa_method.h
    #define OPTIMIZE_CALL      -- allows faster operators execution by eliminating method frame
                                  with local variables creation and extra write context switches.
    #define OPTIMIZE_RESULT    -- parser methods are marked when the $result variable was used.
                                  This allows write operations and context switching optimization.

  src/types/pa_wwrapper.h
    #define OPTIMIZE_SINGLE_STRING_WRITE  -- reuse original VString in single string assignments.

  src/lib/cord/include/cord.h
    #define CORD_CAT_OPTIMIZATION -- CORD library never modifies source concatenations. But in parser
                                     write operations it is safe to modify them and save some memory.
    #define CORD_CHARS_CACHE      -- language cords with same language and length are cached and reused.

  src/include/pa_string.h
    #define STRING_LENGTH_CACHING -- cache String::Body.length() for char* strings

  src/include/pa_hash.h
    #define HASH_ORDER            -- hash keys are iterated in the order of insertion