Ejemplo n.º 1
0
 static function update_l10n($task)
 {
     $errors = array();
     try {
         $start = microtime(true);
         $data = Cache::instance()->get("update_l10n_cache:{$task->id}");
         if ($data) {
             list($dirs, $files, $cache, $num_fetched) = unserialize($data);
         }
         $i = 0;
         switch ($task->get("mode", "init")) {
             case "init":
                 // 0%
                 $dirs = array("gallery", "modules", "themes", "installer");
                 $files = $cache = array();
                 $num_fetched = 0;
                 $task->set("mode", "find_files");
                 $task->status = t("Finding files");
                 break;
             case "find_files":
                 // 0% - 10%
                 while (($dir = array_pop($dirs)) && microtime(true) - $start < 0.5) {
                     if (in_array(basename($dir), array("tests", "lib"))) {
                         continue;
                     }
                     foreach (glob(DOCROOT . "{$dir}/*") as $path) {
                         $relative_path = str_replace(DOCROOT, "", $path);
                         if (is_dir($path)) {
                             $dirs[] = $relative_path;
                         } else {
                             $files[] = $relative_path;
                         }
                     }
                 }
                 $task->status = t2("Finding files: found 1 file", "Finding files: found %count files", count($files));
                 if (!$dirs) {
                     $task->set("mode", "scan_files");
                     $task->set("total_files", count($files));
                     $task->status = t("Scanning files");
                     $task->percent_complete = 10;
                 }
                 break;
             case "scan_files":
                 // 10% - 70%
                 while (($file = array_pop($files)) && microtime(true) - $start < 0.5) {
                     $file = DOCROOT . $file;
                     switch (pathinfo($file, PATHINFO_EXTENSION)) {
                         case "php":
                             l10n_scanner::scan_php_file($file, $cache);
                             break;
                         case "info":
                             l10n_scanner::scan_info_file($file, $cache);
                             break;
                     }
                 }
                 $total_files = $task->get("total_files");
                 $task->status = t2("Scanning files: scanned 1 file", "Scanning files: scanned %count files", $total_files - count($files));
                 $task->percent_complete = 10 + 60 * ($total_files - count($files)) / $total_files;
                 if (empty($files)) {
                     $task->set("mode", "fetch_updates");
                     $task->status = t("Fetching updates");
                     $task->percent_complete = 70;
                 }
                 break;
             case "fetch_updates":
                 // 70% - 100%
                 // Send fetch requests in batches until we're done
                 $num_remaining = l10n_client::fetch_updates($num_fetched);
                 if ($num_remaining) {
                     $total = $num_fetched + $num_remaining;
                     $task->percent_complete = 70 + 30 * ((double) $num_fetched / $total);
                 } else {
                     Gallery_I18n::clear_cache();
                     $task->done = true;
                     $task->state = "success";
                     $task->status = t("Translations installed/updated");
                     $task->percent_complete = 100;
                 }
         }
         if (!$task->done) {
             Cache::instance()->set("update_l10n_cache:{$task->id}", serialize(array($dirs, $files, $cache, $num_fetched)));
         } else {
             Cache::instance()->delete("update_l10n_cache:{$task->id}");
         }
     } catch (Exception $e) {
         Kohana_Log::add("error", (string) $e);
         $task->done = true;
         $task->state = "error";
         $task->status = $e->getMessage();
         $errors[] = (string) $e;
     }
     if ($errors) {
         $task->log($errors);
     }
 }
Ejemplo n.º 2
0
 static function update_l10n(&$task)
 {
     $message = array();
     try {
         $start = microtime(true);
         $dirs = $task->get("dirs");
         $files = $task->get("files");
         $cache = $task->get("cache", array());
         $i = 0;
         switch ($task->get("mode", "init")) {
             case "init":
                 // 0%
                 $dirs = array("gallery", "modules", "themes", "installer");
                 $files = array();
                 $task->set("mode", "find_files");
                 $task->status = t("Finding files");
                 break;
             case "find_files":
                 // 0% - 10%
                 while (($dir = array_pop($dirs)) && microtime(true) - $start < 0.5) {
                     if (in_array(basename($dir), array("tests", "lib"))) {
                         continue;
                     }
                     foreach (glob(DOCROOT . "{$dir}/*") as $path) {
                         $relative_path = str_replace(DOCROOT, "", $path);
                         if (is_dir($path)) {
                             $dirs[] = $relative_path;
                         } else {
                             $files[] = $relative_path;
                         }
                     }
                 }
                 $message[] = $task->status = t2("Finding files: found 1 file", "Finding files: found %count files", count($files));
                 if (!$dirs) {
                     $task->set("mode", "scan_files");
                     $task->set("total_files", count($files));
                     $task->status = t("Scanning files");
                     $task->percent_complete = 10;
                 }
                 break;
             case "scan_files":
                 // 10% - 90%
                 while (($file = array_pop($files)) && microtime(true) - $start < 0.5) {
                     $file = DOCROOT . $file;
                     switch (pathinfo($file, PATHINFO_EXTENSION)) {
                         case "php":
                             l10n_scanner::scan_php_file($file, $cache);
                             break;
                         case "info":
                             l10n_scanner::scan_info_file($file, $cache);
                             break;
                     }
                 }
                 $total_files = $task->get("total_files");
                 $message[] = $task->status = t2("Scanning files: scanned 1 file", "Scanning files: scanned %count files", $total_files - count($files));
                 $task->percent_complete = 10 + 80 * ($total_files - count($files)) / $total_files;
                 if (empty($files)) {
                     $task->set("mode", "fetch_updates");
                     $task->status = t("Fetching updates");
                     $task->percent_complete = 90;
                 }
                 break;
             case "fetch_updates":
                 // 90% - 100%
                 $message = array_merge($message, l10n_client::fetch_updates());
                 $task->done = true;
                 $task->state = "success";
                 $task->status = t("Translations installed/updated");
                 $task->percent_complete = 100;
         }
         $task->set("files", $files);
         $task->set("dirs", $dirs);
         $task->set("cache", $cache);
     } catch (Exception $e) {
         $task->done = true;
         $task->state = "error";
         $task->status = $e->getMessage();
         $message[] = $e->__toString();
     }
     $task->log($message);
 }