From a552b506da64bcedff7af5464ac786c1ce66c43c Mon Sep 17 00:00:00 2001
From: Thomas Bruederli <bruederli@kolabsys.com>
Date: Tue, 02 Jun 2015 15:49:43 -0400
Subject: [PATCH] Fix composer.json update routine

---
 bin/update.sh |   16 +++++++++++-----
 1 files changed, 11 insertions(+), 5 deletions(-)

diff --git a/bin/update.sh b/bin/update.sh
index 1dfaa96..ea82b95 100755
--- a/bin/update.sh
+++ b/bin/update.sh
@@ -5,7 +5,7 @@
  | bin/update.sh                                                         |
  |                                                                       |
  | This file is part of the Roundcube Webmail client                     |
- | Copyright (C) 2010-2014, The Roundcube Dev Team                       |
+ | Copyright (C) 2010-2015, The Roundcube Dev Team                       |
  |                                                                       |
  | Licensed under the GNU General Public License version 3 or            |
  | any later version with exceptions for skins & plugins.                |
@@ -188,18 +188,24 @@
       }
 
       foreach ($composer_template['repositories'] as $repo) {
-        $rkey = $repo['type'] . $repo['url'] . $repo['package']['name'];
+        $rkey = $repo['type'] . preg_replace('/^https?:/', '', $repo['url']) . $repo['package']['name'];
         $existing = false;
-        foreach ($composer_data['repositories'] as $_repo) {
-          if ($rkey == $_repo['type'] . $_repo['url'] . $_repo['package']['name']) {
+        foreach ($composer_data['repositories'] as $k =>  $_repo) {
+          if ($rkey == $_repo['type'] . preg_replace('/^https?:/', '', $_repo['url']) . $_repo['package']['name']) {
             $existing = true;
             break;
+          }
+          // remove old repos
+          else if (strpos($_repo['url'], 'git://git.kolab.org') === 0) {
+              unset($composer_data['repositories'][$k]);
           }
         }
         if (!$existing) {
           $composer_data['repositories'][] = $repo;
         }
       }
+
+      $composer_data['repositories'] = array_values($composer_data['repositories']);
     }
 
     // use the JSON encoder from the Composer package
@@ -209,7 +215,7 @@
     }
     // PHP 5.4's json_encode() does the job, too
     else if (defined('JSON_PRETTY_PRINT')) {
-      $comsposer_json = json_encode($composer_data, JSON_PRETTY_PRINT & JSON_UNESCAPED_SLASHES);
+      $comsposer_json = json_encode($composer_data, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES);
     }
     else {
       $success = false;

--
Gitblit v1.9.1