summaryrefslogtreecommitdiff
Commit message (Collapse)AuthorAgeFilesLines
...
* gitcmd: may now receive extra keyword arguments to be passed directly to the ↵Sebastian Thiel2010-05-311-11/+9
| | | | subproces.Popen invocation. It could be used to pass custom environments, without changing the own one (#26)
* cmd: By default, on linux, the parent file handles will be closed to leave ↵Sebastian Thiel2010-05-271-0/+1
| | | | the child less cluttered, and make it easier to debug as it will only have the file descriptors we set. It appears to be more stable regarding the stdin-is-closed-but-child-doesn't-realize-this issue
* index: index-add fixed to always append a newline after each item. In git ↵Sebastian Thiel2010-05-262-24/+11
| | | | | | has unified its way it reads from stdin, now it wants all items to be terminated by a newline usually. Previously, it could have been that it really didn't want to have a termination character when the last item was written to the file. Bumped the minimum requirements to 1.7.0 to be sure it is working as I think it will. Still, I have to admit that sometime it just appears the closed pipe will not stop git from waiting for more input, at least with the previous implementation
* refs: a Reference can now be created by assigning a commit or object (for ↵Sebastian Thiel2010-05-262-11/+78
| | | | convenience)
* BlockingLockFile: added sanity check that raises IOError if the directory ↵Sebastian Thiel2010-05-261-4/+15
| | | | containing the lock was removed. This is unlikely to happen in a production envrironment, but may happen during testing, as folders are moved/deleted once the test is complete. Daemons might still be waiting for something, and they should be allowed to terminate instead of waiting for a possibly long time
* diff: by limiting the splitcount to 5, a subtle bug was introduced as the ↵0.2.0-beta1Sebastian Thiel2010-05-252-1/+16
| | | | | | newline at the end of the split line was not split away automatically. Added test for this, and the trivial fix Wow, at least two people reviewd the code, but it slipped through anyway :)
* Repo: Added comparison operators and hash operator including testSebastian Thiel2010-05-124-7/+36
| | | | Cmd: AutoInterrupt handles boundary cases more gracefully as it can be that the os module suddenly becomes None if the interpreter is going down
* IndexFile.add: Fixed incorrect path handling if path rewriting was desired ↵Sebastian Thiel2010-05-113-9/+10
| | | | | | | | and absolute paths were given Commit.create_from_tree: fixed critical bug that would cause it to create a branch named master by default, instead of the reference actually set ( which is master in many, but not all cases ) - in fact it could be detached as well, we would fail ungracefully although we could assume master then ... although we cant really make the decision Repo.is_dirty: improved its abiility to deal with empty repositories and a missing head. Weird thing is that the test always worked fine with the previous code, but it didn't work for me in a similar situation without this change at least
* Handle filenames with embedded spaces when generating diffsRick Copeland2010-05-102-1/+2
|
* index.add: added index path rewrite functionality, which allows to store a ↵Sebastian Thiel2010-05-102-1343/+1432
| | | | | | | different path in the index than the actual one on disk ( from which the object will be created ) Fixed bug the way newlines were handled, which hopefully fixes occasional hangs as well. It works fine with git 1.7.1 Most of the changes are due to the tab-space conversion - its weird once more as I thought it was all in spaces before ... .
* repo: added test with some basic assertions for empty repositories theseSebastian Thiel2010-05-107-1361/+1392
| | | | | | | | repo.is_dirty: Will not fail on empty repo ( anymore ) index.entries: will just be empty if the repository is empty refs: added to_full_path method which can be used to create fully synthetic instances of Reference types, added a test for it Converted all touched files to spaces, which is why git reports so many changed files. Actually I was thinking every file would use spaces, but apparently not
* docs: removed >>> in front of examples to make copy-pasting easierSebastian Thiel2010-05-063-212/+174
| | | | remove hard linebreaks in favor of soft-linebreaks done by the editor, as this is more flexible when editing
* README: Added mailing list and issue tracker informationSebastian Thiel2010-05-063-14/+22
| | | | Docs: updated roadmap
* TODO: Removed all entries but left a mesage about where to find the issuee ↵Sebastian Thiel2010-05-044-151/+28
| | | | | | | on lighthouse. README/intro.rst: added information about the new repository at github tree: added marker to indicate that submodules would have to be returned there
* Index: handling an AttributeError exception raised in python 2.6.5 and newer ↵Sebastian Thiel2010-05-041-3/+12
| | | | if an unset slot is being deleted.
* Added additional tz_offset testing in performance test to call it more often.Sebastian Thiel2010-04-303-2/+5
| | | | Fixed test which required to be on master to work - it now uses the HEAD symbolic ref instead.
* Merge commit 'refs/merge-requests/14' of ↵Sebastian Thiel2010-04-304-15/+34
|\ | | | | | | git://gitorious.org/git-python/mainline into integration
| * Add support for time zone information in tags and commits.Rick Copeland2010-04-274-15/+34
| | | | | | | | | | | | | | This commit includes - an update to git.objects.utils:parse_actor_and_date to parse the timezone offset - updates to the git.objects.Commit and git.objects.Tag objects to support *_tz_offset attributes - updates to tests in test.git.test_commit and test.git.test_refs to check for appropriate *_tz_offset attributes
* | conf.py: Adjusted version to match with the actual versionSebastian Thiel2010-04-141-2/+2
|/
* Used this release for a first beta of the 0.2 branch of developmentSebastian Thiel2010-04-074-2/+5
| | | | | TODO: Added info about doc improvements Authors: Added myself as Contributor, and noted the partial rewrite which happend in 0.2
* roadmap added to docs to give an idea of tasks still to be done, especially ↵Sebastian Thiel2010-03-232-0/+14
| | | | if 0.2 should be released one day
* test system: renamed a few test methods in test_remote which could been ↵Sebastian Thiel2010-03-211-16/+16
| | | | mistaken for disabled tests, although they are actually called by the test cases as utility functions
* Converted all tabs to 4 space characters each to comply with pep8Sebastian Thiel2010-03-0439-9078/+9078
|
* Small improvements to the tutorial prior to tagging 0.2rc1Sebastian Thiel2010-03-021-24/+29
|
* Commit.iter_items: Will not restrict comits to the ones containing changes ↵Sebastian Thiel2010-02-282-1/+24
| | | | | | to paths anymore as it will only append '--' if paths are actually given. Added unittest to verify this
* git.Tree: Fixed critical issue when reading trees from binary data. The ↵Sebastian Thiel2010-02-241-8/+6
| | | | previous version was making assumptions that would only be true for old git repositories it sesms. The new version of the algorithm deals with this gracefully.
* IndexFile.write: Added special handling flag allowing to skip TREE extension ↵Sebastian Thiel2010-02-241-17/+27
| | | | data, which becomes important if git-write-tree is supposed to be used
* index: added move method including testSebastian Thiel2010-02-193-13/+132
| | | | test.helpers: temporary rw repository creators now set the working dir of the program, easing working with relative paths a lot
* LockFile: release_lock now checks whether the lockfile to be removed still ↵Sebastian Thiel2010-02-181-1/+6
| | | | exists. Previously it would just fail
* git.commit: Added test to assure we handle the first commit correctly ↵Sebastian Thiel2010-02-182-1/+6
| | | | regarding its parents
* Lockfile now uses low-level commands to interact with the filesystem in ↵Sebastian Thiel2010-02-141-30/+5
| | | | order to make it impossible for threads to overwrite each other if we are talking about miliseconds. This renders plenty of 'special' handling redundant
* Commit.create: now handles empty repositories correctlySebastian Thiel2010-02-131-2/+15
|
* IndexFile: unmerged_blobs lists are now sortedSebastian Thiel2010-02-133-15/+34
| | | | Repo.init: fixed incorrect use of the path which was to optionally specify where to initialize the repository. Update test as well
* Implemented RemoteProgress parsing for git-fetch, which might become ↵Sebastian Thiel2010-01-122-50/+115
| | | | | | available at some point natively, within the git suite Progress parsing now deals properly with Ascii_Escape characters that are meant for the tty - git might stop sending this at some point, but we can deal with it no matter what
* remote.py: improved push-progress parsin to better deal with messages ( i.e. ↵Sebastian Thiel2010-01-121-7/+12
| | | | throughput )
* tree: implemented recursive paths in __div__ and __getitem__ method, ↵Sebastian Thiel2009-12-303-7/+33
| | | | allowing the keys to contain slashes; adjusted test to check for this
* LockFile: id representing the instance that keeps the lock is unique now - ↵Sebastian Thiel2009-12-171-11/+25
| | | | locks will check whether the lock they wrote truly is theirs - in case threads are racing, this might not be the case. Now this issue will be detected and results in a proper failure
* config: GitConfigReader now allows to override its lock-type. By default it ↵Sebastian Thiel2009-12-173-10/+26
| | | | uses a 'failing' lock file, but now its possible to easily put a blocking lock file in its place
* Added imports for standard locking file classes into the git moduleSebastian Thiel2009-12-165-8/+12
|
* index: improved the way stdout is handled as the previous handling rarely ↵Sebastian Thiel2009-12-152-6/+9
| | | | | | caused lockups while waiting for stdout NOTE: This does not have the desired effect, the issue appears to be somewhere within git, possibly, as git simply does not terminate waiting for something, even if stdout is closed.
* refs: Added is_valid method to SymbolicReference base classSebastian Thiel2009-12-152-0/+19
|
* removed nonsense IndexLock implementationSebastian Thiel2009-12-101-32/+1
|
* index: IndexLock added to provide some kind of critical section for index ↵Sebastian Thiel2009-12-101-1/+33
| | | | based git operations in concurrent environments
* index: TempFileMover now handles the case that the file to move does not ↵Sebastian Thiel2009-12-103-4/+65
| | | | | | exist more gracefully Added BlockingLockFile which may be used to wait for the lock according to some criteria
* config: fixed incorrect handling of default value in get_valueSebastian Thiel2009-12-094-4/+11
| | | | remote.config: SectionConstraint now knows about set_value and get_value which are new to the GitConfigParser
* repo: Added alias for refs property, which is called 'references' , to ↵Sebastian Thiel2009-12-091-2/+5
| | | | improve usability. There was no reason that only 'refs' is shortened, whereas there are 'heads' and 'tags' as well
* config.set_value: added more convenient set_value method to ConfigReaderSebastian Thiel2009-12-082-0/+26
|
* config.get_value: Added default argument including testSebastian Thiel2009-12-082-2/+15
|
* index: Checkout exception now contains information about the reason of the ↵Sebastian Thiel2009-12-072-2/+11
| | | | failure as well, one per failed file
* Reference: reading of commit data is now safer and handles non-existing ↵Sebastian Thiel2009-12-073-3/+9
| | | | paths - previously it would run into a code-branch I forgot