From e935635620cbc4a3f2f18303f12891cc997f1cb1 Mon Sep 17 00:00:00 2001
From: Timm Drevensek <abubadabu@gmail.com>
Date: Wed, 26 Feb 2014 23:33:04 +0100
Subject: [PATCH] fixed regex to match url pointing to a user repo

---
 app/helpers/submodule_helper.rb | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)

diff --git a/app/helpers/submodule_helper.rb b/app/helpers/submodule_helper.rb
index ca7b87b69ad..d7a253fac89 100755
--- a/app/helpers/submodule_helper.rb
+++ b/app/helpers/submodule_helper.rb
@@ -39,8 +39,8 @@ module SubmoduleHelper
   end
 
   def relative_self_url?(url)
-    # (./)? ( (../repo.git) | (../../project/repo.git) )
-    url =~ /(^((\.\/)?(((\.\.)\/)|((\.\.)\/(\.\.)\/.*\/)))[^\.\/]*\.git)\Z/
+    # (./)?(../repo.git) || (./)?(../../project/repo.git) )
+    url =~ /^((\.\/)?(\.\.\/))(?!(\.\.)|(.*\/)).*\.git\Z/ || url =~ /^((\.\/)?(\.\.\/){2})(?!(\.\.))([^\/]*)\/(?!(\.\.)|(.*\/)).*\.git\Z/
   end
 
   def standard_links(host, project, commit)
@@ -49,7 +49,7 @@ module SubmoduleHelper
   end
 
   def relative_self_links(url, commit)
-    if url.scan(/(\.\.)/).size == 2
+    if url.scan(/(\.\.\/)/).size == 2
       base = [ Gitlab.config.gitlab.url, '/', url[/.*\/(.*)\/.*\.git/, 1] ].join('')
     else
       base = [ Gitlab.config.gitlab.url, '/', @project.group.path ].join('')
-- 
GitLab