# HG changeset patch # User Marcin Kuzminski # Date 2013-02-17 21:58:09 # Node ID e67b2ef07a8eb8efe1579b849a9848ec6af99e1e # Parent 7000fc4aa56995032ce5e598edd42ea6a718b05c git executable is now configurable via .ini files diff --git a/development.ini b/development.ini --- a/development.ini +++ b/development.ini @@ -43,6 +43,8 @@ pdebug = false #WAITRESS threads = 5 +#100GB +max_request_body_size = 107374182400 use = egg:waitress#main host = 0.0.0.0 @@ -75,6 +77,9 @@ commit_parse_limit = 25 dashboard_items = 100 use_gravatar = true +# path to git executable +git_path = git + ## RSS feed options rss_cut_off_limit = 256000 diff --git a/production.ini b/production.ini --- a/production.ini +++ b/production.ini @@ -43,6 +43,8 @@ pdebug = false #WAITRESS threads = 5 +#100GB +max_request_body_size = 107374182400 use = egg:waitress#main host = 127.0.0.1 @@ -75,6 +77,9 @@ commit_parse_limit = 50 dashboard_items = 100 use_gravatar = true +# path to git executable +git_path = git + ## RSS feed options rss_cut_off_limit = 256000 diff --git a/rhodecode/config/deployment.ini_tmpl b/rhodecode/config/deployment.ini_tmpl --- a/rhodecode/config/deployment.ini_tmpl +++ b/rhodecode/config/deployment.ini_tmpl @@ -43,6 +43,8 @@ pdebug = false #WAITRESS threads = 5 +#100GB +max_request_body_size = 107374182400 use = egg:waitress#main host = 127.0.0.1 @@ -75,6 +77,9 @@ commit_parse_limit = 50 dashboard_items = 100 use_gravatar = true +# path to git executable +git_path = git + ## RSS feed options rss_cut_off_limit = 256000 diff --git a/rhodecode/lib/middleware/pygrack.py b/rhodecode/lib/middleware/pygrack.py --- a/rhodecode/lib/middleware/pygrack.py +++ b/rhodecode/lib/middleware/pygrack.py @@ -6,6 +6,7 @@ import traceback from webob import Request, Response, exc +import rhodecode from rhodecode.lib import subprocessio log = logging.getLogger(__name__) @@ -82,10 +83,11 @@ class GitRepository(object): # if you do add '\n' as part of data, count it. server_advert = '# service=%s' % git_command packet_len = str(hex(len(server_advert) + 4)[2:].rjust(4, '0')).lower() + _git_path = rhodecode.CONFIG.get('git_path', 'git') try: out = subprocessio.SubprocessIOChunker( - r'git %s --stateless-rpc --advertise-refs "%s"' % ( - git_command[4:], self.content_path), + r'%s %s --stateless-rpc --advertise-refs "%s"' % ( + _git_path, git_command[4:], self.content_path), starting_values=[ packet_len + server_advert + '0000' ] @@ -142,8 +144,9 @@ class GitRepository(object): if git_command in [u'git-receive-pack']: # updating refs manually after each push. # Needed for pre-1.7.0.4 git clients using regular HTTP mode. - cmd = (u'git --git-dir "%s" ' - 'update-server-info' % self.content_path) + _git_path = rhodecode.CONFIG.get('git_path', 'git') + cmd = (u'%s --git-dir "%s" ' + 'update-server-info' % (_git_path, self.content_path)) log.debug('handling cmd %s' % cmd) subprocess.call(cmd, shell=True) diff --git a/rhodecode/lib/utils.py b/rhodecode/lib/utils.py --- a/rhodecode/lib/utils.py +++ b/rhodecode/lib/utils.py @@ -744,13 +744,12 @@ def check_git_version(): Checks what version of git is installed in system, and issues a warning if it's too old for RhodeCode to properly work. """ - import subprocess + from rhodecode import BACKENDS + from rhodecode.lib.vcs.backends.git.repository import GitRepository from distutils.version import StrictVersion - from rhodecode import BACKENDS - p = subprocess.Popen('git --version', shell=True, - stdout=subprocess.PIPE, stderr=subprocess.PIPE) - stdout, stderr = p.communicate() + stdout, stderr = GitRepository._run_git_command('--version') + ver = (stdout.split(' ')[-1] or '').strip() or '0.0.0' if len(ver.split('.')) > 3: #StrictVersion needs to be only 3 element type diff --git a/rhodecode/lib/vcs/backends/git/changeset.py b/rhodecode/lib/vcs/backends/git/changeset.py --- a/rhodecode/lib/vcs/backends/git/changeset.py +++ b/rhodecode/lib/vcs/backends/git/changeset.py @@ -2,6 +2,7 @@ import re from itertools import chain from dulwich import objects from subprocess import Popen, PIPE +import rhodecode from rhodecode.lib.vcs.conf import settings from rhodecode.lib.vcs.exceptions import RepositoryError from rhodecode.lib.vcs.exceptions import ChangesetError @@ -362,8 +363,9 @@ class GitChangeset(BaseChangeset): frmt = 'zip' else: frmt = 'tar' - cmd = 'git archive --format=%s --prefix=%s/ %s' % (frmt, prefix, - self.raw_id) + _git_path = rhodecode.CONFIG.get('git_path', 'git') + cmd = '%s archive --format=%s --prefix=%s/ %s' % (_git_path, + frmt, prefix, self.raw_id) if kind == 'tgz': cmd += ' | gzip -9' elif kind == 'tbz2': diff --git a/rhodecode/lib/vcs/backends/git/repository.py b/rhodecode/lib/vcs/backends/git/repository.py --- a/rhodecode/lib/vcs/backends/git/repository.py +++ b/rhodecode/lib/vcs/backends/git/repository.py @@ -20,7 +20,8 @@ import urllib2 from dulwich.repo import Repo, NotGitRepository from dulwich.objects import Tag from string import Template -from subprocess import Popen, PIPE + +import rhodecode from rhodecode.lib.vcs.backends.base import BaseRepository from rhodecode.lib.vcs.exceptions import BranchDoesNotExistError from rhodecode.lib.vcs.exceptions import ChangesetDoesNotExistError @@ -91,17 +92,14 @@ class GitRepository(BaseRepository): """ return self._get_all_revisions() - def run_git_command(self, cmd): + @classmethod + def _run_git_command(cls, cmd, **opts): """ Runs given ``cmd`` as git command and returns tuple - (returncode, stdout, stderr). - - .. note:: - This method exists only until log/blame functionality is implemented - at Dulwich (see https://bugs.launchpad.net/bugs/645142). Parsing - os command's output is road to hell... + (stdout, stderr). :param cmd: git command to be executed + :param opts: env options to pass into Subprocess command """ _copts = ['-c', 'core.quotepath=false', ] @@ -116,17 +114,17 @@ class GitRepository(BaseRepository): del gitenv['GIT_DIR'] gitenv['GIT_CONFIG_NOGLOBAL'] = '1' - cmd = ['git'] + _copts + cmd + _git_path = rhodecode.CONFIG.get('git_path', 'git') + cmd = [_git_path] + _copts + cmd if _str_cmd: cmd = ' '.join(cmd) try: - opts = dict( + _opts = dict( env=gitenv, shell=False, ) - if os.path.isdir(self.path): - opts['cwd'] = self.path - p = subprocessio.SubprocessIOChunker(cmd, **opts) + _opts.update(opts) + p = subprocessio.SubprocessIOChunker(cmd, **_opts) except (EnvironmentError, OSError), err: log.error(traceback.format_exc()) raise RepositoryError("Couldn't run git command (%s).\n" @@ -134,6 +132,12 @@ class GitRepository(BaseRepository): return ''.join(p.output), ''.join(p.error) + def run_git_command(self, cmd): + opts = {} + if os.path.isdir(self.path): + opts['cwd'] = self.path + return self._run_git_command(cmd, **opts) + @classmethod def _check_url(cls, url): """