On Tue, Mar 09, 2021 at 04:03:49PM +0800, Li Yuanchao wrote:
There is a problem to download from github by http or https. fatal: unable to access 'https://github.com/liyc-github/AvxToNeon/': Failed to connect to github.com port 443: Connection timed out
When it occurs, change url to "git://xxx".
Signed-off-by: Li Yuanchao lyc163mail@163.com
lib/git_mirror.rb | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-)
diff --git a/lib/git_mirror.rb b/lib/git_mirror.rb index 53c9e59..1fa8c9e 100644 --- a/lib/git_mirror.rb +++ b/lib/git_mirror.rb @@ -42,16 +42,20 @@ class GitMirror def git_clone(url, mirror_dir) url = get_url(Array(url)[0]) 10.times do
%x(git clone --mirror --depth 1 #{url} #{mirror_dir} 2>&1)
stderr = %x(git clone --mirror --depth 1 #{url} #{mirror_dir} 2>&1) return true if File.directory?(mirror_dir) && File.exist?("#{mirror_dir}/config")
if stderr.include?('Failed to connect to github.com port 443')
url = "git://#{url.split('://')[1]}"
end
end return false end
def git_fetch(mirror_dir) if File.exist?("#{mirror_dir}/shallow")
FileUtils.rm("#{mirror_dir}/shallow.lock") if File.exist?("#{mirror_dir}/shallow.lock") %x(git -C #{mirror_dir} fetch --unshallow 2>&1)
return false
end
fetch_info = %x(git -C #{mirror_dir} fetch 2>&1)
@@ -59,6 +63,11 @@ class GitMirror if fetch_info.include?(ERR_MESSAGE) && Dir.empty?(mirror_dir) FileUtils.rmdir(mirror_dir) end
- if fetch_info.include?('Failed to connect to github.com port 443')
'Failed to connect to github.com port 443' is 2nd used here, suggest to set a string var for it.
Thanks, Xijian
url = %x(git -C #{mirror_dir} ls-remote --get-url origin).chomp
%x(git -C #{mirror_dir} remote set-url origin git://#{url.split('://')[1]})
- end return fetch_info.include? '->' end
@@ -66,7 +75,7 @@ class GitMirror url = get_url(Array(url)[0]) git_url = %x(git -C #{mirror_dir} ls-remote --get-url origin).chomp
- return true if url == git_url
return true if git_url == url || git_url.include?(url.split('://')[1])
return false end
-- 2.23.0