Skip to content

Commit

Permalink
refactor mysql_charsets.inc.php
Browse files Browse the repository at this point in the history
  • Loading branch information
xmujay committed Jun 11, 2013
1 parent 6d00ce0 commit d23aad1
Show file tree
Hide file tree
Showing 20 changed files with 134 additions and 116 deletions.
2 changes: 1 addition & 1 deletion db_create.php
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
*/
require_once 'libraries/common.inc.php';

require_once 'libraries/mysql_charsets.lib.php';
require_once 'libraries/mysql_charsets.inc.php';
if (! PMA_DRIZZLE) {
include_once 'libraries/replication.inc.php';
}
Expand Down
2 changes: 1 addition & 1 deletion db_operations.php
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
* requirements
*/
require_once 'libraries/common.inc.php';
require_once 'libraries/mysql_charsets.lib.php';
require_once 'libraries/mysql_charsets.inc.php';

/**
* functions implementation for this script
Expand Down
2 changes: 1 addition & 1 deletion db_routines.php
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@
*/
require_once 'libraries/common.inc.php';
require_once 'libraries/Util.class.php';
require_once 'libraries/mysql_charsets.lib.php';
require_once 'libraries/mysql_charsets.inc.php';

/**
* Include all other files
Expand Down
2 changes: 1 addition & 1 deletion db_structure.php
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@

require_once 'libraries/bookmark.lib.php';

require_once 'libraries/mysql_charsets.lib.php';
require_once 'libraries/mysql_charsets.inc.php';
$db_collation = PMA_getDbCollation($db);

$titles = PMA_Util::buildActionTitles();
Expand Down
2 changes: 1 addition & 1 deletion libraries/DatabaseInterface.class.php
Original file line number Diff line number Diff line change
Expand Up @@ -905,7 +905,7 @@ public function getDatabasesFull($database = null, $force_stats = false,
$databases[$database_name]['SCHEMA_NAME'] = $database_name;

if ($force_stats) {
include_once './libraries/mysql_charsets.lib.php';
include_once './libraries/mysql_charsets.inc.php';

$databases[$database_name]['DEFAULT_COLLATION_NAME']
= PMA_getDbCollation($database_name);
Expand Down
2 changes: 1 addition & 1 deletion libraries/display_create_database.lib.php
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@
<input type="hidden" name="reload" value="1" />
<input type="text" name="new_db" value="<?php echo $db_to_create; ?>" maxlength="64" class="textfield" id="text_create_db"/>
<?php
include_once './libraries/mysql_charsets.lib.php';
include_once './libraries/mysql_charsets.inc.php';
echo PMA_generateCharsetDropdownBox(PMA_CSDROPDOWN_COLLATION, 'db_collation', null, null, true, 5);

if (! empty($dbstats)) {
Expand Down
2 changes: 1 addition & 1 deletion libraries/display_structure.lib.php
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
*/

require_once 'libraries/common.inc.php';
require_once 'libraries/mysql_charsets.lib.php';
require_once 'libraries/mysql_charsets.inc.php';
require_once 'libraries/structure.lib.php';
require_once 'libraries/index.lib.php';
require_once 'libraries/tbl_info.inc.php';
Expand Down
114 changes: 114 additions & 0 deletions libraries/mysql_charsets.inc.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,114 @@
<?php
/* vim: set expandtab sw=4 ts=4 sts=4: */
/**
*
* @package PhpMyAdmin
*/
if (! defined('PHPMYADMIN')) {
exit;
}

/**
*
*/

