1. 18 6月, 2006 5 次提交
  2. 17 6月, 2006 11 次提交
    • L
      gitweb.cgi history not shown · 9202434c
      Linus Torvalds 提交于
      This does:
      
       - add a "rev.simplify_history" flag which defaults to on
       - it turns it off for "git whatchanged" (which thus now has real
         semantics outside of "git log")
       - it adds a command line flag ("--full-history") to turn it off for
         others (ie you can make "git log" and "gitk" etc get the semantics if
         you want to.
      
      Now, just as an example of _why_ you really really really want to simplify
      history by default, apply this patch, install it, and try these two
      command lines:
      
      	gitk --full-history -- git.c
      	gitk -- git.c
      
      and compare the output.
      
      So with this, you can also now do
      
      	git whatchanged -p -- gitweb.cgi
      	git log -p --full-history -- gitweb.cgi
      
      and it will show the old history of gitweb.cgi, even though it's not
      relevant to the _current_ state of the name "gitweb.cgi"
      
      NOTE NOTE NOTE! It will still actually simplify away merges that didn't
      change anything at all into either child. That creates these bogus strange
      discontinuities if you look at it with "gitk" (look at the --full-history
      gitk output for git.c, and you'll see a few strange cases).
      
      So the whole "--parent" thing ends up somewhat bogus with --full-history
      because of this, but I'm not sure it's worth even worrying about. I don't
      think you'd ever want to really use "--full-history" with the graphical
      representation, I just give it as an example exactly to show _why_ doing
      so would be insane.
      
      I think this is trivial enough and useful enough to be worth merging into
      the stable branch.
      Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
      Signed-off-by: NJunio C Hamano <junkio@cox.net>
      9202434c
    • P
      bfbd0bb6
    • F
      gitweb: Make the `blame' interface in gitweb optional. · 5996ca08
      Florian Forster 提交于
      Since `git-annotate' is an expensive operation to run it may be
      desirable to deactivate this functionality. This patch introduces
      the `gitweb.blame' option to git-repo-config and disables the blame
      support by default.
      Signed-off-by: NFlorian Forster <octo@verplant.org>
      Signed-off-by: NJunio C Hamano <junkio@cox.net>
      5996ca08
    • F
      gitweb: Adding a `blame' interface. · e34ef621
      Florian Forster 提交于
      This patch adds an interface for `git-blame' to `gitweb.cgi'.
      Links to it are placed in `git_blob'.
      
      Internally the code uses `git-annotate' because `git-blame's output
      differs for files that have been renamed in the past. However, I like
      the term `blame' better.
      
      [jc: blame can be told to produce the compatible format btw...]
      Signed-off-by: NFlorian Forster <octo@verplant.org>
      Signed-off-by: NJunio C Hamano <junkio@cox.net>
      e34ef621
    • M
      cvsimport: keep one index per branch during import · 8f732649
      Martin Langhoff 提交于
      With this patch we have a speedup and much lower IO when
      importing trees with many branches. Instead of forcing
      index re-population for each branch switch, we keep
      many index files around, one per branch.
      Signed-off-by: NMartin Langhoff <martin@catalyst.net.nz>
      Signed-off-by: NJunio C Hamano <junkio@cox.net>
      8f732649
    • M
      cvsimport: complete the cvsps run before starting the import · 2f57c697
      Martin Langhoff 提交于
      We now capture the output of cvsps to a tempfile, and then read it in.
      cvsps 2.1 works quite a bit "in memory", and only prints its patchset
      info once it has finished talking with cvs, but apparently retaining
      all that memory allocation. With this patch, cvsps is finished and
      reaped before cvsimport start working (and growing). So the footprint
      of the whole process is much lower.
      Signed-off-by: NMartin Langhoff <martin@catalyst.net.nz>
      Signed-off-by: NJunio C Hamano <junkio@cox.net>
      2f57c697
    • M
      cvsimport: ignore CVSPS_NO_BRANCH and impossible branches · 71b08148
      Martin Langhoff 提交于
      cvsps output often contains references to CVSPS_NO_BRANCH, commits
      that it could not trace to a branch. Ignore that branch.
      
      Additionally, cvsps will sometimes draw circular relationships
      between branches -- where two branches are recorded as opening
      from the other.  In those cases, and where the ancestor branch
      hasn't been seen, ignore it.
      Signed-off-by: NMartin Langhoff <martin@catalyst.net.nz>
      Signed-off-by: NJunio C Hamano <junkio@cox.net>
      71b08148
    • F
      blame: Add --time to produce raw timestamps · b19ee24b
      Fredrik Kuivinen 提交于
      fix the usage string and clean up the docs while we are at it
      Signed-off-by: NFredrik Kuivinen <freku045@student.liu.se>
      Signed-off-by: NJunio C Hamano <junkio@cox.net>
      b19ee24b
    • J
      fix git alias · d8498500
      Junio C Hamano 提交于
      When extra command line arguments are given to a command that
      was alias-expanded, the code generated a wrong argument list,
      leaving the original alias in the result, and forgetting to
      terminate the new argv list.
      Signed-off-by: NJunio C Hamano <junkio@cox.net>
      d8498500
    • S
      Add a "--notags" option for git-p4import. · ada7781d
      Sean 提交于
      P4import currently creates a git tag for every commit it imports.
      When importing from a large repository too many tags can be created
      for git to manage, so this provides an option to shut that feature
      off if necessary.
      Signed-off-by: NSean Estabrooks <seanlkml@sympatico.ca>
      ada7781d
    • J
      Merge git://git.bogomips.org/git-svn · 5b139a66
      Junio C Hamano 提交于
      * git://git.bogomips.org/git-svn: (25 commits)
        git-svn: rebuild convenience and bugfixes
        git-svn: svn (command-line) 1.0.x compatibility
        git-svn: tests no longer fail if LC_ALL is not a UTF-8 locale
        git-svn: bugfix and optimize the 'log' command
        git-svn: Eliminate temp file usage in libsvn_get_file()
        git-svn: fix several small bugs, enable branch optimization
        git-svn: avoid creating some small files
        git-svn: make the $GIT_DIR/svn/*/revs directory obsolete
        git-svn: add support for Perl SVN::* libraries
        git-svn: add 'log' command, a facsimile of basic `svn log'
        git-svn: add UTF-8 message test
        git-svn: add some functionality to better support branches in svn
        git-svn: add --shared and --template= options to pass to init-db
        git-svn: add --repack and --repack-flags= options
        git-svn: minor cleanups, extra error-checking
        git-svn: Move all git-svn-related paths into $GIT_DIR/svn
        git-svn: support manually placed initial trees from fetch
        git-svn: optimize --branch and --branch-all-ref
        git-svn: --branch-all-refs / -B support
        git-svn: support -C<num> passing to git-diff-tree
        ...
      5b139a66
  3. 16 6月, 2006 24 次提交
    • E
      git-svn: rebuild convenience and bugfixes · 1a82e793
      Eric Wong 提交于
      We will now automatically fetch the refs/remotes/git-svn ref
      from origin and store a Pull: line for it.
      
      --remote=<origin> may be passed if your remote is named something
      other than 'origin'
      
      Also, remember to make GIT_SVN_DIR whenever we need to create
      .rev_db
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      1a82e793
    • E
      git-svn: svn (command-line) 1.0.x compatibility · 0e8a002c
      Eric Wong 提交于
      Tested on a plain Ubuntu Warty installation
      using subversion 1.0.6-1.2ubuntu3
      
      svn add --force was never needed, as it only affected
      directories, which git (thankfully) doesn't track
      
      The 1.0.x also didn't support symlinks(!), so allow NO_SYMLINK
      to be defined for running tests
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      0e8a002c
    • E
      86f36379
    • E
      git-svn: bugfix and optimize the 'log' command · c0d48222
      Eric Wong 提交于
      Revisions with long commit messages were being skipped, since
      the 'git-svn-id' metadata line was at the end and git-log uses a
      32k buffer to print the commits.
      
      Also the last 'git-svn-id' metadata line in a commit is always
      the valid one, so make sure we use that, as well.
      
      Made the verbose flag work by passing the correct option switch
      ('--summary') to git-log.
      
      Finally, optimize -r/--revision argument handling by passing
      the appropriate limits to revision
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      c0d48222
    • E
      git-svn: Eliminate temp file usage in libsvn_get_file() · 968bdf1f
      Eric Wong 提交于
      This means we'll have a loose object when we encounter a symlink
      but that's not the common case.
      
      We also don't have to worry about svn:eol-style when using the
      SVN libraries, either.  So remove the code to deal with that.
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      968bdf1f
    • E
      git-svn: fix several small bugs, enable branch optimization · cf7424b0
      Eric Wong 提交于
      Share the repack counter between branches when doing
      multi-fetch.
      
      Pass the -d flag to git repack by default.  That's the
      main reason we will want automatic pack generation, to
      save space and improve disk cache performance.  I won't
      add -a by default since it can generate extremely large
      packs that make RAM-starved systems unhappy.
      
      We no longer generate the .git/svn/$GIT_SVN_ID/info/uuid
      file, either.  It was never read in the first place.
      
      Check for and create .rev_db if we need to during fetch (in case
      somebody manually blew away their .rev_db and wanted to start
      over.  Mainly makes debugging easier).
      
      Croak with $? instead of $! if there's an error closing pipes
      
      Quiet down some of the chatter, too.
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      cf7424b0
    • E
      git-svn: avoid creating some small files · 6c5cda89
      Eric Wong 提交于
      repo_path_split() is already pretty fast, and is already
      optimized via caching.
      
      We also don't need to create an exclude file if we're
      relying on the SVN libraries.
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      6c5cda89
    • E
      git-svn: make the $GIT_DIR/svn/*/revs directory obsolete · 42d32870
      Eric Wong 提交于
      This is a very intrusive change, so I've beefed up the tests
      significantly.  Added 'full-test' a target to the Makefile,
      to test different possible configurations.  This is intended
      for maintainers only.  Users should only be concerned with
      'test' succeeding.
      
      We now have a very simple custom database format for handling
      mapping of svn revisions => git commits.  Of course, we're
      not really using it yet, either.
      
      Also disabled automatic branch-finding on new trees for now.
      It's too easily broken.  revisions_eq() function should be
      helpful for branch detection.
      
      Also removed an extra assertion in fetch_cmd() that wasn't
      correctly done.  This bug was found by full-test.
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      42d32870
    • E
      git-svn: add support for Perl SVN::* libraries · a5e0cedc
      Eric Wong 提交于
      This means we no longer have to deal with having bloated SVN
      working copies around and we get a nice performance increase as
      well because we don't have to exec the SVN binary and start a
      new server connection each time.
      
      Of course we have to manually manage memory with SVN::Pool
      whenever we can, and hack around cases where SVN just eats
      memory despite pools (I blame Perl, too).  I would like to
      keep memory usage as stable as possible during long fetch/commit
      processes since I still use computers with only 256-512M RAM.
      
      commit should always be faster with the SVN library code.  The
      SVN::Delta interface is leaky (or I'm not using it with pools
      correctly), so I'm forking on every commit, but that doesn't
      seem to hurt performance too much (at least on normal Unix/Linux
      systems where fork() is pretty cheap).
      
      fetch should be faster in most common cases, but probably not all.
      fetches will be faster where client/server delta generation is
      the bottleneck and not bandwidth.  Of course, full-files are
      generated server-side via deltas, too.  Full files are always
      transferred when they're updated, just like git-svnimport and
      unlike command-line svn.  I'm also hacking around memory leaks
      (see comments) here by using some more forks.
      
      I've tested fetch with http://, https://, file://, and svn://
      repositories, so we should be reasonably covered in terms of
      error handling for fetching.
      
      Of course, we'll keep plain command-line svn compatibility as a
      fallback for people running SVN 1.1 (I'm looking into library
      support for 1.1.x SVN, too).  If you want to force command-line
      SVN usage, set GIT_SVN_NO_LIB=1 in your environment.
      
      We also require two simultaneous connections (just like
      git-svnimport), but this shouldn't be a problem for most
      servers.
      
      Less important commands:
      
      show-ignore is slower because it requires repository
      access, but -r/--revision <num> can be specified.
      
      graft-branches may use more memory, but it's a
      short-term process and is funky-filename-safe.
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      a5e0cedc
    • E
      git-svn: add 'log' command, a facsimile of basic `svn log' · 79bb8d88
      Eric Wong 提交于
      This quick feature should make it easy to look up svn log
      messages when svn users refer to -r/--revision numbers.
      
      The following features from `svn log' are supported:
      
        --revision=<n>[:<n>] - is supported, non-numeric args are not:
      			 HEAD, NEXT, BASE, PREV, etc ...
        -v/--verbose         - just maps to --raw (in git log), so
      			 it's completely incompatible with
      			 the --verbose output in svn log
        --limit=<n>          - is NOT the same as --max-count,
      			 doesn't count merged/excluded commits
        --incremental        - supported (trivial :P)
      
      New features:
      
        --show-commit        - shows the git commit sha1, as well
        --oneline            - our version of --pretty=oneline
      
      Any other arguments are passed directly to `git log'
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      79bb8d88
    • E
      git-svn: add UTF-8 message test · 7a97de4e
      Eric Wong 提交于
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      7a97de4e
    • E
      git-svn: add some functionality to better support branches in svn · 9d55b41a
      Eric Wong 提交于
      New commands:
      
      graft-branches - The most interesting command of the bunch.  It
      detects branches in SVN via various techniques (currently
      regexes and file copies).   It can be later extended to handle
      svk and other properties people may use to track merges in svk.
      Basically, merge tracking is not standardized at all in the SVN
      world, and git grafts are perfect for dealing with this
      situation.
      
      Existing branch support (via tree matches) is only handled at
      fetch time.
      
      The following tow were originally implemented as shell scripts
      several months ago, but I just decided to streamline things a
      bit and added them to the main script.
      
      multi-init - supports git-svnimport-like command-line syntax for
      importing repositories that are layed out as recommended by the
      SVN folks.  This is a bit more tolerant than the git-svnimport
      command-line syntax and doesn't require the user to figure out
      where the repository URL ends and where the repository path
      begins.
      
      multi-fetch - runs fetch on all known SVN branches we're
      tracking.  This will NOT discover new branches (unlike
      git-svnimport), so multi-init will need to be re-run (it's
      idempotent).
      
      Consider these three to be auxilliary commands (like
      show-ignore, and rebuild) so their behavior won't receive as
      much testing or scrutiny as the core commands (fetch and
      commit).
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      9d55b41a
    • E
      f8ab6b73
    • E
      git-svn: add --repack and --repack-flags= options · dc5869c0
      Eric Wong 提交于
      This should help keep disk usage sane for large imports.
      
      --repack takes an optional argument for the interval, it
      defaults to 1000 if no argument is specified.
      
      Arguments to --repack-flags are passed directly to git-repack.
      No arguments are passed by default.
      
      Idea stolen from git-cvsimport :)
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      dc5869c0
    • E
      git-svn: minor cleanups, extra error-checking · b8c92cad
      Eric Wong 提交于
      While we're at it, read_repo_config has been added and
      expanded to handle case where command-line arguments are
      optional to Getopt::Long
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      b8c92cad
    • E
      git-svn: Move all git-svn-related paths into $GIT_DIR/svn · 883d0a78
      Eric Wong 提交于
      Since GIT_SVN_ID usage is probably going to become more
      widespread <evil grin>, we won't run the chance of somebody
      having a GIT_SVN_ID name that conflicts with one of the default
      directories that already exist in $GIT_DIR (branches/tags).
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      883d0a78
    • E
      git-svn: support manually placed initial trees from fetch · 6dfbe516
      Eric Wong 提交于
      Sometimes I don't feel like downloading an entire tree again when
      I actually decide a branch is worth tracking, so some users can
      get around it more easily with this.
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      6dfbe516
    • E
      git-svn: optimize --branch and --branch-all-ref · 098749d9
      Eric Wong 提交于
      By breaking the pipe read once we've seen a commit twice.
      
      This should make -B/--branch-all-ref faster and usable on a
      frequent basis.
      
      We use topological order now for calling git-rev-list, and any
      commit we've seen before should imply that all parents have been
      seen (at least I hope that's the case for --topo-order).
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      098749d9
    • E
      git-svn: --branch-all-refs / -B support · bf78b1d8
      Eric Wong 提交于
      This should make life easier for all those who type:
      
      	`git-rev-parse --symbolic --all | xargs -n1 echo -b`
      
      every time they run git-svn fetch.
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      bf78b1d8
    • E
      git-svn: support -C<num> passing to git-diff-tree · 162f4129
      Eric Wong 提交于
      The repo-config key is 'svn.copysimilarity'
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      162f4129
    • E
      git-svn: don't allow commit if svn tree is not current · b63af9b3
      Eric Wong 提交于
      If new revisions are fetched, that implies we haven't merged,
      acked, or nacked them yet, and attempting to write the tree
      we're committing means we'd silently clobber the newly fetched
      changes.
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      b63af9b3
    • E
      git-svn: restore original LC_ALL setting (or unset) for commit · ce475dfc
      Eric Wong 提交于
      svn forces UTF-8 for commit messages, and with LC_ALL set to 'C'
      it is unable to determine encoding of the git commit message.
      
      Now we'll just assume the user has set LC_* correctly for
      the commit message they're using.
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      ce475dfc
    • E
      git-svn: eol_cp corner-case fixes · 4a393f2b
      Eric Wong 提交于
      If we read the maximum size of our buffer into $buf, and the
      last character is '\015', there's a chance that the character is
      '\012', which means our regex won't work correctly.  At the
      worst case, this could introduce an extra newline into the code.
      We'll now read an extra character if we see '\015' is the last
      character in $buf.
      
      We also forgot to recalculate the length of $buf after doing the
      newline substitution, causing some files to appeare truncated.
      We'll do that now and force byte semantics in length() for good
      measure.
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      4a393f2b
    • E
      git-svn: fix handling of filenames with embedded '@' · 8a97e368
      Eric Wong 提交于
      svn has trouble parsing files with embedded '@' characters.  For
      example,
      
        svn propget svn:keywords foo@bar.c
        svn: Syntax error parsing revision 'bar.c'
      
      I asked about this on #svn and the workaround suggested was to append
      an explicit revision specifier:
      
        svn propget svn:keywords foo@bar.c@BASE
      
      This patch appends '@base' to the filename in all calls to 'svn
      propget'.
      
      Patch originally by Seth Falcon <sethfalcon@gmail.com>
      Seth: signoff?
      
      [ew: Made to work with older svn that don't support peg revisions]
      Signed-off-by: NEric Wong <normalperson@yhbt.net>
      8a97e368