passenger 2.2.12 → 2.2.13

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of passenger might be problematic. Click here for more details.

data/NEWS CHANGED
@@ -1,3 +1,11 @@
1
+ Release 2.2.13
2
+ --------------
3
+
4
+ * Fixed some Rails 3 compatibility issues that were recently introduced.
5
+ * Fixed a typo that causes config/setup_load_paths.rb not to be loaded
6
+ correctly.
7
+
8
+
1
9
  Release 2.2.12
2
10
  --------------
3
11
 
@@ -3749,7 +3749,7 @@ has no effect.</p></div>
3749
3749
  <div id="footnotes"><hr /></div>
3750
3750
  <div id="footer">
3751
3751
  <div id="footer-text">
3752
- Last updated 2010-05-31 21:19:11 CEST
3752
+ Last updated 2010-06-01 18:33:18 CEST
3753
3753
  </div>
3754
3754
  </div>
3755
3755
  </body>
@@ -2427,7 +2427,7 @@ has no effect.</p></div>
2427
2427
  <div id="footnotes"><hr /></div>
2428
2428
  <div id="footer">
2429
2429
  <div id="footer-text">
2430
- Last updated 2010-05-31 21:19:11 CEST
2430
+ Last updated 2010-06-01 18:33:18 CEST
2431
2431
  </div>
2432
2432
  </div>
2433
2433
  </body>