if (! PMA_Util::cacheExists('mysql_charsets', true)) {
global $mysql_charsets, $mysql_charsets_descriptions,
$mysql_charsets_available, $mysql_collations, $mysql_collations_available,
$mysql_default_collations, $mysql_collations_flat;
$sql = PMA_DRIZZLE
? 'SELECT * FROM data_dictionary.CHARACTER_SETS'
: 'SELECT * FROM information_schema.CHARACTER_SETS';
$res = $GLOBALS['dbi']->query($sql);

$mysql_charsets = array();
while ($row = $GLOBALS['dbi']->fetchAssoc($res)) {
$mysql_charsets[] = $row['CHARACTER_SET_NAME'];
// never used
//$mysql_charsets_maxlen[$row['Charset']] = $row['Maxlen'];
$mysql_charsets_descriptions[$row['CHARACTER_SET_NAME']]
= $row['DESCRIPTION'];
}
$GLOBALS['dbi']->freeResult($res);

sort($mysql_charsets, SORT_STRING);

$mysql_collations = array_flip($mysql_charsets);
$mysql_default_collations = $mysql_collations_flat
= $mysql_charsets_available = $mysql_collations_available = array();

$sql = PMA_DRIZZLE
? 'SELECT * FROM data_dictionary.COLLATIONS'
: 'SELECT * FROM information_schema.COLLATIONS';
$res = $GLOBALS['dbi']->query($sql);
while ($row = $GLOBALS['dbi']->fetchAssoc($res)) {
if (! is_array($mysql_collations[$row['CHARACTER_SET_NAME']])) {
$mysql_collations[$row['CHARACTER_SET_NAME']]
= array($row['COLLATION_NAME']);
} else {
$mysql_collations[$row['CHARACTER_SET_NAME']][] = $row['COLLATION_NAME'];
}
$mysql_collations_flat[] = $row['COLLATION_NAME'];
if ($row['IS_DEFAULT'] == 'Yes' || $row['IS_DEFAULT'] == '1') {
$mysql_default_collations[$row['CHARACTER_SET_NAME']]
= $row['COLLATION_NAME'];
}
//$mysql_collations_available[$row['Collation']]
// = ! isset($row['Compiled']) || $row['Compiled'] == 'Yes';
$mysql_collations_available[$row['COLLATION_NAME']] = true;
$mysql_charsets_available[$row['CHARACTER_SET_NAME']]
= !empty($mysql_charsets_available[$row['CHARACTER_SET_NAME']])
|| !empty($mysql_collations_available[$row['COLLATION_NAME']]);
}
$GLOBALS['dbi']->freeResult($res);
unset($res, $row);

if (PMA_DRIZZLE
&& isset($mysql_collations['utf8_general_ci'])
&& isset($mysql_collations['utf8'])
) {
$mysql_collations['utf8'] = $mysql_collations['utf8_general_ci'];
$mysql_default_collations['utf8']
= $mysql_default_collations['utf8_general_ci'];
$mysql_charsets_available['utf8']
= $mysql_charsets_available['utf8_general_ci'];
unset(
$mysql_collations['utf8_general_ci'],
$mysql_default_collations['utf8_general_ci'],
$mysql_charsets_available['utf8_general_ci']
);
}

sort($mysql_collations_flat, SORT_STRING);
foreach ($mysql_collations as $key => $value) {
sort($mysql_collations[$key], SORT_STRING);
reset($mysql_collations[$key]);
}
unset($key, $value);

PMA_Util::cacheSet('mysql_charsets', $GLOBALS['mysql_charsets'], true);
PMA_Util::cacheSet('mysql_charsets_descriptions', $GLOBALS['mysql_charsets_descriptions'], true);
PMA_Util::cacheSet('mysql_charsets_available', $GLOBALS['mysql_charsets_available'], true);
PMA_Util::cacheSet('mysql_collations', $GLOBALS['mysql_collations'], true);
PMA_Util::cacheSet('mysql_default_collations', $GLOBALS['mysql_default_collations'], true);
PMA_Util::cacheSet('mysql_collations_flat', $GLOBALS['mysql_collations_flat'], true);
PMA_Util::cacheSet('mysql_collations_available', $GLOBALS['mysql_collations_available'], true);
} else {
$GLOBALS['mysql_charsets'] = PMA_Util::cacheGet('mysql_charsets', true);
$GLOBALS['mysql_charsets_descriptions'] = PMA_Util::cacheGet('mysql_charsets_descriptions', true);
$GLOBALS['mysql_charsets_available'] = PMA_Util::cacheGet('mysql_charsets_available', true);
$GLOBALS['mysql_collations'] = PMA_Util::cacheGet('mysql_collations', true);
$GLOBALS['mysql_default_collations'] = PMA_Util::cacheGet('mysql_default_collations', true);
$GLOBALS['mysql_collations_flat'] = PMA_Util::cacheGet('mysql_collations_flat', true);
$GLOBALS['mysql_collations_available'] = PMA_Util::cacheGet('mysql_collations_available', true);
}

define('PMA_CSDROPDOWN_COLLATION', 0);
define('PMA_CSDROPDOWN_CHARSET', 1);

/**
* shared functions for mysql charsets
*/
require_once './libraries/mysql_charsets.lib.php';

?>
100 changes: 2 additions & 98 deletions libraries/mysql_charsets.lib.php
Original file line number Diff line number Diff line change
@@ -1,111 +1,15 @@
<?php
/* vim: set expandtab sw=4 ts=4 sts=4: */
/**
* Shared code for mysql charsets
*
*
* @package PhpMyAdmin
*/
if (! defined('PHPMYADMIN')) {
exit;
}

/**
*
*/

