MDL-31685 new setting for prevention of file based locking
[moodle.git] / lib / minify / config.php
1 <?php
2 /**
3  * Configuration for "min", the default application built with the Minify
4  * library
5  *
6  * @package Minify
7  */
10 defined('MOODLE_INTERNAL') || die(); // start of moodle modification
12 // NOTE: Copy all necessary settings here, do not modify the rest.
13 //       Minifier can not be accessed directly, only use PHP api.
15 $min_enableBuilder = false;
16 $min_errorLogger = false;
17 $min_allowDebugFlag = debugging('', DEBUG_DEVELOPER);
18 $min_cachePath = $CFG->tempdir;
19 $min_documentRoot = $CFG->dirroot.'/lib/minify';
20 $min_cacheFileLocking = empty($CFG->preventfilelocking);
21 $min_serveOptions['bubbleCssImports'] = false;
22 $min_serveOptions['maxAge'] = 1800;
23 $min_serveOptions['minApp']['groupsOnly'] = true;
24 $min_symlinks = array();
25 $min_uploaderHoursBehind = 0;
26 $min_libPath = dirname(__FILE__) . '/lib';
27 // do not change zlib compression or buffering here
29 // TODO: locking setting, caching setting
31 return; // end of moodle modification
34 /**
35  * Allow use of the Minify URI Builder app. Only set this to true while you need it.
36  **/
37 $min_enableBuilder = true;
40 /**
41  * Set to true to log messages to FirePHP (Firefox Firebug addon).
42  * Set to false for no error logging (Minify may be slightly faster).
43  * @link http://www.firephp.org/
44  *
45  * If you want to use a custom error logger, set this to your logger
46  * instance. Your object should have a method log(string $message).
47  */
48 $min_errorLogger = false;
51 /**
52  * To allow debug mode output, you must set this option to true.
53  *
54  * Once true, you can send the cookie minDebug to request debug mode output. The
55  * cookie value should match the URIs you'd like to debug. E.g. to debug
56  * /min/f=file1.js send the cookie minDebug=file1.js
57  * You can manually enable debugging by appending "&debug" to a URI.
58  * E.g. /min/?f=script1.js,script2.js&debug
59  *
60  * In 'debug' mode, Minify combines files with no minification and adds comments
61  * to indicate line #s of the original files.
62  */
63 $min_allowDebugFlag = false;
66 /**
67  * For best performance, specify your temp directory here. Otherwise Minify
68  * will have to load extra code to guess. Some examples below:
69  */
70 //$min_cachePath = 'c:\\WINDOWS\\Temp';
71 //$min_cachePath = '/tmp';
72 //$min_cachePath = preg_replace('/^\\d+;/', '', session_save_path());
73 /**
74  * To use APC/Memcache/ZendPlatform for cache storage, require the class and
75  * set $min_cachePath to an instance. Example below:
76  */
77 //require dirname(__FILE__) . '/lib/Minify/Cache/APC.php';
78 //$min_cachePath = new Minify_Cache_APC();
81 /**
82  * Leave an empty string to use PHP's $_SERVER['DOCUMENT_ROOT'].
83  *
84  * On some servers, this value may be misconfigured or missing. If so, set this
85  * to your full document root path with no trailing slash.
86  * E.g. '/home/accountname/public_html' or 'c:\\xampp\\htdocs'
87  *
88  * If /min/ is directly inside your document root, just uncomment the
89  * second line. The third line might work on some Apache servers.
90  */
91 $min_documentRoot = '';
92 //$min_documentRoot = substr(__FILE__, 0, -15);
93 //$min_documentRoot = $_SERVER['SUBDOMAIN_DOCUMENT_ROOT'];
96 /**
97  * Cache file locking. Set to false if filesystem is NFS. On at least one
98  * NFS system flock-ing attempts stalled PHP for 30 seconds!
99  */
100 $min_cacheFileLocking = true;
103 /**
104  * Combining multiple CSS files can place @import declarations after rules, which
105  * is invalid. Minify will attempt to detect when this happens and place a
106  * warning comment at the top of the CSS output. To resolve this you can either
107  * move the @imports within your CSS files, or enable this option, which will
108  * move all @imports to the top of the output. Note that moving @imports could
109  * affect CSS values (which is why this option is disabled by default).
110  */
111 $min_serveOptions['bubbleCssImports'] = false;
114 /**
115  * Cache-Control: max-age value sent to browser (in seconds). After this period,
116  * the browser will send another conditional GET. Use a longer period for lower
117  * traffic but you may want to shorten this before making changes if it's crucial
118  * those changes are seen immediately.
119  *
120  * Note: Despite this setting, if you include a number at the end of the
121  * querystring, maxAge will be set to one year. E.g. /min/f=hello.css&123456
122  */
123 $min_serveOptions['maxAge'] = 1800;
126 /**
127  * To use Google's Closure Compiler API (falling back to JSMin on failure),
128  * uncomment the following lines:
129  */
130 /*function closureCompiler($js) {
131     require_once 'Minify/JS/ClosureCompiler.php';
132     return Minify_JS_ClosureCompiler::minify($js);
134 $min_serveOptions['minifiers']['application/x-javascript'] = 'closureCompiler';
135 //*/
138 /**
139  * If you'd like to restrict the "f" option to files within/below
140  * particular directories below DOCUMENT_ROOT, set this here.
141  * You will still need to include the directory in the
142  * f or b GET parameters.
143  *
144  * // = shortcut for DOCUMENT_ROOT
145  */
146 //$min_serveOptions['minApp']['allowDirs'] = array('//js', '//css');
148 /**
149  * Set to true to disable the "f" GET parameter for specifying files.
150  * Only the "g" parameter will be considered.
151  */
152 $min_serveOptions['minApp']['groupsOnly'] = false;
155 /**
156  * By default, Minify will not minify files with names containing .min or -min
157  * before the extension. E.g. myFile.min.js will not be processed by JSMin
158  *
159  * To minify all files, set this option to null. You could also specify your
160  * own pattern that is matched against the filename.
161  */
162 //$min_serveOptions['minApp']['noMinPattern'] = '@[-\\.]min\\.(?:js|css)$@i';
165 /**
166  * If you minify CSS files stored in symlink-ed directories, the URI rewriting
167  * algorithm can fail. To prevent this, provide an array of link paths to
168  * target paths, where the link paths are within the document root.
169  *
170  * Because paths need to be normalized for this to work, use "//" to substitute
171  * the doc root in the link paths (the array keys). E.g.:
172  * <code>
173  * array('//symlink' => '/real/target/path') // unix
174  * array('//static' => 'D:\\staticStorage')  // Windows
175  * </code>
176  */
177 $min_symlinks = array();
180 /**
181  * If you upload files from Windows to a non-Windows server, Windows may report
182  * incorrect mtimes for the files. This may cause Minify to keep serving stale
183  * cache files when source file changes are made too frequently (e.g. more than
184  * once an hour).
185  *
186  * Immediately after modifying and uploading a file, use the touch command to
187  * update the mtime on the server. If the mtime jumps ahead by a number of hours,
188  * set this variable to that number. If the mtime moves back, this should not be
189  * needed.
190  *
191  * In the Windows SFTP client WinSCP, there's an option that may fix this
192  * issue without changing the variable below. Under login > environment,
193  * select the option "Adjust remote timestamp with DST".
194  * @link http://winscp.net/eng/docs/ui_login_environment#daylight_saving_time
195  */
196 $min_uploaderHoursBehind = 0;
199 /**
200  * Path to Minify's lib folder. If you happen to move it, change
201  * this accordingly.
202  */
203 $min_libPath = dirname(__FILE__) . '/lib';
206 // try to disable output_compression (may not have an effect)
207 ini_set('zlib.output_compression', '0');