@@ -0,0 +1,117 @@
1
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
2
+ <html xmlns="http://www.w3.org/1999/xhtml">
3
+ <head>
4
+ <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
5
+ <title>Passenger: Bucket.h Source File</title>
6
+ <link href="tabs.css" rel="stylesheet" type="text/css"/>
7
+ <link href="doxygen.css" rel="stylesheet" type="text/css"/>
8
+ </head>
9
+ <body>
10
+ <!-- Generated by Doxygen 1.6.2 -->
11
+ <div class="navigation" id="top">
12
+ <div class="tabs">
13
+ <ul>
14
+ <li><a href="main.html"><span>Main&nbsp;Page</span></a></li>
15
+ <li><a href="modules.html"><span>Modules</span></a></li>
16
+ <li><a href="annotated.html"><span>Classes</span></a></li>
17
+ <li class="current"><a href="files.html"><span>Files</span></a></li>
18
+ </ul>
19
+ </div>
20
+ <div class="tabs">
21
+ <ul>
22
+ <li><a href="files.html"><span>File&nbsp;List</span></a></li>
23
+ </ul>
24
+ </div>
25
+ <h1>Bucket.h</h1><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/*</span>
26
+ <a name="l00002"></a>00002 <span class="comment"> * Phusion Passenger - http://www.modrails.com/</span>
27
+ <a name="l00003"></a>00003 <span class="comment"> * Copyright (c) 2008, 2009 Phusion</span>
28
+ <a name="l00004"></a>00004 <span class="comment"> *</span>
29
+ <a name="l00005"></a>00005 <span class="comment"> * &quot;Phusion Passenger&quot; is a trademark of Hongli Lai &amp; Ninh Bui.</span>
30
+ <a name="l00006"></a>00006 <span class="comment"> *</span>
31
+ <a name="l00007"></a>00007 <span class="comment"> * Permission is hereby granted, free of charge, to any person obtaining a copy</span>
32
+ <a name="l00008"></a>00008 <span class="comment"> * of this software and associated documentation files (the &quot;Software&quot;), to deal</span>
33
+ <a name="l00009"></a>00009 <span class="comment"> * in the Software without restriction, including without limitation the rights</span>
34
+ <a name="l00010"></a>00010 <span class="comment"> * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell</span>
35
+ <a name="l00011"></a>00011 <span class="comment"> * copies of the Software, and to permit persons to whom the Software is</span>
36
+ <a name="l00012"></a>00012 <span class="comment"> * furnished to do so, subject to the following conditions:</span>
37
+ <a name="l00013"></a>00013 <span class="comment"> *</span>
38
+ <a name="l00014"></a>00014 <span class="comment"> * The above copyright notice and this permission notice shall be included in</span>
39
+ <a name="l00015"></a>00015 <span class="comment"> * all copies or substantial portions of the Software.</span>
40
+ <a name="l00016"></a>00016 <span class="comment"> *</span>
41
+ <a name="l00017"></a>00017 <span class="comment"> * THE SOFTWARE IS PROVIDED &quot;AS IS&quot;, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR</span>
42
+ <a name="l00018"></a>00018 <span class="comment"> * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,</span>
43
+ <a name="l00019"></a>00019 <span class="comment"> * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE</span>
44
+ <a name="l00020"></a>00020 <span class="comment"> * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER</span>
45
+ <a name="l00021"></a>00021 <span class="comment"> * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,</span>
46
+ <a name="l00022"></a>00022 <span class="comment"> * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN</span>
47
+ <a name="l00023"></a>00023 <span class="comment"> * THE SOFTWARE.</span>
48
+ <a name="l00024"></a>00024 <span class="comment"> */</span>
49
+ <a name="l00025"></a>00025 <span class="preprocessor">#ifndef _PASSENGER_BUCKET_H_</span>
50
+ <a name="l00026"></a>00026 <span class="preprocessor"></span><span class="preprocessor">#define _PASSENGER_BUCKET_H_</span>
51
+ <a name="l00027"></a>00027 <span class="preprocessor"></span>
52
+ <a name="l00028"></a>00028 <span class="preprocessor">#include &lt;boost/shared_ptr.hpp&gt;</span>
53
+ <a name="l00029"></a>00029 <span class="preprocessor">#include &lt;apr_buckets.h&gt;</span>
54
+ <a name="l00030"></a>00030 <span class="preprocessor">#include &quot;Application.h&quot;</span>
55
+ <a name="l00031"></a>00031
56
+ <a name="l00032"></a>00032 <span class="keyword">namespace </span>Passenger {
57
+ <a name="l00033"></a>00033
58
+ <a name="l00034"></a>00034 <span class="keyword">using namespace </span>boost;
59
+ <a name="l00035"></a>00035
60
+ <a name="l00036"></a>00036 <span class="keyword">struct </span>PassengerBucketState {<span class="comment"></span>
61
+ <a name="l00037"></a>00037 <span class="comment"> /** The number of bytes that this PassengerBucket has read so far. */</span>
62
+ <a name="l00038"></a>00038 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> bytesRead;
63
+ <a name="l00039"></a>00039 <span class="comment"></span>
64
+ <a name="l00040"></a>00040 <span class="comment"> /** Whether this PassengerBucket is completed, i.e. no more data</span>
65
+ <a name="l00041"></a>00041 <span class="comment"> * can be read from the underlying file descriptor. When true,</span>
66
+ <a name="l00042"></a>00042 <span class="comment"> * this can either mean that EOF has been reached, or that an I/O</span>
67
+ <a name="l00043"></a>00043 <span class="comment"> * error occured. Use errorCode to check whether an error occurred.</span>
68
+ <a name="l00044"></a>00044 <span class="comment"> */</span>
69
+ <a name="l00045"></a>00045 <span class="keywordtype">bool</span> completed;
70
+ <a name="l00046"></a>00046 <span class="comment"></span>
71
+ <a name="l00047"></a>00047 <span class="comment"> /** When completed is true, errorCode contains the errno value of</span>
72
+ <a name="l00048"></a>00048 <span class="comment"> * the last read() call.</span>
73
+ <a name="l00049"></a>00049 <span class="comment"> *</span>
74
+ <a name="l00050"></a>00050 <span class="comment"> * A value of 0 means that no error occured.</span>
75
+ <a name="l00051"></a>00051 <span class="comment"> */</span>
76
+ <a name="l00052"></a>00052 <span class="keywordtype">int</span> errorCode;
77
+ <a name="l00053"></a>00053
78
+ <a name="l00054"></a>00054 PassengerBucketState() {
79
+ <a name="l00055"></a>00055 bytesRead = 0;
80
+ <a name="l00056"></a>00056 completed = <span class="keyword">false</span>;
81
+ <a name="l00057"></a>00057 errorCode = 0;
82
+ <a name="l00058"></a>00058 }
83
+ <a name="l00059"></a>00059 };
84
+ <a name="l00060"></a>00060
85
+ <a name="l00061"></a>00061 <span class="keyword">typedef</span> shared_ptr&lt;PassengerBucketState&gt; PassengerBucketStatePtr;
86
+ <a name="l00062"></a>00062 <span class="comment"></span>
87
+ <a name="l00063"></a>00063 <span class="comment">/**</span>
88
+ <a name="l00064"></a>00064 <span class="comment"> * We used to use an apr_bucket_pipe for forwarding the backend process&#39;s</span>
89
+ <a name="l00065"></a>00065 <span class="comment"> * response to the HTTP client. However, apr_bucket_pipe has a number of</span>
90
+ <a name="l00066"></a>00066 <span class="comment"> * issues:</span>
91
+ <a name="l00067"></a>00067 <span class="comment"> * - It closes the pipe&#39;s file descriptor when it has reached</span>
92
+ <a name="l00068"></a>00068 <span class="comment"> * end-of-stream, but not when an error has occurred. This behavior is</span>
93
+ <a name="l00069"></a>00069 <span class="comment"> * undesirable because it can easily cause file descriptor leaks.</span>
94
+ <a name="l00070"></a>00070 <span class="comment"> * - It does weird non-blocking-I/O related things which can cause it</span>
95
+ <a name="l00071"></a>00071 <span class="comment"> * to read less data than can actually be read.</span>
96
+ <a name="l00072"></a>00072 <span class="comment"> *</span>
97
+ <a name="l00073"></a>00073 <span class="comment"> * PassengerBucket is like apr_bucket_pipe, but:</span>
98
+ <a name="l00074"></a>00074 <span class="comment"> * - It also holds a reference to a Session. When a read error has occured</span>
99
+ <a name="l00075"></a>00075 <span class="comment"> * or when end-of-stream has been reached, the Session will be</span>
100
+ <a name="l00076"></a>00076 <span class="comment"> * dereferenced, so that the underlying file descriptor is closed.</span>
101
+ <a name="l00077"></a>00077 <span class="comment"> * - It ignores the APR_NONBLOCK_READ flag because that&#39;s known to cause</span>
102
+ <a name="l00078"></a>00078 <span class="comment"> * strange I/O problems.</span>
103
+ <a name="l00079"></a>00079 <span class="comment"> * - It can store its current state in a PassengerBucketState data structure.</span>
104
+ <a name="l00080"></a>00080 <span class="comment"> */</span>
105
+ <a name="l00081"></a>00081 apr_bucket *passenger_bucket_create(Passenger::Application::SessionPtr session,
106
+ <a name="l00082"></a>00082 PassengerBucketStatePtr state,
107
+ <a name="l00083"></a>00083 apr_bucket_alloc_t *list);
108
+ <a name="l00084"></a>00084
109
+ <a name="l00085"></a>00085 } <span class="comment">// namespace Passenger</span>
110
+ <a name="l00086"></a>00086
111
+ <a name="l00087"></a>00087 <span class="preprocessor">#endif </span><span class="comment">/* _PASSENGER_BUCKET_H_ */</span>
112
+ </pre></div></div>
113
+ <hr size="1"/><address style="text-align: right;"><small>Generated by&nbsp;
114
+ <a href="http://www.doxygen.org/index.html">
115
+ <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.6.2 </small></address>
116
+ </body>
117
+ </html>
@@ -0,0 +1,435 @@
1
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
2
+ <html xmlns="http://www.w3.org/1999/xhtml">
3
+ <head>
4
+ <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
5
+ <title>Passenger: Configuration.h Source File</title>
6
+ <link href="tabs.css" rel="stylesheet" type="text/css"/>
7
+ <link href="doxygen.css" rel="stylesheet" type="text/css"/>
8
+ </head>
9
+ <body>
10
+ <!-- Generated by Doxygen 1.6.2 -->
11
+ <div class="navigation" id="top">
12
+ <div class="tabs">
13
+ <ul>
14
+ <li><a href="main.html"><span>Main&nbsp;Page</span></a></li>
15
+ <li><a href="modules.html"><span>Modules</span></a></li>
16
+ <li><a href="annotated.html"><span>Classes</span></a></li>
17
+ <li class="current"><a href="files.html"><span>Files</span></a></li>
18
+ </ul>
19
+ </div>
20
+ <div class="tabs">
21
+ <ul>
22
+ <li><a href="files.html"><span>File&nbsp;List</span></a></li>
23
+ </ul>
24
+ </div>
25
+ <h1>Configuration.h</h1><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/*</span>
26
+ <a name="l00002"></a>00002 <span class="comment"> * Phusion Passenger - http://www.modrails.com/</span>
27
+ <a name="l00003"></a>00003 <span class="comment"> * Copyright (c) 2008, 2009 Phusion</span>
28
+ <a name="l00004"></a>00004 <span class="comment"> *</span>
29
+ <a name="l00005"></a>00005 <span class="comment"> * &quot;Phusion Passenger&quot; is a trademark of Hongli Lai &amp; Ninh Bui.</span>
30
+ <a name="l00006"></a>00006 <span class="comment"> *</span>
31
+ <a name="l00007"></a>00007 <span class="comment"> * Permission is hereby granted, free of charge, to any person obtaining a copy</span>
32
+ <a name="l00008"></a>00008 <span class="comment"> * of this software and associated documentation files (the &quot;Software&quot;), to deal</span>
33
+ <a name="l00009"></a>00009 <span class="comment"> * in the Software without restriction, including without limitation the rights</span>
34
+ <a name="l00010"></a>00010 <span class="comment"> * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell</span>
35
+ <a name="l00011"></a>00011 <span class="comment"> * copies of the Software, and to permit persons to whom the Software is</span>
36
+ <a name="l00012"></a>00012 <span class="comment"> * furnished to do so, subject to the following conditions:</span>
37
+ <a name="l00013"></a>00013 <span class="comment"> *</span>
38
+ <a name="l00014"></a>00014 <span class="comment"> * The above copyright notice and this permission notice shall be included in</span>
39
+ <a name="l00015"></a>00015 <span class="comment"> * all copies or substantial portions of the Software.</span>
40
+ <a name="l00016"></a>00016 <span class="comment"> *</span>
41
+ <a name="l00017"></a>00017 <span class="comment"> * THE SOFTWARE IS PROVIDED &quot;AS IS&quot;, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR</span>
42
+ <a name="l00018"></a>00018 <span class="comment"> * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,</span>
43
+ <a name="l00019"></a>00019 <span class="comment"> * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE</span>
44
+ <a name="l00020"></a>00020 <span class="comment"> * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER</span>
45
+ <a name="l00021"></a>00021 <span class="comment"> * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,</span>
46
+ <a name="l00022"></a>00022 <span class="comment"> * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN</span>
47
+ <a name="l00023"></a>00023 <span class="comment"> * THE SOFTWARE.</span>
48
+ <a name="l00024"></a>00024 <span class="comment"> */</span>
49
+ <a name="l00025"></a>00025 <span class="preprocessor">#ifndef _PASSENGER_CONFIGURATION_H_</span>
50
+ <a name="l00026"></a>00026 <span class="preprocessor"></span><span class="preprocessor">#define _PASSENGER_CONFIGURATION_H_</span>
51
+ <a name="l00027"></a>00027 <span class="preprocessor"></span>
52
+ <a name="l00028"></a>00028 <span class="preprocessor">#ifdef __cplusplus</span>
53
+ <a name="l00029"></a>00029 <span class="preprocessor"></span><span class="preprocessor"> #include &quot;Utils.h&quot;</span>
54
+ <a name="l00030"></a>00030 <span class="preprocessor"> #include &quot;MessageChannel.h&quot;</span>
55
+ <a name="l00031"></a>00031 <span class="preprocessor"> #include &quot;Logging.h&quot;</span>
56
+ <a name="l00032"></a>00032 <span class="preprocessor">#endif</span>
57
+ <a name="l00033"></a>00033 <span class="preprocessor"></span>
58
+ <a name="l00034"></a>00034 <span class="comment">/* The APR headers must come after the Passenger headers. See Hooks.cpp</span>
59
+ <a name="l00035"></a>00035 <span class="comment"> * to learn why.</span>
60
+ <a name="l00036"></a>00036 <span class="comment"> *</span>
61
+ <a name="l00037"></a>00037 <span class="comment"> * MessageChannel.h must be included -- even though we don&#39;t actually use</span>
62
+ <a name="l00038"></a>00038 <span class="comment"> * MessageChannel.h in here, it&#39;s necessary to make sure that apr_want.h</span>
63
+ <a name="l00039"></a>00039 <span class="comment"> * doesn&#39;t b0rk on &#39;struct iovec&#39;.</span>
64
+ <a name="l00040"></a>00040 <span class="comment"> */</span>
65
+ <a name="l00041"></a>00041 <span class="preprocessor">#include &lt;apr_pools.h&gt;</span>
66
+ <a name="l00042"></a>00042 <span class="preprocessor">#include &lt;httpd.h&gt;</span>
67
+ <a name="l00043"></a>00043 <span class="preprocessor">#include &lt;http_config.h&gt;</span>
68
+ <a name="l00044"></a>00044 <span class="comment"></span>
69
+ <a name="l00045"></a>00045 <span class="comment">/**</span>
70
+ <a name="l00046"></a>00046 <span class="comment"> * @defgroup Configuration Apache module configuration</span>
71
+ <a name="l00047"></a>00047 <span class="comment"> * @ingroup Core</span>
72
+ <a name="l00048"></a>00048 <span class="comment"> * @{</span>
73
+ <a name="l00049"></a>00049 <span class="comment"> */</span>
74
+ <a name="l00050"></a>00050
75
+ <a name="l00051"></a>00051 <span class="preprocessor">#ifdef __cplusplus</span>
76
+ <a name="l00052"></a>00052 <span class="preprocessor"></span><span class="preprocessor"> #include &lt;set&gt;</span>
77
+ <a name="l00053"></a>00053 <span class="preprocessor"> #include &lt;string&gt;</span>
78
+ <a name="l00054"></a>00054
79
+ <a name="l00055"></a>00055 <span class="keyword">namespace </span>Passenger {
80
+ <a name="l00056"></a>00056
81
+ <a name="l00057"></a>00057 <span class="keyword">using namespace </span>std;
82
+ <a name="l00058"></a>00058 <span class="comment"></span>
83
+ <a name="l00059"></a>00059 <span class="comment"> /**</span>
84
+ <a name="l00060"></a>00060 <span class="comment"> * Per-directory configuration information.</span>
85
+ <a name="l00061"></a>00061 <span class="comment"> *</span>
86
+ <a name="l00062"></a>00062 <span class="comment"> * Use the getter methods to query information, because those will return</span>
87
+ <a name="l00063"></a>00063 <span class="comment"> * the default value if the value is not specified.</span>
88
+ <a name="l00064"></a>00064 <span class="comment"> */</span>
89
+ <a name="l00065"></a>00065 <span class="keyword">struct </span>DirConfig {
90
+ <a name="l00066"></a>00066 <span class="keyword">enum</span> Threeway { ENABLED, DISABLED, UNSET };
91
+ <a name="l00067"></a>00067 <span class="keyword">enum</span> SpawnMethod { SM_UNSET, SM_SMART, SM_SMART_LV2, SM_CONSERVATIVE };
92
+ <a name="l00068"></a>00068
93
+ <a name="l00069"></a>00069 Threeway enabled;
94
+ <a name="l00070"></a>00070
95
+ <a name="l00071"></a>00071 std::set&lt;std::string&gt; railsBaseURIs;
96
+ <a name="l00072"></a>00072 std::set&lt;std::string&gt; rackBaseURIs;
97
+ <a name="l00073"></a>00073 <span class="comment"></span>
98
+ <a name="l00074"></a>00074 <span class="comment"> /** Whether to autodetect Rails applications. */</span>
99
+ <a name="l00075"></a>00075 Threeway autoDetectRails;
100
+ <a name="l00076"></a>00076 <span class="comment"></span>
101
+ <a name="l00077"></a>00077 <span class="comment"> /** Whether to autodetect Rack applications. */</span>
102
+ <a name="l00078"></a>00078 Threeway autoDetectRack;
103
+ <a name="l00079"></a>00079 <span class="comment"></span>
104
+ <a name="l00080"></a>00080 <span class="comment"> /** Whether to autodetect WSGI applications. */</span>
105
+ <a name="l00081"></a>00081 Threeway autoDetectWSGI;
106
+ <a name="l00082"></a>00082 <span class="comment"></span>
107
+ <a name="l00083"></a>00083 <span class="comment"> /** Whether mod_rewrite should be allowed for Rails applications. */</span>
108
+ <a name="l00084"></a>00084 Threeway allowModRewrite;
109
+ <a name="l00085"></a>00085 <span class="comment"></span>
110
+ <a name="l00086"></a>00086 <span class="comment"> /** The environment (i.e. value for RAILS_ENV) under which</span>
111
+ <a name="l00087"></a>00087 <span class="comment"> * Rails applications should operate. */</span>
112
+ <a name="l00088"></a>00088 <span class="keyword">const</span> <span class="keywordtype">char</span> *railsEnv;
113
+ <a name="l00089"></a>00089 <span class="comment"></span>
114
+ <a name="l00090"></a>00090 <span class="comment"> /** The path to the application&#39;s root (for example: RAILS_ROOT</span>
115
+ <a name="l00091"></a>00091 <span class="comment"> * for Rails applications, directory containing &#39;config.ru&#39;</span>
116
+ <a name="l00092"></a>00092 <span class="comment"> * for Rack applications). If this value is NULL, the default</span>
117
+ <a name="l00093"></a>00093 <span class="comment"> * autodetected path will be used.</span>
118
+ <a name="l00094"></a>00094 <span class="comment"> */</span>
119
+ <a name="l00095"></a>00095 <span class="keyword">const</span> <span class="keywordtype">char</span> *appRoot;
120
+ <a name="l00096"></a>00096 <span class="comment"></span>
121
+ <a name="l00097"></a>00097 <span class="comment"> /** The environment (i.e. value for RACK_ENV) under which</span>
122
+ <a name="l00098"></a>00098 <span class="comment"> * Rack applications should operate. */</span>
123
+ <a name="l00099"></a>00099 <span class="keyword">const</span> <span class="keywordtype">char</span> *rackEnv;
124
+ <a name="l00100"></a>00100 <span class="comment"></span>
125
+ <a name="l00101"></a>00101 <span class="comment"> /** The Rails spawn method to use. */</span>
126
+ <a name="l00102"></a>00102 SpawnMethod spawnMethod;
127
+ <a name="l00103"></a>00103 <span class="comment"></span>
128
+ <a name="l00104"></a>00104 <span class="comment"> /**</span>
129
+ <a name="l00105"></a>00105 <span class="comment"> * The idle timeout, in seconds, of Rails framework spawners.</span>
130
+ <a name="l00106"></a>00106 <span class="comment"> * May also be 0 (which indicates that the framework spawner should</span>
131
+ <a name="l00107"></a>00107 <span class="comment"> * never idle timeout) or -1 (which means that the value is not specified).</span>
132
+ <a name="l00108"></a>00108 <span class="comment"> */</span>
133
+ <a name="l00109"></a>00109 <span class="keywordtype">long</span> frameworkSpawnerTimeout;
134
+ <a name="l00110"></a>00110 <span class="comment"></span>
135
+ <a name="l00111"></a>00111 <span class="comment"> /**</span>
136
+ <a name="l00112"></a>00112 <span class="comment"> * The idle timeout, in seconds, of Rails application spawners.</span>
137
+ <a name="l00113"></a>00113 <span class="comment"> * May also be 0 (which indicates that the application spawner should</span>
138
+ <a name="l00114"></a>00114 <span class="comment"> * never idle timeout) or -1 (which means that the value is not specified).</span>
139
+ <a name="l00115"></a>00115 <span class="comment"> */</span>
140
+ <a name="l00116"></a>00116 <span class="keywordtype">long</span> appSpawnerTimeout;
141
+ <a name="l00117"></a>00117 <span class="comment"></span>
142
+ <a name="l00118"></a>00118 <span class="comment"> /**</span>
143
+ <a name="l00119"></a>00119 <span class="comment"> * The maximum number of requests that the spawned application may process</span>
144
+ <a name="l00120"></a>00120 <span class="comment"> * before exiting. A value of 0 means unlimited.</span>
145
+ <a name="l00121"></a>00121 <span class="comment"> */</span>
146
+ <a name="l00122"></a>00122 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> maxRequests;
147
+ <a name="l00123"></a>00123 <span class="comment"></span>
148
+ <a name="l00124"></a>00124 <span class="comment"> /** Indicates whether the maxRequests option was explicitly specified</span>
149
+ <a name="l00125"></a>00125 <span class="comment"> * in the directory configuration. */</span>
150
+ <a name="l00126"></a>00126 <span class="keywordtype">bool</span> maxRequestsSpecified;
151
+ <a name="l00127"></a>00127 <span class="comment"></span>
152
+ <a name="l00128"></a>00128 <span class="comment"> /**</span>
153
+ <a name="l00129"></a>00129 <span class="comment"> * The maximum amount of memory (in MB) the spawned application may use.</span>
154
+ <a name="l00130"></a>00130 <span class="comment"> * A value of 0 means unlimited.</span>
155
+ <a name="l00131"></a>00131 <span class="comment"> */</span>
156
+ <a name="l00132"></a>00132 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> memoryLimit;
157
+ <a name="l00133"></a>00133 <span class="comment"></span>
158
+ <a name="l00134"></a>00134 <span class="comment"> /** Indicates whether the memoryLimit option was explicitly specified</span>
159
+ <a name="l00135"></a>00135 <span class="comment"> * in the directory configuration. */</span>
160
+ <a name="l00136"></a>00136 <span class="keywordtype">bool</span> memoryLimitSpecified;
161
+ <a name="l00137"></a>00137 <span class="comment"></span>
162
+ <a name="l00138"></a>00138 <span class="comment"> /** Whether symlinks in the document root path should be resolved.</span>
163
+ <a name="l00139"></a>00139 <span class="comment"> * The implication of this is documented in the users guide, section</span>
164
+ <a name="l00140"></a>00140 <span class="comment"> * &quot;How Phusion Passenger detects whether a virtual host is a web application&quot;.</span>
165
+ <a name="l00141"></a>00141 <span class="comment"> */</span>
166
+ <a name="l00142"></a>00142 Threeway resolveSymlinksInDocRoot;
167
+ <a name="l00143"></a>00143 <span class="comment"></span>
168
+ <a name="l00144"></a>00144 <span class="comment"> /** Whether high performance mode should be turned on. */</span>
169
+ <a name="l00145"></a>00145 Threeway highPerformance;
170
+ <a name="l00146"></a>00146 <span class="comment"></span>
171
+ <a name="l00147"></a>00147 <span class="comment"> /** Whether global queuing should be used. */</span>
172
+ <a name="l00148"></a>00148 Threeway useGlobalQueue;
173
+ <a name="l00149"></a>00149 <span class="comment"></span>
174
+ <a name="l00150"></a>00150 <span class="comment"> /**</span>
175
+ <a name="l00151"></a>00151 <span class="comment"> * Whether encoded slashes in URLs should be supported. This however conflicts</span>
176
+ <a name="l00152"></a>00152 <span class="comment"> * with mod_rewrite support because of a bug/limitation in Apache, so it&#39;s one</span>
177
+ <a name="l00153"></a>00153 <span class="comment"> * or the other.</span>
178
+ <a name="l00154"></a>00154 <span class="comment"> */</span>
179
+ <a name="l00155"></a>00155 Threeway allowEncodedSlashes;
180
+ <a name="l00156"></a>00156 <span class="comment"></span>
181
+ <a name="l00157"></a>00157 <span class="comment"> /**</span>
182
+ <a name="l00158"></a>00158 <span class="comment"> * Throttle the number of stat() calls on files like</span>
183
+ <a name="l00159"></a>00159 <span class="comment"> * restart.txt to the once per given number of seconds.</span>
184
+ <a name="l00160"></a>00160 <span class="comment"> */</span>
185
+ <a name="l00161"></a>00161 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> statThrottleRate;
186
+ <a name="l00162"></a>00162 <span class="comment"></span>
187
+ <a name="l00163"></a>00163 <span class="comment"> /** Indicates whether the statThrottleRate option was</span>
188
+ <a name="l00164"></a>00164 <span class="comment"> * explicitly specified in the directory configuration. */</span>
189
+ <a name="l00165"></a>00165 <span class="keywordtype">bool</span> statThrottleRateSpecified;
190
+ <a name="l00166"></a>00166 <span class="comment"></span>
191
+ <a name="l00167"></a>00167 <span class="comment"> /** The directory in which Passenger should look for</span>
192
+ <a name="l00168"></a>00168 <span class="comment"> * restart.txt. NULL means that the default directory</span>
193
+ <a name="l00169"></a>00169 <span class="comment"> * should be used.</span>
194
+ <a name="l00170"></a>00170 <span class="comment"> */</span>
195
+ <a name="l00171"></a>00171 <span class="keyword">const</span> <span class="keywordtype">char</span> *restartDir;
196
+ <a name="l00172"></a>00172 <span class="comment"></span>
197
+ <a name="l00173"></a>00173 <span class="comment"> /**</span>
198
+ <a name="l00174"></a>00174 <span class="comment"> * The directory in which Passenger should place upload buffer</span>
199
+ <a name="l00175"></a>00175 <span class="comment"> * files. NULL means that the default directory should be used.</span>
200
+ <a name="l00176"></a>00176 <span class="comment"> */</span>
201
+ <a name="l00177"></a>00177 <span class="keyword">const</span> <span class="keywordtype">char</span> *uploadBufferDir;
202
+ <a name="l00178"></a>00178
203
+ <a name="l00179"></a>00179 <span class="comment">/*************************************/</span>
204
+ <a name="l00180"></a>00180 <span class="comment">/*************************************/</span>
205
+ <a name="l00181"></a>00181
206
+ <a name="l00182"></a>00182 <span class="keywordtype">bool</span> isEnabled()<span class="keyword"> const </span>{
207
+ <a name="l00183"></a>00183 <span class="keywordflow">return</span> enabled != DISABLED;
208
+ <a name="l00184"></a>00184 }
209
+ <a name="l00185"></a>00185
210
+ <a name="l00186"></a>00186 <span class="keywordtype">string</span> getAppRoot(<span class="keyword">const</span> <span class="keywordtype">char</span> *documentRoot)<span class="keyword"> const </span>{
211
+ <a name="l00187"></a>00187 <span class="keywordflow">if</span> (appRoot == NULL) {
212
+ <a name="l00188"></a>00188 <span class="keywordflow">if</span> (resolveSymlinksInDocRoot == DirConfig::ENABLED) {
213
+ <a name="l00189"></a>00189 <span class="keywordflow">return</span> extractDirName(resolveSymlink(documentRoot));
214
+ <a name="l00190"></a>00190 } <span class="keywordflow">else</span> {
215
+ <a name="l00191"></a>00191 <span class="keywordflow">return</span> extractDirName(documentRoot);
216
+ <a name="l00192"></a>00192 }
217
+ <a name="l00193"></a>00193 } <span class="keywordflow">else</span> {
218
+ <a name="l00194"></a>00194 <span class="keywordflow">return</span> appRoot;
219
+ <a name="l00195"></a>00195 }
220
+ <a name="l00196"></a>00196 }
221
+ <a name="l00197"></a>00197
222
+ <a name="l00198"></a>00198 <span class="keywordtype">string</span> getAppRoot(<span class="keyword">const</span> <span class="keywordtype">string</span> &amp;documentRoot)<span class="keyword"> const </span>{
223
+ <a name="l00199"></a>00199 <span class="keywordflow">if</span> (appRoot == NULL) {
224
+ <a name="l00200"></a>00200 <span class="keywordflow">if</span> (resolveSymlinksInDocRoot == DirConfig::ENABLED) {
225
+ <a name="l00201"></a>00201 <span class="keywordflow">return</span> extractDirName(resolveSymlink(documentRoot));
226
+ <a name="l00202"></a>00202 } <span class="keywordflow">else</span> {
227
+ <a name="l00203"></a>00203 <span class="keywordflow">return</span> extractDirName(documentRoot);
228
+ <a name="l00204"></a>00204 }
229
+ <a name="l00205"></a>00205 } <span class="keywordflow">else</span> {
230
+ <a name="l00206"></a>00206 <span class="keywordflow">return</span> appRoot;
231
+ <a name="l00207"></a>00207 }
232
+ <a name="l00208"></a>00208 }
233
+ <a name="l00209"></a>00209
234
+ <a name="l00210"></a>00210 <span class="keyword">const</span> <span class="keywordtype">char</span> *getRailsEnv()<span class="keyword"> const </span>{
235
+ <a name="l00211"></a>00211 <span class="keywordflow">if</span> (railsEnv != NULL) {
236
+ <a name="l00212"></a>00212 <span class="keywordflow">return</span> railsEnv;
237
+ <a name="l00213"></a>00213 } <span class="keywordflow">else</span> {
238
+ <a name="l00214"></a>00214 <span class="keywordflow">return</span> <span class="stringliteral">&quot;production&quot;</span>;
239
+ <a name="l00215"></a>00215 }
240
+ <a name="l00216"></a>00216 }
241
+ <a name="l00217"></a>00217
242
+ <a name="l00218"></a>00218 <span class="keyword">const</span> <span class="keywordtype">char</span> *getRackEnv()<span class="keyword"> const </span>{
243
+ <a name="l00219"></a>00219 <span class="keywordflow">if</span> (rackEnv != NULL) {
244
+ <a name="l00220"></a>00220 <span class="keywordflow">return</span> rackEnv;
245
+ <a name="l00221"></a>00221 } <span class="keywordflow">else</span> {
246
+ <a name="l00222"></a>00222 <span class="keywordflow">return</span> <span class="stringliteral">&quot;production&quot;</span>;
247
+ <a name="l00223"></a>00223 }
248
+ <a name="l00224"></a>00224 }
249
+ <a name="l00225"></a>00225
250
+ <a name="l00226"></a>00226 <span class="keyword">const</span> <span class="keywordtype">char</span> *getSpawnMethodString() {
251
+ <a name="l00227"></a>00227 <span class="keywordflow">switch</span> (spawnMethod) {
252
+ <a name="l00228"></a>00228 <span class="keywordflow">case</span> SM_SMART:
253
+ <a name="l00229"></a>00229 <span class="keywordflow">return</span> <span class="stringliteral">&quot;smart&quot;</span>;
254
+ <a name="l00230"></a>00230 <span class="keywordflow">case</span> SM_SMART_LV2:
255
+ <a name="l00231"></a>00231 <span class="keywordflow">return</span> <span class="stringliteral">&quot;smart-lv2&quot;</span>;
256
+ <a name="l00232"></a>00232 <span class="keywordflow">case</span> SM_CONSERVATIVE:
257
+ <a name="l00233"></a>00233 <span class="keywordflow">return</span> <span class="stringliteral">&quot;conservative&quot;</span>;
258
+ <a name="l00234"></a>00234 <span class="keywordflow">default</span>:
259
+ <a name="l00235"></a>00235 <span class="keywordflow">return</span> <span class="stringliteral">&quot;smart-lv2&quot;</span>;
260
+ <a name="l00236"></a>00236 }
261
+ <a name="l00237"></a>00237 }
262
+ <a name="l00238"></a>00238
263
+ <a name="l00239"></a>00239 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> getMaxRequests() {
264
+ <a name="l00240"></a>00240 <span class="keywordflow">if</span> (maxRequestsSpecified) {
265
+ <a name="l00241"></a>00241 <span class="keywordflow">return</span> maxRequests;
266
+ <a name="l00242"></a>00242 } <span class="keywordflow">else</span> {
267
+ <a name="l00243"></a>00243 <span class="keywordflow">return</span> 0;
268
+ <a name="l00244"></a>00244 }
269
+ <a name="l00245"></a>00245 }
270
+ <a name="l00246"></a>00246
271
+ <a name="l00247"></a>00247 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> getMemoryLimit() {
272
+ <a name="l00248"></a>00248 <span class="keywordflow">if</span> (memoryLimitSpecified) {
273
+ <a name="l00249"></a>00249 <span class="keywordflow">return</span> memoryLimit;
274
+ <a name="l00250"></a>00250 } <span class="keywordflow">else</span> {
275
+ <a name="l00251"></a>00251 <span class="keywordflow">return</span> 200;
276
+ <a name="l00252"></a>00252 }
277
+ <a name="l00253"></a>00253 }
278
+ <a name="l00254"></a>00254
279
+ <a name="l00255"></a>00255 <span class="keywordtype">bool</span> highPerformanceMode()<span class="keyword"> const </span>{
280
+ <a name="l00256"></a>00256 <span class="keywordflow">return</span> highPerformance == ENABLED;
281
+ <a name="l00257"></a>00257 }
282
+ <a name="l00258"></a>00258
283
+ <a name="l00259"></a>00259 <span class="keywordtype">bool</span> usingGlobalQueue()<span class="keyword"> const </span>{
284
+ <a name="l00260"></a>00260 <span class="keywordflow">return</span> useGlobalQueue == ENABLED;
285
+ <a name="l00261"></a>00261 }
286
+ <a name="l00262"></a>00262
287
+ <a name="l00263"></a>00263 <span class="keywordtype">bool</span> allowsEncodedSlashes()<span class="keyword"> const </span>{
288
+ <a name="l00264"></a>00264 <span class="keywordflow">return</span> allowEncodedSlashes == ENABLED;
289
+ <a name="l00265"></a>00265 }
290
+ <a name="l00266"></a>00266
291
+ <a name="l00267"></a>00267 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> getStatThrottleRate()<span class="keyword"> const </span>{
292
+ <a name="l00268"></a>00268 <span class="keywordflow">if</span> (statThrottleRateSpecified) {
293
+ <a name="l00269"></a>00269 <span class="keywordflow">return</span> statThrottleRate;
294
+ <a name="l00270"></a>00270 } <span class="keywordflow">else</span> {
295
+ <a name="l00271"></a>00271 <span class="keywordflow">return</span> 0;
296
+ <a name="l00272"></a>00272 }
297
+ <a name="l00273"></a>00273 }
298
+ <a name="l00274"></a>00274
299
+ <a name="l00275"></a>00275 <span class="keyword">const</span> <span class="keywordtype">char</span> *getRestartDir()<span class="keyword"> const </span>{
300
+ <a name="l00276"></a>00276 <span class="keywordflow">if</span> (restartDir != NULL) {
301
+ <a name="l00277"></a>00277 <span class="keywordflow">return</span> restartDir;
302
+ <a name="l00278"></a>00278 } <span class="keywordflow">else</span> {
303
+ <a name="l00279"></a>00279 <span class="keywordflow">return</span> <span class="stringliteral">&quot;&quot;</span>;
304
+ <a name="l00280"></a>00280 }
305
+ <a name="l00281"></a>00281 }
306
+ <a name="l00282"></a>00282
307
+ <a name="l00283"></a>00283 <span class="keywordtype">string</span> getUploadBufferDir()<span class="keyword"> const </span>{
308
+ <a name="l00284"></a>00284 <span class="keywordflow">if</span> (uploadBufferDir != NULL) {
309
+ <a name="l00285"></a>00285 <span class="keywordflow">return</span> uploadBufferDir;
310
+ <a name="l00286"></a>00286 } <span class="keywordflow">else</span> {
311
+ <a name="l00287"></a>00287 <span class="keywordflow">return</span> getPassengerTempDir() + <span class="stringliteral">&quot;/webserver_private&quot;</span>;
312
+ <a name="l00288"></a>00288 }
313
+ <a name="l00289"></a>00289 }
314
+ <a name="l00290"></a>00290
315
+ <a name="l00291"></a>00291 <span class="comment">/*************************************/</span>
316
+ <a name="l00292"></a>00292 };
317
+ <a name="l00293"></a>00293 <span class="comment"></span>
318
+ <a name="l00294"></a>00294 <span class="comment"> /**</span>
319
+ <a name="l00295"></a>00295 <span class="comment"> * Server-wide (global, not per-virtual host) configuration information.</span>
320
+ <a name="l00296"></a>00296 <span class="comment"> *</span>
321
+ <a name="l00297"></a>00297 <span class="comment"> * Use the getter methods to query information, because those will return</span>
322
+ <a name="l00298"></a>00298 <span class="comment"> * the default value if the value is not specified.</span>
323
+ <a name="l00299"></a>00299 <span class="comment"> */</span>
324
+ <a name="l00300"></a>00300 <span class="keyword">struct </span>ServerConfig {<span class="comment"></span>
325
+ <a name="l00301"></a>00301 <span class="comment"> /** The filename of the Ruby interpreter to use. */</span>
326
+ <a name="l00302"></a>00302 <span class="keyword">const</span> <span class="keywordtype">char</span> *ruby;
327
+ <a name="l00303"></a>00303 <span class="comment"></span>
328
+ <a name="l00304"></a>00304 <span class="comment"> /** The Passenger root folder. */</span>
329
+ <a name="l00305"></a>00305 <span class="keyword">const</span> <span class="keywordtype">char</span> *root;
330
+ <a name="l00306"></a>00306 <span class="comment"></span>
331
+ <a name="l00307"></a>00307 <span class="comment"> /** The log verbosity. */</span>
332
+ <a name="l00308"></a>00308 <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> logLevel;
333
+ <a name="l00309"></a>00309 <span class="comment"></span>
334
+ <a name="l00310"></a>00310 <span class="comment"> /** The maximum number of simultaneously alive application</span>
335
+ <a name="l00311"></a>00311 <span class="comment"> * instances. */</span>
336
+ <a name="l00312"></a>00312 <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> maxPoolSize;
337
+ <a name="l00313"></a>00313 <span class="comment"></span>
338
+ <a name="l00314"></a>00314 <span class="comment"> /** Whether the maxPoolSize option was explicitly specified in</span>
339
+ <a name="l00315"></a>00315 <span class="comment"> * this server config. */</span>
340
+ <a name="l00316"></a>00316 <span class="keywordtype">bool</span> maxPoolSizeSpecified;
341
+ <a name="l00317"></a>00317 <span class="comment"></span>
342
+ <a name="l00318"></a>00318 <span class="comment"> /** The maximum number of simultaneously alive Rails application</span>
343
+ <a name="l00319"></a>00319 <span class="comment"> * that a single Rails application may occupy. */</span>
344
+ <a name="l00320"></a>00320 <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> maxInstancesPerApp;
345
+ <a name="l00321"></a>00321 <span class="comment"></span>
346
+ <a name="l00322"></a>00322 <span class="comment"> /** Whether the maxInstancesPerApp option was explicitly specified in</span>
347
+ <a name="l00323"></a>00323 <span class="comment"> * this server config. */</span>
348
+ <a name="l00324"></a>00324 <span class="keywordtype">bool</span> maxInstancesPerAppSpecified;
349
+ <a name="l00325"></a>00325 <span class="comment"></span>
350
+ <a name="l00326"></a>00326 <span class="comment"> /** The maximum number of seconds that an application may be</span>
351
+ <a name="l00327"></a>00327 <span class="comment"> * idle before it gets terminated. */</span>
352
+ <a name="l00328"></a>00328 <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> poolIdleTime;
353
+ <a name="l00329"></a>00329 <span class="comment"></span>
354
+ <a name="l00330"></a>00330 <span class="comment"> /** Whether the poolIdleTime option was explicitly specified in</span>
355
+ <a name="l00331"></a>00331 <span class="comment"> * this server config. */</span>
356
+ <a name="l00332"></a>00332 <span class="keywordtype">bool</span> poolIdleTimeSpecified;
357
+ <a name="l00333"></a>00333 <span class="comment"></span>
358
+ <a name="l00334"></a>00334 <span class="comment"> /** Whether user switching support is enabled. */</span>
359
+ <a name="l00335"></a>00335 <span class="keywordtype">bool</span> userSwitching;
360
+ <a name="l00336"></a>00336 <span class="comment"></span>
361
+ <a name="l00337"></a>00337 <span class="comment"> /** Whether the userSwitching option was explicitly specified in</span>
362
+ <a name="l00338"></a>00338 <span class="comment"> * this server config. */</span>
363
+ <a name="l00339"></a>00339 <span class="keywordtype">bool</span> userSwitchingSpecified;
364
+ <a name="l00340"></a>00340 <span class="comment"></span>
365
+ <a name="l00341"></a>00341 <span class="comment"> /** The user that applications must run as if user switching</span>
366
+ <a name="l00342"></a>00342 <span class="comment"> * fails or is disabled. NULL means the option is not specified.</span>
367
+ <a name="l00343"></a>00343 <span class="comment"> */</span>
368
+ <a name="l00344"></a>00344 <span class="keyword">const</span> <span class="keywordtype">char</span> *defaultUser;
369
+ <a name="l00345"></a>00345 <span class="comment"></span>
370
+ <a name="l00346"></a>00346 <span class="comment"> /** The temp directory that Passenger should use. NULL</span>
371
+ <a name="l00347"></a>00347 <span class="comment"> * means unspecified.</span>
372
+ <a name="l00348"></a>00348 <span class="comment"> */</span>
373
+ <a name="l00349"></a>00349 <span class="keyword">const</span> <span class="keywordtype">char</span> *tempDir;
374
+ <a name="l00350"></a>00350
375
+ <a name="l00351"></a>00351 <span class="keyword">const</span> <span class="keywordtype">char</span> *getRuby()<span class="keyword"> const </span>{
376
+ <a name="l00352"></a>00352 <span class="keywordflow">if</span> (ruby != NULL) {
377
+ <a name="l00353"></a>00353 <span class="keywordflow">return</span> ruby;
378
+ <a name="l00354"></a>00354 } <span class="keywordflow">else</span> {
379
+ <a name="l00355"></a>00355 <span class="keywordflow">return</span> <span class="stringliteral">&quot;ruby&quot;</span>;
380
+ <a name="l00356"></a>00356 }
381
+ <a name="l00357"></a>00357 }
382
+ <a name="l00358"></a>00358
383
+ <a name="l00359"></a>00359 <span class="keyword">const</span> <span class="keywordtype">char</span> *getDefaultUser()<span class="keyword"> const </span>{
384
+ <a name="l00360"></a>00360 <span class="keywordflow">if</span> (defaultUser != NULL) {
385
+ <a name="l00361"></a>00361 <span class="keywordflow">return</span> defaultUser;
386
+ <a name="l00362"></a>00362 } <span class="keywordflow">else</span> {
387
+ <a name="l00363"></a>00363 <span class="keywordflow">return</span> <span class="stringliteral">&quot;nobody&quot;</span>;
388
+ <a name="l00364"></a>00364 }
389
+ <a name="l00365"></a>00365 }
390
+ <a name="l00366"></a>00366
391
+ <a name="l00367"></a>00367 <span class="keyword">const</span> <span class="keywordtype">char</span> *getTempDir()<span class="keyword"> const </span>{
392
+ <a name="l00368"></a>00368 <span class="keywordflow">if</span> (tempDir != NULL) {
393
+ <a name="l00369"></a>00369 <span class="keywordflow">return</span> tempDir;
394
+ <a name="l00370"></a>00370 } <span class="keywordflow">else</span> {
395
+ <a name="l00371"></a>00371 <span class="keywordflow">return</span> getSystemTempDir();
396
+ <a name="l00372"></a>00372 }
397
+ <a name="l00373"></a>00373 }
398
+ <a name="l00374"></a>00374 };
399
+ <a name="l00375"></a>00375 }
400
+ <a name="l00376"></a>00376
401
+ <a name="l00377"></a>00377 <span class="keyword">extern</span> <span class="stringliteral">&quot;C&quot;</span> {
402
+ <a name="l00378"></a>00378 <span class="preprocessor">#endif</span>
403
+ <a name="l00379"></a>00379 <span class="preprocessor"></span><span class="comment"></span>
404
+ <a name="l00380"></a>00380 <span class="comment">/** Configuration hook for per-directory configuration structure creation. */</span>
405
+ <a name="l00381"></a>00381 <span class="keywordtype">void</span> *<a class="code" href="group__Configuration.html#ga92dc583c1fa5f8025149799e356a6c78" title="Configuration hook for per-directory configuration structure creation.">passenger_config_create_dir</a>(apr_pool_t *p, <span class="keywordtype">char</span> *dirspec);
406
+ <a name="l00382"></a>00382 <span class="comment"></span>
407
+ <a name="l00383"></a>00383 <span class="comment">/** Configuration hook for per-directory configuration structure merging. */</span>
408
+ <a name="l00384"></a>00384 <span class="keywordtype">void</span> *<a class="code" href="group__Configuration.html#ga17787a036ef3f4dc46ae0acc9da2c7b0" title="Configuration hook for per-directory configuration structure merging.">passenger_config_merge_dir</a>(apr_pool_t *p, <span class="keywordtype">void</span> *basev, <span class="keywordtype">void</span> *addv);
409
+ <a name="l00385"></a>00385 <span class="comment"></span>
410
+ <a name="l00386"></a>00386 <span class="comment">/** Configuration hook for per-server configuration structure creation. */</span>
411
+ <a name="l00387"></a>00387 <span class="keywordtype">void</span> *<a class="code" href="group__Configuration.html#gaa93bd8d426649b4e86da38eb67a49178" title="Configuration hook for per-server configuration structure creation.">passenger_config_create_server</a>(apr_pool_t *p, server_rec *s);
412
+ <a name="l00388"></a>00388 <span class="comment"></span>
413
+ <a name="l00389"></a>00389 <span class="comment">/** Configuration hook for per-server configuration structure merging. */</span>
414
+ <a name="l00390"></a>00390 <span class="keywordtype">void</span> *<a class="code" href="group__Configuration.html#ga95c963a61867190928d912779952b15e" title="Configuration hook for per-server configuration structure merging.">passenger_config_merge_server</a>(apr_pool_t *p, <span class="keywordtype">void</span> *basev, <span class="keywordtype">void</span> *overridesv);
415
+ <a name="l00391"></a>00391
416
+ <a name="l00392"></a>00392 <span class="keywordtype">void</span> passenger_config_merge_all_servers(apr_pool_t *pool, server_rec *main_server);
417
+ <a name="l00393"></a>00393 <span class="comment"></span>
418
+ <a name="l00394"></a>00394 <span class="comment">/** Apache module commands array. */</span>
419
+ <a name="l00395"></a>00395 <span class="keyword">extern</span> <span class="keyword">const</span> command_rec <a class="code" href="group__Configuration.html#ga21954abbf4018583acb9d8daef3dfd95" title="Apache module commands array.">passenger_commands</a>[];
420
+ <a name="l00396"></a>00396
421
+ <a name="l00397"></a>00397 <span class="preprocessor">#ifdef __cplusplus</span>
422
+ <a name="l00398"></a>00398 <span class="preprocessor"></span> }
423
+ <a name="l00399"></a>00399 <span class="preprocessor">#endif</span>
424
+ <a name="l00400"></a>00400 <span class="preprocessor"></span><span class="comment"></span>
425
+ <a name="l00401"></a>00401 <span class="comment">/**</span>
426
+ <a name="l00402"></a>00402 <span class="comment"> * @}</span>
427
+ <a name="l00403"></a>00403 <span class="comment"> */</span>
428
+ <a name="l00404"></a>00404
429
+ <a name="l00405"></a>00405 <span class="preprocessor">#endif </span><span class="comment">/* _PASSENGER_CONFIGURATION_H_ */</span>
430
+ </pre></div></div>
431
+ <hr size="1"/><address style="text-align: right;"><small>Generated by&nbsp;
432
+ <a href="http://www.doxygen.org/index.html">
433
+ <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.6.2 </small></address>
434
+ </body>
435
+ </html>