if (! PMA_Util::cacheExists('mysql_charsets', true)) {
global $mysql_charsets, $mysql_charsets_descriptions,
$mysql_charsets_available, $mysql_collations, $mysql_collations_available,
$mysql_default_collations, $mysql_collations_flat;
$sql = PMA_DRIZZLE
? 'SELECT * FROM data_dictionary.CHARACTER_SETS'
: 'SELECT * FROM information_schema.CHARACTER_SETS';
$res = $GLOBALS['dbi']->query($sql);

$mysql_charsets = array();
while ($row = $GLOBALS['dbi']->fetchAssoc($res)) {
$mysql_charsets[] = $row['CHARACTER_SET_NAME'];
// never used
//$mysql_charsets_maxlen[$row['Charset']] = $row['Maxlen'];
$mysql_charsets_descriptions[$row['CHARACTER_SET_NAME']]
= $row['DESCRIPTION'];
}
$GLOBALS['dbi']->freeResult($res);

sort($mysql_charsets, SORT_STRING);

$mysql_collations = array_flip($mysql_charsets);
$mysql_default_collations = $mysql_collations_flat
= $mysql_charsets_available = $mysql_collations_available = array();

$sql = PMA_DRIZZLE
? 'SELECT * FROM data_dictionary.COLLATIONS'
: 'SELECT * FROM information_schema.COLLATIONS';
$res = $GLOBALS['dbi']->query($sql);
while ($row = $GLOBALS['dbi']->fetchAssoc($res)) {
if (! is_array($mysql_collations[$row['CHARACTER_SET_NAME']])) {
$mysql_collations[$row['CHARACTER_SET_NAME']]
= array($row['COLLATION_NAME']);
} else {
$mysql_collations[$row['CHARACTER_SET_NAME']][] = $row['COLLATION_NAME'];
}
$mysql_collations_flat[] = $row['COLLATION_NAME'];
if ($row['IS_DEFAULT'] == 'Yes' || $row['IS_DEFAULT'] == '1') {
$mysql_default_collations[$row['CHARACTER_SET_NAME']]
= $row['COLLATION_NAME'];
}
//$mysql_collations_available[$row['Collation']]
// = ! isset($row['Compiled']) || $row['Compiled'] == 'Yes';
$mysql_collations_available[$row['COLLATION_NAME']] = true;
$mysql_charsets_available[$row['CHARACTER_SET_NAME']]
= !empty($mysql_charsets_available[$row['CHARACTER_SET_NAME']])
|| !empty($mysql_collations_available[$row['COLLATION_NAME']]);
}
$GLOBALS['dbi']->freeResult($res);
unset($res, $row);

if (PMA_DRIZZLE
&& isset($mysql_collations['utf8_general_ci'])
&& isset($mysql_collations['utf8'])
) {
$mysql_collations['utf8'] = $mysql_collations['utf8_general_ci'];
$mysql_default_collations['utf8']
= $mysql_default_collations['utf8_general_ci'];
$mysql_charsets_available['utf8']
= $mysql_charsets_available['utf8_general_ci'];
unset(
$mysql_collations['utf8_general_ci'],
$mysql_default_collations['utf8_general_ci'],
$mysql_charsets_available['utf8_general_ci']
);
}

sort($mysql_collations_flat, SORT_STRING);
foreach ($mysql_collations as $key => $value) {
sort($mysql_collations[$key], SORT_STRING);
reset($mysql_collations[$key]);
}
unset($key, $value);

PMA_Util::cacheSet('mysql_charsets', $GLOBALS['mysql_charsets'], true);
PMA_Util::cacheSet('mysql_charsets_descriptions', $GLOBALS['mysql_charsets_descriptions'], true);
PMA_Util::cacheSet('mysql_charsets_available', $GLOBALS['mysql_charsets_available'], true);
PMA_Util::cacheSet('mysql_collations', $GLOBALS['mysql_collations'], true);
PMA_Util::cacheSet('mysql_default_collations', $GLOBALS['mysql_default_collations'], true);
PMA_Util::cacheSet('mysql_collations_flat', $GLOBALS['mysql_collations_flat'], true);
PMA_Util::cacheSet('mysql_collations_available', $GLOBALS['mysql_collations_available'], true);
} else {
$GLOBALS['mysql_charsets'] = PMA_Util::cacheGet('mysql_charsets', true);
$GLOBALS['mysql_charsets_descriptions'] = PMA_Util::cacheGet('mysql_charsets_descriptions', true);
$GLOBALS['mysql_charsets_available'] = PMA_Util::cacheGet('mysql_charsets_available', true);
$GLOBALS['mysql_collations'] = PMA_Util::cacheGet('mysql_collations', true);
$GLOBALS['mysql_default_collations'] = PMA_Util::cacheGet('mysql_default_collations', true);
$GLOBALS['mysql_collations_flat'] = PMA_Util::cacheGet('mysql_collations_flat', true);
$GLOBALS['mysql_collations_available'] = PMA_Util::cacheGet('mysql_collations_available', true);
}

