Localisation updates for core and extension messages from translatewiki.net (2011...
[lhc/web/wiklou.git] / includes / installer / CliInstaller.php
index 4613388..455a45f 100644 (file)
@@ -1,11 +1,19 @@
 <?php
+/**
+ * Core installer command line interface.
+ *
+ * @file
+ * @ingroup Deployment
+ */
 
 /**
  * Class for the core installer command line interface.
- * 
+ *
+ * @ingroup Deployment
  * @since 1.17
  */
-class CliInstaller extends CoreInstaller {
+class CliInstaller extends Installer {
+
        private $optionMap = array(
                'dbtype' => 'wgDBtype',
                'dbserver' => 'wgDBserver',
@@ -23,10 +31,20 @@ class CliInstaller extends CoreInstaller {
                'dbschema' => 'wgDBmwschema',
                'dbts2schema' => 'wgDBts2schema',
                'dbpath' => 'wgSQLiteDataDir',
+               'scriptpath' => 'wgScriptPath',
+               'upgrade' => 'cliUpgrade', /* As long as it isn't $confItems
+                                                                       * in LocalSettingsGenerator, we
+                                                                       * should be fine. */
        );
 
-       /** Constructor */
-       function __construct( $siteName, $admin = null, $option = array() ) {
+       /**
+        * Constructor.
+        *
+        * @param $siteName
+        * @param $admin
+        * @param $option Array
+        */
+       function __construct( $siteName, $admin = null, array $option = array() ) {
                parent::__construct();
 
                foreach ( $this->optionMap as $opt => $global ) {
@@ -45,6 +63,7 @@ class CliInstaller extends CoreInstaller {
                }
 
                $this->setVar( 'wgSitename', $siteName );
+
                if ( $admin ) {
                        $this->setVar( '_AdminName', $admin );
                }
@@ -65,39 +84,68 @@ class CliInstaller extends CoreInstaller {
         * Main entry point.
         */
        public function execute() {
+               global $cliUpgrade;
+
+               $vars = $this->getExistingLocalSettings();
+               if( $vars && ( !isset( $cliUpgrade ) || $cliUpgrade !== "yes" )  ) {
+                       $this->showStatusMessage(
+                               Status::newFatal( "config-localsettings-cli-upgrade" )
+                       );
+               }
+
                $this->performInstallation(
-                       array( $this, 'startStage'),
+                       array( $this, 'startStage' ),
                        array( $this, 'endStage' )
                );
        }
 
+       /**
+        * Write LocalSettings.php to a given path
+        *
+        * @param $path String Full path to write LocalSettings.php to
+        */
+       public function writeConfigurationFile( $path ) {
+               $ls = new LocalSettingsGenerator( $this );
+               $ls->writeFile( "$path/LocalSettings.php" );
+       }
+
        public function startStage( $step ) {
-               $this->showMessage( wfMsg( "config-install-$step") .
+               $this->showMessage( wfMsg( "config-install-$step" ) .
                        wfMsg( 'ellipsis' ) . wfMsg( 'word-separator' ) );
        }
 
        public function endStage( $step, $status ) {
-               $warnings = $status->getWarningsArray();
-               if ( !$status->isOk() ) {
-                       $this->showStatusMessage( $status );
-                       echo "\n";
-                       exit;
-               } elseif ( count($warnings) !== 0 ) {
-                       foreach ( $status->getWikiTextArray( $warnings ) as $w ) {
-                               $this->showMessage( $w . wfMsg( 'ellipsis') .
-                                       wfMsg( 'word-separator' ) );
-                       }
-               }
-               $this->showMessage( wfMsg( 'config-install-step-done' ) ."\n");
+               $this->showStatusMessage( $status );
+               $this->showMessage( wfMsg( 'config-install-step-done' ) . "\n" );
        }
 
        public function showMessage( $msg /*, ... */ ) {
-               echo html_entity_decode( strip_tags( $msg ), ENT_QUOTES );
+               $params = func_get_args();
+               array_shift( $params );
+
+               /* parseinline has the nasty side-effect of putting encoded
+                * angle brackets, around the message, so the substr removes
+                * them. */
+               $text = substr( wfMsgExt( $msg, array( 'parseinline' ), $params ), 4, -4 );
+               $text = preg_replace( '/<a href="(.*?)".*?>(.*?)<\/a>/', '$2 &lt;$1&gt;', $text );
+               echo html_entity_decode( strip_tags( $text ), ENT_QUOTES ) . "\n";
                flush();
        }
 
        public function showStatusMessage( Status $status ) {
-               $this->showMessage( $status->getWikiText() );
-       }
+               $warnings = array_merge( $status->getWarningsArray(),
+                       $status->getErrorsArray() );
+
+               if ( count( $warnings ) !== 0 ) {
+                       foreach ( $status->getWikiTextArray( $warnings ) as $w ) {
+                               $this->showMessage( $w . wfMsg( 'ellipsis' ) .
+                                       wfMsg( 'word-separator' ) );
+                       }
+               }
 
-}
\ No newline at end of file
+               if ( !$status->isOk() ) {
+                       echo "\n";
+                       exit;
+               }
+       }
+}