Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/phpmyadmin/phpmyadmin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristian Foellmann <foellmann@foe-services.de>2014-04-05 17:35:38 +0400
committerChristian Foellmann <foellmann@foe-services.de>2014-04-05 17:35:38 +0400
commit9eb27ef6ebc763ddc6f6278462b8ffeed6de0e36 (patch)
treed3b4a1c7ae68cafb05b9d60040c9c22d457cee62 /libraries/navigation/NodeFactory.class.php
parentd472216554769ba596795f23a70c1809fa8897a3 (diff)
INIT phpmyadmin 4.1.12 multilanguage
Diffstat (limited to 'libraries/navigation/NodeFactory.class.php')
-rw-r--r--libraries/navigation/NodeFactory.class.php97
1 files changed, 97 insertions, 0 deletions
diff --git a/libraries/navigation/NodeFactory.class.php b/libraries/navigation/NodeFactory.class.php
new file mode 100644
index 0000000000..f561fb87f5
--- /dev/null
+++ b/libraries/navigation/NodeFactory.class.php
@@ -0,0 +1,97 @@
+<?php
+/* vim: set expandtab sw=4 ts=4 sts=4: */
+/**
+ * This class is responsible for creating Node objects
+ *
+ * @package PhpMyAdmin-navigation
+ */
+if (! defined('PHPMYADMIN')) {
+ exit;
+}
+
+require_once 'libraries/navigation/Nodes/Node.class.php';
+
+/**
+ * Node factory - instanciates Node objects or objects derived from the Node class
+ *
+ * @package PhpMyAdmin-Navigation
+ */
+class PMA_NodeFactory
+{
+ /**
+ * @var string $_path A template for generating paths to files
+ * that contain various Node classes
+ * @access private
+ */
+ private static $_path = 'libraries/navigation/Nodes/%s.class.php';
+ /**
+ * Sanitizes the name of a Node class
+ *
+ * @param string $class The class name to be sanitized
+ *
+ * @return string
+ */
+ private static function _sanitizeClass($class)
+ {
+ if ($class !== 'Node' && ! preg_match('@^Node_\w+(_\w+)?$@', $class)) {
+ $class = 'Node';
+ trigger_error(
+ sprintf(
+ /* l10n: The word "Node" must not be translated here */
+ __('Invalid class name "%1$s", using default of "Node"'),
+ $class
+ ),
+ E_USER_ERROR
+ );
+ }
+ return self::_checkFile($class);
+ }
+ /**
+ * Checks if a file exists for a given class name
+ * Will return the default class name back if the
+ * file for some subclass is not available
+ *
+ * @param string $class The class name to check
+ *
+ * @return string
+ */
+ private static function _checkFile($class)
+ {
+ $path = sprintf(self::$_path, $class);
+ if (! is_readable($path)) {
+ $class = 'Node';
+ trigger_error(
+ sprintf(
+ __('Could not include class "%1$s", file "%2$s" not found'),
+ $class,
+ 'Nodes/' . $class . '.class.php'
+ ),
+ E_USER_ERROR
+ );
+ }
+ return $class;
+ }
+ /**
+ * Instanciates a Node object
+ *
+ * @param string $class The name of the class to instanciate
+ * @param string $name An identifier for the new node
+ * @param int $type Type of node, may be one of CONTAINER or OBJECT
+ * @param bool $is_group Whether this object has been created
+ * while grouping nodes
+ *
+ * @return mixed
+ */
+ public static function getInstance(
+ $class = 'Node',
+ $name = 'default',
+ $type = Node::OBJECT,
+ $is_group = false
+ ) {
+ $class = self::_sanitizeClass($class);
+ include_once sprintf(self::$_path, $class);
+ return new $class($name, $type, $is_group);
+ }
+}
+
+?>