--- parser3/INSTALL 2005/03/16 14:37:03 1.40 +++ parser3/INSTALL 2005/12/29 08:27:42 1.48.2.2 @@ -1,56 +1,27 @@ -0.Assuming your perform your builds in $HOME directory - and suggested subdirectories. +Alexander Petrosian (http://paf.design.ru) +$Id: INSTALL,v 1.48.2.2 2005/12/29 08:27:42 paf Exp $ 1.What is the process to compile Parser3? - First, you must have LIBGC installed (conservative garbage collector for C++). - libgc >= 6.1 [http://www.hpl.hp.com/personal/Hans_Boehm/gc/gc_source/gc6.4.tar.gz] - - Installation sequence of this library to $HOME/gc: + Just start ./buildall-with-xml script and you would get $HOME/parser3install/bin/parser3 binary. + In case you do not need XML support, use ./buildall-without-xml - cd libgc-x.x - ./configure --prefix=$HOME/gc --disable-threads --silent - make install - - Then you can use these Parser3 configure options to specify the location and static/dynamic linkage with libgc: - --with-static-gc=$HOME/gc/lib - --with-shared-gc=$HOME/gc/lib - - NOTE: - On some platforms there is special version of libgc patched to support some - local piece of subtlety. - Official libgc does not work there, use special version instead. - (OpenBSD reported to be one of those) - - As most UNIX programs Parser3 follows the "standard": - - mkdir $HOME/parser3project - cd $HOME/parser3project - gunzip -c parser3-x.x.tar.gz | tar xvf - - mv parser3-x.x parser3 - cd parser3 - ./configure --prefix=$HOME/parser3install --silent - make - - That renaming is needed for SQL drivers to be able to find - necessary include-file in Parser3 sources. NOTE: - On some system you should run 'gmake'. + On some platforms there is special version of libgc patched to support some + local piece of subtlety. + Official libgc does not work there, use special version instead. + (OpenBSD reported to be one of those) + If you need that special version, please change buildall script accordingly. NOTE: - By default your would get 'parser3' binary without support of these features: - * xml(xdoc and xnode classes) - Read section (3) on getting xml-abled parser. - - - Read section (4) on configure options. + 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? - make install + Just copy files from $HOME/parser3install directory into your cgi-bin directory. - Installation layout: + Files layout: $prefix/bin/ parser3 -- CGI and command line Parser3 interpreter auto.p.dist -- configuration file sample, @@ -62,88 +33,31 @@ windows-1251.cfg -- cyrillic charset [windows-1251 encoding] windows-1257.cfg -- baltic charset [windows-1257 encoding] -3.What other libraries are needed to compile/install parser? - -3a. In case you wish XML(xdoc and xnode classes) support, you need libraries - libxml2 >= 2.6.5 [ftp://xmlsoft.org/libxml2-2.6.17.tar.gz] - libxslt >= 1.1.2 [ftp://xmlsoft.org/libxslt-1.1.10.tar.gz] - glib >= 1.2.10 [ftp://ftp.gtk.org/pub/gtk/v1.2/glib-1.2.10.tar.gz] - on freebsd5 this is reported to work: ftp://ftp.gtk.org/pub/gtk/v1.1/glib-1.1.16.tar.gz - gdome2 >= 0.7.4 [http://gdome2.cs.unibo.it/tarball/gdome2-0.8.1.tar.gz] - on your system, and specify path to them to Parser3 configure script. - - Sources of libgdome library must be patched prior to compile. [library author bug confirmation pending] - - Installation sequence of these libraries to $HOME/gnome: - - libxml2: - - cd libxml2-x.x.x - ./configure --prefix=$HOME/gnome --without-zlib --without-iconv --without-threads --silent - make install - - libxslt: - - cd libxslt-x.x.x - ./configure --with-libxml-prefix=$HOME/gnome --prefix=$HOME/gnome --without-debug --without-debugger --silent - make install - - glib: - - cd glib-x.x.x - ./configure --prefix=$HOME/gnome --silent - make install - - gdome2: - - cd gdome2-x.x.x - patch -p0 < $HOME/parser3project/parser3/src/lib/patches/gdome2.patch - ./configure --with-glib-prefix=$HOME/gnome --disable-glibtest --with-libxml-prefix=$HOME/gnome --prefix=$HOME/gnome --silent - make install - - And copy these additional headers into install includes directory - - mkdir -p $HOME/gnome/include/libgdome/gdomecore - cp libgdome/gdomecore/gdome-xml-node.h $HOME/gnome/include/libgdome/gdomecore - cp libgdome/gdomecore/gdome-xml-document.h $HOME/gnome/include/libgdome/gdomecore - - - Parser3 configure options, choose whether you need static or dynamic linkage with xml libs: - --with-static-xml=$HOME/gnome - --with-shared-xml=$HOME/gnome - - NOTE: - In case your glib as installed into some other prefix, - specify it's configuration file with - --with-glib-config=/path/to/your/glib-config - NOTE: - In case you are using SHARED xml libraries, you may want to link in direct path to them, - use this key to specify which linker key to use do do that: - --with-pathlink=LKEY put dynamic libraries paths to binary - using linker key (-R, -rpath-link) - -3b. In case you wish $mail:receive support you need libraries - glib >= 1.2.10 [ftp://ftp.gtk.org/pub/gtk/v1.2/glib-1.2.10.tar.gz] +3.I have heard about $mail:receive experimental support, how do I use it? + You need to bulid these additional libraries + glib >= 1.2.10 gmime >= 1.0.1 [http://spruce.sourceforge.net/gmime/sources/v1.0/gmime-1.0.8.tar.gz] on your system, and specify path to them to Parser3 configure script. - You may have already installed glib at 3b step. - glib: - cd glib-x.x.x - ./configure --prefix=$HOME/gnome + cd $HOME/parser3project/src + #on freebsd5 this is reported to work: ftp://ftp.gtk.org/pub/gtk/v1.1/glib-1.1.16.tar.gz + wget --passive-ftp ftp://ftp.gtk.org/pub/gtk/v1.2/glib-1.2.10.tar.gz + gunzip -c glib-1.2.10.tar.gz | tar vxf - + cd glib-1.2.10 + ./configure --prefix=$HOME/parser3project/gnome --silent make install gmime: cd gmime-x.x.x - ./configure --prefix=$HOME/gnome + ./configure --prefix=$HOME/parser3project/gnome make install - Parser3 configure options, choose whether you need static or dynamic linkage with xml libs: - --with-static-mailreceive=$HOME/gnome - --with-shared-mailreceive=$HOME/gnome + Then you need to change buildall script to add this to parser3 configure line: + --with-static-mailreceive=$HOME/parser3project/gnome + And start that changed ./buildall. NOTE: In case your glib as installed into some other prefix, @@ -155,14 +69,7 @@ --with-pathlink=LKEY put dynamic libraries paths to binary using linker key (-R, -rpath-link) -4. - - In case you're not root on machine you're installing Parser, - we recommend you to do: - ./configure --prefix=/your/home/parser3install - and afterwards copy parser3install/bin/parser3 to your CGI directory - or make a symlink [if your web server configured to follow symlinks]. - +4.Security issues You can disable any exec operations by setting --disable-execs option to configure. @@ -175,12 +82,15 @@ You can disable user-configured sendmail commands by forcing it, setting "--with=sendmail=COMMAND" - option to configure. + option to configure, for example: + "--with-sendmail=/usr/sbin/sendmail -i -t -f postmaster" - In case you are experiencing problem with gcc runtime exception handling, + In case you are experiencing problem with gcc runtime exception handling + (most notable when reporting sql-related problems), try to configure with --with-sjlj-exceptions - option. + option. + (HPUX is reported to be have such problems) By default libstdc++ is linked statically, you can re-enable dynamic libstdc++ linkage by specifying --with-dynamic-stdcpp @@ -206,11 +116,7 @@ ./p3runConfigure example: - ./p3runConfigure --prefix=$D/apache13install --enable-module=rewrite + ./p3runConfigure --prefix=$HOME/apache13install --enable-module=rewrite WARNING: if you want to use apache configure option --enable-shared=max, do this: ./p3runConfigure --enable-shared=max --disable-shared=mod_parser3.c - -Alexandr Petrosian (http://paf.design.ru) - -$Id: INSTALL,v 1.40 2005/03/16 14:37:03 paf Exp $