define('PMA_CSDROPDOWN_COLLATION', 0);
define('PMA_CSDROPDOWN_CHARSET', 1);

function PMA_generateCharsetDropdownBox($type = PMA_CSDROPDOWN_COLLATION,
$name = null, $id = null, $default = null, $label = true, $indent = 0,
$submitOnChange = false, $displayUnavailable = false
Expand Down
2 changes: 1 addition & 1 deletion libraries/sqlparser.lib.php
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@
* Charset information
*/
if (!defined('TESTSUITE')) {
include_once './libraries/mysql_charsets.lib.php';
include_once './libraries/mysql_charsets.inc.php';
}
if (! isset($mysql_charsets)) {
$mysql_charsets = array();
Expand Down
2 changes: 1 addition & 1 deletion libraries/tbl_columns_definition_form.inc.php
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@


// Get available character sets and storage engines
require_once './libraries/mysql_charsets.lib.php';
require_once './libraries/mysql_charsets.inc.php';
require_once './libraries/StorageEngine.class.php';

/**
Expand Down
2 changes: 1 addition & 1 deletion server_collations.php
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@
/**
* Includes the required charset library
*/
require_once 'libraries/mysql_charsets.lib.php';
require_once 'libraries/mysql_charsets.inc.php';

$response = PMA_Response::getInstance();

Expand Down
2 changes: 1 addition & 1 deletion tbl_operations.php
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@
/**
* Gets available MySQL charsets and storage engines
*/
require_once 'libraries/mysql_charsets.lib.php';
require_once 'libraries/mysql_charsets.inc.php';
require_once 'libraries/StorageEngine.class.php';

/**
Expand Down
2 changes: 1 addition & 1 deletion tbl_row_action.php
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
*
*/
require_once 'libraries/common.inc.php';
require_once 'libraries/mysql_charsets.lib.php';
require_once 'libraries/mysql_charsets.inc.php';

/**
* No rows were selected => show again the query and tell that user.
Expand Down
2 changes: 1 addition & 1 deletion tbl_select.php
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
* Gets some core libraries
*/
require_once 'libraries/common.inc.php';
require_once 'libraries/mysql_charsets.lib.php';
require_once 'libraries/mysql_charsets.inc.php';
require_once 'libraries/TableSearch.class.php';

$response = PMA_Response::getInstance();
Expand Down
2 changes: 1 addition & 1 deletion tbl_structure.php
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@
*
*/
require_once 'libraries/common.inc.php';
require_once 'libraries/mysql_charsets.lib.php';
require_once 'libraries/mysql_charsets.inc.php';

/**
* Function implementations for this script
Expand Down
2 changes: 1 addition & 1 deletion tbl_zoom_select.php
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@
* Gets some core libraries
*/
require_once './libraries/common.inc.php';
require_once './libraries/mysql_charsets.lib.php';
require_once './libraries/mysql_charsets.inc.php';
require_once './libraries/TableSearch.class.php';
require_once './libraries/tbl_info.inc.php';

Expand Down
2 changes: 1 addition & 1 deletion test/libraries/PMA_build_html_for_db_test.php
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@
require_once 'libraries/database_interface.inc.php';
require_once 'libraries/Tracker.class.php';
require_once 'libraries/Types.class.php';
require_once 'libraries/mysql_charsets.lib.php';
require_once 'libraries/mysql_charsets.inc.php';

class PMA_BuildHtmlForDb_Test extends PHPUnit_Framework_TestCase
{
Expand Down
2 changes: 1 addition & 1 deletion test/libraries/PMA_operations_test.php
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@
require_once 'libraries/Theme.class.php';
require_once 'libraries/database_interface.inc.php';
require_once 'libraries/Tracker.class.php';
require_once 'libraries/mysql_charsets.lib.php';
require_once 'libraries/mysql_charsets.inc.php';

/**
* tests for operations
Expand Down
2 changes: 1 addition & 1 deletion test/libraries/rte/PMA_RTN_getEditorForm_test.php
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
require_once 'libraries/Theme.class.php';
require_once 'libraries/database_interface.inc.php';
require_once 'libraries/Tracker.class.php';
require_once 'libraries/mysql_charsets.lib.php';
require_once 'libraries/mysql_charsets.inc.php';
/*
* Include to test.
*/
Expand Down

0 comments on commit d23aad1

Please sign in to comment.