summaryrefslogtreecommitdiff
path: root/documentation/install.html
blob: 7f7a2c38df2289ac67c1e585c50da86ba1658bb5 (plain)
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
<h1>How to install PHP-CPP</h1>
<p>
    Before you can build your own super fast native PHP extension using the 
    PHP-CPP library, you will first have to install the PHP-CPP library on your 
    system(s).
</p>
<p>
    Luckily, for most of us (those who use Linux environments), this will be
    a piece of cake. If you're on a different platform however, you are left on 
    your own, because we (as in me, the PHP-CPP developer), only uses Linux
    systems. There is however no reason why this library should not also work on 
    other platforms, because it only uses straight forward C++ code. Thus, if 
    you are on a different platform and have managed to compile the library on 
    it, please give us feedback so that we can update these installation 
    instructions and include other platforms as well.
</p>


<h2 id="limitations">Limitations</h2>
<p>
    At this moment, PHP-CPP only supports single-threaded PHP installations.
    Web servers come in a number forms: there are the ones that handle each
    page request in different process, and the ones that handle each page request
    in the same process, but in a different thread. If you're using such a
    multi-threaded PHP installation, you can not use the PHP-CPP library. Most
    installations are single-threaded however, so this should not be a show stopper.
</p>
<p>
    Are you not sure whether you have a single-threaded or multi-threaded PHP
    environment? Just try to compile the PHP-CPP library, if you see a zillion
    errors, you can be pretty sure that this is because of your installation
    is multi-threaded.
</p>
<p>
    The reason why we've chosen not to support multi-threaded PHP installations
    lies in the fact that internally the Zend engine uses a very odd system
    to ensure thread safety. Essentially, they pass an additional parameter to 
    each and every function call that holds a pointer-to-a-pointer with thread
    information that you can access with specific C macro's, and that you have
    to pass on to every other function call that you make. This makes life for 
    extension writers much harder than is necessary - and is in total conflict
    with the core principle of the PHP-CPP library: to make life easy.
</p>
<p>
    However, if there is demand for, we will add support for multi-threaded PHP
    installations, and hopefully we can even keep the same simple C++ API as we 
    have now.
</p>



<h2 id="download">Download</h2>
<p>
    Installation begins with downloading the source code. You can either
    download the latest release from our
    <a href="http://www.php-cpp.com/download">download</a> page, or get the
    latest bleeding edge work-in-progress version from 
    <a href="https://github.com/CopernicaMarketingSoftware/PHP-CPP">GitHub</a>.
</p>
<p>
    To get the latest GitHub version, run the following command from the command
    line:
</p>
<p>
    <pre><code>git clone https://github.com/CopernicaMarketingSoftware/PHP-CPP.git</code></pre>
</p>
<p>
    After you've downloaded the software (either from our website, or directly
    from GitHub), change your working directory to the PHP-CPP directory, and open
    the file named "Makefile" with your editor of choice.
</p>
<p>
    The Makefile is a file that holds settings and instructions for the compiler.
    In 96 out of 100 situations, the default settings in this Makefile will
    already be perfect for you, but you may want to have a look at it and make
    (small) changes to it. You can for example change the installation directory,
    and the compiler that is going to be used.
</p>
<p>
    After you've checked that all settings in the Makefile are correct, you can
    build the software. Do this by running the following command from within
    the PHP-CPP directory.
</p>
<p>
    <pre><code>make</code></pre>
</p>
<p>
    The PHP-CPP library has now been built, and all that is left to do is 
    install it on your system. You can use the "make install" command for it.
    This command should be executed as root, either by using "sudo", or by
    logging on as root first.
</p>
<p>
    <pre><code>sudo make install</code></pre>
</p>
<p>
    Congratulations! You are now the happy owner of a system with PHP-CPP installed
    and nothing can stop you from building your first fast native PHP extension.
</p>