diff options
Diffstat (limited to 'phpBB')
175 files changed, 988 insertions, 957 deletions
| diff --git a/phpBB/adm/style/acp_styles.html b/phpBB/adm/style/acp_styles.html index e0149c2a0f..86e666c4ed 100644 --- a/phpBB/adm/style/acp_styles.html +++ b/phpBB/adm/style/acp_styles.html @@ -24,7 +24,7 @@  	</div>  </fieldset> -		 +  </form>  <!-- ELSE --> @@ -44,7 +44,7 @@  		<dd><input type="text" id="name" name="style_name" value="{STYLE_NAME}" /></dd>  	</dl>  	<dl> -		<dt><label>{L_STYLE_PATH}</label></dt> +		<dt><label>{L_STYLE_PATH}{L_COLON}</label></dt>  		<dd><strong>{STYLE_PATH}</strong></dd>  	</dl>  	<dl> @@ -117,7 +117,7 @@  				<span class="error"><br />{styles_list.COMMENT}</span>  			<!-- ENDIF -->  			<!-- IF not styles_list.STYLE_ID and styles_list.COMMENT == '' --> -				<span class="style-path"><br />{L_STYLE_PATH} {styles_list.STYLE_PATH_FULL}</span> +				<span class="style-path"><br />{L_STYLE_PATH}{L_COLON} {styles_list.STYLE_PATH_FULL}</span>  			<!-- ENDIF -->  		</td>  		<!-- IF not STYLES_LIST_HIDE_COUNT --> diff --git a/phpBB/adm/style/overall_header.html b/phpBB/adm/style/overall_header.html index 7e7f0cecee..f5d0fda88a 100644 --- a/phpBB/adm/style/overall_header.html +++ b/phpBB/adm/style/overall_header.html @@ -110,7 +110,7 @@ function popup(url, width, height, name)  </head> -<body class="{S_CONTENT_DIRECTION} nojs"> +<body class="{S_CONTENT_DIRECTION} {BODY_CLASS} nojs">  <!-- EVENT acp_overall_header_body_before --> diff --git a/phpBB/adm/style/simple_header.html b/phpBB/adm/style/simple_header.html index 770b7da8a6..fd5145f0d5 100644 --- a/phpBB/adm/style/simple_header.html +++ b/phpBB/adm/style/simple_header.html @@ -104,7 +104,7 @@ function find_username(url)  <!-- EVENT acp_simple_header_head_append -->  </head> -<body class="{S_CONTENT_DIRECTION}"> +<body class="{S_CONTENT_DIRECTION} {BODY_CLASS}">  <!-- EVENT acp_simple_header_body_before --> diff --git a/phpBB/assets/javascript/plupload.js b/phpBB/assets/javascript/plupload.js index 3c2fc5c3cb..8ffd452a09 100644 --- a/phpBB/assets/javascript/plupload.js +++ b/phpBB/assets/javascript/plupload.js @@ -253,10 +253,7 @@ phpbb.plupload.deleteFile = function(row, attachId) {  	};  	var done = function(response) { -		var json = {}; -		try { -			json = $.parseJSON(response); -		} catch (e) { +		if (typeof response !== 'object') {  			return;  		} diff --git a/phpBB/develop/create_schema_files.php b/phpBB/develop/create_schema_files.php index 8e01b3c286..9ab8bd193f 100644 --- a/phpBB/develop/create_schema_files.php +++ b/phpBB/develop/create_schema_files.php @@ -21,6 +21,7 @@ $supported_dbms = array(  	'postgres',  	'sqlite',  ); +$table_prefix = 'phpbb_';  if (!is_writable($schema_path))  { @@ -28,19 +29,29 @@ if (!is_writable($schema_path))  }  define('IN_PHPBB', true); -define('IN_INSTALL', true); -$phpbb_root_path = (defined('PHPBB_ROOT_PATH')) ? PHPBB_ROOT_PATH : './../'; +$phpbb_root_path = dirname(__FILE__) . '/../';  $phpEx = substr(strrchr(__FILE__, '.'), 1); -include($phpbb_root_path . 'common.' . $phpEx); -$classes = $phpbb_container->get('ext.manager') -	->get_finder() -	->core_path('phpbb/') +include($phpbb_root_path . 'includes/constants.' . $phpEx); +require($phpbb_root_path . 'phpbb/class_loader.' . $phpEx); +$phpbb_class_loader = new \phpbb\class_loader('phpbb\\', "{$phpbb_root_path}phpbb/", $phpEx); +$phpbb_class_loader->register(); + +class phpbb_extension_empty_manager extends \phpbb\extension\manager +{ +	public function __construct() +	{ +		$this->extensions = array(); +	} +} + +$finder = new \phpbb\extension\finder(new \phpbb_extension_empty_manager(), new \phpbb\filesystem(), $phpbb_root_path); +$classes = $finder->core_path('phpbb/')  	->directory('db/migration/data')  	->get_classes(); -$db_tools = new \phpbb\db\tools($db, true); -$schema_generator = new \phpbb\db\migration\schema_generator($classes, $config, $db, $db_tools, $phpbb_root_path, $phpEx, 'phpbb_'); +$db = new \phpbb\db\driver\sqlite(); +$schema_generator = new \phpbb\db\migration\schema_generator($classes, new \phpbb\config\config(array()), $db, new \phpbb\db\tools($db, true), $phpbb_root_path, $phpEx, $table_prefix);  $schema_data = $schema_generator->get_schema();  $dbms_type_map = phpbb\db\tools::get_dbms_type_map(); diff --git a/phpBB/docs/coding-guidelines.html b/phpBB/docs/coding-guidelines.html index 6cd2627f43..cedf03ba9b 100644 --- a/phpBB/docs/coding-guidelines.html +++ b/phpBB/docs/coding-guidelines.html @@ -79,6 +79,8 @@  	<ol style="list-style-type: lower-roman;">  		<li><a href="#standardisation">Standardisation</a></li>  		<li><a href="#otherconsiderations">Other considerations</a></li> +		<li><a href="#placeholders">Working with placeholders</a></li> +		<li><a href="#usingplurals">Using plurals</a></li>  		<li><a href="#writingstyle">Writing Style</a></li>  	</ol>  	</li> @@ -106,8 +108,8 @@  	<p>Tabs in front of lines are no problem, but having them within the text can be a problem if you do not set it to the amount of spaces every one of us uses. Here is a short example of how it should look like:</p>  	<div class="codebox"><pre> -{TAB}$mode{TAB}{TAB}= request_var('mode', ''); -{TAB}$search_id{TAB}= request_var('search_id', ''); +{TAB}$mode{TAB}{TAB}= $request->variable('mode', ''); +{TAB}$search_id{TAB}= $request->variable('search_id', '');  	</pre></div>  	<p>If entered with tabs (replace the {TAB}) both equal signs need to be on the same column.</p> @@ -190,19 +192,12 @@ class ...  	<ul>  		<li><strong>phpBB3</strong><br />Core files and all files not assigned to a separate package</li> -		<li><strong>acm</strong><br /><code>/includes/cache</code><br />Cache System</li> +		<li><strong>acm</strong><br /><code>/phpbb/cache</code><br />Cache System</li>  		<li><strong>acp</strong><br /><code>/adm</code>, <code>/includes/acp</code>, <code>/includes/functions_admin.php</code><br />Administration Control Panel</li> -		<li><strong>dbal</strong><br /><code>/includes/db</code><br />Database Abstraction Layer.<br />Base class is <code>dbal</code> +		<li><strong>dbal</strong><br /><code>/phpbb/db</code>, <code>/includes/db</code><br />Database Abstraction Layer.  			<ul> -				<li><code>/includes/db/dbal.php</code><br />Base DBAL class, defining the overall framework</li> -				<li><code>/includes/db/firebird.php</code><br />Firebird/Interbase Database Abstraction Layer</li> -				<li><code>/includes/db/msssql.php</code><br />MSSQL Database Abstraction Layer</li> -				<li><code>/includes/db/mssql_odbc.php</code><br />MSSQL ODBC Database Abstraction Layer for MSSQL</li> -				<li><code>/includes/db/mysql.php</code><br />MySQL Database Abstraction Layer for MySQL 3.x/4.0.x/4.1.x/5.x</li> -				<li><code>/includes/db/mysqli.php</code><br />MySQLi Database Abstraction Layer</li> -				<li><code>/includes/db/oracle.php</code><br />Oracle Database Abstraction Layer</li> -				<li><code>/includes/db/postgres.php</code><br />PostgreSQL Database Abstraction Layer</li> -				<li><code>/includes/db/sqlite.php</code><br />Sqlite Database Abstraction Layer</li> +				<li><code>/phpbb/db/driver/</code><br />Database Abstraction Layer classes</li> +				<li><code>/phpbb/db/migration/</code><br />Migrations are used for updating the database from one release to another</li>  			</ul>  		</li>  		<li><strong>diff</strong><br /><code>/includes/diff</code><br />Diff Engine</li> @@ -210,13 +205,13 @@ class ...  		<li><strong>images</strong><br /><code>/images</code><br />All global images not connected to styles</li>  		<li><strong>install</strong><br /><code>/install</code><br />Installation System</li>  		<li><strong>language</strong><br /><code>/language</code><br />All language files</li> -		<li><strong>login</strong><br /><code>/includes/auth</code><br />Login Authentication Plugins</li> +		<li><strong>login</strong><br /><code>/phpbb/auth</code><br />Login Authentication Plugins</li>  		<li><strong>VC</strong><br /><code>/includes/captcha</code><br />CAPTCHA</li>  		<li><strong>mcp</strong><br /><code>mcp.php</code>, <code>/includes/mcp</code>, <code>report.php</code><br />Moderator Control Panel</li>  		<li><strong>ucp</strong><br /><code>ucp.php</code>, <code>/includes/ucp</code><br />User Control Panel</li>  		<li><strong>utf</strong><br /><code>/includes/utf</code><br />UTF8-related functions/classes</li> -		<li><strong>search</strong><br /><code>/includes/search</code>, <code>search.php</code><br />Search System</li> -		<li><strong>styles</strong><br /><code>/styles</code>, <code>style.php</code><br />phpBB Styles/Templates/Themes/Imagesets</li> +		<li><strong>search</strong><br /><code>/phpbb/search</code>, <code>search.php</code><br />Search System</li> +		<li><strong>styles</strong><br /><code>/styles</code><br />phpBB Styles/Templates/Themes</li>  	</ul>  	<a name="constants"></a><h3>1.iv. Special Constants</h3> @@ -249,7 +244,7 @@ PHPBB_QA                   (Set board to QA-Mode, which means the updater also c  <p>If the <code>PHPBB_USE_BOARD_URL_PATH</code> constant is set to true, phpBB uses generate_board_url() (this will return the boards url with the script path included) on all instances where web-accessible images are loaded. The exact locations are:</p>  <ul> -	<li>/includes/user.php - phpbb_user::img()</li> +	<li>/phpbb/user.php - \phpbb\user::img()</li>  	<li>/includes/functions_content.php - smiley_text()</li>  </ul> @@ -260,8 +255,6 @@ PHPBB_QA                   (Set board to QA-Mode, which means the updater also c  	<li>{T_THEME_PATH} - styles/xxx/theme</li>  	<li>{T_TEMPLATE_PATH} - styles/xxx/template</li>  	<li>{T_SUPER_TEMPLATE_PATH} - styles/xxx/template</li> -	<li>{T_IMAGESET_PATH} - styles/xxx/imageset</li> -	<li>{T_IMAGESET_LANG_PATH} - styles/xxx/imageset/yy</li>  	<li>{T_IMAGES_PATH} - images/</li>  	<li>{T_SMILIES_PATH} - $config['smilies_path']/</li>  	<li>{T_AVATAR_PATH} - $config['avatar_path']/</li> @@ -269,7 +262,7 @@ PHPBB_QA                   (Set board to QA-Mode, which means the updater also c  	<li>{T_ICONS_PATH} - $config['icons_path']/</li>  	<li>{T_RANKS_PATH} - $config['ranks_path']/</li>  	<li>{T_UPLOAD_PATH} - $config['upload_path']/</li> -	<li>{T_STYLESHEET_LINK} - styles/xxx/theme/stylesheet.css (or link to style.php if css is parsed dynamically)</li> +	<li>{T_STYLESHEET_LINK} - styles/xxx/theme/stylesheet.css</li>  	<li>New template variable {BOARD_URL} for the board url + script path.</li>  </ul> @@ -324,7 +317,7 @@ for ($i = 0; $i < $outer_size; $i++)  	</pre></div>  	<h4>Function Names:</h4> -	<p>Functions should also be named descriptively. We're not programming in C here, we don't want to write functions called things like "stristr()". Again, all lower-case names with words separated by a single underscore character in PHP, and camel caps in JavaScript. Function names should preferably have a verb in them somewhere. Good function names are <code>print_login_status()</code>, <code>get_user_data()</code>, etc. Constructor functions in JavaScript should begin with a capital letter.</p> +	<p>Functions should also be named descriptively. We're not programming in C here, we don't want to write functions called things like "stristr()". Again, all lower-case names with words separated by a single underscore character in PHP, and camel caps in JavaScript. Function names should be prefixed with "phpbb_" and preferably have a verb in them somewhere. Good function names are <code>phpbb_print_login_status()</code>, <code>phpbb_get_user_data()</code>, etc. Constructor functions in JavaScript should begin with a capital letter.</p>  	<h4>Function Arguments:</h4>  	<p>Arguments are subject to the same guidelines as variable names. We don't want a bunch of functions like: <code>do_stuff($a, $b, $c)</code>. In most cases, we'd like to be able to tell how to use a function by just looking at its declaration. </p> @@ -334,33 +327,31 @@ for ($i = 0; $i < $outer_size; $i++)  	<p>Apart from following the rules for function names, all classes should meet the following conditions:</p>  	<ul>  		<li>Every class must be defined in a separate file.</li> -		<li>The classes have to be located in a subdirectory of <code>includes/</code>.</li> -		<li>Classnames to be prefixed with <code>phpbb_</code> to avoid name clashes, the filename should not contain the prefix.</li> -		<li>Class names have to reflect the location of the file they are defined in. The longest list of prefixes, separated by underscores, which is a valid path must be the directory in which the file is located. So the directory names must not contain any underscores, but the filename may. If the filename would be empty the last directory name is used for the filename as well.</li> +		<li>The classes have to be located in a subdirectory of <code>phpbb/</code>.</li> +		<li>Classnames must be namespaced with <code>\phpbb\</code> to avoid name clashes.</li> +		<li>Class names/namespaces have to reflect the location of the file they are defined in. The namespace must be the directory in which the file is located. So the directory names must not contain any underscores, but the filename may.</li>  		<li>Directories should typically be a singular noun (e.g. <code>dir</code> in the example below, not <code>dirs</code>.</li>  	</ul>  	<p>So given the following example directory structure you would result in the below listed lookups</p>  	<div class="codebox"><pre> -includes/ +phpbb/    class_name.php    dir/      class_name.php -    dir.php        subdir/          class_name.php  	</pre></div>  	<div class="codebox"><pre> -phpbb_class_name            - includes/class_name.php -phpbb_dir_class_name        - includes/dir/class_name.php -phpbb_dir                   - includes/dir/dir.php -phpbb_dir_subdir_class_name - includes/dir/subdir/class_name.php +\phpbb\class_name            - phpbb/class_name.php +\phpbb\dir\class_name        - phpbb/dir/class_name.php +\phpbb\dir\subdir\class_name - phpbb/dir/subdir/class_name.php  	</pre></div>  	<h4>Summary:</h4> -	<p>The basic philosophy here is to not hurt code clarity for the sake of laziness. This has to be balanced by a little bit of common sense, though; <code>print_login_status_for_a_given_user()</code> goes too far, for example -- that function would be better named <code>print_user_login_status()</code>, or just <code>print_login_status()</code>.</p> +	<p>The basic philosophy here is to not hurt code clarity for the sake of laziness. This has to be balanced by a little bit of common sense, though; <code>phpbb_print_login_status_for_a_given_user()</code> goes too far, for example -- that function would be better named <code>phpbb_print_user_login_status()</code>, or just <code>phpbb_print_login_status()</code>.</p>  	<h4>Special Namings: </h4>  	<p>For all emoticons use the term <code>smiley</code> in singular and <code>smilies</code> in plural. For emails we use the term <code>email</code> (without dash between “e” and “m”).</p> @@ -1027,8 +1018,8 @@ for ($i = 0, $size = sizeof($post_data); $i < $size; $i++)  	<p>No attempt should be made to remove any copyright information (either contained within the source or displayed interactively when the source is run/compiled), neither should the copyright information be altered in any way (it may be added to).</p>  	<h4>Variables: </h4> -	<p>Make use of the <code>request_var()</code> function for anything except for submit or single checking params.</p> -	<p>The request_var function determines the type to set from the second parameter (which determines the default value too). If you need to get a scalar variable type, you need to tell this the request_var function explicitly. Examples:</p> +	<p>Make use of the <code>\phpbb\request\request</code> class for everything.</p> +	<p>The $request->variable() method determines the type to set from the second parameter (which determines the default value too). If you need to get a scalar variable type, you need to tell this the variable() method explicitly. Examples:</p>  	<p class="bad">// Old method, do not use it</p>  	<div class="codebox"><pre> @@ -1038,23 +1029,23 @@ $submit = (isset($HTTP_POST_VARS['submit'])) ? true : false;  	<p class="good">// Use request var and define a default variable (use the correct type)</p>  	<div class="codebox"><pre> -$start = request_var('start', 0); -$submit = (isset($_POST['submit'])) ? true : false; +$start = $request->variable('start', 0); +$submit = $request->is_set_post('submit');  	</pre></div> -	<p class="bad">// $start is an int, the following use of request_var therefore is not allowed</p> +	<p class="bad">// $start is an int, the following use of $request->variable() therefore is not allowed</p>  	<div class="codebox"><pre> -$start = request_var('start', '0'); +$start = $request->variable('start', '0');  	</pre></div>  	<p class="good">// Getting an array, keys are integers, value defaults to 0</p>  	<div class="codebox"><pre> -$mark_array = request_var('mark', array(0)); +$mark_array = $request->variable('mark', array(0));  	</pre></div>  	<p class="good">// Getting an array, keys are strings, value defaults to 0</p>  	<div class="codebox"><pre> -$action_ary = request_var('action', array('' => 0)); +$action_ary = $request->variable('action', array('' => 0));  	</pre></div>  	<h4>Login checks/redirection: </h4> @@ -1162,6 +1153,14 @@ append_sid("{$phpbb_root_path}memberlist.$phpEx", 'mode=group&amp;  	<p>The <strong>e</strong> modifier in <strong>preg_replace</strong> can be replaced by <strong>preg_replace_callback</strong> and objects to encapsulate state that is needed in the callback code.</p> +	<h4>Other functions, operators, statements and keywords:</h4> + +	<p>The following PHP statements should also not be used in phpBB:</p> + +	<ul> +		<li><strong>goto</strong></li> +	</ul> +  		</div>  		<div class="back2top"><a href="#wrap" class="top">Back to Top</a></div> @@ -1181,8 +1180,9 @@ append_sid("{$phpbb_root_path}memberlist.$phpEx", 'mode=group&amp;  	<div class="codebox"><pre>  # General Information about this style  name = prosilver_duplicate -copyright = © phpBB Group, 2007 -version = 3.1.0 +copyright = © phpBB Group, 2007 +style_version = 3.1.0 +phpbb_version = 3.1.0  # Defining a different template bitfield  # template_bitfield = lNg= @@ -1670,8 +1670,9 @@ div  		<div class="codebox"><pre>  # General Information about this style  name = Custom Style -copyright = &copy; phpBB Group, 2007 -version = 3.1.0 +copyright = © phpBB Group, 2007 +style_version = 3.1.0-b1 +phpbb_version = 3.1.0-b1  # Defining a different template bitfield  # template_bitfield = lNg= @@ -1689,13 +1690,15 @@ parent = prosilver  		<ul>  			<li>An event name must be all lowercase, with each word separated by an underscore.</li>  			<li>An event name must briefly describe the location and purpose of the event.</li> -			<li>An event name must end with one of the following suffixes:</li> -			<ul> -				<li><code>_prepend</code> - This event adds an item to the beginning of a block of related items, or adds to the beginning of individual items in a block.</li> -				<li><code>_append</code> - This event adds an item to the end of a block of related items, or adds to the end of individual items in a block.</li> -				<li><code>_before</code> - This event adds content directly before the specified block</li> -				<li><code>_after</code> - This event adds content directly after the specified block</li> -			</ul> +			<li> +				An event name must end with one of the following suffixes: +				<ul> +					<li><code>_prepend</code> - This event adds an item to the beginning of a block of related items, or adds to the beginning of individual items in a block.</li> +					<li><code>_append</code> - This event adds an item to the end of a block of related items, or adds to the end of individual items in a block.</li> +					<li><code>_before</code> - This event adds content directly before the specified block</li> +					<li><code>_after</code> - This event adds content directly after the specified block</li> +				</ul> +			</li>  		</ul>  		<h4>Template event documentation</h4> @@ -1707,6 +1710,7 @@ parent = prosilver  * Location: styles/<style_name>/template/filename.html  * Purpose: A brief description of what this event should be used for.  This may span multiple lines. +* Since: Version since when the event was added  </pre></div></li>  		<li>An event found in multiple template files:  		<div class="codebox"><pre>event_name @@ -1715,6 +1719,7 @@ This may span multiple lines.      + first/file/path.html      + second/file/path.html  * Purpose: Same as above. +* Since: 3.1.0-b1  </pre></div>  		<li>An event that is found multiple times in a file should have the number of instances in parenthesis next to the filename.  		<div class="codebox"><pre>event_name @@ -1723,6 +1728,7 @@ This may span multiple lines.      + first/file/path.html (2)      + second/file/path.html  * Purpose: Same as above. +* Since: 3.1.0-b1  </pre></div></li>  		<li>An actual example event documentation:  		<div class="codebox"><pre>forumlist_body_last_post_title_prepend @@ -1730,7 +1736,9 @@ This may span multiple lines.  * Locations:      + styles/prosilver/template/forumlist_body.html      + styles/subsilver2/template/forumlist_body.html -* Purpose: Add content before the post title of the latest post in a forum on the forum list.</pre></div></ul><br /> +* Purpose: Add content before the post title of the latest post in a forum on the forum list. +* Since: 3.1.0-a1 +</pre></div></ul><br />  		</div> @@ -1760,16 +1768,16 @@ This may span multiple lines.  <p>phpBB only uses the ASCII and the UTF-8 character encodings. Still all Strings are UTF-8 encoded because ASCII is a subset of UTF-8. The only exceptions to this rule are code sections which deal with external systems which use other encodings and character sets. Such external data should be converted to UTF-8 using the <code>utf8_recode()</code> function supplied with phpBB. It supports a variety of other character sets and encodings, a full list can be found below.</p> -<p>With <code>request_var()</code> you can either allow all UCS characters in user input or restrict user input to ASCII characters. This feature is controlled by the function's third parameter called <code>$multibyte</code>. You should allow multibyte characters in posts, PMs, topic titles, forum names, etc. but it's not necessary for internal uses like a <code>$mode</code> variable which should only hold a predefined list of ASCII strings anyway.</p> +<p>With <code>$request->variable()</code> you can either allow all UCS characters in user input or restrict user input to ASCII characters. This feature is controlled by the method's third parameter called <code>$multibyte</code>. You should allow multibyte characters in posts, PMs, topic titles, forum names, etc. but it's not necessary for internal uses like a <code>$mode</code> variable which should only hold a predefined list of ASCII strings anyway.</p>  <div class="codebox"><pre>  // an input string containing a multibyte character  $_REQUEST['multibyte_string'] = 'Käse';  // print request variable as a UTF-8 string allowing multibyte characters -echo request_var('multibyte_string', '', true); +echo $request->variable('multibyte_string', '', true);  // print request variable as ASCII string -echo request_var('multibyte_string', ''); +echo $request->variable('multibyte_string', '');  </pre></div>  <p>This code snippet will generate the following output:</p> @@ -1779,19 +1787,6 @@ Käse  K??se  </pre></div> -<h4>Unicode Normalization</h4> - -<p>If you retrieve user input with multibyte characters you should additionally normalize the string using <code>utf8_normalize_nfc()</code> before you work with it. This is necessary to make sure that equal characters can only occur in one particular binary representation. For example the character Å can be represented either as <code>U+00C5</code> (LATIN CAPITAL LETTER A WITH RING ABOVE) or as <code>U+212B</code> (ANGSTROM SIGN). phpBB uses Normalization Form Canonical Composition (NFC) for all text. So the correct version of the above example would look like this:</p> - -<div class="codebox"><pre> -$_REQUEST['multibyte_string'] = 'Käse'; - -// normalize multibyte strings -echo utf8_normalize_nfc(request_var('multibyte_string', '', true)); -// ASCII strings do not need to be normalized -echo request_var('multibyte_string', ''); -</pre></div> -  <h4>Case Folding</h4>  <p>Case insensitive comparison of strings is no longer possible with <code>strtolower</code> or <code>strtoupper</code> as some characters have multiple lower case or multiple upper case forms depending on their position in a word. The <code>utf8_strtolower</code> and the <code>utf8_strtoupper</code> functions suffer from the same problem so they can only be used to display upper/lower case versions of a string but they cannot be used for case insensitive comparisons either. So instead you should use case folding which gives you a case insensitive version of the string which can be used for case insensitive comparisons. An NFC normalized string can be case folded using <code>utf8_case_fold_nfc()</code>.</p> @@ -2348,7 +2343,7 @@ if (utf8_case_fold_nfc($string1) == utf8_case_fold_nfc($string2))  	<p>Within some cases, there may be mixed scripts of a left-to-right and right-to-left direction, so using <code>LRE</code> & <code>RLE</code> with <code>PDF</code> may be more appropriate. Lastly, in very rare instances where directionality must be forced, then use <code>LRO</code> & <code>RLO</code> with <code>PDF</code>.</p>  	<p>For further information on authoring techniques of bi-directional text, please see the W3C tutorial on <a href="http://www.w3.org/International/tutorials/bidi-xhtml/">authoring techniques for XHTML pages with bi-directional text</a>.</p> -	<h4>Working with placeholders:</h4> +	<a name="placeholders"></a><h3>6.iii. Working with placeholders</h3>  	<p>As phpBB is translated into languages with different ordering rules to that of English, it is possible to show specific values in any order deemed appropriate. Take for example the extremely simple "Page <em>X</em> of <em>Y</em>", whilst in English this could just be coded as:</p> @@ -2380,7 +2375,59 @@ if (utf8_case_fold_nfc($string1) == utf8_case_fold_nfc($string2))  	...  	</pre></div> -	<a name="writingstyle"></a><h3>6.iii. Writing Style</h3> +	<a name="usingplurals"></a><h3>6.iv. Using plurals</h3> + +	<p> +		The english language is very simple when it comes to plurals.<br /> +		You have <code>0 elephants</code>, <code>1 elephant</code>, or <code>2+ elephants</code>. So basically you have 2 different forms: one singular and one plural.<br /> +		But for some other languages this is quite more difficult. Let's take the Bosnian language as another example:<br /> +		You have <code>[1/21/31] slon</code>, <code>[2/3/4] slona</code>, <code>[0/5/6] slonova</code> and <code>[7/8/9/11] ...</code> and some more difficult rules. +	</p> + +	<p>The <a href="https://wiki.phpbb.com/Plural_Rules">plural system</a> takes care of this and can be used as follows:</p> + +	<p>The PHP code will basically look like this:</p> + +	<div class="codebox"><pre> +	... +	$user->lang('NUMBER_OF_ELEPHANTS', $number_of_elephants); +	... +	</pre></div> + +	<p>And the English translation would be:</p> + +	<div class="codebox"><pre> +	... +	'NUMBER_OF_ELEPHANTS'	=> array( +		0	=> 'You have no elephants', // Optional special case for 0 +		1	=> 'You have 1 elephant', // Singular +		2	=> 'You have %d elephants', // Plural +	), +	... +	</pre></div> + +	<p>While the Bosnian translation can have more cases:</p> + +	<div class="codebox"><pre> +	... +	'NUMBER_OF_ELEPHANTS'	=> array( +		0	=> 'You have no slonova', // Optional special case for 0 +		1	=> 'You have %d slon', // Used for 1, 21, 31, .. +		2	=> 'You have %d slona', // Used for 5, 6, +		3	=> ... +	), +	... +	</pre></div> + +	<p><strong>NOTE:</strong> It is okay to use plurals for an unknown number compared to a single item, when the number is not known and displayed:</p> +	<div class="codebox"><pre> +	... +	'MODERATOR'	=> 'Moderator',  // Your board has 1 moderator +	'MODERATORS'	=> 'Moderators', // Your board has multiple moderators +	... +	</pre></div> + +	<a name="writingstyle"></a><h3>6.v. Writing Style</h3>  	<h4>Miscellaneous tips & hints:</h4> diff --git a/phpBB/faq.php b/phpBB/faq.php index 53de850195..19be7da43a 100644 --- a/phpBB/faq.php +++ b/phpBB/faq.php @@ -74,6 +74,7 @@ $template->assign_vars(array(  	'L_BACK_TO_TOP'				=> $user->lang['BACK_TO_TOP'],  	'SWITCH_COLUMN_MANUALLY'	=> (!$found_switch) ? true : false, +	'S_IN_FAQ'					=> true,  ));  page_header($l_title); diff --git a/phpBB/includes/acp/acp_attachments.php b/phpBB/includes/acp/acp_attachments.php index 958a6456c2..f68fd76587 100644 --- a/phpBB/includes/acp/acp_attachments.php +++ b/phpBB/includes/acp/acp_attachments.php @@ -20,7 +20,7 @@ if (!defined('IN_PHPBB'))  */  class acp_attachments  { -	/** @var \phpbb\db\driver\driver */ +	/** @var \phpbb\db\driver\driver_interface */  	protected $db;  	/** @var \phpbb\config\config */ diff --git a/phpBB/includes/acp/acp_users.php b/phpBB/includes/acp/acp_users.php index 59b6f49436..a720334ed2 100644 --- a/phpBB/includes/acp/acp_users.php +++ b/phpBB/includes/acp/acp_users.php @@ -1253,17 +1253,13 @@ class acp_users  								WHERE user_id = $user_id";  							$db->sql_query($sql); -							switch ($log_warnings) +							if ($log_warnings)  							{ -								case 2: -									add_log('admin', 'LOG_WARNINGS_DELETED', $user_row['username'], $num_warnings); -								break; -								case 1: -									add_log('admin', 'LOG_WARNING_DELETED', $user_row['username']); -								break; -								default: -									add_log('admin', 'LOG_WARNINGS_DELETED_ALL', $user_row['username']); -								break; +								add_log('admin', 'LOG_WARNINGS_DELETED', $user_row['username'], $num_warnings); +							} +							else +							{ +								add_log('admin', 'LOG_WARNINGS_DELETED_ALL', $user_row['username']);  							}  						}  					} diff --git a/phpBB/includes/functions.php b/phpBB/includes/functions.php index 8c29bc7171..69f7c3f162 100644 --- a/phpBB/includes/functions.php +++ b/phpBB/includes/functions.php @@ -2437,19 +2437,19 @@ function meta_refresh($time, $url, $disable_cd_check = false)  {  	global $template, $refresh_data, $request; +	$url = redirect($url, true, $disable_cd_check);  	if ($request->is_ajax())  	{  		$refresh_data = array(  			'time'	=> $time, -			'url'		=> str_replace('&', '&', $url) +			'url'	=> $url,  		);  	}  	else  	{ -		$url = redirect($url, true, $disable_cd_check); +		// For XHTML compatibility we change back & to &  		$url = str_replace('&', '&', $url); -		// For XHTML compatibility we change back & to &  		$template->assign_vars(array(  			'META' => '<meta http-equiv="refresh" content="' . $time . '; url=' . $url . '" />')  		); diff --git a/phpBB/includes/functions_admin.php b/phpBB/includes/functions_admin.php index 2bf8e6dcf0..d72f89b6ac 100644 --- a/phpBB/includes/functions_admin.php +++ b/phpBB/includes/functions_admin.php @@ -2404,7 +2404,7 @@ function auto_prune($forum_id, $prune_mode, $prune_flags, $prune_days, $prune_fr  * via admin_permissions. Changes of usernames and group names  * must be carried through for the moderators table.  * -* @param \phpbb\db\driver\driver $db Database connection +* @param \phpbb\db\driver\driver_interface $db Database connection  * @param \phpbb\cache\driver\driver_interface Cache driver  * @param \phpbb\auth\auth $auth Authentication object  * @return null @@ -2627,7 +2627,7 @@ function view_log($mode, &$log, &$log_count, $limit = 0, $offset = 0, $forum_id  /**  * Removes moderators and administrators from foe lists.  * -* @param \phpbb\db\driver\driver $db Database connection +* @param \phpbb\db\driver\driver_interface $db Database connection  * @param \phpbb\auth\auth $auth Authentication object  * @param array|bool $group_id If an array, remove all members of this group from foe lists, or false to ignore  * @param array|bool $user_id If an array, remove this user from foe lists, or false to ignore diff --git a/phpBB/includes/functions_container.php b/phpBB/includes/functions_container.php index 667d27fd20..448cb0b7ed 100644 --- a/phpBB/includes/functions_container.php +++ b/phpBB/includes/functions_container.php @@ -26,7 +26,7 @@ if (!defined('IN_PHPBB'))  * Used to bootstrap the container.  *  * @param string $config_file -* @return \phpbb\db\driver\driver +* @return \phpbb\db\driver\driver_interface  */  function phpbb_bootstrap_db_connection($config_file)  { diff --git a/phpBB/includes/functions_database_helper.php b/phpBB/includes/functions_database_helper.php index 923e542690..4b2cbdd25b 100644 --- a/phpBB/includes/functions_database_helper.php +++ b/phpBB/includes/functions_database_helper.php @@ -22,14 +22,14 @@ if (!defined('IN_PHPBB'))  *  * The only supported table is bookmarks.  * -* @param \phpbb\db\driver\driver $db Database object +* @param \phpbb\db\driver\driver_interface $db Database object  * @param string $table Table on which to perform the update  * @param string $column Column whose values to change  * @param array $from_values An array of values that should be changed  * @param int $to_value The new value  * @return null  */ -function phpbb_update_rows_avoiding_duplicates(\phpbb\db\driver\driver $db, $table, $column, $from_values, $to_value) +function phpbb_update_rows_avoiding_duplicates(\phpbb\db\driver\driver_interface $db, $table, $column, $from_values, $to_value)  {  	$sql = "SELECT $column, user_id  		FROM $table @@ -107,14 +107,14 @@ function phpbb_update_rows_avoiding_duplicates(\phpbb\db\driver\driver $db, $tab  *  * The only supported table is topics_watch.  * -* @param \phpbb\db\driver\driver $db Database object +* @param \phpbb\db\driver\driver_interface $db Database object  * @param string $table Table on which to perform the update  * @param string $column Column whose values to change  * @param array $from_values An array of values that should be changed  * @param int $to_value The new value  * @return null  */ -function phpbb_update_rows_avoiding_duplicates_notify_status(\phpbb\db\driver\driver $db, $table, $column, $from_values, $to_value) +function phpbb_update_rows_avoiding_duplicates_notify_status(\phpbb\db\driver\driver_interface $db, $table, $column, $from_values, $to_value)  {  	$sql = "SELECT $column, user_id, notify_status  		FROM $table diff --git a/phpBB/includes/functions_download.php b/phpBB/includes/functions_download.php index c895f7b54b..7ad34d9515 100644 --- a/phpBB/includes/functions_download.php +++ b/phpBB/includes/functions_download.php @@ -596,7 +596,7 @@ function phpbb_parse_range_request($request_array, $filesize)  /**  * Increments the download count of all provided attachments  * -* @param \phpbb\db\driver\driver $db The database object +* @param \phpbb\db\driver\driver_interface $db The database object  * @param array|int $ids The attach_id of each attachment  *  * @return null @@ -617,7 +617,7 @@ function phpbb_increment_downloads($db, $ids)  /**  * Handles authentication when downloading attachments from a post or topic  * -* @param \phpbb\db\driver\driver $db The database object +* @param \phpbb\db\driver\driver_interface $db The database object  * @param \phpbb\auth\auth $auth The authentication object  * @param int $topic_id The id of the topic that we are downloading from  * @@ -663,7 +663,7 @@ function phpbb_download_handle_forum_auth($db, $auth, $topic_id)  /**  * Handles authentication when downloading attachments from PMs  * -* @param \phpbb\db\driver\driver $db The database object +* @param \phpbb\db\driver\driver_interface $db The database object  * @param \phpbb\auth\auth $auth The authentication object  * @param int $user_id The user id  * @param int $msg_id The id of the PM that we are downloading from @@ -690,7 +690,7 @@ function phpbb_download_handle_pm_auth($db, $auth, $user_id, $msg_id)  /**  * Checks whether a user can download from a particular PM  * -* @param \phpbb\db\driver\driver $db The database object +* @param \phpbb\db\driver\driver_interface $db The database object  * @param int $user_id The user id  * @param int $msg_id The id of the PM that we are downloading from  * diff --git a/phpBB/includes/mcp/mcp_main.php b/phpBB/includes/mcp/mcp_main.php index 016094c5d4..55440bf192 100644 --- a/phpBB/includes/mcp/mcp_main.php +++ b/phpBB/includes/mcp/mcp_main.php @@ -415,9 +415,8 @@ function change_topic_type($action, $topic_ids)  */  function mcp_move_topic($topic_ids)  { -	global $auth, $user, $db, $template; +	global $auth, $user, $db, $template, $phpbb_log, $request;  	global $phpEx, $phpbb_root_path; -	global $request;  	// Here we limit the operation to one forum only  	$forum_id = check_ids($topic_ids, TOPICS_TABLE, 'topic_id', array('m_move'), true); @@ -525,9 +524,19 @@ function mcp_move_topic($topic_ids)  		$forum_ids = array($to_forum_id);  		foreach ($topic_data as $topic_id => $row)  		{ -			// Get the list of forums to resync, add a log entry +			// Get the list of forums to resync  			$forum_ids[] = $row['forum_id']; -			add_log('mod', $to_forum_id, $topic_id, 'LOG_MOVE', $row['forum_name'], $forum_data['forum_name']); + +			// We add the $to_forum_id twice, because 'forum_id' is updated +			// when the topic is moved again later. +			$phpbb_log->add('mod', $user->data['user_id'], $user->ip, 'LOG_MOVE', false, array( +				'forum_id'		=> (int) $to_forum_id, +				'topic_id'		=> (int) $topic_id, +				$row['forum_name'], +				$forum_data['forum_name'], +				(int) $row['forum_id'], +				(int) $forum_data['forum_id'], +			));  			// Leave a redirection if required and only if the topic is visible to users  			if ($leave_shadow && $row['topic_visibility'] == ITEM_APPROVED && $row['topic_type'] != POST_GLOBAL) diff --git a/phpBB/includes/mcp/mcp_queue.php b/phpBB/includes/mcp/mcp_queue.php index a46c4bd499..8d998919e5 100644 --- a/phpBB/includes/mcp/mcp_queue.php +++ b/phpBB/includes/mcp/mcp_queue.php @@ -1163,6 +1163,22 @@ class mcp_queue  				$success_msg .= '_DELETED_SUCCESS';  			} +			// If we came from viewtopic, we try to go back to it. +			if (strpos($redirect, $phpbb_root_path . 'viewtopic.' . $phpEx) === 0) +			{ +				if ($num_disapproved_topics == 0) +				{ +					// So we need to remove the post id part from the Url +					$redirect = str_replace("&p={$post_id_list[0]}#p{$post_id_list[0]}", '', $redirect); +				} +				else +				{ +					// However this is only possible if the topic still exists, +					// Otherwise we go back to the viewforum page +					$redirect = append_sid($phpbb_root_path . 'viewforum.' . $phpEx, 'f=' . $request->variable('f', 0)); +				} +			} +  			meta_refresh(3, $redirect);  			$message = $user->lang[$success_msg]; diff --git a/phpBB/includes/ucp/ucp_pm_compose.php b/phpBB/includes/ucp/ucp_pm_compose.php index 87dfdf902b..3d95dc9a97 100644 --- a/phpBB/includes/ucp/ucp_pm_compose.php +++ b/phpBB/includes/ucp/ucp_pm_compose.php @@ -1081,6 +1081,7 @@ function compose_pm($id, $mode, $action, $user_folders = array())  		'S_SAVE_ALLOWED'		=> ($auth->acl_get('u_savedrafts') && $action != 'edit') ? true : false,  		'S_HAS_DRAFTS'			=> ($auth->acl_get('u_savedrafts') && $drafts),  		'S_FORM_ENCTYPE'		=> $form_enctype, +		'S_ATTACH_DATA'			=> json_encode($message_parser->attachment_data),  		'S_BBCODE_IMG'			=> $img_status,  		'S_BBCODE_FLASH'		=> $flash_status, @@ -1104,7 +1105,8 @@ function compose_pm($id, $mode, $action, $user_folders = array())  	if ($allowed)  	{ -		$plupload->configure($cache, $template, $s_action, false); +		$max_files = ($auth->acl_gets('a_', 'm_')) ? 0 : (int) $config['max_attachments_pm']; +		$plupload->configure($cache, $template, $s_action, false, $max_files);  	}  	// Attachment entry diff --git a/phpBB/includes/ucp/ucp_profile.php b/phpBB/includes/ucp/ucp_profile.php index 76f8988fb9..a14f79f9fd 100644 --- a/phpBB/includes/ucp/ucp_profile.php +++ b/phpBB/includes/ucp/ucp_profile.php @@ -679,8 +679,6 @@ class ucp_profile  				while ($row = $db->sql_fetchrow($result))  				{  					$template->assign_block_vars('sessions', array( -						'errors' => $error, -  						'KEY' => $row['key_id'],  						'IP' => $row['last_ip'],  						'LOGIN_TIME' => $user->format_date($row['last_login']), @@ -693,6 +691,8 @@ class ucp_profile  		}  		$template->assign_vars(array( +			'ERROR'		=> (sizeof($error)) ? implode('<br />', $error) : '', +  			'L_TITLE'	=> $user->lang['UCP_PROFILE_' . strtoupper($mode)],  			'S_HIDDEN_FIELDS'	=> $s_hidden_fields, diff --git a/phpBB/index.php b/phpBB/index.php index 49baf33392..32bc118e8c 100644 --- a/phpBB/index.php +++ b/phpBB/index.php @@ -175,6 +175,7 @@ $template->assign_vars(array(  	'S_LOGIN_ACTION'			=> append_sid("{$phpbb_root_path}ucp.$phpEx", 'mode=login'),  	'U_SEND_PASSWORD'           => ($config['email_enable']) ? append_sid("{$phpbb_root_path}ucp.$phpEx", 'mode=sendpassword') : '',  	'S_DISPLAY_BIRTHDAY_LIST'	=> ($config['load_birthdays']) ? true : false, +	'S_INDEX'					=> true,  	'U_MARK_FORUMS'		=> ($user->data['is_registered'] || $config['load_anon_lastread']) ? append_sid("{$phpbb_root_path}index.$phpEx", 'hash=' . generate_link_hash('global') . '&mark=forums&mark_time=' . time()) : '',  	'U_MCP'				=> ($auth->acl_get('m_') || $auth->acl_getf_global('m_')) ? append_sid("{$phpbb_root_path}mcp.$phpEx", 'i=main&mode=front', true, $user->session_id) : '') diff --git a/phpBB/install/install_convert.php b/phpBB/install/install_convert.php index a837e9d52a..82311bd04d 100644 --- a/phpBB/install/install_convert.php +++ b/phpBB/install/install_convert.php @@ -443,7 +443,7 @@ class install_convert extends module  			if (!isset($available_dbms[$src_dbms]) || !$available_dbms[$src_dbms]['AVAILABLE'])  			{ -				$error['db'][] = $lang['INST_ERR_NO_DB']; +				$error[] = $lang['INST_ERR_NO_DB'];  				$connect_test = false;  			}  			else diff --git a/phpBB/language/en/acp/common.php b/phpBB/language/en/acp/common.php index 2dc58d8361..5794a7c833 100644 --- a/phpBB/language/en/acp/common.php +++ b/phpBB/language/en/acp/common.php @@ -776,7 +776,10 @@ $lang = array_merge($lang, array(  	'LOG_USER_GROUP_RESIGN'			=> '<strong>User resigned membership from group</strong><br />» %s',  	'LOG_WARNING_DELETED'		=> '<strong>Deleted user warning</strong><br />» %s', -	'LOG_WARNINGS_DELETED'		=> '<strong>Deleted %2$s user warnings</strong><br />» %1$s', // Example: '<strong>Deleted 2 user warnings</strong><br />» username' +	'LOG_WARNINGS_DELETED'		=> array( +		1 => '<strong>Deleted user warning</strong><br />» %1$s', +		2 => '<strong>Deleted %2$d user warnings</strong><br />» %1$s', // Example: '<strong>Deleted 2 user warnings</strong><br />» username' +	),  	'LOG_WARNINGS_DELETED_ALL'	=> '<strong>Deleted all user warnings</strong><br />» %s',  	'LOG_WORD_ADD'			=> '<strong>Added word censor</strong><br />» %s', diff --git a/phpBB/language/en/acp/styles.php b/phpBB/language/en/acp/styles.php index e7c149600d..76b1d5e7dd 100644 --- a/phpBB/language/en/acp/styles.php +++ b/phpBB/language/en/acp/styles.php @@ -36,332 +36,48 @@ if (empty($lang) || !is_array($lang))  $lang = array_merge($lang, array(  	'ACP_STYLES_EXPLAIN'	=> 'Here you can manage the available styles on your board. You may alter existing styles, delete, deactivate, reactivate, install new ones. You can also see what a style will look like using the preview function. Also listed is the total user count for each style, note that overriding user styles will not be reflected here.', -	'ADD_TEMPLATE'			=> 'Create template', -	'ADD_TEMPLATE_EXPLAIN'	=> 'Here you can add a new template. Depending on your server configuration and file permissions you may have additional options here. For example you may be able to base this template set on an existing one. You may also be able to upload or import (from the store directory) a template archive. If you upload or import an archive the template name can be optionally taken from the archive name (to do this leave the template name blank).', -	'ARCHIVE_FORMAT'		=> 'Archive file type', -	'AUTOMATIC_EXPLAIN'		=> 'Leave blank to attempt automatic detection.', -	'BACKGROUND'			=> 'Background', -	'BACKGROUND_COLOUR'		=> 'Background colour', -	'BACKGROUND_IMAGE'		=> 'Background image', -	'BACKGROUND_REPEAT'		=> 'Background repeat', -	'BOLD'					=> 'Bold', - -	'CACHE'							=> 'Cache', -	'CACHE_CACHED'					=> 'Cached', -	'CACHE_FILENAME'				=> 'Template file', -	'CACHE_FILESIZE'				=> 'File size', -	'CACHE_MODIFIED'				=> 'Modified',  	'CANNOT_BE_INSTALLED'			=> 'Cannot be installed', -	'CONFIRM_TEMPLATE_CLEAR_CACHE'	=> 'Are you sure you wish to clear all cached versions of your template files?', -	'CONFIRM_DELETE_STYLES'			=> 'Are you sure you wish to delete selected styles?',  	'CONFIRM_UNINSTALL_STYLES'		=> 'Are you sure you wish to uninstall selected styles?',  	'COPYRIGHT'						=> 'Copyright', -	'CREATE_STYLE'					=> 'Create new style', -	'CREATE_TEMPLATE'				=> 'Create new template set', -	'CREATE_THEME'					=> 'Create new theme', -	'CURRENT_IMAGE'					=> 'Current image',  	'DEACTIVATE_DEFAULT'		=> 'You cannot deactivate the default style.',  	'DELETE_FROM_FS'			=> 'Delete from filesystem', -	'DELETE_STYLE'				=> 'Delete style', -	'DELETE_STYLE_EXPLAIN'		=> 'Here you can remove the selected style. Take care in deleting styles, there is no undo capability.',  	'DELETE_STYLE_FILES_FAILED'	=> 'Error deleting files for style "%s".',  	'DELETE_STYLE_FILES_SUCCESS'	=> 'Files for style "%s" have been deleted.', -	'DELETE_TEMPLATE'			=> 'Delete template', -	'DELETE_TEMPLATE_EXPLAIN'	=> 'Here you can remove the selected template set from the database. Please note that there is no undo capability. It is recommended that you first export your set for possible future use.',  	'DETAILS'					=> 'Details', -	'DIMENSIONS_EXPLAIN'		=> 'Selecting yes here will include width/height parameters.', - - -	'EDIT_DETAILS_STYLE'				=> 'Edit style', -	'EDIT_DETAILS_STYLE_EXPLAIN'		=> 'Using the form below you can modify this existing style. You may alter the combination of template and theme which define the style itself. You may also make the style the default one.', -	'EDIT_DETAILS_TEMPLATE'				=> 'Edit template details', -	'EDIT_DETAILS_TEMPLATE_EXPLAIN'		=> 'Here you can edit certain template details such as its name.', -	'EDIT_DETAILS_THEME'				=> 'Edit theme details', -	'EDIT_DETAILS_THEME_EXPLAIN'		=> 'Here you can edit certain theme details such as its name.', -	'EDIT_TEMPLATE'						=> 'Edit template', -	'EDIT_TEMPLATE_EXPLAIN'				=> 'Here you can edit your template set directly. Please remember that these edits are permanent and cannot be undone once submitted. Please take care when editing your template set, remember to close all replacement variable terms {XXXX} and conditional statements.', -	'EDIT_THEME'						=> 'Edit theme', -	'EDIT_THEME_EXPLAIN'				=> 'Here you can edit the selected theme, changing colours, images, etc.', -	'EDITOR_DISABLED'					=> 'The template editor is disabled.', -	'EXPORT'							=> 'Export', - -	'FOREGROUND'			=> 'Foreground', -	'FONT_COLOUR'			=> 'Font colour', -	'FONT_FACE'				=> 'Font face', -	'FONT_FACE_EXPLAIN'		=> 'You can specify multiple fonts separated by commas. If a user doesn’t have the first font installed the first other working font will be chosen.', -	'FONT_SIZE'				=> 'Font size', - -	'GLOBAL_IMAGES'			=> 'Global', - -	'HIDE_CSS'				=> 'Hide raw CSS', - -	'IMAGE_WIDTH'				=> 'Image width', -	'IMAGE_HEIGHT'				=> 'Image height', -	'IMAGE'						=> 'Image', -	'IMAGE_NAME'				=> 'Image name', -	'IMAGE_PARAMETER'			=> 'Parameter', -	'IMAGE_VALUE'				=> 'Value', - -	'ITALIC'					=> 'Italic', - -	'IMG_CAT_BUTTONS'		=> 'Localised buttons', -	'IMG_CAT_CUSTOM'		=> 'Custom images', -	'IMG_CAT_FOLDERS'		=> 'Topic icons', -	'IMG_CAT_FORUMS'		=> 'Forum icons', -	'IMG_CAT_ICONS'			=> 'General icons', -	'IMG_CAT_LOGOS'			=> 'Logos', -	'IMG_CAT_POLLS'			=> 'Polling images', -	'IMG_CAT_UI'			=> 'General user interface elements', -	'IMG_CAT_USER'			=> 'Additional images', - -	'IMG_SITE_LOGO'			=> 'Main logo', -	'IMG_UPLOAD_BAR'		=> 'Upload progress bar', -	'IMG_POLL_LEFT'			=> 'Poll left end', -	'IMG_POLL_CENTER'		=> 'Poll centre', -	'IMG_POLL_RIGHT'		=> 'Poll right end', -	'IMG_ICON_FRIEND'		=> 'Add as friend', -	'IMG_ICON_FOE'			=> 'Add as foe', - -	'IMG_FORUM_LINK'			=> 'Forum link', -	'IMG_FORUM_READ'			=> 'Forum', -	'IMG_FORUM_READ_LOCKED'		=> 'Forum locked', -	'IMG_FORUM_READ_SUBFORUM'	=> 'Subforum', -	'IMG_FORUM_UNREAD'			=> 'Forum unread posts', -	'IMG_FORUM_UNREAD_LOCKED'	=> 'Forum unread posts locked', -	'IMG_FORUM_UNREAD_SUBFORUM'	=> 'Subforum unread posts', -	'IMG_SUBFORUM_READ'			=> 'Legend subforum', -	'IMG_SUBFORUM_UNREAD'		=> 'Legend subforum unread posts', - -	'IMG_TOPIC_MOVED'			=> 'Topic moved', - -	'IMG_TOPIC_READ'				=> 'Topic', -	'IMG_TOPIC_READ_MINE'			=> 'Topic posted to', -	'IMG_TOPIC_READ_HOT'			=> 'Topic popular', -	'IMG_TOPIC_READ_HOT_MINE'		=> 'Topic popular posted to', -	'IMG_TOPIC_READ_LOCKED'			=> 'Topic locked', -	'IMG_TOPIC_READ_LOCKED_MINE'	=> 'Topic locked posted to', - -	'IMG_TOPIC_UNREAD'				=> 'Topic unread posts', -	'IMG_TOPIC_UNREAD_MINE'			=> 'Topic posted to unread', -	'IMG_TOPIC_UNREAD_HOT'			=> 'Topic popular unread posts', -	'IMG_TOPIC_UNREAD_HOT_MINE'		=> 'Topic popular posted to unread', -	'IMG_TOPIC_UNREAD_LOCKED'		=> 'Topic locked unread', -	'IMG_TOPIC_UNREAD_LOCKED_MINE'	=> 'Topic locked posted to unread', - -	'IMG_STICKY_READ'				=> 'Sticky topic', -	'IMG_STICKY_READ_MINE'			=> 'Sticky topic posted to', -	'IMG_STICKY_READ_LOCKED'		=> 'Sticky topic locked', -	'IMG_STICKY_READ_LOCKED_MINE'	=> 'Sticky topic locked posted to', -	'IMG_STICKY_UNREAD'				=> 'Sticky topic unread posts', -	'IMG_STICKY_UNREAD_MINE'		=> 'Sticky topic posted to unread', -	'IMG_STICKY_UNREAD_LOCKED'		=> 'Sticky topic locked unread posts', -	'IMG_STICKY_UNREAD_LOCKED_MINE'	=> 'Sticky topic locked posted to unread', - -	'IMG_ANNOUNCE_READ'					=> 'Announcement', -	'IMG_ANNOUNCE_READ_MINE'			=> 'Announcement posted to', -	'IMG_ANNOUNCE_READ_LOCKED'			=> 'Announcement locked', -	'IMG_ANNOUNCE_READ_LOCKED_MINE'		=> 'Announcement locked posted to', -	'IMG_ANNOUNCE_UNREAD'				=> 'Announcement unread posts', -	'IMG_ANNOUNCE_UNREAD_MINE'			=> 'Announcement posted to unread', -	'IMG_ANNOUNCE_UNREAD_LOCKED'		=> 'Announcement locked unread posts', -	'IMG_ANNOUNCE_UNREAD_LOCKED_MINE'	=> 'Announcement locked posted to unread', -	'IMG_GLOBAL_READ'					=> 'Global', -	'IMG_GLOBAL_READ_MINE'				=> 'Global posted to', -	'IMG_GLOBAL_READ_LOCKED'			=> 'Global locked', -	'IMG_GLOBAL_READ_LOCKED_MINE'		=> 'Global locked posted to', -	'IMG_GLOBAL_UNREAD'					=> 'Global unread posts', -	'IMG_GLOBAL_UNREAD_MINE'			=> 'Global posted to unread', -	'IMG_GLOBAL_UNREAD_LOCKED'			=> 'Global locked unread posts', -	'IMG_GLOBAL_UNREAD_LOCKED_MINE'		=> 'Global locked posted to unread', - -	'IMG_PM_READ'		=> 'Read private message', -	'IMG_PM_UNREAD'		=> 'Unread private message', - -	'IMG_ICON_BACK_TOP'		=> 'Top', - -	'IMG_ICON_CONTACT_EMAIL'	=> 'Send email', -	'IMG_ICON_CONTACT_JABBER'	=> 'Jabber', -	'IMG_ICON_CONTACT_PM'		=> 'Send message', - -	'IMG_ICON_POST_DELETE'			=> 'Delete post', -	'IMG_ICON_POST_EDIT'			=> 'Edit post', -	'IMG_ICON_POST_INFO'			=> 'Show post details', -	'IMG_ICON_POST_QUOTE'			=> 'Quote post', -	'IMG_ICON_POST_REPORT'			=> 'Report post', -	'IMG_ICON_POST_TARGET'			=> 'Minipost', -	'IMG_ICON_POST_TARGET_UNREAD'	=> 'New minipost', - - -	'IMG_ICON_TOPIC_ATTACH'			=> 'Attachment', -	'IMG_ICON_TOPIC_LATEST'			=> 'Last post', -	'IMG_ICON_TOPIC_NEWEST'			=> 'Last unread post', -	'IMG_ICON_TOPIC_REPORTED'		=> 'Post reported', -	'IMG_ICON_TOPIC_UNAPPROVED'		=> 'Post unapproved', - -	'IMG_ICON_USER_ONLINE'		=> 'User online', -	'IMG_ICON_USER_OFFLINE'		=> 'User offline', -	'IMG_ICON_USER_PROFILE'		=> 'Show profile', -	'IMG_ICON_USER_SEARCH'		=> 'Search posts', -	'IMG_ICON_USER_WARN'		=> 'Warn user', - -	'IMG_BUTTON_PM_FORWARD'		=> 'Forward private message', -	'IMG_BUTTON_PM_NEW'			=> 'New private message', -	'IMG_BUTTON_PM_REPLY'		=> 'Reply private message', -	'IMG_BUTTON_TOPIC_LOCKED'	=> 'Topic locked', -	'IMG_BUTTON_TOPIC_NEW'		=> 'New topic', -	'IMG_BUTTON_TOPIC_REPLY'	=> 'Reply topic', - -	'IMG_USER_ICON1'		=> 'User defined image 1', -	'IMG_USER_ICON2'		=> 'User defined image 2', -	'IMG_USER_ICON3'		=> 'User defined image 3', -	'IMG_USER_ICON4'		=> 'User defined image 4', -	'IMG_USER_ICON5'		=> 'User defined image 5', -	'IMG_USER_ICON6'		=> 'User defined image 6', -	'IMG_USER_ICON7'		=> 'User defined image 7', -	'IMG_USER_ICON8'		=> 'User defined image 8', -	'IMG_USER_ICON9'		=> 'User defined image 9', -	'IMG_USER_ICON10'		=> 'User defined image 10', - -	'INACTIVE_STYLES'			=> 'Inactive styles', -	'INCLUDE_DIMENSIONS'		=> 'Include dimensions', -	'INCLUDE_TEMPLATE'			=> 'Include template', -	'INCLUDE_THEME'				=> 'Include theme',  	'INHERITING_FROM'			=> 'Inherits from',  	'INSTALL_STYLE'				=> 'Install style',  	'INSTALL_STYLES'			=> 'Install styles',  	'INSTALL_STYLES_EXPLAIN'	=> 'Here you can install new styles.<br />If you cannot find a specific style in list below, check to make sure style is already installed. If it is not installed, check if it was uploaded correctly.', -	'INSTALLED_STYLE'			=> 'Installed styles',  	'INVALID_STYLE_ID'			=> 'Invalid style ID.', -	'LINE_SPACING'				=> 'Line spacing', -	'LOCALISED_IMAGES'			=> 'Localised', - -	'NO_CLASS'					=> 'Cannot find class in stylesheet.', -	'NO_IMAGE'					=> 'No image', -	'NO_IMAGE_ERROR'			=> 'Cannot find image on filesystem.',  	'NO_MATCHING_STYLES_FOUND'	=> 'No styles match your query.', -	'NO_STYLE'					=> 'Cannot find style on filesystem.', -	'NO_TEMPLATE'				=> 'Cannot find template on filesystem.', -	'NO_THEME'					=> 'Cannot find theme on filesystem.',  	'NO_UNINSTALLED_STYLE'		=> 'No uninstalled styles detected.', -	'NO_UNIT'					=> 'None', - -	'ONLY_STYLE'			=> 'This is the only remaining style, you cannot delete it.', -	'PARENT_STYLE_NOT_FOUND'	=> 'Parent style was not found. This style may not work correctly. Please uninstall it.',  	'PURGED_CACHE'				=> 'Cache was purged.', -	'REFRESH'					=> 'Refresh', -	'REPEAT_NO'					=> 'None', -	'REPEAT_X'					=> 'Only horizontally', -	'REPEAT_Y'					=> 'Only vertically', -	'REPEAT_ALL'				=> 'Both directions', -	'REPLACE_STYLE'				=> 'Replace style with', -	'REPLACE_STYLE_EXPLAIN'		=> 'This style will replace the one being deleted for members that use it.', -	'REPLACE_TEMPLATE'			=> 'Replace template with', -	'REPLACE_TEMPLATE_EXPLAIN'	=> 'This template set will replace the one you are deleting in any styles that use it.', -	'REPLACE_THEME'				=> 'Replace theme with', -	'REPLACE_THEME_EXPLAIN'		=> 'This theme will replace the one you are deleting in any styles that use it.', -	'REPLACE_WITH_OPTION'		=> 'Replace with “%s”',  	'REQUIRES_STYLE'			=> 'This style requires the style "%s" to be installed.', -	'SELECT_IMAGE'				=> 'Select image', -	'SELECT_TEMPLATE'			=> 'Select template file', -	'SELECT_THEME'				=> 'Select theme file', -	'SELECTED_IMAGE'			=> 'Selected image', -	'SELECTED_TEMPLATE'			=> 'Selected template', -	'SELECTED_TEMPLATE_FILE'	=> 'Selected template file', -	'SELECTED_THEME'			=> 'Selected theme', -	'SELECTED_THEME_FILE'		=> 'Selected theme file', -	'STORE_FILESYSTEM'			=> 'Filesystem',  	'STYLE_ACTIVATE'			=> 'Activate', -	'STYLE_ACTIVATED'			=> 'Style activated successfully',  	'STYLE_ACTIVE'				=> 'Active', -	'STYLE_ADDED'				=> 'Style added successfully.',  	'STYLE_DEACTIVATE'			=> 'Deactivate', -	'STYLE_DEACTIVATED'			=> 'Style deactivated successfully',  	'STYLE_DEFAULT'				=> 'Make default style', -	'STYLE_DEFAULT_CHANGE'		=> 'Change default style',  	'STYLE_DEFAULT_CHANGE_INACTIVE'	=> 'You must activate style before making it default style.', -	'STYLE_DELETED'				=> 'Style "%s" deleted successfully.', -	'STYLE_DETAILS_UPDATED'		=> 'Style edited successfully.', -	'STYLE_ERR_ARCHIVE'			=> 'Please select an archive method.', -	'STYLE_ERR_COPY_LONG'		=> 'The copyright can be no longer than 60 characters.',  	'STYLE_ERR_INVALID_PARENT'	=> 'Invalid parent style.', -	'STYLE_ERR_MORE_ELEMENTS'	=> 'You must select at least one style element.', -	'STYLE_ERR_NAME_CHARS'		=> 'The style name can only contain alphanumeric characters, -, +, _ and space.',  	'STYLE_ERR_NAME_EXIST'		=> 'A style with that name already exists.', -	'STYLE_ERR_NAME_LONG'		=> 'The style name can be no longer than 30 characters.', -	'STYLE_ERR_NOT_STYLE'		=> 'The imported or uploaded file did not contain a valid style archive.',  	'STYLE_ERR_STYLE_NAME'		=> 'You must supply a name for this style.', -	'STYLE_EXPORT'				=> 'Export style', -	'STYLE_EXPORT_EXPLAIN'		=> 'Here you can export a style in the form of an archive. A style does not need to contain all elements but it must contain at least one. For example if you have created a new theme for a commonly used template you could simply export the theme and omit the template. You may select whether to download the file directly or to place it in your store folder for download later or via FTP.', -	'STYLE_EXPORTED'			=> 'Style exported successfully and stored in %s.',  	'STYLE_INSTALLED'			=> 'Style "%s" has been installed.', -	'STYLE_INSTALLED_EDIT_DETAILS'	=> '<a href="%s">Click here</a> to edit style details or to change default style.',  	'STYLE_INSTALLED_RETURN_STYLES'	=> '<a href="%s">Click here</a> to return to installed styles list.',  	'STYLE_INSTALLED_RETURN_UNINSTALLED'	=> '<a href="%s">Click here</a> to install more styles.',  	'STYLE_NAME'				=> 'Style name',  	'STYLE_NOT_INSTALLED'		=> 'Style "%s" was not installed.', -	'STYLE_PATH'				=> 'Style path:', -	'STYLE_PARENT'				=> 'Parent style:', -	'STYLE_TEMPLATE'			=> 'Template', -	'STYLE_THEME'				=> 'Theme', +	'STYLE_PATH'				=> 'Style path',  	'STYLE_UNINSTALL'			=> 'Uninstall',  	'STYLE_UNINSTALL_DEPENDENT'	=> 'Style "%s" cannot be uninstalled because it has one or more child styles.',  	'STYLE_UNINSTALLED'			=> 'Style "%s" uninstalled successfully.',  	'STYLE_USED_BY'				=> 'Used by (including robots)', -	'TEMPLATE_ADDED'			=> 'Template set added.', -	'TEMPLATE_CACHE'			=> 'Template cache', -	'TEMPLATE_CACHE_EXPLAIN'	=> 'By default phpBB caches the compiled version of its templates. This decreases the load on the server each time a page is viewed and thus may reduce the page generation time. Here you can view the cache status of each file and delete individual files or the entire cache.', -	'TEMPLATE_CACHE_CLEARED'	=> 'Template cache cleared successfully.', -	'TEMPLATE_CACHE_EMPTY'		=> 'There are no cached templates.', -	'TEMPLATE_DELETED_FS'		=> 'Template set removed from database but files remain on the filesystem.', -	'TEMPLATE_DETAILS_UPDATED'	=> 'Template details successfully updated.', -	'TEMPLATE_EDITOR'			=> 'Raw HTML template editor', -	'TEMPLATE_EDITOR_HEIGHT'	=> 'Template editor height', -	'TEMPLATE_ERR_ARCHIVE'		=> 'Please select an archive method.', -	'TEMPLATE_ERR_CACHE_READ'	=> 'The cache directory used to store cached versions of template files could not be opened.', -	'TEMPLATE_ERR_COPY_LONG'	=> 'The copyright can be no longer than 60 characters.', -	'TEMPLATE_ERR_NAME_CHARS'	=> 'The template name can only contain alphanumeric characters, -, +, _ and space.', -	'TEMPLATE_ERR_NAME_LONG'	=> 'The template name can be no longer than 30 characters.', -	'TEMPLATE_ERR_STYLE_NAME'	=> 'You must supply a name for this template.', -	'TEMPLATE_EXPORT_EXPLAIN'	=> 'Here you can export a template set in the form of an archive. This archive will contain all the files necessary to install the templates on another board. You may select whether to download the file directly or to place it in your store folder for download later or via FTP.', -	'TEMPLATE_EXPORTED'			=> 'Templates exported successfully and stored in %s.', -	'TEMPLATE_FILE'				=> 'Template file', -	'TEMPLATE_FILE_UPDATED'		=> 'Template file updated successfully.', -	'TEMPLATE_NAME'				=> 'Template name', -	'TEMPLATE_FILE_NOT_WRITABLE'=> 'Unable to write to template file %s. Please check the permissions for the directory and the files.', - -	'THEME_ADDED'				=> 'New theme added.', -	'THEME_CLASS_ADDED'			=> 'Custom class added successfully.', -	'THEME_DELETED'				=> 'Theme deleted successfully.', -	'THEME_DELETED_FS'			=> 'Theme removed from database but files remain on the filesystem.', -	'THEME_DETAILS_UPDATED'		=> 'Theme details successfully updated.', -	'THEME_EDITOR'				=> 'Theme editor', -	'THEME_EDITOR_HEIGHT'		=> 'Theme editor height', -	'THEME_ERR_ARCHIVE'			=> 'Please select an archive method.', -	'THEME_ERR_CLASS_CHARS'		=> 'Only alphanumeric characters plus ., :, -, _ and # are valid in class names.', -	'THEME_ERR_COPY_LONG'		=> 'The copyright can be no longer than 60 characters.', -	'THEME_ERR_NAME_CHARS'		=> 'The theme name can only contain alphanumeric characters, -, +, _ and space.', -	'THEME_ERR_NAME_EXIST'		=> 'A theme with that name already exists.', -	'THEME_ERR_NAME_LONG'		=> 'The theme name can be no longer than 30 characters.', -	'THEME_ERR_NOT_THEME'		=> 'The archive you specified does not contain a valid theme.', -	'THEME_ERR_STYLE_NAME'		=> 'You must supply a name for this theme.', -	'THEME_FILE'				=> 'Theme file', -	'THEME_FILE_NOT_WRITABLE'	=> 'Unable to write to theme file %s. Please check the permissions for the directory and the files.', -	'THEME_EXPORT'				=> 'Export Theme', -	'THEME_EXPORT_EXPLAIN'		=> 'Here you can export a theme in the form of an archive. This archive will contain all the data necessary to install the theme on another board. You may select whether to download the file directly or to place it in your store folder for download later or via FTP.', -	'THEME_EXPORTED'			=> 'Theme exported successfully and stored in %s.', -	'THEME_NAME'				=> 'Theme name', -	'THEME_UPDATED'				=> 'Theme updated successfully.', - -	'UNDERLINE'				=> 'Underline',  	'UNINSTALL_DEFAULT'		=> 'You cannot uninstall the default style.', -	'UNSET'					=> 'Undefined', -  )); diff --git a/phpBB/language/en/help_bbcode.php b/phpBB/language/en/help_bbcode.php index e0cda9df04..d627ac3908 100644 --- a/phpBB/language/en/help_bbcode.php +++ b/phpBB/language/en/help_bbcode.php @@ -88,7 +88,7 @@ $help = array(  	),  	array(  		0 => 'Linking to another site', -		1 => 'phpBB BBCode supports a number of ways of creating URIs (Uniform Resource Indicators) better known as URLs.<ul><li>The first of these uses the <strong>[url=][/url]</strong> tag, whatever you type after the = sign will cause the contents of that tag to act as a URL. For example to link to phpBB.com you could use:<br /><br /><strong>[url=http://www.phpbb.com/]</strong>Visit phpBB!<strong>[/url]</strong><br /><br />This would generate the following link, <a href="http://www.phpbb.com/">Visit phpBB!</a> Please notice that the link opens in the same window or a new window depending on the users browser preferences.</li><li>If you want the URL itself displayed as the link you can do this by simply using:<br /><br /><strong>[url]</strong>http://www.phpbb.com/<strong>[/url]</strong><br /><br />This would generate the following link, <a href="http://www.phpbb.com/">http://www.phpbb.com/</a></li><li>Additionally, phpBB features something called <i>Magic Links</i>, this will turn any syntactically correct URL into a link without you needing to specify any tags or even the leading http://. For example typing www.phpbb.com into your message will automatically lead to <a href="http://www.phpbb.com/">www.phpbb.com</a> being output when you view the message.</li><li>The same thing applies equally to email addresses, you can either specify an address explicitly for example:<br /><br /><strong>[email]</strong>no.one@domain.adr<strong>[/email]</strong><br /><br />which will output <a href="mailto:no.one@domain.adr">no.one@domain.adr</a> or you can just type no.one@domain.adr into your message and it will be automatically converted when you view.</li></ul>As with all the BBCode tags you can wrap URLs around any of the other tags such as <strong>[img][/img]</strong> (see next entry), <strong>[b][/b]</strong>, etc. As with the formatting tags it is up to you to ensure the correct open and close order is following, for example:<br /><br /><strong>[url=http://www.google.com/][img]</strong>http://www.google.com/intl/en_ALL/images/logo.gif<strong>[/url][/img]</strong><br /><br />is <span style="text-decoration: underline">not</span> correct which may lead to your post being deleted so take care.' +		1 => 'phpBB BBCode supports a number of ways of creating URIs (Uniform Resource Indicators) better known as URLs.<ul><li>The first of these uses the <strong>[url=][/url]</strong> tag, whatever you type after the = sign will cause the contents of that tag to act as a URL. For example to link to phpBB.com you could use:<br /><br /><strong>[url=http://www.phpbb.com/]</strong>Visit phpBB!<strong>[/url]</strong><br /><br />This would generate the following link, <a href="http://www.phpbb.com/">Visit phpBB!</a> Please notice that the link opens in the same window or a new window depending on the users browser preferences.</li><li>If you want the URL itself displayed as the link you can do this by simply using:<br /><br /><strong>[url]</strong>http://www.phpbb.com/<strong>[/url]</strong><br /><br />This would generate the following link, <a href="http://www.phpbb.com/">http://www.phpbb.com/</a></li><li>Additionally, phpBB features something called <i>Magic Links</i>, this will turn any syntactically correct URL into a link without you needing to specify any tags or even the leading http://. For example typing www.phpbb.com into your message will automatically lead to <a href="http://www.phpbb.com/">www.phpbb.com</a> being output when you view the message.</li><li>The same thing applies equally to email addresses, you can either specify an address explicitly for example:<br /><br /><strong>[email]</strong>no.one@domain.adr<strong>[/email]</strong><br /><br />which will output <a href="mailto:no.one@domain.adr">no.one@domain.adr</a> or you can just type no.one@domain.adr into your message and it will be automatically converted when you view.</li></ul>As with all the BBCode tags you can wrap URLs around any of the other tags such as <strong>[img][/img]</strong> (see next entry), <strong>[b][/b]</strong>, etc. As with the formatting tags it is up to you to ensure the correct open and close order is following, for example:<br /><br /><strong>[url=http://www.phpbb.com/][img]</strong>http://www.phpbb.com/theme/images/logos/blue/160x52.png<strong>[/url][/img]</strong><br /><br />is <span style="text-decoration: underline">not</span> correct which may lead to your post being deleted so take care.'  	),  	array(  		0 => '--', @@ -96,7 +96,7 @@ $help = array(  	),  	array(  		0 => 'Adding an image to a post', -		1 => 'phpBB BBCode incorporates a tag for including images in your posts. Two very important things to remember when using this tag are: many users do not appreciate lots of images being shown in posts and secondly the image you display must already be available on the internet (it cannot exist only on your computer for example, unless you run a webserver!). To display an image you must surround the URL pointing to the image with <strong>[img][/img]</strong> tags. For example:<br /><br /><strong>[img]</strong>http://www.google.com/intl/en_ALL/images/logo.gif<strong>[/img]</strong><br /><br />As noted in the URL section above you can wrap an image in a <strong>[url][/url]</strong> tag if you wish, e.g.<br /><br /><strong>[url=http://www.google.com/][img]</strong>http://www.google.com/intl/en_ALL/images/logo.gif<strong>[/img][/url]</strong><br /><br />would generate:<br /><br /><a href="http://www.google.com/"><img src="http://www.google.com/intl/en_ALL/images/logo.gif" alt="" /></a>' +		1 => 'phpBB BBCode incorporates a tag for including images in your posts. Two very important things to remember when using this tag are: many users do not appreciate lots of images being shown in posts and secondly the image you display must already be available on the internet (it cannot exist only on your computer for example, unless you run a webserver!). To display an image you must surround the URL pointing to the image with <strong>[img][/img]</strong> tags. For example:<br /><br /><strong>[img]</strong>http://www.phpbb.com/theme/images/logos/blue/160x52.png<strong>[/img]</strong><br /><br />As noted in the URL section above you can wrap an image in a <strong>[url][/url]</strong> tag if you wish, e.g.<br /><br /><strong>[url=http://www.phpbb.com/][img]</strong>http://www.phpbb.com/theme/images/logos/blue/160x52.png<strong>[/img][/url]</strong><br /><br />would generate:<br /><br /><a href="http://www.phpbb.com/"><img src="http://www.phpbb.com/theme/images/logos/blue/160x52.png" alt="" /></a>'  	),  	array(  		0 => 'Adding attachments into a post', diff --git a/phpBB/memberlist.php b/phpBB/memberlist.php index c6bdff3071..8fceb4ac5b 100644 --- a/phpBB/memberlist.php +++ b/phpBB/memberlist.php @@ -21,6 +21,9 @@ $user->session_begin();  $auth->acl($user->data);  $user->setup(array('memberlist', 'groups')); +// Setting a variable to let the style designer know where he is... +$template->assign_var('S_IN_MEMBERLIST', true); +  // Grab data  $mode		= request_var('mode', '');  $action		= request_var('action', ''); diff --git a/phpBB/phpbb/auth/provider/apache.php b/phpBB/phpbb/auth/provider/apache.php index 23cdc89829..6374f29d67 100644 --- a/phpBB/phpbb/auth/provider/apache.php +++ b/phpBB/phpbb/auth/provider/apache.php @@ -26,7 +26,7 @@ class apache extends \phpbb\auth\provider\base  	/**  	 * Apache Authentication Constructor  	 * -	 * @param 	\phpbb\db\driver\driver 	$db +	 * @param 	\phpbb\db\driver\driver_interface 	$db  	 * @param 	\phpbb\config\config 		$config  	 * @param	\phpbb\passwords\manager	$passwords_manager  	 * @param 	\phpbb\request\request 		$request @@ -34,7 +34,7 @@ class apache extends \phpbb\auth\provider\base  	 * @param 	string 				$phpbb_root_path  	 * @param 	string 				$php_ext  	 */ -	public function __construct(\phpbb\db\driver\driver $db, \phpbb\config\config $config, \phpbb\passwords\manager $passwords_manager, \phpbb\request\request $request, \phpbb\user $user, $phpbb_root_path, $php_ext) +	public function __construct(\phpbb\db\driver\driver_interface $db, \phpbb\config\config $config, \phpbb\passwords\manager $passwords_manager, \phpbb\request\request $request, \phpbb\user $user, $phpbb_root_path, $php_ext)  	{  		$this->db = $db;  		$this->config = $config; diff --git a/phpBB/phpbb/auth/provider/db.php b/phpBB/phpbb/auth/provider/db.php index 6bbbc0be16..5adbf84d9f 100644 --- a/phpBB/phpbb/auth/provider/db.php +++ b/phpBB/phpbb/auth/provider/db.php @@ -28,7 +28,7 @@ class db extends \phpbb\auth\provider\base  	/**  	 * Database Authentication Constructor  	 * -	 * @param	\phpbb\db\driver\driver		$db +	 * @param	\phpbb\db\driver\driver_interface		$db  	 * @param	\phpbb\config\config 		$config  	 * @param	\phpbb\passwords\manager	$passwords_manager  	 * @param	\phpbb\request\request		$request @@ -36,7 +36,7 @@ class db extends \phpbb\auth\provider\base  	 * @param	string				$phpbb_root_path  	 * @param	string				$php_ext  	 */ -	public function __construct(\phpbb\db\driver\driver $db, \phpbb\config\config $config, \phpbb\passwords\manager $passwords_manager, \phpbb\request\request $request, \phpbb\user $user, $phpbb_root_path, $php_ext) +	public function __construct(\phpbb\db\driver\driver_interface $db, \phpbb\config\config $config, \phpbb\passwords\manager $passwords_manager, \phpbb\request\request $request, \phpbb\user $user, $phpbb_root_path, $php_ext)  	{  		$this->db = $db;  		$this->config = $config; diff --git a/phpBB/phpbb/auth/provider/ldap.php b/phpBB/phpbb/auth/provider/ldap.php index e92a227e16..3d3f1990eb 100644 --- a/phpBB/phpbb/auth/provider/ldap.php +++ b/phpBB/phpbb/auth/provider/ldap.php @@ -28,12 +28,12 @@ class ldap extends \phpbb\auth\provider\base  	/**  	 * LDAP Authentication Constructor  	 * -	 * @param 	\phpbb\db\driver\driver		$db +	 * @param 	\phpbb\db\driver\driver_interface		$db  	 * @param 	\phpbb\config\config		$config  	 * @param	\phpbb\passwords\manager	$passwords_manager  	 * @param 	\phpbb\user			$user  	 */ -	public function __construct(\phpbb\db\driver\driver $db, \phpbb\config\config $config, \phpbb\passwords\manager $passwords_manager, \phpbb\user $user) +	public function __construct(\phpbb\db\driver\driver_interface $db, \phpbb\config\config $config, \phpbb\passwords\manager $passwords_manager, \phpbb\user $user)  	{  		$this->db = $db;  		$this->config = $config; diff --git a/phpBB/phpbb/auth/provider/oauth/oauth.php b/phpBB/phpbb/auth/provider/oauth/oauth.php index 0128c89248..10d5cda5e3 100644 --- a/phpBB/phpbb/auth/provider/oauth/oauth.php +++ b/phpBB/phpbb/auth/provider/oauth/oauth.php @@ -22,7 +22,7 @@ class oauth extends \phpbb\auth\provider\base  	/**  	* Database driver  	* -	* @var \phpbb\db\driver\driver +	* @var \phpbb\db\driver\driver_interface  	*/  	protected $db; @@ -106,7 +106,7 @@ class oauth extends \phpbb\auth\provider\base  	/**  	* OAuth Authentication Constructor  	* -	* @param	\phpbb\db\driver\driver	$db +	* @param	\phpbb\db\driver\driver_interface	$db  	* @param	\phpbb\config\config	$config  	* @param	\phpbb\passwords\manager	$passwords_manager  	* @param	\phpbb\request\request_interface	$request @@ -118,7 +118,7 @@ class oauth extends \phpbb\auth\provider\base  	* @param	string			$phpbb_root_path  	* @param	string			$php_ext  	*/ -	public function __construct(\phpbb\db\driver\driver $db, \phpbb\config\config $config, \phpbb\passwords\manager $passwords_manager, \phpbb\request\request_interface $request, \phpbb\user $user, $auth_provider_oauth_token_storage_table, $auth_provider_oauth_token_account_assoc, \phpbb\di\service_collection $service_providers, $users_table, $phpbb_root_path, $php_ext) +	public function __construct(\phpbb\db\driver\driver_interface $db, \phpbb\config\config $config, \phpbb\passwords\manager $passwords_manager, \phpbb\request\request_interface $request, \phpbb\user $user, $auth_provider_oauth_token_storage_table, $auth_provider_oauth_token_account_assoc, \phpbb\di\service_collection $service_providers, $users_table, $phpbb_root_path, $php_ext)  	{  		$this->db = $db;  		$this->config = $config; diff --git a/phpBB/phpbb/auth/provider/oauth/token_storage.php b/phpBB/phpbb/auth/provider/oauth/token_storage.php index 43574288dc..d32a03be0a 100644 --- a/phpBB/phpbb/auth/provider/oauth/token_storage.php +++ b/phpBB/phpbb/auth/provider/oauth/token_storage.php @@ -26,7 +26,7 @@ class token_storage implements TokenStorageInterface  	/**  	* Cache driver.  	* -	* @var \phpbb\db\driver\driver +	* @var \phpbb\db\driver\driver_interface  	*/  	protected $db; @@ -52,11 +52,11 @@ class token_storage implements TokenStorageInterface  	/**  	* Creates token storage for phpBB.  	* -	* @param	\phpbb\db\driver\driver	$db +	* @param	\phpbb\db\driver\driver_interface	$db  	* @param	\phpbb\user		$user  	* @param	string			$auth_provider_oauth_table  	*/ -	public function __construct(\phpbb\db\driver\driver $db, \phpbb\user $user, $auth_provider_oauth_table) +	public function __construct(\phpbb\db\driver\driver_interface $db, \phpbb\user $user, $auth_provider_oauth_table)  	{  		$this->db = $db;  		$this->user = $user; diff --git a/phpBB/phpbb/cache/driver/driver_interface.php b/phpBB/phpbb/cache/driver/driver_interface.php index 8444028115..8929647411 100644 --- a/phpBB/phpbb/cache/driver/driver_interface.php +++ b/phpBB/phpbb/cache/driver/driver_interface.php @@ -106,7 +106,7 @@ interface driver_interface  	* result to persistent storage. In other words, there is no need  	* to call save() afterwards.  	* -	* @param \phpbb\db\driver\driver $db	Database connection +	* @param \phpbb\db\driver\driver_interface $db	Database connection  	* @param string $query			SQL query, should be used for generating storage key  	* @param mixed $query_result	The result from \dbal::sql_query, to be passed to  	* 								\dbal::sql_fetchrow to get all rows and store them @@ -117,7 +117,7 @@ interface driver_interface  	* 								representing the query should be returned. Otherwise  	* 								the original $query_result should be returned.  	*/ -	public function sql_save(\phpbb\db\driver\driver $db, $query, $query_result, $ttl); +	public function sql_save(\phpbb\db\driver\driver_interface $db, $query, $query_result, $ttl);  	/**  	* Check if result for a given SQL query exists in cache. diff --git a/phpBB/phpbb/cache/driver/file.php b/phpBB/phpbb/cache/driver/file.php index a57a805193..286ba328c3 100644 --- a/phpBB/phpbb/cache/driver/file.php +++ b/phpBB/phpbb/cache/driver/file.php @@ -407,7 +407,7 @@ class file extends \phpbb\cache\driver\base  	/**  	* {@inheritDoc}  	*/ -	function sql_save(\phpbb\db\driver\driver $db, $query, $query_result, $ttl) +	function sql_save(\phpbb\db\driver\driver_interface $db, $query, $query_result, $ttl)  	{  		// Remove extra spaces and tabs  		$query = preg_replace('/[\n\r\s\t]+/', ' ', $query); diff --git a/phpBB/phpbb/cache/driver/memory.php b/phpBB/phpbb/cache/driver/memory.php index b618b0f3e6..d5404455d1 100644 --- a/phpBB/phpbb/cache/driver/memory.php +++ b/phpBB/phpbb/cache/driver/memory.php @@ -279,7 +279,7 @@ abstract class memory extends \phpbb\cache\driver\base  	/**  	* {@inheritDoc}  	*/ -	function sql_save(\phpbb\db\driver\driver $db, $query, $query_result, $ttl) +	function sql_save(\phpbb\db\driver\driver_interface $db, $query, $query_result, $ttl)  	{  		// Remove extra spaces and tabs  		$query = preg_replace('/[\n\r\s\t]+/', ' ', $query); diff --git a/phpBB/phpbb/cache/driver/null.php b/phpBB/phpbb/cache/driver/null.php index 8af63eb725..99cfe454e0 100644 --- a/phpBB/phpbb/cache/driver/null.php +++ b/phpBB/phpbb/cache/driver/null.php @@ -101,7 +101,7 @@ class null extends \phpbb\cache\driver\base  	/**  	* {@inheritDoc}  	*/ -	function sql_save(\phpbb\db\driver\driver $db, $query, $query_result, $ttl) +	function sql_save(\phpbb\db\driver\driver_interface $db, $query, $query_result, $ttl)  	{  		return $query_result;  	} diff --git a/phpBB/phpbb/cache/service.php b/phpBB/phpbb/cache/service.php index ebbcfb8cdb..f9b6324b05 100644 --- a/phpBB/phpbb/cache/service.php +++ b/phpBB/phpbb/cache/service.php @@ -32,7 +32,7 @@ class service  	/**  	* Database connection.  	* -	* @var \phpbb\db\driver\driver +	* @var \phpbb\db\driver\driver_interface  	*/  	protected $db; @@ -55,11 +55,11 @@ class service  	*  	* @param \phpbb\cache\driver\driver_interface $driver The cache driver  	* @param \phpbb\config\config $config The config -	* @param \phpbb\db\driver\driver $db Database connection +	* @param \phpbb\db\driver\driver_interface $db Database connection  	* @param string $phpbb_root_path Root path  	* @param string $php_ext PHP extension  	*/ -	public function __construct(\phpbb\cache\driver\driver_interface $driver, \phpbb\config\config $config, \phpbb\db\driver\driver $db, $phpbb_root_path, $php_ext) +	public function __construct(\phpbb\cache\driver\driver_interface $driver, \phpbb\config\config $config, \phpbb\db\driver\driver_interface $db, $phpbb_root_path, $php_ext)  	{  		$this->set_driver($driver);  		$this->config = $config; diff --git a/phpBB/phpbb/config/db.php b/phpBB/phpbb/config/db.php index c1a3630a14..ea84a9f873 100644 --- a/phpBB/phpbb/config/db.php +++ b/phpBB/phpbb/config/db.php @@ -23,7 +23,7 @@ class db extends \phpbb\config\config  	/**  	* Database connection -	* @var \phpbb\db\driver\driver +	* @var \phpbb\db\driver\driver_interface  	*/  	protected $db; @@ -36,11 +36,11 @@ class db extends \phpbb\config\config  	/**  	* Creates a configuration container with a default set of values  	* -	* @param \phpbb\db\driver\driver              $db    Database connection +	* @param \phpbb\db\driver\driver_interface    $db    Database connection  	* @param \phpbb\cache\driver\driver_interface $cache Cache instance  	* @param string                       $table Configuration table name  	*/ -	public function __construct(\phpbb\db\driver\driver $db, \phpbb\cache\driver\driver_interface $cache, $table) +	public function __construct(\phpbb\db\driver\driver_interface $db, \phpbb\cache\driver\driver_interface $cache, $table)  	{  		$this->db = $db;  		$this->cache = $cache; diff --git a/phpBB/phpbb/config/db_text.php b/phpBB/phpbb/config/db_text.php index b1ea112b53..250a2ec7de 100644 --- a/phpBB/phpbb/config/db_text.php +++ b/phpBB/phpbb/config/db_text.php @@ -20,7 +20,7 @@ class db_text  {  	/**  	* Database connection -	* @var \phpbb\db\driver\driver +	* @var \phpbb\db\driver\driver_interface  	*/  	protected $db; @@ -31,10 +31,10 @@ class db_text  	protected $table;  	/** -	* @param \phpbb\db\driver\driver $db        Database connection +	* @param \phpbb\db\driver\driver_interface $db        Database connection  	* @param string          $table     Table name  	*/ -	public function __construct(\phpbb\db\driver\driver $db, $table) +	public function __construct(\phpbb\db\driver\driver_interface $db, $table)  	{  		$this->db = $db;  		$this->table = $this->db->sql_escape($table); diff --git a/phpBB/phpbb/console/command/fixup/recalculate_email_hash.php b/phpBB/phpbb/console/command/fixup/recalculate_email_hash.php index 04db880091..8c520673d9 100644 --- a/phpBB/phpbb/console/command/fixup/recalculate_email_hash.php +++ b/phpBB/phpbb/console/command/fixup/recalculate_email_hash.php @@ -13,10 +13,10 @@ use Symfony\Component\Console\Output\OutputInterface;  class recalculate_email_hash extends \phpbb\console\command\command  { -	/** @var \phpbb\db\driver\driver */ +	/** @var \phpbb\db\driver\driver_interface */  	protected $db; -	function __construct(\phpbb\db\driver\driver $db) +	function __construct(\phpbb\db\driver\driver_interface $db)  	{  		$this->db = $db; diff --git a/phpBB/phpbb/content_visibility.php b/phpBB/phpbb/content_visibility.php index f18ee0fd73..f3db37e478 100644 --- a/phpBB/phpbb/content_visibility.php +++ b/phpBB/phpbb/content_visibility.php @@ -18,7 +18,7 @@ class content_visibility  {  	/**  	* Database object -	* @var \phpbb\db\driver\driver +	* @var \phpbb\db\driver\driver_interface  	*/  	protected $db; @@ -50,13 +50,13 @@ class content_visibility  	* Constructor  	*  	* @param	\phpbb\auth\auth		$auth	Auth object -	* @param	\phpbb\db\driver\driver	$db		Database object +	* @param	\phpbb\db\driver\driver_interface	$db		Database object  	* @param	\phpbb\user		$user	User object  	* @param	string		$phpbb_root_path	Root path  	* @param	string		$php_ext			PHP Extension  	* @return	null  	*/ -	public function __construct(\phpbb\auth\auth $auth, \phpbb\db\driver\driver $db, \phpbb\user $user, $phpbb_root_path, $php_ext, $forums_table, $posts_table, $topics_table, $users_table) +	public function __construct(\phpbb\auth\auth $auth, \phpbb\db\driver\driver_interface $db, \phpbb\user $user, $phpbb_root_path, $php_ext, $forums_table, $posts_table, $topics_table, $users_table)  	{  		$this->auth = $auth;  		$this->db = $db; diff --git a/phpBB/phpbb/cron/task/core/prune_all_forums.php b/phpBB/phpbb/cron/task/core/prune_all_forums.php index 90b9a5914b..36a551394a 100644 --- a/phpBB/phpbb/cron/task/core/prune_all_forums.php +++ b/phpBB/phpbb/cron/task/core/prune_all_forums.php @@ -31,9 +31,9 @@ class prune_all_forums extends \phpbb\cron\task\base  	* @param string $phpbb_root_path The root path  	* @param string $php_ext The PHP extension  	* @param \phpbb\config\config $config The config -	* @param \phpbb\db\driver\driver $db The db connection +	* @param \phpbb\db\driver\driver_interface $db The db connection  	*/ -	public function __construct($phpbb_root_path, $php_ext, \phpbb\config\config $config, \phpbb\db\driver\driver $db) +	public function __construct($phpbb_root_path, $php_ext, \phpbb\config\config $config, \phpbb\db\driver\driver_interface $db)  	{  		$this->phpbb_root_path = $phpbb_root_path;  		$this->php_ext = $php_ext; diff --git a/phpBB/phpbb/cron/task/core/prune_forum.php b/phpBB/phpbb/cron/task/core/prune_forum.php index e0d8b067c5..542d75e5b9 100644 --- a/phpBB/phpbb/cron/task/core/prune_forum.php +++ b/phpBB/phpbb/cron/task/core/prune_forum.php @@ -41,9 +41,9 @@ class prune_forum extends \phpbb\cron\task\base implements \phpbb\cron\task\para  	* @param string $phpbb_root_path The root path  	* @param string $php_ext The PHP extension  	* @param \phpbb\config\config $config The config -	* @param \phpbb\db\driver\driver $db The db connection +	* @param \phpbb\db\driver\driver_interface $db The db connection  	*/ -	public function __construct($phpbb_root_path, $php_ext, \phpbb\config\config $config, \phpbb\db\driver\driver $db) +	public function __construct($phpbb_root_path, $php_ext, \phpbb\config\config $config, \phpbb\db\driver\driver_interface $db)  	{  		$this->phpbb_root_path = $phpbb_root_path;  		$this->php_ext = $php_ext; diff --git a/phpBB/phpbb/cron/task/core/tidy_search.php b/phpBB/phpbb/cron/task/core/tidy_search.php index 42f7df308f..eac6aa0a36 100644 --- a/phpBB/phpbb/cron/task/core/tidy_search.php +++ b/phpBB/phpbb/cron/task/core/tidy_search.php @@ -32,10 +32,10 @@ class tidy_search extends \phpbb\cron\task\base  	* @param string $php_ext The PHP extension  	* @param \phpbb\auth\auth $auth The auth  	* @param \phpbb\config\config $config The config -	* @param \phpbb\db\driver\driver $db The db connection +	* @param \phpbb\db\driver\driver_interface $db The db connection  	* @param \phpbb\user $user The user  	*/ -	public function __construct($phpbb_root_path, $php_ext, \phpbb\auth\auth $auth, \phpbb\config\config $config, \phpbb\db\driver\driver $db, \phpbb\user $user) +	public function __construct($phpbb_root_path, $php_ext, \phpbb\auth\auth $auth, \phpbb\config\config $config, \phpbb\db\driver\driver_interface $db, \phpbb\user $user)  	{  		$this->phpbb_root_path = $phpbb_root_path;  		$this->php_ext = $php_ext; diff --git a/phpBB/phpbb/db/driver/driver.php b/phpBB/phpbb/db/driver/driver.php index b61800006f..85d160c80e 100644 --- a/phpBB/phpbb/db/driver/driver.php +++ b/phpBB/phpbb/db/driver/driver.php @@ -13,7 +13,7 @@ namespace phpbb\db\driver;  * Database Abstraction Layer  * @package dbal  */ -class driver +abstract class driver implements driver_interface  {  	var $db_connect_id;  	var $query_result; @@ -84,7 +84,7 @@ class driver  	}  	/** -	* return on error or display error message +	* {@inheritDoc}  	*/  	function sql_return_on_error($fail = false)  	{ @@ -95,7 +95,7 @@ class driver  	}  	/** -	* Return number of sql queries and cached sql queries used +	* {@inheritDoc}  	*/  	function sql_num_queries($cached = false)  	{ @@ -103,7 +103,7 @@ class driver  	}  	/** -	* Add to query count +	* {@inheritDoc}  	*/  	function sql_add_num_queries($cached = false)  	{ @@ -113,7 +113,7 @@ class driver  	}  	/** -	* DBAL garbage collection, close sql connection +	* {@inheritDoc}  	*/  	function sql_close()  	{ @@ -146,8 +146,7 @@ class driver  	}  	/** -	* Build LIMIT query -	* Doing some validation here. +	* {@inheritDoc}  	*/  	function sql_query_limit($query, $total, $offset = 0, $cache_ttl = 0)  	{ @@ -164,7 +163,7 @@ class driver  	}  	/** -	* Fetch all rows +	* {@inheritDoc}  	*/  	function sql_fetchrowset($query_id = false)  	{ @@ -188,8 +187,7 @@ class driver  	}  	/** -	* Seek to given row number -	* rownum is zero-based +	* {@inheritDoc}  	*/  	function sql_rowseek($rownum, &$query_id)  	{ @@ -231,8 +229,7 @@ class driver  	}  	/** -	* Fetch field -	* if rownum is false, the current row is used, else it is pointing to the row (zero-based) +	* {@inheritDoc}  	*/  	function sql_fetchfield($field, $rownum = false, $query_id = false)  	{ @@ -263,11 +260,7 @@ class driver  	}  	/** -	* Correctly adjust LIKE expression for special characters -	* Some DBMS are handling them in a different way -	* -	* @param string $expression The expression to use. Every wildcard is escaped, except $this->any_char and $this->one_char -	* @return string LIKE expression including the keyword! +	* {@inheritDoc}  	*/  	function sql_like_expression($expression)  	{ @@ -278,14 +271,7 @@ class driver  	}  	/** -	* Build a case expression -	* -	* Note: The two statements action_true and action_false must have the same data type (int, vchar, ...) in the database! -	* -	* @param	string	$condition		The condition which must be true, to use action_true rather then action_else -	* @param	string	$action_true	SQL expression that is used, if the condition is true -	* @param	string	$action_else	SQL expression that is used, if the condition is false, optional -	* @return	string			CASE expression including the condition and statements +	* {@inheritDoc}  	*/  	public function sql_case($condition, $action_true, $action_false = false)  	{ @@ -297,11 +283,7 @@ class driver  	}  	/** -	* Build a concatenated expression -	* -	* @param	string	$expr1		Base SQL expression where we append the second one -	* @param	string	$expr2		SQL expression that is appended to the first expression -	* @return	string		Concatenated string +	* {@inheritDoc}  	*/  	public function sql_concatenate($expr1, $expr2)  	{ @@ -309,9 +291,7 @@ class driver  	}  	/** -	* Returns whether results of a query need to be buffered to run a transaction while iterating over them. -	* -	* @return bool Whether buffering is required. +	* {@inheritDoc}  	*/  	function sql_buffer_nested_transactions()  	{ @@ -319,15 +299,14 @@ class driver  	}  	/** -	* SQL Transaction -	* @access private +	* {@inheritDoc}  	*/  	function sql_transaction($status = 'begin')  	{  		switch ($status)  		{  			case 'begin': -				// If we are within a transaction we will not open another one, but enclose the current one to not loose data (prevening auto commit) +				// If we are within a transaction we will not open another one, but enclose the current one to not loose data (preventing auto commit)  				if ($this->transaction)  				{  					$this->transactions++; @@ -345,14 +324,16 @@ class driver  			break;  			case 'commit': -				// If there was a previously opened transaction we do not commit yet... but count back the number of inner transactions +				// If there was a previously opened transaction we do not commit yet... +				// but count back the number of inner transactions  				if ($this->transaction && $this->transactions)  				{  					$this->transactions--;  					return true;  				} -				// Check if there is a transaction (no transaction can happen if there was an error, with a combined rollback and error returning enabled) +				// Check if there is a transaction (no transaction can happen if +				// there was an error, with a combined rollback and error returning enabled)  				// This implies we have transaction always set for autocommit db's  				if (!$this->transaction)  				{ @@ -385,11 +366,7 @@ class driver  	}  	/** -	* Build sql statement from array for insert/update/select statements -	* -	* Idea for this from Ikonboard -	* Possible query values: INSERT, INSERT_SELECT, UPDATE, SELECT, DELETE -	* +	* {@inheritDoc}  	*/  	function sql_build_array($query, $assoc_ary = false)  	{ @@ -437,14 +414,7 @@ class driver  	}  	/** -	* Build IN or NOT IN sql comparison string, uses <> or = on single element -	* arrays to improve comparison speed -	* -	* @access public -	* @param	string	$field				name of the sql column that shall be compared -	* @param	array	$array				array of values that are allowed (IN) or not allowed (NOT IN) -	* @param	bool	$negate				true for NOT IN (), false for IN () (default) -	* @param	bool	$allow_empty_set	If true, allow $array to be empty, this function will return 1=1 or 1=0 then. Default to false. +	* {@inheritDoc}  	*/  	function sql_in_set($field, $array, $negate = false, $allow_empty_set = false)  	{ @@ -489,12 +459,7 @@ class driver  	}  	/** -	* Run binary AND operator on DB column. -	* Results in sql statement: "{$column_name} & (1 << {$bit}) {$compare}" -	* -	* @param string $column_name The column name to use -	* @param int $bit The value to use for the AND operator, will be converted to (1 << $bit). Is used by options, using the number schema... 0, 1, 2...29 -	* @param string $compare Any custom SQL code after the check (for example "= 0") +	* {@inheritDoc}  	*/  	function sql_bit_and($column_name, $bit, $compare = '')  	{ @@ -507,12 +472,7 @@ class driver  	}  	/** -	* Run binary OR operator on DB column. -	* Results in sql statement: "{$column_name} | (1 << {$bit}) {$compare}" -	* -	* @param string $column_name The column name to use -	* @param int $bit The value to use for the OR operator, will be converted to (1 << $bit). Is used by options, using the number schema... 0, 1, 2...29 -	* @param string $compare Any custom SQL code after the check (for example "= 0") +	* {@inheritDoc}  	*/  	function sql_bit_or($column_name, $bit, $compare = '')  	{ @@ -525,10 +485,7 @@ class driver  	}  	/** -	* Returns SQL string to cast a string expression to an int. -	* -	* @param  string $expression An expression evaluating to string -	* @return string             Expression returning an int +	* {@inheritDoc}  	*/  	function cast_expr_to_bigint($expression)  	{ @@ -536,10 +493,7 @@ class driver  	}  	/** -	* Returns SQL string to cast an integer expression to a string. -	* -	* @param  string $expression An expression evaluating to int -	* @return string             Expression returning a string +	* {@inheritDoc}  	*/  	function cast_expr_to_string($expression)  	{ @@ -547,11 +501,7 @@ class driver  	}  	/** -	* Run LOWER() on DB column of type text (i.e. neither varchar nor char). -	* -	* @param string $column_name	The column name to use -	* -	* @return string				A SQL statement like "LOWER($column_name)" +	* {@inheritDoc}  	*/  	function sql_lower_text($column_name)  	{ @@ -559,13 +509,7 @@ class driver  	}  	/** -	* Run more than one insert statement. -	* -	* @param string $table table name to run the statements on -	* @param array $sql_ary multi-dimensional array holding the statement data. -	* -	* @return bool false if no statements were executed. -	* @access public +	* {@inheritDoc}  	*/  	function sql_multi_insert($table, $sql_ary)  	{ @@ -637,9 +581,7 @@ class driver  	}  	/** -	* Build sql statement from array for select and select distinct statements -	* -	* Possible query values: SELECT, SELECT_DISTINCT +	* {@inheritDoc}  	*/  	function sql_build_query($query, $array)  	{ @@ -742,7 +684,7 @@ class driver  	}  	/** -	* display sql error page +	* {@inheritDoc}  	*/  	function sql_error($sql = '')  	{ @@ -812,7 +754,7 @@ class driver  	}  	/** -	* Explain queries +	* {@inheritDoc}  	*/  	function sql_report($mode, $query = '')  	{ @@ -1002,14 +944,7 @@ class driver  	}  	/** -	* Gets the estimated number of rows in a specified table. -	* -	* @param string $table_name		Table name -	* -	* @return string				Number of rows in $table_name. -	*								Prefixed with ~ if estimated (otherwise exact). -	* -	* @access public +	* {@inheritDoc}  	*/  	function get_estimated_row_count($table_name)  	{ @@ -1017,13 +952,7 @@ class driver  	}  	/** -	* Gets the exact number of rows in a specified table. -	* -	* @param string $table_name		Table name -	* -	* @return string				Exact number of rows in $table_name. -	* -	* @access public +	* {@inheritDoc}  	*/  	function get_row_count($table_name)  	{ diff --git a/phpBB/phpbb/db/driver/driver_interface.php b/phpBB/phpbb/db/driver/driver_interface.php new file mode 100644 index 0000000000..a9051616c9 --- /dev/null +++ b/phpBB/phpbb/db/driver/driver_interface.php @@ -0,0 +1,355 @@ +<?php +/** +* +* @package dbal +* @copyright (c) 2014 phpBB Group +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* +*/ + +namespace phpbb\db\driver; + +interface driver_interface +{ +	/** +	* Gets the exact number of rows in a specified table. +	* +	* @param string $table_name Table name +	* @return string	Exact number of rows in $table_name. +	*/ +	public function get_row_count($table_name); + +	/** +	* Gets the estimated number of rows in a specified table. +	* +	* @param string $table_name Table name +	* @return string	Number of rows in $table_name. +	*					Prefixed with ~ if estimated (otherwise exact). +	*/ +	public function get_estimated_row_count($table_name); + +	/** +	* Run LOWER() on DB column of type text (i.e. neither varchar nor char). +	* +	* @param string $column_name	The column name to use +	* @return string		A SQL statement like "LOWER($column_name)" +	*/ +	public function sql_lower_text($column_name); + +	/** +	* Display sql error page +	* +	* @param string		$sql	The SQL query causing the error +	* @return mixed		Returns the full error message, if $this->return_on_error +	*					is set, null otherwise +	*/ +	public function sql_error($sql = ''); + +	/** +	* Returns whether results of a query need to be buffered to run a +	* transaction while iterating over them. +	* +	* @return bool	Whether buffering is required. +	*/ +	public function sql_buffer_nested_transactions(); + +	/** +	* Run binary OR operator on DB column. +	* +	* @param string	$column_name	The column name to use +	* @param int	$bit			The value to use for the OR operator, +	*					will be converted to (1 << $bit). Is used by options, +	*					using the number schema... 0, 1, 2...29 +	* @param string	$compare	Any custom SQL code after the check (e.g. "= 0") +	* @return string	A SQL statement like "$column | (1 << $bit) {$compare}" +	*/ +	public function sql_bit_or($column_name, $bit, $compare = ''); + +	/** +	* Version information about used database +	* +	* @param bool $raw			Only return the fetched sql_server_version +	* @param bool $use_cache	Is it safe to retrieve the value from the cache +	* @return string sql server version +	*/ +	public function sql_server_info($raw = false, $use_cache = true); + +	/** +	* Return on error or display error message +	* +	* @param bool	$fail		Should we return on errors, or stop +	* @return null +	*/ +	public function sql_return_on_error($fail = false); + +	/** +	* Build sql statement from an array +	* +	* @param	string	$query		Should be on of the following strings: +	*						INSERT, INSERT_SELECT, UPDATE, SELECT, DELETE +	* @param	array	$assoc_ary	Array with "column => value" pairs +	* @return	string		A SQL statement like "c1 = 'a' AND c2 = 'b'" +	*/ +	public function sql_build_array($query, $assoc_ary = array()); + +	/** +	* Fetch all rows +	* +	* @param	mixed	$query_id	Already executed query to get the rows from, +	*								if false, the last query will be used. +	* @return	mixed		Nested array if the query had rows, false otherwise +	*/ +	public function sql_fetchrowset($query_id = false); + +	/** +	* SQL Transaction +	* +	* @param	string	$status		Should be one of the following strings: +	*								begin, commit, rollback +	* @return	mixed	Buffered, seekable result handle, false on error +	*/ +	public function sql_transaction($status = 'begin'); + +	/** +	* Build a concatenated expression +	* +	* @param	string	$expr1		Base SQL expression where we append the second one +	* @param	string	$expr2		SQL expression that is appended to the first expression +	* @return	string		Concatenated string +	*/ +	public function sql_concatenate($expr1, $expr2); + +	/** +	* Build a case expression +	* +	* Note: The two statements action_true and action_false must have the same +	* data type (int, vchar, ...) in the database! +	* +	* @param	string	$condition		The condition which must be true, +	*							to use action_true rather then action_else +	* @param	string	$action_true	SQL expression that is used, if the condition is true +	* @param	mixed	$action_false	SQL expression that is used, if the condition is false +	* @return	string		CASE expression including the condition and statements +	*/ +	public function sql_case($condition, $action_true, $action_false = false); + +	/** +	* Build sql statement from array for select and select distinct statements +	* +	* Possible query values: SELECT, SELECT_DISTINCT +	* +	* @param	string	$query	Should be one of: SELECT, SELECT_DISTINCT +	* @param	array	$array	Array with the query data: +	*					SELECT		A comma imploded list of columns to select +	*					FROM		Array with "table => alias" pairs, +	*								(alias can also be an array) +	*		Optional:	LEFT_JOIN	Array of join entries: +	*						FROM		Table that should be joined +	*						ON			Condition for the join +	*		Optional:	WHERE		Where SQL statement +	*		Optional:	GROUP_BY	Group by SQL statement +	*		Optional:	ORDER_BY	Order by SQL statement +	* @return	string		A SQL statement ready for execution +	*/ +	public function sql_build_query($query, $array); + +	/** +	* Fetch field +	* if rownum is false, the current row is used, else it is pointing to the row (zero-based) +	* +	* @param	string	$field		Name of the column +	* @param	mixed	$rownum		Row number, if false the current row will be used +	*								and the row curser will point to the next row +	*								Note: $rownum is 0 based +	* @param	mixed	$query_id	Already executed query to get the rows from, +	*								if false, the last query will be used. +	* @return	mixed		String value of the field in the selected row, +	*						false, if the row does not exist +	*/ +	public function sql_fetchfield($field, $rownum = false, $query_id = false); + +	/** +	* Fetch current row +	* +	* @param	mixed	$query_id	Already executed query to get the rows from, +	*								if false, the last query will be used. +	* @return	mixed		Array with the current row, +	*						false, if the row does not exist +	*/ +	public function sql_fetchrow($query_id = false); + +	/** +	* Returns SQL string to cast a string expression to an int. +	* +	* @param  string $expression An expression evaluating to string +	* @return string             Expression returning an int +	*/ +	public function cast_expr_to_bigint($expression); + +	/** +	* Get last inserted id after insert statement +	* +	* @return	string		Autoincrement value of the last inserted row +	*/ +	public function sql_nextid(); + +	/** +	* Add to query count +	* +	* @param bool $cached	Is this query cached? +	* @return null +	*/ +	public function sql_add_num_queries($cached = false); + +	/** +	* Build LIMIT query +	* +	* @param	string	$query		The SQL query to execute +	* @param	int		$total		The number of rows to select +	* @param	int		$offset +	* @param	int		$cache_ttl	Either 0 to avoid caching or +	*				the time in seconds which the result shall be kept in cache +	* @return	mixed	Buffered, seekable result handle, false on error +	*/ +	public function sql_query_limit($query, $total, $offset = 0, $cache_ttl = 0); + +	/** +	* Base query method +	* +	* @param	string	$query		The SQL query to execute +	* @param	int		$cache_ttl	Either 0 to avoid caching or +	*				the time in seconds which the result shall be kept in cache +	* @return	mixed	Buffered, seekable result handle, false on error +	*/ +	public function sql_query($query = '', $cache_ttl = 0); + +	/** +	* Returns SQL string to cast an integer expression to a string. +	* +	* @param	string	$expression		An expression evaluating to int +	* @return string		Expression returning a string +	*/ +	public function cast_expr_to_string($expression); + +	/** +	 * Connect to server +	 * +	 * @param	string	$sqlserver		Address of the database server +	 * @param	string	$sqluser		User name of the SQL user +	 * @param	string	$sqlpassword	Password of the SQL user +	 * @param	string	$database		Name of the database +	 * @param	mixed	$port			Port of the database server +	 * @param	bool	$persistency +	 * @param	bool	$new_link		Should a new connection be established +	 * @return	mixed	Connection ID on success, string error message otherwise +	 */ +	public function sql_connect($sqlserver, $sqluser, $sqlpassword, $database, $port = false, $persistency = false, $new_link = false); + +	/** +	* Run binary AND operator on DB column. +	* Results in sql statement: "{$column_name} & (1 << {$bit}) {$compare}" +	* +	* @param string	$column_name	The column name to use +	* @param int	$bit			The value to use for the AND operator, +	*								will be converted to (1 << $bit). Is used by +	*								options, using the number schema: 0, 1, 2...29 +	* @param string	$compare		Any custom SQL code after the check (for example "= 0") +	* @return string	A SQL statement like: "{$column} & (1 << {$bit}) {$compare}" +	*/ +	public function sql_bit_and($column_name, $bit, $compare = ''); + +	/** +	* Free sql result +	* +	* @param	mixed	$query_id	Already executed query result, +	*								if false, the last query will be used. +	* @return	null +	*/ +	public function sql_freeresult($query_id = false); + +	/** +	* Return number of sql queries and cached sql queries used +	* +	* @param	bool	$cached		Should we return the number of cached or normal queries? +	* @return	int		Number of queries that have been executed +	*/ +	public function sql_num_queries($cached = false); + +	/** +	* Run more than one insert statement. +	* +	* @param string	$table		Table name to run the statements on +	* @param array	$sql_ary	Multi-dimensional array holding the statement data +	* @return bool		false if no statements were executed. +	*/ +	public function sql_multi_insert($table, $sql_ary); + +	/** +	* Return number of affected rows +	* +	* @return	mixed		Number of the affected rows by the last query +	*						false if no query has been run before +	*/ +	public function sql_affectedrows(); + +	/** +	* DBAL garbage collection, close SQL connection +	* +	* @return	mixed		False if no connection was opened before, +	*						Server response otherwise +	*/ +	public function sql_close(); + +	/** +	* Seek to given row number +	* +	* @param	mixed	$rownum		Row number the curser should point to +	*								Note: $rownum is 0 based +	* @param	mixed	$query_id	ID of the query to set the row cursor on +	*								if false, the last query will be used. +	*								$query_id will then be set correctly +	* @return	bool		False if something went wrong +	*/ +	public function sql_rowseek($rownum, &$query_id); + +	/** +	* Escape string used in sql query +	* +	* @param	string	$msg	String to be escaped +	* @return	string		Escaped version of $msg +	*/ +	public function sql_escape($msg); + +	/** +	* Correctly adjust LIKE expression for special characters +	* Some DBMS are handling them in a different way +	* +	* @param	string	$expression	The expression to use. Every wildcard is +	*						escaped, except $this->any_char and $this->one_char +	* @return string	A SQL statement like: "LIKE 'bertie_%'" +	*/ +	public function sql_like_expression($expression); + +	/** +	* Explain queries +	* +	* @param	string	$mode		Available modes: display, start, stop, +	 *								add_select_row, fromcache, record_fromcache +	* @param	string	$query		The Query that should be explained +	* @return	mixed		Either a full HTML page, boolean or null +	*/ +	public function sql_report($mode, $query = ''); + +	/** +	* Build IN or NOT IN sql comparison string, uses <> or = on single element +	* arrays to improve comparison speed +	* +	* @param	string	$field			Name of the sql column that shall be compared +	* @param	array	$array			Array of values that are (not) allowed +	* @param	bool	$negate			true for NOT IN (), false for IN () +	* @param	bool	$allow_empty_set	If true, allow $array to be empty, +	*								this function will return 1=1 or 1=0 then. +	* @return string	A SQL statement like: "IN (1, 2, 3, 4)" or "= 1" +	*/ +	public function sql_in_set($field, $array, $negate = false, $allow_empty_set = false); +} diff --git a/phpBB/phpbb/db/driver/firebird.php b/phpBB/phpbb/db/driver/firebird.php index ed56a5d154..a4967c7ffe 100644 --- a/phpBB/phpbb/db/driver/firebird.php +++ b/phpBB/phpbb/db/driver/firebird.php @@ -22,7 +22,7 @@ class firebird extends \phpbb\db\driver\driver  	var $connect_error = '';  	/** -	* Connect to server +	* {@inheritDoc}  	*/  	function sql_connect($sqlserver, $sqluser, $sqlpassword, $database, $port = false, $persistency = false, $new_link = false)  	{ @@ -79,10 +79,7 @@ class firebird extends \phpbb\db\driver\driver  	}  	/** -	* Version information about used database -	* @param bool $raw if true, only return the fetched sql_server_version -	* @param bool $use_cache forced to false for Interbase -	* @return string sql server version +	* {@inheritDoc}  	*/  	function sql_server_info($raw = false, $use_cache = true)  	{ @@ -127,13 +124,7 @@ class firebird extends \phpbb\db\driver\driver  	}  	/** -	* Base query method -	* -	* @param	string	$query		Contains the SQL query which shall be executed -	* @param	int		$cache_ttl	Either 0 to avoid caching or the time in seconds which the result shall be kept in cache -	* @return	mixed				When casted to bool the returned value returns true on success and false on failure -	* -	* @access	public +	* {@inheritDoc}  	*/  	function sql_query($query = '', $cache_ttl = 0)  	{ @@ -297,7 +288,7 @@ class firebird extends \phpbb\db\driver\driver  	}  	/** -	* Return number of affected rows +	* {@inheritDoc}  	*/  	function sql_affectedrows()  	{ @@ -313,7 +304,7 @@ class firebird extends \phpbb\db\driver\driver  	}  	/** -	* Fetch current row +	* {@inheritDoc}  	*/  	function sql_fetchrow($query_id = false)  	{ @@ -351,7 +342,7 @@ class firebird extends \phpbb\db\driver\driver  	}  	/** -	* Get last inserted id after insert statement +	* {@inheritDoc}  	*/  	function sql_nextid()  	{ @@ -379,7 +370,7 @@ class firebird extends \phpbb\db\driver\driver  	}  	/** -	* Free sql result +	* {@inheritDoc}  	*/  	function sql_freeresult($query_id = false)  	{ @@ -405,7 +396,7 @@ class firebird extends \phpbb\db\driver\driver  	}  	/** -	* Escape string used in sql query +	* {@inheritDoc}  	*/  	function sql_escape($msg)  	{ @@ -441,7 +432,7 @@ class firebird extends \phpbb\db\driver\driver  	}  	/** -	* @inheritdoc +	* {@inheritDoc}  	*/  	function cast_expr_to_bigint($expression)  	{ @@ -450,7 +441,7 @@ class firebird extends \phpbb\db\driver\driver  	}  	/** -	* @inheritdoc +	* {@inheritDoc}  	*/  	function cast_expr_to_string($expression)  	{ diff --git a/phpBB/phpbb/db/driver/mssql.php b/phpBB/phpbb/db/driver/mssql.php index 6ebc891673..588cd7a7e8 100644 --- a/phpBB/phpbb/db/driver/mssql.php +++ b/phpBB/phpbb/db/driver/mssql.php @@ -19,7 +19,7 @@ class mssql extends \phpbb\db\driver\driver  	var $connect_error = '';  	/** -	* Connect to server +	* {@inheritDoc}  	*/  	function sql_connect($sqlserver, $sqluser, $sqlpassword, $database, $port = false, $persistency = false, $new_link = false)  	{ @@ -55,10 +55,7 @@ class mssql extends \phpbb\db\driver\driver  	}  	/** -	* Version information about used database -	* @param bool $raw if true, only return the fetched sql_server_version -	* @param bool $use_cache If true, it is safe to retrieve the value from the cache -	* @return string sql server version +	* {@inheritDoc}  	*/  	function sql_server_info($raw = false, $use_cache = true)  	{ @@ -124,13 +121,7 @@ class mssql extends \phpbb\db\driver\driver  	}  	/** -	* Base query method -	* -	* @param	string	$query		Contains the SQL query which shall be executed -	* @param	int		$cache_ttl	Either 0 to avoid caching or the time in seconds which the result shall be kept in cache -	* @return	mixed				When casted to bool the returned value returns true on success and false on failure -	* -	* @access	public +	* {@inheritDoc}  	*/  	function sql_query($query = '', $cache_ttl = 0)  	{ @@ -215,7 +206,7 @@ class mssql extends \phpbb\db\driver\driver  	}  	/** -	* Return number of affected rows +	* {@inheritDoc}  	*/  	function sql_affectedrows()  	{ @@ -223,7 +214,7 @@ class mssql extends \phpbb\db\driver\driver  	}  	/** -	* Fetch current row +	* {@inheritDoc}  	*/  	function sql_fetchrow($query_id = false)  	{ @@ -259,8 +250,7 @@ class mssql extends \phpbb\db\driver\driver  	}  	/** -	* Seek to given row number -	* rownum is zero-based +	* {@inheritDoc}  	*/  	function sql_rowseek($rownum, &$query_id)  	{ @@ -280,7 +270,7 @@ class mssql extends \phpbb\db\driver\driver  	}  	/** -	* Get last inserted id after insert statement +	* {@inheritDoc}  	*/  	function sql_nextid()  	{ @@ -299,7 +289,7 @@ class mssql extends \phpbb\db\driver\driver  	}  	/** -	* Free sql result +	* {@inheritDoc}  	*/  	function sql_freeresult($query_id = false)  	{ @@ -325,7 +315,7 @@ class mssql extends \phpbb\db\driver\driver  	}  	/** -	* Escape string used in sql query +	* {@inheritDoc}  	*/  	function sql_escape($msg)  	{ diff --git a/phpBB/phpbb/db/driver/mssql_base.php b/phpBB/phpbb/db/driver/mssql_base.php index 113f1c6902..1e3fb8235a 100644 --- a/phpBB/phpbb/db/driver/mssql_base.php +++ b/phpBB/phpbb/db/driver/mssql_base.php @@ -24,7 +24,7 @@ abstract class mssql_base extends \phpbb\db\driver\driver  	}  	/** -	* Escape string used in sql query +	* {@inheritDoc}  	*/  	function sql_escape($msg)  	{ diff --git a/phpBB/phpbb/db/driver/mssql_odbc.php b/phpBB/phpbb/db/driver/mssql_odbc.php index f8c70f1cd7..34b913dc8a 100644 --- a/phpBB/phpbb/db/driver/mssql_odbc.php +++ b/phpBB/phpbb/db/driver/mssql_odbc.php @@ -26,7 +26,7 @@ class mssql_odbc extends \phpbb\db\driver\mssql_base  	var $connect_error = '';  	/** -	* Connect to server +	* {@inheritDoc}  	*/  	function sql_connect($sqlserver, $sqluser, $sqlpassword, $database, $port = false, $persistency = false, $new_link = false)  	{ @@ -83,10 +83,7 @@ class mssql_odbc extends \phpbb\db\driver\mssql_base  	}  	/** -	* Version information about used database -	* @param bool $raw if true, only return the fetched sql_server_version -	* @param bool $use_cache If true, it is safe to retrieve the value from the cache -	* @return string sql server version +	* {@inheritDoc}  	*/  	function sql_server_info($raw = false, $use_cache = true)  	{ @@ -144,13 +141,7 @@ class mssql_odbc extends \phpbb\db\driver\mssql_base  	}  	/** -	* Base query method -	* -	* @param	string	$query		Contains the SQL query which shall be executed -	* @param	int		$cache_ttl	Either 0 to avoid caching or the time in seconds which the result shall be kept in cache -	* @return	mixed				When casted to bool the returned value returns true on success and false on failure -	* -	* @access	public +	* {@inheritDoc}  	*/  	function sql_query($query = '', $cache_ttl = 0)  	{ @@ -236,7 +227,7 @@ class mssql_odbc extends \phpbb\db\driver\mssql_base  	}  	/** -	* Return number of affected rows +	* {@inheritDoc}  	*/  	function sql_affectedrows()  	{ @@ -244,8 +235,7 @@ class mssql_odbc extends \phpbb\db\driver\mssql_base  	}  	/** -	* Fetch current row -	* @note number of bytes returned depends on odbc.defaultlrl php.ini setting. If it is limited to 4K for example only 4K of data is returned max. +	* {@inheritDoc}  	*/  	function sql_fetchrow($query_id = false)  	{ @@ -265,7 +255,7 @@ class mssql_odbc extends \phpbb\db\driver\mssql_base  	}  	/** -	* Get last inserted id after insert statement +	* {@inheritDoc}  	*/  	function sql_nextid()  	{ @@ -286,7 +276,7 @@ class mssql_odbc extends \phpbb\db\driver\mssql_base  	}  	/** -	* Free sql result +	* {@inheritDoc}  	*/  	function sql_freeresult($query_id = false)  	{ diff --git a/phpBB/phpbb/db/driver/mssqlnative.php b/phpBB/phpbb/db/driver/mssqlnative.php index 125db9c8d4..b449de2ae4 100644 --- a/phpBB/phpbb/db/driver/mssqlnative.php +++ b/phpBB/phpbb/db/driver/mssqlnative.php @@ -24,7 +24,7 @@ class mssqlnative extends \phpbb\db\driver\mssql_base  	var $connect_error = '';  	/** -	* Connect to server +	* {@inheritDoc}  	*/  	function sql_connect($sqlserver, $sqluser, $sqlpassword, $database, $port = false, $persistency = false, $new_link = false)  	{ @@ -53,10 +53,7 @@ class mssqlnative extends \phpbb\db\driver\mssql_base  	}  	/** -	* Version information about used database -	* @param bool $raw if true, only return the fetched sql_server_version -	* @param bool $use_cache If true, it is safe to retrieve the value from the cache -	* @return string sql server version +	* {@inheritDoc}  	*/  	function sql_server_info($raw = false, $use_cache = true)  	{ @@ -113,13 +110,7 @@ class mssqlnative extends \phpbb\db\driver\mssql_base  	}  	/** -	* Base query method -	* -	* @param	string	$query		Contains the SQL query which shall be executed -	* @param	int		$cache_ttl	Either 0 to avoid caching or the time in seconds which the result shall be kept in cache -	* @return	mixed				When casted to bool the returned value returns true on success and false on failure -	* -	* @access	public +	* {@inheritDoc}  	*/  	function sql_query($query = '', $cache_ttl = 0)  	{ @@ -215,7 +206,7 @@ class mssqlnative extends \phpbb\db\driver\mssql_base  	}  	/** -	* Return number of affected rows +	* {@inheritDoc}  	*/  	function sql_affectedrows()  	{ @@ -223,7 +214,7 @@ class mssqlnative extends \phpbb\db\driver\mssql_base  	}  	/** -	* Fetch current row +	* {@inheritDoc}  	*/  	function sql_fetchrow($query_id = false)  	{ @@ -263,7 +254,7 @@ class mssqlnative extends \phpbb\db\driver\mssql_base  	}  	/** -	* Get last inserted id after insert statement +	* {@inheritDoc}  	*/  	function sql_nextid()  	{ @@ -283,7 +274,7 @@ class mssqlnative extends \phpbb\db\driver\mssql_base  	}  	/** -	* Free sql result +	* {@inheritDoc}  	*/  	function sql_freeresult($query_id = false)  	{ diff --git a/phpBB/phpbb/db/driver/mysql.php b/phpBB/phpbb/db/driver/mysql.php index e311f0dd74..1a4fd364df 100644 --- a/phpBB/phpbb/db/driver/mysql.php +++ b/phpBB/phpbb/db/driver/mysql.php @@ -24,8 +24,7 @@ class mysql extends \phpbb\db\driver\mysql_base  	var $connect_error = '';  	/** -	* Connect to server -	* @access public +	* {@inheritDoc}  	*/  	function sql_connect($sqlserver, $sqluser, $sqlpassword, $database, $port = false, $persistency = false, $new_link = false)  	{ @@ -103,10 +102,7 @@ class mysql extends \phpbb\db\driver\mysql_base  	}  	/** -	* Version information about used database -	* @param bool $raw if true, only return the fetched sql_server_version -	* @param bool $use_cache If true, it is safe to retrieve the value from the cache -	* @return string sql server version +	* {@inheritDoc}  	*/  	function sql_server_info($raw = false, $use_cache = true)  	{ @@ -154,13 +150,7 @@ class mysql extends \phpbb\db\driver\mysql_base  	}  	/** -	* Base query method -	* -	* @param	string	$query		Contains the SQL query which shall be executed -	* @param	int		$cache_ttl	Either 0 to avoid caching or the time in seconds which the result shall be kept in cache -	* @return	mixed				When casted to bool the returned value returns true on success and false on failure -	* -	* @access	public +	* {@inheritDoc}  	*/  	function sql_query($query = '', $cache_ttl = 0)  	{ @@ -213,7 +203,7 @@ class mysql extends \phpbb\db\driver\mysql_base  	}  	/** -	* Return number of affected rows +	* {@inheritDoc}  	*/  	function sql_affectedrows()  	{ @@ -221,7 +211,7 @@ class mysql extends \phpbb\db\driver\mysql_base  	}  	/** -	* Fetch current row +	* {@inheritDoc}  	*/  	function sql_fetchrow($query_id = false)  	{ @@ -241,8 +231,7 @@ class mysql extends \phpbb\db\driver\mysql_base  	}  	/** -	* Seek to given row number -	* rownum is zero-based +	* {@inheritDoc}  	*/  	function sql_rowseek($rownum, &$query_id)  	{ @@ -262,7 +251,7 @@ class mysql extends \phpbb\db\driver\mysql_base  	}  	/** -	* Get last inserted id after insert statement +	* {@inheritDoc}  	*/  	function sql_nextid()  	{ @@ -270,7 +259,7 @@ class mysql extends \phpbb\db\driver\mysql_base  	}  	/** -	* Free sql result +	* {@inheritDoc}  	*/  	function sql_freeresult($query_id = false)  	{ @@ -296,7 +285,7 @@ class mysql extends \phpbb\db\driver\mysql_base  	}  	/** -	* Escape string used in sql query +	* {@inheritDoc}  	*/  	function sql_escape($msg)  	{ diff --git a/phpBB/phpbb/db/driver/mysql_base.php b/phpBB/phpbb/db/driver/mysql_base.php index 87b6d153a9..d0f6a9e8fa 100644 --- a/phpBB/phpbb/db/driver/mysql_base.php +++ b/phpBB/phpbb/db/driver/mysql_base.php @@ -43,14 +43,7 @@ abstract class mysql_base extends \phpbb\db\driver\driver  	}  	/** -	* Gets the estimated number of rows in a specified table. -	* -	* @param string $table_name		Table name -	* -	* @return string				Number of rows in $table_name. -	*								Prefixed with ~ if estimated (otherwise exact). -	* -	* @access public +	* {@inheritDoc}  	*/  	function get_estimated_row_count($table_name)  	{ @@ -72,13 +65,7 @@ abstract class mysql_base extends \phpbb\db\driver\driver  	}  	/** -	* Gets the exact number of rows in a specified table. -	* -	* @param string $table_name		Table name -	* -	* @return string				Exact number of rows in $table_name. -	* -	* @access public +	* {@inheritDoc}  	*/  	function get_row_count($table_name)  	{ diff --git a/phpBB/phpbb/db/driver/mysqli.php b/phpBB/phpbb/db/driver/mysqli.php index adc8f96302..6814599b24 100644 --- a/phpBB/phpbb/db/driver/mysqli.php +++ b/phpBB/phpbb/db/driver/mysqli.php @@ -21,7 +21,7 @@ class mysqli extends \phpbb\db\driver\mysql_base  	var $connect_error = '';  	/** -	* Connect to server +	* {@inheritDoc}  	*/  	function sql_connect($sqlserver, $sqluser, $sqlpassword, $database, $port = false, $persistency = false, $new_link = false)  	{ @@ -96,10 +96,7 @@ class mysqli extends \phpbb\db\driver\mysql_base  	}  	/** -	* Version information about used database -	* @param bool $raw if true, only return the fetched sql_server_version -	* @param bool $use_cache If true, it is safe to retrieve the value from the cache -	* @return string sql server version +	* {@inheritDoc}  	*/  	function sql_server_info($raw = false, $use_cache = true)  	{ @@ -151,13 +148,7 @@ class mysqli extends \phpbb\db\driver\mysql_base  	}  	/** -	* Base query method -	* -	* @param	string	$query		Contains the SQL query which shall be executed -	* @param	int		$cache_ttl	Either 0 to avoid caching or the time in seconds which the result shall be kept in cache -	* @return	mixed				When casted to bool the returned value returns true on success and false on failure -	* -	* @access	public +	* {@inheritDoc}  	*/  	function sql_query($query = '', $cache_ttl = 0)  	{ @@ -205,7 +196,7 @@ class mysqli extends \phpbb\db\driver\mysql_base  	}  	/** -	* Return number of affected rows +	* {@inheritDoc}  	*/  	function sql_affectedrows()  	{ @@ -213,7 +204,7 @@ class mysqli extends \phpbb\db\driver\mysql_base  	}  	/** -	* Fetch current row +	* {@inheritDoc}  	*/  	function sql_fetchrow($query_id = false)  	{ @@ -239,8 +230,7 @@ class mysqli extends \phpbb\db\driver\mysql_base  	}  	/** -	* Seek to given row number -	* rownum is zero-based +	* {@inheritDoc}  	*/  	function sql_rowseek($rownum, &$query_id)  	{ @@ -260,7 +250,7 @@ class mysqli extends \phpbb\db\driver\mysql_base  	}  	/** -	* Get last inserted id after insert statement +	* {@inheritDoc}  	*/  	function sql_nextid()  	{ @@ -268,7 +258,7 @@ class mysqli extends \phpbb\db\driver\mysql_base  	}  	/** -	* Free sql result +	* {@inheritDoc}  	*/  	function sql_freeresult($query_id = false)  	{ @@ -288,7 +278,7 @@ class mysqli extends \phpbb\db\driver\mysql_base  	}  	/** -	* Escape string used in sql query +	* {@inheritDoc}  	*/  	function sql_escape($msg)  	{ diff --git a/phpBB/phpbb/db/driver/oracle.php b/phpBB/phpbb/db/driver/oracle.php index 36ed43d4a7..8a304b5042 100644 --- a/phpBB/phpbb/db/driver/oracle.php +++ b/phpBB/phpbb/db/driver/oracle.php @@ -19,7 +19,7 @@ class oracle extends \phpbb\db\driver\driver  	var $connect_error = '';  	/** -	* Connect to server +	* {@inheritDoc}  	*/  	function sql_connect($sqlserver, $sqluser, $sqlpassword, $database, $port = false, $persistency = false, $new_link = false)  	{ @@ -72,10 +72,7 @@ class oracle extends \phpbb\db\driver\driver  	}  	/** -	* Version information about used database -	* @param bool $raw if true, only return the fetched sql_server_version -	* @param bool $use_cache forced to false for Oracle -	* @return string sql server version +	* {@inheritDoc}  	*/  	function sql_server_info($raw = false, $use_cache = true)  	{ @@ -240,13 +237,7 @@ class oracle extends \phpbb\db\driver\driver  	}  	/** -	* Base query method -	* -	* @param	string	$query		Contains the SQL query which shall be executed -	* @param	int		$cache_ttl	Either 0 to avoid caching or the time in seconds which the result shall be kept in cache -	* @return	mixed				When casted to bool the returned value returns true on success and false on failure -	* -	* @access	public +	* {@inheritDoc}  	*/  	function sql_query($query = '', $cache_ttl = 0)  	{ @@ -473,7 +464,7 @@ class oracle extends \phpbb\db\driver\driver  	}  	/** -	* Return number of affected rows +	* {@inheritDoc}  	*/  	function sql_affectedrows()  	{ @@ -481,7 +472,7 @@ class oracle extends \phpbb\db\driver\driver  	}  	/** -	* Fetch current row +	* {@inheritDoc}  	*/  	function sql_fetchrow($query_id = false)  	{ @@ -532,8 +523,7 @@ class oracle extends \phpbb\db\driver\driver  	}  	/** -	* Seek to given row number -	* rownum is zero-based +	* {@inheritDoc}  	*/  	function sql_rowseek($rownum, &$query_id)  	{ @@ -570,7 +560,7 @@ class oracle extends \phpbb\db\driver\driver  	}  	/** -	* Get last inserted id after insert statement +	* {@inheritDoc}  	*/  	function sql_nextid()  	{ @@ -602,7 +592,7 @@ class oracle extends \phpbb\db\driver\driver  	}  	/** -	* Free sql result +	* {@inheritDoc}  	*/  	function sql_freeresult($query_id = false)  	{ @@ -628,7 +618,7 @@ class oracle extends \phpbb\db\driver\driver  	}  	/** -	* Escape string used in sql query +	* {@inheritDoc}  	*/  	function sql_escape($msg)  	{ diff --git a/phpBB/phpbb/db/driver/postgres.php b/phpBB/phpbb/db/driver/postgres.php index 5dbd1ca74f..9e091f0a5d 100644 --- a/phpBB/phpbb/db/driver/postgres.php +++ b/phpBB/phpbb/db/driver/postgres.php @@ -20,7 +20,7 @@ class postgres extends \phpbb\db\driver\driver  	var $connect_error = '';  	/** -	* Connect to server +	* {@inheritDoc}  	*/  	function sql_connect($sqlserver, $sqluser, $sqlpassword, $database, $port = false, $persistency = false, $new_link = false)  	{ @@ -115,10 +115,7 @@ class postgres extends \phpbb\db\driver\driver  	}  	/** -	* Version information about used database -	* @param bool $raw if true, only return the fetched sql_server_version -	* @param bool $use_cache If true, it is safe to retrieve the value from the cache -	* @return string sql server version +	* {@inheritDoc}  	*/  	function sql_server_info($raw = false, $use_cache = true)  	{ @@ -166,13 +163,7 @@ class postgres extends \phpbb\db\driver\driver  	}  	/** -	* Base query method -	* -	* @param	string	$query		Contains the SQL query which shall be executed -	* @param	int		$cache_ttl	Either 0 to avoid caching or the time in seconds which the result shall be kept in cache -	* @return	mixed				When casted to bool the returned value returns true on success and false on failure -	* -	* @access	public +	* {@inheritDoc}  	*/  	function sql_query($query = '', $cache_ttl = 0)  	{ @@ -253,7 +244,7 @@ class postgres extends \phpbb\db\driver\driver  	}  	/** -	* Return number of affected rows +	* {@inheritDoc}  	*/  	function sql_affectedrows()  	{ @@ -261,7 +252,7 @@ class postgres extends \phpbb\db\driver\driver  	}  	/** -	* Fetch current row +	* {@inheritDoc}  	*/  	function sql_fetchrow($query_id = false)  	{ @@ -281,8 +272,7 @@ class postgres extends \phpbb\db\driver\driver  	}  	/** -	* Seek to given row number -	* rownum is zero-based +	* {@inheritDoc}  	*/  	function sql_rowseek($rownum, &$query_id)  	{ @@ -302,7 +292,7 @@ class postgres extends \phpbb\db\driver\driver  	}  	/** -	* Get last inserted id after insert statement +	* {@inheritDoc}  	*/  	function sql_nextid()  	{ @@ -331,7 +321,7 @@ class postgres extends \phpbb\db\driver\driver  	}  	/** -	* Free sql result +	* {@inheritDoc}  	*/  	function sql_freeresult($query_id = false)  	{ @@ -357,8 +347,7 @@ class postgres extends \phpbb\db\driver\driver  	}  	/** -	* Escape string used in sql query -	* Note: Do not use for bytea values if we may use them at a later stage +	* {@inheritDoc}  	*/  	function sql_escape($msg)  	{ @@ -375,7 +364,7 @@ class postgres extends \phpbb\db\driver\driver  	}  	/** -	* @inheritdoc +	* {@inheritDoc}  	*/  	function cast_expr_to_bigint($expression)  	{ @@ -383,7 +372,7 @@ class postgres extends \phpbb\db\driver\driver  	}  	/** -	* @inheritdoc +	* {@inheritDoc}  	*/  	function cast_expr_to_string($expression)  	{ diff --git a/phpBB/phpbb/db/driver/sqlite.php b/phpBB/phpbb/db/driver/sqlite.php index 59ec895c0f..86a585f4eb 100644 --- a/phpBB/phpbb/db/driver/sqlite.php +++ b/phpBB/phpbb/db/driver/sqlite.php @@ -19,7 +19,7 @@ class sqlite extends \phpbb\db\driver\driver  	var $connect_error = '';  	/** -	* Connect to server +	* {@inheritDoc}  	*/  	function sql_connect($sqlserver, $sqluser, $sqlpassword, $database, $port = false, $persistency = false, $new_link = false)  	{ @@ -58,10 +58,7 @@ class sqlite extends \phpbb\db\driver\driver  	}  	/** -	* Version information about used database -	* @param bool $raw if true, only return the fetched sql_server_version -	* @param bool $use_cache if true, it is safe to retrieve the stored value from the cache -	* @return string sql server version +	* {@inheritDoc}  	*/  	function sql_server_info($raw = false, $use_cache = true)  	{ @@ -108,13 +105,7 @@ class sqlite extends \phpbb\db\driver\driver  	}  	/** -	* Base query method -	* -	* @param	string	$query		Contains the SQL query which shall be executed -	* @param	int		$cache_ttl	Either 0 to avoid caching or the time in seconds which the result shall be kept in cache -	* @return	mixed				When casted to bool the returned value returns true on success and false on failure -	* -	* @access	public +	* {@inheritDoc}  	*/  	function sql_query($query = '', $cache_ttl = 0)  	{ @@ -185,7 +176,7 @@ class sqlite extends \phpbb\db\driver\driver  	}  	/** -	* Return number of affected rows +	* {@inheritDoc}  	*/  	function sql_affectedrows()  	{ @@ -193,7 +184,7 @@ class sqlite extends \phpbb\db\driver\driver  	}  	/** -	* Fetch current row +	* {@inheritDoc}  	*/  	function sql_fetchrow($query_id = false)  	{ @@ -213,8 +204,7 @@ class sqlite extends \phpbb\db\driver\driver  	}  	/** -	* Seek to given row number -	* rownum is zero-based +	* {@inheritDoc}  	*/  	function sql_rowseek($rownum, &$query_id)  	{ @@ -234,7 +224,7 @@ class sqlite extends \phpbb\db\driver\driver  	}  	/** -	* Get last inserted id after insert statement +	* {@inheritDoc}  	*/  	function sql_nextid()  	{ @@ -242,7 +232,7 @@ class sqlite extends \phpbb\db\driver\driver  	}  	/** -	* Free sql result +	* {@inheritDoc}  	*/  	function sql_freeresult($query_id = false)  	{ @@ -262,7 +252,7 @@ class sqlite extends \phpbb\db\driver\driver  	}  	/** -	* Escape string used in sql query +	* {@inheritDoc}  	*/  	function sql_escape($msg)  	{ @@ -270,7 +260,8 @@ class sqlite extends \phpbb\db\driver\driver  	}  	/** -	* Correctly adjust LIKE expression for special characters +	* {@inheritDoc} +	*  	* For SQLite an underscore is a not-known character... this may change with SQLite3  	*/  	function sql_like_expression($expression) diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_1.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_1.php index aed0f2784b..2b65bb0185 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_1.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_1.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_10.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_10.php index 305309c3bd..d6f3029f7e 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_10.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_10.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_10_rc1.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_10_rc1.php index fb50d67fb5..0ee2a46a00 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_10_rc1.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_10_rc1.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_10_rc2.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_10_rc2.php index 63ba1e8fc2..e676571a15 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_10_rc2.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_10_rc2.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_10_rc3.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_10_rc3.php index 7055063032..d2656397a2 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_10_rc3.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_10_rc3.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_11.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_11.php index 1246597efb..6b7c9735fa 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_11.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_11.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_11_rc1.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_11_rc1.php index 7e284235e1..91ffae2f05 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_11_rc1.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_11_rc1.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_11_rc2.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_11_rc2.php index 017038855d..55290dcbcf 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_11_rc2.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_11_rc2.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_12.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_12.php index 5a2d569724..c4bf3a30ef 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_12.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_12.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2013 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_12_rc1.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_12_rc1.php index 35a3015959..ab8463cc73 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_12_rc1.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_12_rc1.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_12_rc2.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_12_rc2.php index 3edb578fc8..f41f20954a 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_12_rc2.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_12_rc2.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2013 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_12_rc3.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_12_rc3.php index 510693a5b7..9171ceb26f 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_12_rc3.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_12_rc3.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2013 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_1_rc1.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_1_rc1.php index c8273c0801..724a61ecce 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_1_rc1.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_1_rc1.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_2.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_2.php index 7e2a08590e..53792d4ce1 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_2.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_2.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_2_rc1.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_2_rc1.php index 7a856383e2..691ad44406 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_2_rc1.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_2_rc1.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_2_rc2.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_2_rc2.php index 61562575eb..26fa4f015b 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_2_rc2.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_2_rc2.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_3.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_3.php index b2adbeaa43..5374e8786a 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_3.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_3.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_3_rc1.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_3_rc1.php index 57bd59bba3..367bf2c806 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_3_rc1.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_3_rc1.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_4.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_4.php index 5d6140393b..94bba00079 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_4.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_4.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_4_rc1.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_4_rc1.php index a8af4dd76c..98aafc6d43 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_4_rc1.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_4_rc1.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_5.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_5.php index 7bbe7ffed9..92555adf78 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_5.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_5.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_5_rc1.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_5_rc1.php index ffe2c6a44d..c6b77bc379 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_5_rc1.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_5_rc1.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_5_rc1part2.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_5_rc1part2.php index 04b14b5189..b56721bd80 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_5_rc1part2.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_5_rc1part2.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_6.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_6.php index 85ea2e9d20..fb0957fc45 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_6.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_6.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_6_rc1.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_6_rc1.php index 87d5e490f8..12b0122237 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_6_rc1.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_6_rc1.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_6_rc2.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_6_rc2.php index 7a0ef28601..351079e96c 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_6_rc2.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_6_rc2.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_6_rc3.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_6_rc3.php index 73a1fe9e6a..1ccfa1cb37 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_6_rc3.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_6_rc3.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_6_rc4.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_6_rc4.php index b6e5be2c2f..6451f4fe02 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_6_rc4.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_6_rc4.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_7.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_7.php index 2b0da30bc6..70cb1293e6 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_7.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_7.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_7_pl1.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_7_pl1.php index 3547ee77e1..db2175a99a 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_7_pl1.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_7_pl1.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_7_rc1.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_7_rc1.php index de4d772808..3bdedf8c57 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_7_rc1.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_7_rc1.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_7_rc2.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_7_rc2.php index 800803a753..65ad905aa7 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_7_rc2.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_7_rc2.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_8.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_8.php index 6c8b1df6fc..c1e49f1dde 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_8.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_8.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_8_rc1.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_8_rc1.php index 1a14e5c961..e3c232f9e4 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_8_rc1.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_8_rc1.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_9.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_9.php index 9af2fce971..34e85f010a 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_9.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_9.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_9_rc1.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_9_rc1.php index 3fb790bc0d..79ef839005 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_9_rc1.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_9_rc1.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_9_rc2.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_9_rc2.php index cd79d24ade..1eb7837faf 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_9_rc2.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_9_rc2.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_9_rc3.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_9_rc3.php index 7e59b8f9e8..bbeb76509f 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_9_rc3.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_9_rc3.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v30x/release_3_0_9_rc4.php b/phpBB/phpbb/db/migration/data/v30x/release_3_0_9_rc4.php index e71d9defa6..bc75891f4d 100644 --- a/phpBB/phpbb/db/migration/data/v30x/release_3_0_9_rc4.php +++ b/phpBB/phpbb/db/migration/data/v30x/release_3_0_9_rc4.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/acp_prune_users_module.php b/phpBB/phpbb/db/migration/data/v310/acp_prune_users_module.php index ab5b1a535b..aa44222cd8 100644 --- a/phpBB/phpbb/db/migration/data/v310/acp_prune_users_module.php +++ b/phpBB/phpbb/db/migration/data/v310/acp_prune_users_module.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2014 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/allow_cdn.php b/phpBB/phpbb/db/migration/data/v310/allow_cdn.php index aa471df6e7..2cb9e58767 100644 --- a/phpBB/phpbb/db/migration/data/v310/allow_cdn.php +++ b/phpBB/phpbb/db/migration/data/v310/allow_cdn.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2013 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/alpha1.php b/phpBB/phpbb/db/migration/data/v310/alpha1.php index 403e301e64..704f5a7a29 100644 --- a/phpBB/phpbb/db/migration/data/v310/alpha1.php +++ b/phpBB/phpbb/db/migration/data/v310/alpha1.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2013 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/auth_provider_oauth.php b/phpBB/phpbb/db/migration/data/v310/auth_provider_oauth.php index 971a7e8504..daca99c255 100644 --- a/phpBB/phpbb/db/migration/data/v310/auth_provider_oauth.php +++ b/phpBB/phpbb/db/migration/data/v310/auth_provider_oauth.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2013 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/avatar_types.php b/phpBB/phpbb/db/migration/data/v310/avatar_types.php index bdbdccf0c5..17bb1f26ca 100644 --- a/phpBB/phpbb/db/migration/data/v310/avatar_types.php +++ b/phpBB/phpbb/db/migration/data/v310/avatar_types.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2013 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/avatars.php b/phpBB/phpbb/db/migration/data/v310/avatars.php index 80ce606f29..b6cd914dd9 100644 --- a/phpBB/phpbb/db/migration/data/v310/avatars.php +++ b/phpBB/phpbb/db/migration/data/v310/avatars.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2013 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/boardindex.php b/phpBB/phpbb/db/migration/data/v310/boardindex.php index 27492f2d0d..17040a60b8 100644 --- a/phpBB/phpbb/db/migration/data/v310/boardindex.php +++ b/phpBB/phpbb/db/migration/data/v310/boardindex.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2013 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/config_db_text.php b/phpBB/phpbb/db/migration/data/v310/config_db_text.php index 1a7ee7a9a6..49f30d289f 100644 --- a/phpBB/phpbb/db/migration/data/v310/config_db_text.php +++ b/phpBB/phpbb/db/migration/data/v310/config_db_text.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2013 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/dev.php b/phpBB/phpbb/db/migration/data/v310/dev.php index 83611d3731..da78db7b89 100644 --- a/phpBB/phpbb/db/migration/data/v310/dev.php +++ b/phpBB/phpbb/db/migration/data/v310/dev.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/extensions.php b/phpBB/phpbb/db/migration/data/v310/extensions.php index d8b38dbc9e..a0d57087d4 100644 --- a/phpBB/phpbb/db/migration/data/v310/extensions.php +++ b/phpBB/phpbb/db/migration/data/v310/extensions.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/forgot_password.php b/phpBB/phpbb/db/migration/data/v310/forgot_password.php index 814093caa9..523f4e2c0a 100644 --- a/phpBB/phpbb/db/migration/data/v310/forgot_password.php +++ b/phpBB/phpbb/db/migration/data/v310/forgot_password.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/jquery_update.php b/phpBB/phpbb/db/migration/data/v310/jquery_update.php index bd2de2b4d4..187d6b876a 100644 --- a/phpBB/phpbb/db/migration/data/v310/jquery_update.php +++ b/phpBB/phpbb/db/migration/data/v310/jquery_update.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2013 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/mod_rewrite.php b/phpBB/phpbb/db/migration/data/v310/mod_rewrite.php index ffb790b135..e7d71f63e3 100644 --- a/phpBB/phpbb/db/migration/data/v310/mod_rewrite.php +++ b/phpBB/phpbb/db/migration/data/v310/mod_rewrite.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2013 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/namespaces.php b/phpBB/phpbb/db/migration/data/v310/namespaces.php index f74ecbd874..aa0b2bbfac 100644 --- a/phpBB/phpbb/db/migration/data/v310/namespaces.php +++ b/phpBB/phpbb/db/migration/data/v310/namespaces.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/notifications.php b/phpBB/phpbb/db/migration/data/v310/notifications.php index 61be25bb5f..cf26436ccb 100644 --- a/phpBB/phpbb/db/migration/data/v310/notifications.php +++ b/phpBB/phpbb/db/migration/data/v310/notifications.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/notifications_schema_fix.php b/phpBB/phpbb/db/migration/data/v310/notifications_schema_fix.php index eb2eb361ee..a9d11d384c 100644 --- a/phpBB/phpbb/db/migration/data/v310/notifications_schema_fix.php +++ b/phpBB/phpbb/db/migration/data/v310/notifications_schema_fix.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2013 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/passwords.php b/phpBB/phpbb/db/migration/data/v310/passwords.php index 3422f75917..2bba9b7a70 100644 --- a/phpBB/phpbb/db/migration/data/v310/passwords.php +++ b/phpBB/phpbb/db/migration/data/v310/passwords.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2013 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/passwords_p2.php b/phpBB/phpbb/db/migration/data/v310/passwords_p2.php index 553e79403d..2768c8975d 100644 --- a/phpBB/phpbb/db/migration/data/v310/passwords_p2.php +++ b/phpBB/phpbb/db/migration/data/v310/passwords_p2.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2014 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/profilefield_cleanup.php b/phpBB/phpbb/db/migration/data/v310/profilefield_cleanup.php index 9e7ba68327..625e74fba1 100644 --- a/phpBB/phpbb/db/migration/data/v310/profilefield_cleanup.php +++ b/phpBB/phpbb/db/migration/data/v310/profilefield_cleanup.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2014 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/profilefield_interests.php b/phpBB/phpbb/db/migration/data/v310/profilefield_interests.php index 2b943c5e53..53fae2ea1a 100644 --- a/phpBB/phpbb/db/migration/data/v310/profilefield_interests.php +++ b/phpBB/phpbb/db/migration/data/v310/profilefield_interests.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2014 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/profilefield_location.php b/phpBB/phpbb/db/migration/data/v310/profilefield_location.php index 4e62eab2d7..f4db79ca5e 100644 --- a/phpBB/phpbb/db/migration/data/v310/profilefield_location.php +++ b/phpBB/phpbb/db/migration/data/v310/profilefield_location.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2014 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/profilefield_occupation.php b/phpBB/phpbb/db/migration/data/v310/profilefield_occupation.php index b0ea961c08..9a710fbcbc 100644 --- a/phpBB/phpbb/db/migration/data/v310/profilefield_occupation.php +++ b/phpBB/phpbb/db/migration/data/v310/profilefield_occupation.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2014 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/profilefield_on_memberlist.php b/phpBB/phpbb/db/migration/data/v310/profilefield_on_memberlist.php index ce51944c3e..4733b7713d 100644 --- a/phpBB/phpbb/db/migration/data/v310/profilefield_on_memberlist.php +++ b/phpBB/phpbb/db/migration/data/v310/profilefield_on_memberlist.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2014 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/profilefield_types.php b/phpBB/phpbb/db/migration/data/v310/profilefield_types.php index 2152aaee20..9b54d87c9a 100644 --- a/phpBB/phpbb/db/migration/data/v310/profilefield_types.php +++ b/phpBB/phpbb/db/migration/data/v310/profilefield_types.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2014 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/reported_posts_display.php b/phpBB/phpbb/db/migration/data/v310/reported_posts_display.php index 56b7a0916c..c6618cf467 100644 --- a/phpBB/phpbb/db/migration/data/v310/reported_posts_display.php +++ b/phpBB/phpbb/db/migration/data/v310/reported_posts_display.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/softdelete_mcp_modules.php b/phpBB/phpbb/db/migration/data/v310/softdelete_mcp_modules.php index d1a31815b2..18c225d19f 100644 --- a/phpBB/phpbb/db/migration/data/v310/softdelete_mcp_modules.php +++ b/phpBB/phpbb/db/migration/data/v310/softdelete_mcp_modules.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2013 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/softdelete_p1.php b/phpBB/phpbb/db/migration/data/v310/softdelete_p1.php index f080c78c50..d5da54b888 100644 --- a/phpBB/phpbb/db/migration/data/v310/softdelete_p1.php +++ b/phpBB/phpbb/db/migration/data/v310/softdelete_p1.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/softdelete_p2.php b/phpBB/phpbb/db/migration/data/v310/softdelete_p2.php index 38b190c766..6b84a1b980 100644 --- a/phpBB/phpbb/db/migration/data/v310/softdelete_p2.php +++ b/phpBB/phpbb/db/migration/data/v310/softdelete_p2.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/style_update_p1.php b/phpBB/phpbb/db/migration/data/v310/style_update_p1.php index 26f1046287..fcba1d73ed 100644 --- a/phpBB/phpbb/db/migration/data/v310/style_update_p1.php +++ b/phpBB/phpbb/db/migration/data/v310/style_update_p1.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/style_update_p2.php b/phpBB/phpbb/db/migration/data/v310/style_update_p2.php index 40d6a4dbbd..316741e11d 100644 --- a/phpBB/phpbb/db/migration/data/v310/style_update_p2.php +++ b/phpBB/phpbb/db/migration/data/v310/style_update_p2.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/teampage.php b/phpBB/phpbb/db/migration/data/v310/teampage.php index 172435c672..f03c09e04f 100644 --- a/phpBB/phpbb/db/migration/data/v310/teampage.php +++ b/phpBB/phpbb/db/migration/data/v310/teampage.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/timezone.php b/phpBB/phpbb/db/migration/data/v310/timezone.php index dd0c6a2093..c1da2f4998 100644 --- a/phpBB/phpbb/db/migration/data/v310/timezone.php +++ b/phpBB/phpbb/db/migration/data/v310/timezone.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/data/v310/timezone_p2.php b/phpBB/phpbb/db/migration/data/v310/timezone_p2.php index 1066ab8571..891d8622a0 100644 --- a/phpBB/phpbb/db/migration/data/v310/timezone_p2.php +++ b/phpBB/phpbb/db/migration/data/v310/timezone_p2.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/exception.php b/phpBB/phpbb/db/migration/exception.php index cfe546d1ab..c6c1a45947 100644 --- a/phpBB/phpbb/db/migration/exception.php +++ b/phpBB/phpbb/db/migration/exception.php @@ -3,7 +3,7 @@  *  * @package db  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/helper.php b/phpBB/phpbb/db/migration/helper.php index 009ad1da9f..238b2dbe53 100644 --- a/phpBB/phpbb/db/migration/helper.php +++ b/phpBB/phpbb/db/migration/helper.php @@ -3,7 +3,7 @@  *  * @package db  * @copyright (c) 2014 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/migration.php b/phpBB/phpbb/db/migration/migration.php index b32de00871..85c5fc5d08 100644 --- a/phpBB/phpbb/db/migration/migration.php +++ b/phpBB/phpbb/db/migration/migration.php @@ -3,7 +3,7 @@  *  * @package db  * @copyright (c) 2011 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ @@ -23,7 +23,7 @@ abstract class migration  	/** @var \phpbb\config\config */  	protected $config; -	/** @var \phpbb\db\driver\driver */ +	/** @var \phpbb\db\driver\driver_interface */  	protected $db;  	/** @var \phpbb\db\tools */ @@ -48,13 +48,13 @@ abstract class migration  	* Constructor  	*  	* @param \phpbb\config\config $config -	* @param \phpbb\db\driver\driver $db +	* @param \phpbb\db\driver\driver_interface $db  	* @param \phpbb\db\tools $db_tools  	* @param string $phpbb_root_path  	* @param string $php_ext  	* @param string $table_prefix  	*/ -	public function __construct(\phpbb\config\config $config, \phpbb\db\driver\driver $db, \phpbb\db\tools $db_tools, $phpbb_root_path, $php_ext, $table_prefix) +	public function __construct(\phpbb\config\config $config, \phpbb\db\driver\driver_interface $db, \phpbb\db\tools $db_tools, $phpbb_root_path, $php_ext, $table_prefix)  	{  		$this->config = $config;  		$this->db = $db; diff --git a/phpBB/phpbb/db/migration/profilefield_base_migration.php b/phpBB/phpbb/db/migration/profilefield_base_migration.php index dec7a4c2bb..3797d670f7 100644 --- a/phpBB/phpbb/db/migration/profilefield_base_migration.php +++ b/phpBB/phpbb/db/migration/profilefield_base_migration.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2014 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/schema_generator.php b/phpBB/phpbb/db/migration/schema_generator.php index a7e2fa8f06..5d40b0b26f 100644 --- a/phpBB/phpbb/db/migration/schema_generator.php +++ b/phpBB/phpbb/db/migration/schema_generator.php @@ -19,7 +19,7 @@ class schema_generator  	/** @var \phpbb\config\config */  	protected $config; -	/** @var \phpbb\db\driver\driver */ +	/** @var \phpbb\db\driver\driver_interface */  	protected $db;  	/** @var \phpbb\db\tools */ @@ -40,10 +40,13 @@ class schema_generator  	/** @var array */  	protected $tables; +	/** @var array */ +	protected $dependencies = array(); +  	/**  	* Constructor  	*/ -	public function __construct(array $class_names, \phpbb\config\config $config, \phpbb\db\driver\driver $db, \phpbb\db\tools $db_tools, $phpbb_root_path, $php_ext, $table_prefix) +	public function __construct(array $class_names, \phpbb\config\config $config, \phpbb\db\driver\driver_interface $db, \phpbb\db\tools $db_tools, $phpbb_root_path, $php_ext, $table_prefix)  	{  		$this->config = $config;  		$this->db = $db; @@ -69,11 +72,13 @@ class schema_generator  		$migrations = $this->class_names;  		$tree = array(); +		$check_dependencies = true;  		while (!empty($migrations))  		{  			foreach ($migrations as $migration_class)  			{  				$open_dependencies = array_diff($migration_class::depends_on(), $tree); +  				if (empty($open_dependencies))  				{  					$migration = new $migration_class($this->config, $this->db, $this->db_tools, $this->phpbb_root_path, $this->php_ext, $this->table_prefix); @@ -170,10 +175,41 @@ class schema_generator  					}  					unset($migrations[$migration_key]);  				} +				else if ($check_dependencies) +				{ +					$this->dependencies = array_merge($this->dependencies, $open_dependencies); +				} +			} + +			// Only run this check after the first run +			if ($check_dependencies) +			{ +				$this->check_dependencies(); +				$check_dependencies = false;  			}  		}  		ksort($this->tables);  		return $this->tables;  	} + +	/** +	* Check if one of the migrations files' dependencies can't be resolved +	* by the supplied list of migrations +	* +	* @throws UnexpectedValueException If a dependency can't be resolved +	*/ +	protected function check_dependencies() +	{ +		// Strip duplicate values from array +		$this->dependencies = array_unique($this->dependencies); + +		foreach ($this->dependencies as $dependency) +		{ +			if (!in_array($dependency, $this->class_names)) +			{ +				throw new \UnexpectedValueException("Unable to resolve the dependency '$dependency'"); +			} +		} +	}  } diff --git a/phpBB/phpbb/db/migration/tool/config.php b/phpBB/phpbb/db/migration/tool/config.php index 36a1931f4e..96d358f647 100644 --- a/phpBB/phpbb/db/migration/tool/config.php +++ b/phpBB/phpbb/db/migration/tool/config.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migration/tool/module.php b/phpBB/phpbb/db/migration/tool/module.php index ebbcbae301..96cc6b54a5 100644 --- a/phpBB/phpbb/db/migration/tool/module.php +++ b/phpBB/phpbb/db/migration/tool/module.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ @@ -19,7 +19,7 @@ class module implements \phpbb\db\migration\tool\tool_interface  	/** @var \phpbb\cache\service */  	protected $cache; -	/** @var \phpbb\db\driver\driver */ +	/** @var \phpbb\db\driver\driver_interface */  	protected $db;  	/** @var \phpbb\user */ @@ -37,14 +37,14 @@ class module implements \phpbb\db\migration\tool\tool_interface  	/**  	* Constructor  	* -	* @param \phpbb\db\driver\driver $db +	* @param \phpbb\db\driver\driver_interface $db  	* @param \phpbb\cache\service $cache  	* @param \phpbb\user $user  	* @param string $phpbb_root_path  	* @param string $php_ext  	* @param string $modules_table  	*/ -	public function __construct(\phpbb\db\driver\driver $db, \phpbb\cache\service $cache, \phpbb\user $user, $phpbb_root_path, $php_ext, $modules_table) +	public function __construct(\phpbb\db\driver\driver_interface $db, \phpbb\cache\service $cache, \phpbb\user $user, $phpbb_root_path, $php_ext, $modules_table)  	{  		$this->db = $db;  		$this->cache = $cache; diff --git a/phpBB/phpbb/db/migration/tool/permission.php b/phpBB/phpbb/db/migration/tool/permission.php index 38fcbd2952..6cb3f213f1 100644 --- a/phpBB/phpbb/db/migration/tool/permission.php +++ b/phpBB/phpbb/db/migration/tool/permission.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ @@ -22,7 +22,7 @@ class permission implements \phpbb\db\migration\tool\tool_interface  	/** @var \phpbb\cache\service */  	protected $cache; -	/** @var \phpbb\db\driver\driver */ +	/** @var \phpbb\db\driver\driver_interface */  	protected $db;  	/** @var string */ @@ -34,13 +34,13 @@ class permission implements \phpbb\db\migration\tool\tool_interface  	/**  	* Constructor  	* -	* @param \phpbb\db\driver\driver $db +	* @param \phpbb\db\driver\driver_interface $db  	* @param \phpbb\cache\service $cache  	* @param \phpbb\auth\auth $auth  	* @param string $phpbb_root_path  	* @param string $php_ext  	*/ -	public function __construct(\phpbb\db\driver\driver $db, \phpbb\cache\service $cache, \phpbb\auth\auth $auth, $phpbb_root_path, $php_ext) +	public function __construct(\phpbb\db\driver\driver_interface $db, \phpbb\cache\service $cache, \phpbb\auth\auth $auth, $phpbb_root_path, $php_ext)  	{  		$this->db = $db;  		$this->cache = $cache; diff --git a/phpBB/phpbb/db/migration/tool/tool_interface.php b/phpBB/phpbb/db/migration/tool/tool_interface.php index e7b89d8858..5eb1a2f521 100644 --- a/phpBB/phpbb/db/migration/tool/tool_interface.php +++ b/phpBB/phpbb/db/migration/tool/tool_interface.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/db/migrator.php b/phpBB/phpbb/db/migrator.php index 4fb3f1a241..d3bbbc63c5 100644 --- a/phpBB/phpbb/db/migrator.php +++ b/phpBB/phpbb/db/migrator.php @@ -3,7 +3,7 @@  *  * @package db  * @copyright (c) 2011 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ @@ -19,7 +19,7 @@ class migrator  	/** @var \phpbb\config\config */  	protected $config; -	/** @var \phpbb\db\driver\driver */ +	/** @var \phpbb\db\driver\driver_interface */  	protected $db;  	/** @var \phpbb\db\tools */ @@ -68,7 +68,7 @@ class migrator  	/**  	* Constructor of the database migrator  	*/ -	public function __construct(\phpbb\config\config $config, \phpbb\db\driver\driver $db, \phpbb\db\tools $db_tools, $migrations_table, $phpbb_root_path, $php_ext, $table_prefix, $tools, \phpbb\db\migration\helper $helper) +	public function __construct(\phpbb\config\config $config, \phpbb\db\driver\driver_interface $db, \phpbb\db\tools $db_tools, $migrations_table, $phpbb_root_path, $php_ext, $table_prefix, $tools, \phpbb\db\migration\helper $helper)  	{  		$this->config = $config;  		$this->db = $db; diff --git a/phpBB/phpbb/db/sql_insert_buffer.php b/phpBB/phpbb/db/sql_insert_buffer.php index 41026ad425..0236a55b82 100644 --- a/phpBB/phpbb/db/sql_insert_buffer.php +++ b/phpBB/phpbb/db/sql_insert_buffer.php @@ -49,7 +49,7 @@ namespace phpbb\db;  */  class sql_insert_buffer  { -	/** @var \phpbb\db\driver\driver */ +	/** @var \phpbb\db\driver\driver_interface */  	protected $db;  	/** @var string */ @@ -62,11 +62,11 @@ class sql_insert_buffer  	protected $buffer = array();  	/** -	* @param \phpbb\db\driver\driver $db +	* @param \phpbb\db\driver\driver_interface $db  	* @param string          $table_name  	* @param int             $max_buffered_rows  	*/ -	public function __construct(\phpbb\db\driver\driver $db, $table_name, $max_buffered_rows = 500) +	public function __construct(\phpbb\db\driver\driver_interface $db, $table_name, $max_buffered_rows = 500)  	{  		$this->db = $db;  		$this->table_name = $table_name; diff --git a/phpBB/phpbb/db/tools.php b/phpBB/phpbb/db/tools.php index 25c495b80b..7616849465 100644 --- a/phpBB/phpbb/db/tools.php +++ b/phpBB/phpbb/db/tools.php @@ -304,10 +304,10 @@ class tools  	/**  	* Constructor. Set DB Object and set {@link $return_statements return_statements}.  	* -	* @param \phpbb\db\driver\driver	$db					Database connection +	* @param \phpbb\db\driver\driver_interface	$db					Database connection  	* @param bool		$return_statements	True if only statements should be returned and no SQL being executed  	*/ -	public function __construct(\phpbb\db\driver\driver $db, $return_statements = false) +	public function __construct(\phpbb\db\driver\driver_interface $db, $return_statements = false)  	{  		$this->db = $db;  		$this->return_statements = $return_statements; diff --git a/phpBB/phpbb/extension/manager.php b/phpBB/phpbb/extension/manager.php index 993bd1b925..b22fbf07a6 100644 --- a/phpBB/phpbb/extension/manager.php +++ b/phpBB/phpbb/extension/manager.php @@ -34,7 +34,7 @@ class manager  	* Creates a manager and loads information from database  	*  	* @param ContainerInterface $container A container -	* @param \phpbb\db\driver\driver $db A database connection +	* @param \phpbb\db\driver\driver_interface $db A database connection  	* @param \phpbb\config\config $config \phpbb\config\config  	* @param \phpbb\filesystem $filesystem  	* @param string $extension_table The name of the table holding extensions @@ -43,7 +43,7 @@ class manager  	* @param \phpbb\cache\driver\driver_interface $cache A cache instance or null  	* @param string $cache_name The name of the cache variable, defaults to _ext  	*/ -	public function __construct(ContainerInterface $container, \phpbb\db\driver\driver $db, \phpbb\config\config $config, \phpbb\filesystem $filesystem, $extension_table, $phpbb_root_path, $php_ext = 'php', \phpbb\cache\driver\driver_interface $cache = null, $cache_name = '_ext') +	public function __construct(ContainerInterface $container, \phpbb\db\driver\driver_interface $db, \phpbb\config\config $config, \phpbb\filesystem $filesystem, $extension_table, $phpbb_root_path, $php_ext = 'php', \phpbb\cache\driver\driver_interface $cache = null, $cache_name = '_ext')  	{  		$this->container = $container;  		$this->phpbb_root_path = $phpbb_root_path; diff --git a/phpBB/phpbb/feed/base.php b/phpBB/phpbb/feed/base.php index e6c1e606fa..0e3a80ebb8 100644 --- a/phpBB/phpbb/feed/base.php +++ b/phpBB/phpbb/feed/base.php @@ -25,7 +25,7 @@ abstract class base  	/** @var \phpbb\config\config */  	protected $config; -	/** @var \phpbb\db\driver\driver */ +	/** @var \phpbb\db\driver\driver_interface */  	protected $db;  	/** @var \phpbb\cache\driver\driver_interface */ @@ -70,7 +70,7 @@ abstract class base  	*  	* @param \phpbb\feed\helper $helper Feed helper  	* @param \phpbb\config\config		$config		Config object -	* @param \phpbb\db\driver\driver	$db			Database connection +	* @param \phpbb\db\driver\driver_interface	$db			Database connection  	* @param \phpbb\cache\driver\driver_interface	$cache			Cache object  	* @param \phpbb\user			$user		User object  	* @param \phpbb\auth\auth			$auth		Auth object @@ -78,7 +78,7 @@ abstract class base  	* @param string				$phpEx		php file extension  	* @return	null  	*/ -	function __construct(\phpbb\feed\helper $helper, \phpbb\config\config $config, \phpbb\db\driver\driver $db, \phpbb\cache\driver\driver_interface $cache, \phpbb\user $user, \phpbb\auth\auth $auth, \phpbb\content_visibility $content_visibility, $phpEx) +	function __construct(\phpbb\feed\helper $helper, \phpbb\config\config $config, \phpbb\db\driver\driver_interface $db, \phpbb\cache\driver\driver_interface $cache, \phpbb\user $user, \phpbb\auth\auth $auth, \phpbb\content_visibility $content_visibility, $phpEx)  	{  		$this->config = $config;  		$this->helper = $helper; diff --git a/phpBB/phpbb/feed/factory.php b/phpBB/phpbb/feed/factory.php index d370160563..742b279ef4 100644 --- a/phpBB/phpbb/feed/factory.php +++ b/phpBB/phpbb/feed/factory.php @@ -24,7 +24,7 @@ class factory  	/** @var \phpbb\config\config */  	protected $config; -	/** @var \phpbb\db\driver\driver */ +	/** @var \phpbb\db\driver\driver_interface */  	protected $db;  	/** @@ -32,10 +32,10 @@ class factory  	*  	* @param objec				$container	Container object  	* @param \phpbb\config\config		$config		Config object -	* @param \phpbb\db\driver\driver	$db			Database connection +	* @param \phpbb\db\driver\driver_interface	$db			Database connection  	* @return	null  	*/ -	public function __construct($container, \phpbb\config\config $config, \phpbb\db\driver\driver $db) +	public function __construct($container, \phpbb\config\config $config, \phpbb\db\driver\driver_interface $db)  	{  		$this->container = $container;  		$this->config = $config; diff --git a/phpBB/phpbb/groupposition/exception.php b/phpBB/phpbb/groupposition/exception.php index f43502235d..9b55669524 100644 --- a/phpBB/phpbb/groupposition/exception.php +++ b/phpBB/phpbb/groupposition/exception.php @@ -3,7 +3,7 @@  *  * @package groupposition  * @copyright (c) 2013 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/groupposition/legend.php b/phpBB/phpbb/groupposition/legend.php index 47ba06c006..42af005622 100644 --- a/phpBB/phpbb/groupposition/legend.php +++ b/phpBB/phpbb/groupposition/legend.php @@ -26,7 +26,7 @@ class legend implements \phpbb\groupposition\groupposition_interface  	/**  	* Database object -	* @var \phpbb\db\driver\driver +	* @var \phpbb\db\driver\driver_interface  	*/  	protected $db; @@ -39,10 +39,10 @@ class legend implements \phpbb\groupposition\groupposition_interface  	/**  	* Constructor  	* -	* @param \phpbb\db\driver\driver	$db		Database object +	* @param \phpbb\db\driver\driver_interface	$db		Database object  	* @param \phpbb\user			$user	User object  	*/ -	public function __construct(\phpbb\db\driver\driver $db, \phpbb\user $user) +	public function __construct(\phpbb\db\driver\driver_interface $db, \phpbb\user $user)  	{  		$this->db = $db;  		$this->user = $user; diff --git a/phpBB/phpbb/groupposition/teampage.php b/phpBB/phpbb/groupposition/teampage.php index d934571ebc..4f1b102720 100644 --- a/phpBB/phpbb/groupposition/teampage.php +++ b/phpBB/phpbb/groupposition/teampage.php @@ -30,7 +30,7 @@ class teampage implements \phpbb\groupposition\groupposition_interface  	/**  	* Database object -	* @var \phpbb\db\driver\driver +	* @var \phpbb\db\driver\driver_interface  	*/  	protected $db; @@ -49,11 +49,11 @@ class teampage implements \phpbb\groupposition\groupposition_interface  	/**  	* Constructor  	* -	* @param \phpbb\db\driver\driver				$db		Database object +	* @param \phpbb\db\driver\driver_interface				$db		Database object  	* @param \phpbb\user						$user	User object  	* @param \phpbb\cache\driver\driver_interface	$cache	Cache object  	*/ -	public function __construct(\phpbb\db\driver\driver $db, \phpbb\user $user, \phpbb\cache\driver\driver_interface $cache) +	public function __construct(\phpbb\db\driver\driver_interface $db, \phpbb\user $user, \phpbb\cache\driver\driver_interface $cache)  	{  		$this->db = $db;  		$this->user = $user; diff --git a/phpBB/phpbb/json_response.php b/phpBB/phpbb/json_response.php index 45c2f6cac4..e17525519a 100644 --- a/phpBB/phpbb/json_response.php +++ b/phpBB/phpbb/json_response.php @@ -3,7 +3,7 @@  *  * @package phpBB3  * @copyright (c) 2011 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/lock/db.php b/phpBB/phpbb/lock/db.php index 461adda045..2b437ef899 100644 --- a/phpBB/phpbb/lock/db.php +++ b/phpBB/phpbb/lock/db.php @@ -42,7 +42,7 @@ class db  	/**  	* A database connection -	* @var \phpbb\db\driver\driver +	* @var \phpbb\db\driver\driver_interface  	*/  	private $db; @@ -53,9 +53,9 @@ class db  	*  	* @param	string	$config_name	A config variable to be used for locking  	* @param	array	$config			The phpBB configuration -	* @param	\phpbb\db\driver\driver	$db				A database connection +	* @param	\phpbb\db\driver\driver_interface	$db				A database connection  	*/ -	public function __construct($config_name, \phpbb\config\config $config, \phpbb\db\driver\driver $db) +	public function __construct($config_name, \phpbb\config\config $config, \phpbb\db\driver\driver_interface $db)  	{  		$this->config_name = $config_name;  		$this->config = $config; diff --git a/phpBB/phpbb/log/log.php b/phpBB/phpbb/log/log.php index 68b023e244..24eb408b63 100644 --- a/phpBB/phpbb/log/log.php +++ b/phpBB/phpbb/log/log.php @@ -93,10 +93,10 @@ class log implements \phpbb\log\log_interface  	/**  	* Constructor  	* -	* @param	\phpbb\db\driver\driver	$db		Database object +	* @param	\phpbb\db\driver\driver_interface	$db		Database object  	* @param	\phpbb\user		$user	User object  	* @param	\phpbb\auth\auth		$auth	Auth object -	* @param	phpbb_dispatcher	$phpbb_dispatcher	Event dispatcher +	* @param	\phpbb\event\dispatcher	$phpbb_dispatcher	Event dispatcher  	* @param	string		$phpbb_root_path		Root path  	* @param	string		$relative_admin_path	Relative admin root path  	* @param	string		$php_ext			PHP Extension @@ -490,7 +490,7 @@ class log implements \phpbb\log\log_interface  				'topic_id'			=> (int) $row['topic_id'],  				'viewforum'			=> ($row['forum_id'] && $this->auth->acl_get('f_read', $row['forum_id'])) ? append_sid("{$this->phpbb_root_path}viewforum.{$this->php_ext}", 'f=' . $row['forum_id']) : false, -				'action'			=> (isset($this->user->lang[$row['log_operation']])) ? $this->user->lang[$row['log_operation']] : '{' . ucfirst(str_replace('_', ' ', $row['log_operation'])) . '}', +				'action'			=> (isset($this->user->lang[$row['log_operation']])) ? $row['log_operation'] : '{' . ucfirst(str_replace('_', ' ', $row['log_operation'])) . '}',  			);  			/** @@ -517,12 +517,26 @@ class log implements \phpbb\log\log_interface  					// arguments, if there are we fill out the arguments  					// array. It doesn't matter if we add more arguments than  					// placeholders. -					if ((substr_count($log[$i]['action'], '%') - sizeof($log_data_ary)) > 0) +					$num_args = 0; +					if (!is_array($this->user->lang[$row['log_operation']]))  					{ -						$log_data_ary = array_merge($log_data_ary, array_fill(0, substr_count($log[$i]['action'], '%') - sizeof($log_data_ary), '')); +						$num_args = substr_count($log[$i]['action'], '%'); +					} +					else +					{ +						foreach ($this->user->lang[$row['log_operation']] as $case => $plural_string) +						{ +							$num_args = max($num_args, substr_count($plural_string, '%')); +						} +					} + +					if (($num_args - sizeof($log_data_ary)) > 0) +					{ +						$log_data_ary = array_merge($log_data_ary, array_fill(0, $num_args - sizeof($log_data_ary), ''));  					} -					$log[$i]['action'] = vsprintf($log[$i]['action'], $log_data_ary); +					$lang_arguments = array_merge(array($log[$i]['action']), $log_data_ary); +					$log[$i]['action'] = call_user_func_array(array($this->user, 'lang'), $lang_arguments);  					// If within the admin panel we do not censor text out  					if ($this->get_is_admin()) diff --git a/phpBB/phpbb/notification/exception.php b/phpBB/phpbb/notification/exception.php index 6bdded3fd8..1b4cc89fc9 100644 --- a/phpBB/phpbb/notification/exception.php +++ b/phpBB/phpbb/notification/exception.php @@ -3,7 +3,7 @@  *  * @package notifications  * @copyright (c) 2013 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/phpBB/phpbb/notification/manager.php b/phpBB/phpbb/notification/manager.php index 2e8652771b..09d9677ccd 100644 --- a/phpBB/phpbb/notification/manager.php +++ b/phpBB/phpbb/notification/manager.php @@ -30,7 +30,7 @@ class manager  	/** @var \phpbb\config\config */  	protected $config; -	/** @var \phpbb\db\driver\driver */ +	/** @var \phpbb\db\driver\driver_interface */  	protected $db;  	/** @var \phpbb\cache\service */ @@ -62,7 +62,7 @@ class manager  	* @param ContainerBuilder $phpbb_container  	* @param \phpbb\user_loader $user_loader  	* @param \phpbb\config\config $config -	* @param \phpbb\db\driver\driver $db +	* @param \phpbb\db\driver\driver_interface $db  	* @param \phpbb\user $user  	* @param string $phpbb_root_path  	* @param string $php_ext @@ -71,7 +71,7 @@ class manager  	* @param string $user_notifications_table  	* @return \phpbb\notification\manager  	*/ -	public function __construct($notification_types, $notification_methods, $phpbb_container, \phpbb\user_loader $user_loader, \phpbb\config\config $config, \phpbb\db\driver\driver $db, \phpbb\cache\service $cache, $user, $phpbb_root_path, $php_ext, $notification_types_table, $notifications_table, $user_notifications_table) +	public function __construct($notification_types, $notification_methods, $phpbb_container, \phpbb\user_loader $user_loader, \phpbb\config\config $config, \phpbb\db\driver\driver_interface $db, \phpbb\cache\service $cache, $user, $phpbb_root_path, $php_ext, $notification_types_table, $notifications_table, $user_notifications_table)  	{  		$this->notification_types = $notification_types;  		$this->notification_methods = $notification_methods; diff --git a/phpBB/phpbb/notification/method/base.php b/phpBB/phpbb/notification/method/base.php index 4ce42de830..2e6507d30f 100644 --- a/phpBB/phpbb/notification/method/base.php +++ b/phpBB/phpbb/notification/method/base.php @@ -21,7 +21,7 @@ abstract class base implements \phpbb\notification\method\method_interface  	/** @var \phpbb\user_loader */  	protected $user_loader; -	/** @var \phpbb\db\driver\driver */ +	/** @var \phpbb\db\driver\driver_interface */  	protected $db;  	/** @var \phpbb\cache\driver\driver_interface */ @@ -59,7 +59,7 @@ abstract class base implements \phpbb\notification\method\method_interface  	* Notification Method Base Constructor  	*   	* @param \phpbb\user_loader $user_loader -	* @param \phpbb\db\driver\driver $db +	* @param \phpbb\db\driver\driver_interface $db  	* @param \phpbb\cache\driver\driver_interface $cache  	* @param \phpbb\user $user  	* @param \phpbb\auth\auth $auth @@ -68,7 +68,7 @@ abstract class base implements \phpbb\notification\method\method_interface  	* @param string $php_ext  	* @return \phpbb\notification\method\base  	*/ -	public function __construct(\phpbb\user_loader $user_loader, \phpbb\db\driver\driver $db, \phpbb\cache\driver\driver_interface $cache, $user, \phpbb\auth\auth $auth, \phpbb\config\config $config, $phpbb_root_path, $php_ext) +	public function __construct(\phpbb\user_loader $user_loader, \phpbb\db\driver\driver_interface $db, \phpbb\cache\driver\driver_interface $cache, $user, \phpbb\auth\auth $auth, \phpbb\config\config $config, $phpbb_root_path, $php_ext)  	{  		$this->user_loader = $user_loader;  		$this->db = $db; diff --git a/phpBB/phpbb/notification/type/base.php b/phpBB/phpbb/notification/type/base.php index 10c876b286..0719540bdb 100644 --- a/phpBB/phpbb/notification/type/base.php +++ b/phpBB/phpbb/notification/type/base.php @@ -21,7 +21,7 @@ abstract class base implements \phpbb\notification\type\type_interface  	/** @var \phpbb\user_loader */  	protected $user_loader; -	/** @var \phpbb\db\driver\driver */ +	/** @var \phpbb\db\driver\driver_interface */  	protected $db;  	/** @var \phpbb\cache\driver\driver_interface */ @@ -89,7 +89,7 @@ abstract class base implements \phpbb\notification\type\type_interface  	* Notification Type Base Constructor  	*  	* @param \phpbb\user_loader $user_loader -	* @param \phpbb\db\driver\driver $db +	* @param \phpbb\db\driver\driver_interface $db  	* @param \phpbb\cache\driver\driver_interface $cache  	* @param \phpbb\user $user  	* @param \phpbb\auth\auth $auth @@ -101,7 +101,7 @@ abstract class base implements \phpbb\notification\type\type_interface  	* @param string $user_notifications_table  	* @return \phpbb\notification\type\base  	*/ -	public function __construct(\phpbb\user_loader $user_loader, \phpbb\db\driver\driver $db, \phpbb\cache\driver\driver_interface $cache, $user, \phpbb\auth\auth $auth, \phpbb\config\config $config, $phpbb_root_path, $php_ext, $notification_types_table, $notifications_table, $user_notifications_table) +	public function __construct(\phpbb\user_loader $user_loader, \phpbb\db\driver\driver_interface $db, \phpbb\cache\driver\driver_interface $cache, $user, \phpbb\auth\auth $auth, \phpbb\config\config $config, $phpbb_root_path, $php_ext, $notification_types_table, $notifications_table, $user_notifications_table)  	{  		$this->user_loader = $user_loader;  		$this->db = $db; diff --git a/phpBB/phpbb/plupload/plupload.php b/phpBB/phpbb/plupload/plupload.php index 6bff2b8a7e..b988ce7ce0 100644 --- a/phpBB/phpbb/plupload/plupload.php +++ b/phpBB/phpbb/plupload/plupload.php @@ -146,10 +146,11 @@ class plupload  	* @param \phpbb\template\template	$template  	* @param string						$s_action The URL to submit the POST data to  	* @param int						$forum_id The ID of the forum +	* @param int						$max_files Maximum number of files allowed. 0 for unlimited.  	*  	* @return null  	*/ -	public function configure(\phpbb\cache\service $cache, \phpbb\template\template $template, $s_action, $forum_id) +	public function configure(\phpbb\cache\service $cache, \phpbb\template\template $template, $s_action, $forum_id, $max_files)  	{  		$filters = $this->generate_filter_string($cache, $forum_id);  		$chunk_size = $this->get_chunk_size(); @@ -161,6 +162,9 @@ class plupload  			'FILTERS'			=> $filters,  			'CHUNK_SIZE'		=> $chunk_size,  			'S_PLUPLOAD_URL'	=> htmlspecialchars_decode($s_action), +			'MAX_ATTACHMENTS'	=> $max_files, +			'ATTACH_ORDER'		=> ($this->config['display_order']) ? 'asc' : 'desc', +			'L_TOO_MANY_ATTACHMENTS'	=> $this->user->lang('TOO_MANY_ATTACHMENTS', $max_files),  		));  		$this->user->add_lang('plupload'); diff --git a/phpBB/phpbb/profilefields/lang_helper.php b/phpBB/phpbb/profilefields/lang_helper.php index 7bae1bdc18..7ad4722230 100644 --- a/phpBB/phpbb/profilefields/lang_helper.php +++ b/phpBB/phpbb/profilefields/lang_helper.php @@ -23,7 +23,7 @@ class lang_helper  	/**  	* Database object -	* @var \phpbb\db\driver\driver +	* @var \phpbb\db\driver\driver_interface  	*/  	protected $db; @@ -36,7 +36,7 @@ class lang_helper  	/**  	* Construct  	* -	* @param	\phpbb\db\driver\driver	$db		Database object +	* @param	\phpbb\db\driver\driver_interface	$db		Database object  	* @param	string		$language_table		Table where the language strings are stored  	*/  	public function __construct($db, $language_table) diff --git a/phpBB/phpbb/profilefields/manager.php b/phpBB/phpbb/profilefields/manager.php index a4626bc5de..37449c67c4 100644 --- a/phpBB/phpbb/profilefields/manager.php +++ b/phpBB/phpbb/profilefields/manager.php @@ -23,7 +23,7 @@ class manager  	/**  	* Database object -	* @var \phpbb\db\driver\driver +	* @var \phpbb\db\driver\driver_interface  	*/  	protected $db; @@ -63,7 +63,7 @@ class manager  	* Construct  	*  	* @param	\phpbb\auth\auth			$auth		Auth object -	* @param	\phpbb\db\driver\driver		$db			Database object +	* @param	\phpbb\db\driver\driver_interface	$db			Database object  	* @param	\phpbb\request\request		$request	Request object  	* @param	\phpbb\template\template	$template	Template object  	* @param	\phpbb\di\service_collection $type_collection @@ -72,7 +72,7 @@ class manager  	* @param	string				$fields_language_table  	* @param	string				$fields_data_table  	*/ -	public function __construct(\phpbb\auth\auth $auth, \phpbb\db\driver\driver $db, \phpbb\request\request $request, \phpbb\template\template $template, \phpbb\di\service_collection $type_collection, \phpbb\user $user, $fields_table, $fields_language_table, $fields_data_table) +	public function __construct(\phpbb\auth\auth $auth, \phpbb\db\driver\driver_interface $db, \phpbb\request\request $request, \phpbb\template\template $template, \phpbb\di\service_collection $type_collection, \phpbb\user $user, $fields_table, $fields_language_table, $fields_data_table)  	{  		$this->auth = $auth;  		$this->db = $db; @@ -231,6 +231,7 @@ class manager  		if (!$this->db->sql_affectedrows())  		{ +			$cp_data = $this->build_insert_sql_array($cp_data);  			$cp_data['user_id'] = (int) $user_id;  			$this->db->sql_return_on_error(true); diff --git a/phpBB/phpbb/search/fulltext_mysql.php b/phpBB/phpbb/search/fulltext_mysql.php index 509b73e26e..e5b0c89cb6 100644 --- a/phpBB/phpbb/search/fulltext_mysql.php +++ b/phpBB/phpbb/search/fulltext_mysql.php @@ -36,7 +36,7 @@ class fulltext_mysql extends \phpbb\search\base  	/**  	 * Database connection -	 * @var \phpbb\db\driver\driver +	 * @var \phpbb\db\driver\driver_interface  	 */  	protected $db; diff --git a/phpBB/phpbb/search/fulltext_native.php b/phpBB/phpbb/search/fulltext_native.php index 60180f1728..7d51d164c7 100644 --- a/phpBB/phpbb/search/fulltext_native.php +++ b/phpBB/phpbb/search/fulltext_native.php @@ -80,7 +80,7 @@ class fulltext_native extends \phpbb\search\base  	/**  	 * Database connection -	 * @var \phpbb\db\driver\driver +	 * @var \phpbb\db\driver\driver_interface  	 */  	protected $db; diff --git a/phpBB/phpbb/search/fulltext_postgres.php b/phpBB/phpbb/search/fulltext_postgres.php index 63caeffcc5..864a53e642 100644 --- a/phpBB/phpbb/search/fulltext_postgres.php +++ b/phpBB/phpbb/search/fulltext_postgres.php @@ -61,7 +61,7 @@ class fulltext_postgres extends \phpbb\search\base  	/**  	 * Database connection -	 * @var \phpbb\db\driver\driver +	 * @var \phpbb\db\driver\driver_interface  	 */  	protected $db; diff --git a/phpBB/phpbb/search/fulltext_sphinx.php b/phpBB/phpbb/search/fulltext_sphinx.php index d86a394326..1501dcdc31 100644 --- a/phpBB/phpbb/search/fulltext_sphinx.php +++ b/phpBB/phpbb/search/fulltext_sphinx.php @@ -77,7 +77,7 @@ class fulltext_sphinx  	/**  	 * Database connection -	 * @var \phpbb\db\driver\driver +	 * @var \phpbb\db\driver\driver_interface  	 */  	protected $db; diff --git a/phpBB/phpbb/tree/nestedset.php b/phpBB/phpbb/tree/nestedset.php index 2bfb65732d..9aaee9e468 100644 --- a/phpBB/phpbb/tree/nestedset.php +++ b/phpBB/phpbb/tree/nestedset.php @@ -11,7 +11,7 @@ namespace phpbb\tree;  abstract class nestedset implements \phpbb\tree\tree_interface  { -	/** @var \phpbb\db\driver\driver */ +	/** @var \phpbb\db\driver\driver_interface */  	protected $db;  	/** @var \phpbb\lock\db */ @@ -52,7 +52,7 @@ abstract class nestedset implements \phpbb\tree\tree_interface  	/**  	* Construct  	* -	* @param \phpbb\db\driver\driver	$db		Database connection +	* @param \phpbb\db\driver\driver_interface	$db		Database connection  	* @param \phpbb\lock\db		$lock	Lock class used to lock the table when moving forums around  	* @param string			$table_name			Table name  	* @param string			$message_prefix		Prefix for the messages thrown by exceptions @@ -60,7 +60,7 @@ abstract class nestedset implements \phpbb\tree\tree_interface  	* @param array			$item_basic_data	Array with basic item data that is stored in item_parents  	* @param array			$columns			Array with column names to overwrite  	*/ -	public function __construct(\phpbb\db\driver\driver $db, \phpbb\lock\db $lock, $table_name, $message_prefix = '', $sql_where = '', $item_basic_data = array(), $columns = array()) +	public function __construct(\phpbb\db\driver\driver_interface $db, \phpbb\lock\db $lock, $table_name, $message_prefix = '', $sql_where = '', $item_basic_data = array(), $columns = array())  	{  		$this->db = $db;  		$this->lock = $lock; diff --git a/phpBB/phpbb/tree/nestedset_forum.php b/phpBB/phpbb/tree/nestedset_forum.php index ef6023546b..5973b0b6d9 100644 --- a/phpBB/phpbb/tree/nestedset_forum.php +++ b/phpBB/phpbb/tree/nestedset_forum.php @@ -14,11 +14,11 @@ class nestedset_forum extends \phpbb\tree\nestedset  	/**  	* Construct  	* -	* @param \phpbb\db\driver\driver	$db		Database connection +	* @param \phpbb\db\driver\driver_interface	$db		Database connection  	* @param \phpbb\lock\db		$lock	Lock class used to lock the table when moving forums around  	* @param string				$table_name		Table name  	*/ -	public function __construct(\phpbb\db\driver\driver $db, \phpbb\lock\db $lock, $table_name) +	public function __construct(\phpbb\db\driver\driver_interface $db, \phpbb\lock\db $lock, $table_name)  	{  		parent::__construct(  			$db, diff --git a/phpBB/phpbb/user_loader.php b/phpBB/phpbb/user_loader.php index c1d69802f8..9179572277 100644 --- a/phpBB/phpbb/user_loader.php +++ b/phpBB/phpbb/user_loader.php @@ -19,7 +19,7 @@ namespace phpbb;  */  class user_loader  { -	/** @var \phpbb\db\driver\driver */ +	/** @var \phpbb\db\driver\driver_interface */  	protected $db = null;  	/** @var string */ @@ -41,12 +41,12 @@ class user_loader  	/**  	* User loader constructor  	* -	* @param \phpbb\db\driver\driver $db A database connection +	* @param \phpbb\db\driver\driver_interface $db A database connection  	* @param string $phpbb_root_path Path to the phpbb includes directory.  	* @param string $php_ext php file extension  	* @param string $users_table The name of the database table (phpbb_users)  	*/ -	public function __construct(\phpbb\db\driver\driver $db, $phpbb_root_path, $php_ext, $users_table) +	public function __construct(\phpbb\db\driver\driver_interface $db, $phpbb_root_path, $php_ext, $users_table)  	{  		$this->db = $db; diff --git a/phpBB/posting.php b/phpBB/posting.php index ef90c229da..f592402fc6 100644 --- a/phpBB/posting.php +++ b/phpBB/posting.php @@ -1478,7 +1478,6 @@ $template->assign_vars(array(  	'L_POST_A'					=> $page_title,  	'L_ICON'					=> ($mode == 'reply' || $mode == 'quote' || ($mode == 'edit' && $post_id != $post_data['topic_first_post_id'])) ? $user->lang['POST_ICON'] : $user->lang['TOPIC_ICON'],  	'L_MESSAGE_BODY_EXPLAIN'	=> $user->lang('MESSAGE_BODY_EXPLAIN', (int) $config['max_post_chars']), -	'L_TOO_MANY_ATTACHMENTS'	=> $user->lang('TOO_MANY_ATTACHMENTS', (int) $config['max_attachments']),  	'FORUM_NAME'			=> $post_data['forum_name'],  	'FORUM_DESC'			=> ($post_data['forum_desc']) ? generate_text_for_display($post_data['forum_desc'], $post_data['forum_desc_uid'], $post_data['forum_desc_bitfield'], $post_data['forum_desc_options']) : '', @@ -1502,8 +1501,6 @@ $template->assign_vars(array(  	'U_VIEW_TOPIC'			=> ($mode != 'post') ? append_sid("{$phpbb_root_path}viewtopic.$phpEx", "f=$forum_id&t=$topic_id") : '',  	'U_PROGRESS_BAR'		=> append_sid("{$phpbb_root_path}posting.$phpEx", "f=$forum_id&mode=popup"),  	'UA_PROGRESS_BAR'		=> addslashes(append_sid("{$phpbb_root_path}posting.$phpEx", "f=$forum_id&mode=popup")), -	'ATTACH_ORDER'			=> ($config['display_order']) ? 'asc' : 'desc', -	'MAX_ATTACHMENTS'		=> ($auth->acl_get('a_') || $auth->acl_get('m_', $forum_id)) ? 0 : (int) $config['max_attachments'],  	'S_PRIVMSGS'				=> false,  	'S_CLOSE_PROGRESS_WINDOW'	=> (isset($_POST['add_file'])) ? true : false, @@ -1544,6 +1541,7 @@ $template->assign_vars(array(  	'S_POST_ACTION'			=> $s_action,  	'S_HIDDEN_FIELDS'		=> $s_hidden_fields,  	'S_ATTACH_DATA'			=> json_encode($message_parser->attachment_data), +	'S_IN_POSTING'			=> true,  ));  /** @@ -1582,7 +1580,8 @@ $allowed = ($auth->acl_get('f_attach', $forum_id) && $auth->acl_get('u_attach')  if ($allowed)  { -	$plupload->configure($cache, $template, $s_action, $forum_id); +	$max_files = ($auth->acl_get('a_') || $auth->acl_get('m_', $forum_id)) ? 0 : (int) $config['max_attachments']; +	$plupload->configure($cache, $template, $s_action, $forum_id, $max_files);  }  // Attachment entry diff --git a/phpBB/report.php b/phpBB/report.php index 5081f90ad1..1adee028dc 100644 --- a/phpBB/report.php +++ b/phpBB/report.php @@ -301,8 +301,9 @@ $template->assign_vars(array(  	'S_HIDDEN_FIELDS'	=> (sizeof($s_hidden_fields)) ? $s_hidden_fields : null,  	'S_NOTIFY'			=> $user_notify, -	'S_CAN_NOTIFY'		=> ($user->data['is_registered']) ? true : false) -); +	'S_CAN_NOTIFY'		=> ($user->data['is_registered']) ? true : false, +	'S_IN_REPORT'		=> true, +));  generate_forum_nav($forum_data); diff --git a/phpBB/styles/prosilver/template/forum_fn.js b/phpBB/styles/prosilver/template/forum_fn.js index de51b54e9b..56dfcb04c7 100644 --- a/phpBB/styles/prosilver/template/forum_fn.js +++ b/phpBB/styles/prosilver/template/forum_fn.js @@ -184,9 +184,10 @@ function selectCode(a) {  	// Not IE and IE9+  	if (window.getSelection) {  		s = window.getSelection(); -		// Safari +		// Safari and Chrome  		if (s.setBaseAndExtent) { -			s.setBaseAndExtent(e, 0, e, e.innerText.length - 1); +			var l = (e.innerText.length > 1) ? e.innerText.length - 1 : 1; +			s.setBaseAndExtent(e, 0, e, l);  		}  		// Firefox and Opera  		else { diff --git a/phpBB/styles/prosilver/template/overall_header.html b/phpBB/styles/prosilver/template/overall_header.html index 5d09694346..d342fce441 100644 --- a/phpBB/styles/prosilver/template/overall_header.html +++ b/phpBB/styles/prosilver/template/overall_header.html @@ -48,7 +48,7 @@  {$STYLESHEETS}  </head> -<body id="phpbb" class="nojs section-{SCRIPT_NAME} {S_CONTENT_DIRECTION}"> +<body id="phpbb" class="nojs section-{SCRIPT_NAME} {S_CONTENT_DIRECTION} {BODY_CLASS}">  <!-- EVENT overall_header_body_before --> diff --git a/phpBB/styles/prosilver/template/posting_attach_body.html b/phpBB/styles/prosilver/template/posting_attach_body.html index 8a2004c29b..b6f4d13804 100644 --- a/phpBB/styles/prosilver/template/posting_attach_body.html +++ b/phpBB/styles/prosilver/template/posting_attach_body.html @@ -35,7 +35,6 @@  				<tbody class="responsive-skip-empty" id="file-list">  					<tr class="attach-row" id="attach-row-tpl">  							<td class="attach-name"> -								<dfn style="display: none;">{L_PLUPLOAD_FILENAME}</dfn>  								<span class="file-name"></span>  								<span class="attach-controls">  									<input type="button" value="{L_PLACE_INLINE}" class="button2 hidden file-inline-bbcode" />  @@ -44,15 +43,12 @@  								<span class="clear"></span>  							</td>  							<td class="attach-comment"> -								<dfn style="display: none;">{L_FILE_COMMENT}</dfn>  								<textarea rows="1" cols="30" class="inputbox"></textarea>  							</td>  							<td class="attach-filesize"> -								<dfn style="display: none;">{L_PLUPLOAD_SIZE}</dfn>  								<span class="file-size"></span>  							</td>  							<td class="attach-status"> -								<dfn style="display: none;">{L_PLUPLOAD_STATUS}</dfn>  								<span class="file-progress">  									<span class="file-progress-bar"></span>  								</span> diff --git a/phpBB/styles/prosilver/template/simple_header.html b/phpBB/styles/prosilver/template/simple_header.html index 24a99154d0..f5e265ac16 100644 --- a/phpBB/styles/prosilver/template/simple_header.html +++ b/phpBB/styles/prosilver/template/simple_header.html @@ -26,7 +26,7 @@  </head> -<body id="phpbb" class="nojs {S_CONTENT_DIRECTION}"> +<body id="phpbb" class="nojs {S_CONTENT_DIRECTION} {BODY_CLASS}">  <!-- EVENT simple_header_body_before --> diff --git a/phpBB/styles/prosilver/template/ucp_notifications.html b/phpBB/styles/prosilver/template/ucp_notifications.html index 2712e53034..b400a3c8b1 100644 --- a/phpBB/styles/prosilver/template/ucp_notifications.html +++ b/phpBB/styles/prosilver/template/ucp_notifications.html @@ -11,11 +11,13 @@  		<!-- IF MODE == 'notification_options' -->  			<table class="table1">  				<thead> -					<th>{L_NOTIFICATION_TYPE}</th> -					<!-- BEGIN notification_methods --> -						<th class="mark">{notification_methods.NAME}</th> -					<!-- END notification_methods --> -					<th class="mark">{L_NOTIFICATIONS}</th> +					<tr> +						<th>{L_NOTIFICATION_TYPE}</th> +						<!-- BEGIN notification_methods --> +							<th class="mark">{notification_methods.NAME}</th> +						<!-- END notification_methods --> +						<th class="mark">{L_NOTIFICATIONS}</th> +					</tr>  				</thead>  				<tbody>  				<!-- BEGIN notification_types --> diff --git a/phpBB/styles/prosilver/template/ucp_profile_autologin_keys.html b/phpBB/styles/prosilver/template/ucp_profile_autologin_keys.html index bf97434bac..6fec0b8aed 100644 --- a/phpBB/styles/prosilver/template/ucp_profile_autologin_keys.html +++ b/phpBB/styles/prosilver/template/ucp_profile_autologin_keys.html @@ -5,47 +5,41 @@  <h2>{L_TITLE}</h2>  <div class="panel">  	<div class="inner"> - -	<!-- IF .errors --> -	<p class="error"> -		<!-- BEGIN errors --> -			{errors} <br /> -		<!-- END errors --> -	</p> -	<!-- ENDIF --> - -	<p>{L_PROFILE_AUTOLOGIN_KEYS}</p><br /> -	<table class="table1"> -	<thead> -	<tr> -		<th>{L_MARK}</th> -		<th>{L_LOGIN_KEY}</th> -		<th>{L_IP}</th> -		<th>{L_LOGIN_TIME}</th> -	</tr> -	</thead> -	<tbody> -	<!-- BEGIN sessions --> -		<!-- IF sessions.S_ROW_COUNT is even --><tr class="bg1"><!-- ELSE --><tr class="bg2"><!-- ENDIF --> -			<td style="text-align: center"><input type="checkbox" name="keys[]" value="{sessions.KEY}" id="{sessions.KEY}"/></td> -			<td><label for="{sessions.KEY}">{sessions.KEY}</label></td> -			<td style="text-align: center">{sessions.IP}</td> -			<td style="text-align: center">{sessions.LOGIN_TIME}</td> -		</tr> -	<!-- BEGINELSE --> -		<tr><td colspan="4" class="bg1" style="text-align: center">{L_PROFILE_NO_AUTOLOGIN_KEYS}</td></tr> -	<!-- END sessions --> -	</tbody> -	</table> +		<p>{L_PROFILE_AUTOLOGIN_KEYS}</p> +		<!-- IF ERROR --><p class="error">{ERROR}</p><!-- ENDIF --> +		<table class="table1"> +			<thead> +				<tr> +					<th>{L_LOGIN_KEY}</th> +					<th>{L_IP}</th> +					<th>{L_LOGIN_TIME}</th> +					<th class="mark">{L_MARK}</th> +				</tr> +			</thead> +			<tbody> +			<!-- BEGIN sessions --> +				<!-- IF sessions.S_ROW_COUNT is even --><tr class="bg1"><!-- ELSE --><tr class="bg2"><!-- ENDIF --> +					<td><label for="{sessions.KEY}">{sessions.KEY}</label></td> +					<td style="text-align: center">{sessions.IP}</td> +					<td style="text-align: center">{sessions.LOGIN_TIME}</td> +					<td style="text-align: center" class="mark"><input type="checkbox" name="keys[]" value="{sessions.KEY}" id="{sessions.KEY}" /></td> +				</tr> +			<!-- BEGINELSE --> +				<tr><td colspan="4" class="bg1" style="text-align: center">{L_PROFILE_NO_AUTOLOGIN_KEYS}</td></tr> +			<!-- END sessions --> +			</tbody> +		</table>  	</div>  </div>  <!-- IF .sessions --> -	<fieldset class="submit-buttons"> -		{S_HIDDEN_FIELDS}<input type="submit" name="submit" value="{L_DELETE}" class="button1" /> +	<fieldset class="display-actions"> +		{S_HIDDEN_FIELDS}<input type="submit" name="submit" value="{L_DELETE_MARKED}" class="button2" /> +		<div><a href="#" onclick="$('#ucp input:checkbox').prop('checked', true); return false;">{L_MARK_ALL}</a> • <a href="#" onclick="$('#ucp input:checkbox').prop('checked', false); return false;">{L_UNMARK_ALL}</a></div>  		{S_FORM_TOKEN}  	</fieldset>  <!-- ENDIF --> +  </form>  <!-- INCLUDE ucp_footer.html --> diff --git a/phpBB/styles/prosilver/theme/content.css b/phpBB/styles/prosilver/theme/content.css index 082016252f..d27fb81fee 100644 --- a/phpBB/styles/prosilver/theme/content.css +++ b/phpBB/styles/prosilver/theme/content.css @@ -570,8 +570,6 @@ blockquote .codebox {  .attach-image {  	margin: 3px 0;  	max-width: 100%; -	max-height: 350px; -	overflow: auto;  }  .attach-image img { diff --git a/phpBB/styles/subsilver2/template/overall_header.html b/phpBB/styles/subsilver2/template/overall_header.html index 0882f5c97d..0d3e727ecd 100644 --- a/phpBB/styles/subsilver2/template/overall_header.html +++ b/phpBB/styles/subsilver2/template/overall_header.html @@ -132,7 +132,7 @@ function marklist(id, name, state)  {$STYLESHEETS}  </head> -<body class="{S_CONTENT_DIRECTION}"> +<body class="{S_CONTENT_DIRECTION} {BODY_CLASS}">  <!-- EVENT overall_header_body_before --> diff --git a/phpBB/styles/subsilver2/template/simple_header.html b/phpBB/styles/subsilver2/template/simple_header.html index 85528e6769..37a33415e9 100644 --- a/phpBB/styles/subsilver2/template/simple_header.html +++ b/phpBB/styles/subsilver2/template/simple_header.html @@ -11,7 +11,7 @@  <link rel="stylesheet" href="{T_STYLESHEET_LANG_LINK}" type="text/css" />  </head> -<body class="{S_CONTENT_DIRECTION}"> +<body class="{S_CONTENT_DIRECTION} {BODY_CLASS}">  <!-- EVENT simple_header_body_before -->  <a name="top"></a>  <div id="wrapcentre"> diff --git a/phpBB/styles/subsilver2/template/ucp_profile_autologin_keys.html b/phpBB/styles/subsilver2/template/ucp_profile_autologin_keys.html index 1dab9acb9c..3f63319b59 100644 --- a/phpBB/styles/subsilver2/template/ucp_profile_autologin_keys.html +++ b/phpBB/styles/subsilver2/template/ucp_profile_autologin_keys.html @@ -2,15 +2,12 @@  <table class="tablebg" width="100%" cellspacing="1">  <tr> -	<th colspan="4" valign="middle">{L_TITLE}</th> +	<th colspan="4">{L_TITLE}</th>  </tr> -<!-- IF .errors --> + +<!-- IF ERROR -->  	<tr> -		<td class="row3" colspan="2" align="center"><span class="gensmall error"> -			<!-- BEGIN errors --> -				{errors} <br /> -			<!-- END errors --> -		</td> +		<td class="row3" colspan="4" align="center"><span class="genmed error">{ERROR}</span></td>  	</tr>  <!-- ENDIF --> @@ -18,17 +15,17 @@  	<td colspan="4" class="row1">{L_PROFILE_AUTOLOGIN_KEYS}</td>  </tr>  <tr> -	<th>{L_MARK}</th>  	<th>{L_LOGIN_KEY}</th>  	<th>{L_IP}</th>  	<th>{L_LOGIN_TIME}</th> +	<th>{L_MARK}</th>  </tr>  <!-- BEGIN sessions -->  	<!-- IF sessions.S_ROW_COUNT is even --><tr class="row1"><!-- ELSE --><tr class="row2"><!-- ENDIF --> -		<td class="genmed" style="text-align: center"><input type="checkbox" name="keys[]" value="{sessions.KEY}" id="{sessions.KEY}"/></td>  		<td class="genmed"><label for="{sessions.KEY}">{sessions.KEY}</label></td>  		<td class="genmed" style="text-align: center">{sessions.IP}</td>  		<td class="genmed" style="text-align: center">{sessions.LOGIN_TIME}</td> +		<td class="genmed" style="text-align: center"><input type="checkbox" name="keys[]" value="{sessions.KEY}" id="{sessions.KEY}"/></td>  	</tr>  <!-- BEGINELSE -->  	<tr> @@ -38,12 +35,16 @@  <!-- IF .sessions -->  	<tr> -		<td class="cat" colspan="4" align="center"> -			{S_HIDDEN_FIELDS}<input class="btnmain" type="submit" name="submit" value="{L_DELETE}" /> +		<td class="cat" colspan="4" align="{S_CONTENT_FLOW_END}"> +			{S_HIDDEN_FIELDS}<input class="btnlite" type="submit" name="submit" value="{L_DELETE_MARKED}" />  			{S_FORM_TOKEN}  		</td>  	</tr>  <!-- ENDIF -->  </table> +<!-- IF .sessions --> +	<div class="gensmall" style="float: {S_CONTENT_FLOW_END}; padding-top: 2px;"><b><a href="#" onclick="marklist('ucp', 'keys', true); return false;">{L_MARK_ALL}</a> :: <a href="#" onclick="marklist('ucp', 'keys', false); return false;">{L_UNMARK_ALL}</a></b></div> +<!-- ENDIF --> +  <!-- INCLUDE ucp_footer.html --> diff --git a/phpBB/ucp.php b/phpBB/ucp.php index 8c773886a6..eaa40a07a2 100644 --- a/phpBB/ucp.php +++ b/phpBB/ucp.php @@ -94,7 +94,6 @@ switch ($mode)  		if ($user->data['user_id'] != ANONYMOUS && $request->is_set('sid') && $request->variable('sid', '') === $user->session_id)  		{  			$user->session_kill(); -			$user->session_begin();  		}  		else if ($user->data['user_id'] != ANONYMOUS)  		{ diff --git a/phpBB/viewonline.php b/phpBB/viewonline.php index 87813596fa..1738005786 100644 --- a/phpBB/viewonline.php +++ b/phpBB/viewonline.php @@ -437,8 +437,9 @@ $template->assign_vars(array(  	'U_SWITCH_GUEST_DISPLAY'	=> append_sid("{$phpbb_root_path}viewonline.$phpEx", 'sg=' . ((int) !$show_guests)),  	'L_SWITCH_GUEST_DISPLAY'	=> ($show_guests) ? $user->lang['HIDE_GUESTS'] : $user->lang['DISPLAY_GUESTS'], -	'S_SWITCH_GUEST_DISPLAY'	=> ($config['load_online_guests']) ? true : false) -); +	'S_SWITCH_GUEST_DISPLAY'	=> ($config['load_online_guests']) ? true : false, +	'S_VIEWONLINE'				=> true, +));  // We do not need to load the who is online box here. ;)  $config['load_online'] = false; | 
