|   | 679b69c4 | 2011-11-28T13:05:25 |  | Resolve remaining feedback
* replace some ints with size_ts
* update NULL checks in various places | 
            
              |   | 3aa294fd | 2011-11-28T10:42:57 |  | Add two string git_buf_join and tweak input error checking.
This commit addresses two of the comments:
* renamed existing n-input git_buf_join to git_buf_join_n
* added new git_buf_join that always takes two inputs
* moved some parameter error checking to asserts
* extended unit tests to cover new version of git_buf_join | 
            
              |   | 8c74d22e | 2011-11-27T21:47:58 |  | Extend git_buf with new utility functions and unit tests.
Add new functions to git_buf for:
* initializing a buffer from a string
* joining one or more strings onto a buffer with separators
* swapping two buffers in place
* extracting data from a git_buf (leaving it empty)
Also, make git_buf_free leave a git_buf back in its initted state,
and slightly tweak buffer allocation sizes and thresholds.
Finally, port unit tests to clay and extend with lots of new tests
for the various git_buf functions. | 
            
              |   | 880b6f0c | 2011-11-25T21:31:35 |  | Merge pull request #497 from carlosmn/config
Don't fail when opening a new config file | 
            
              |   | e42ea1f4 | 2011-11-25T21:30:08 |  | Merge pull request #491 from schu/refs-cleanup
reference_rename() cleanup | 
            
              |   | 533fda3b | 2011-11-26T02:00:18 |  | config: test saving config to new file | 
            
              |   | 4e90a0a4 | 2011-11-26T01:54:12 |  | config: allow to open and write to a new file | 
            
              |   | 2869f404 | 2011-11-22T15:48:37 |  | transport: Add `git_transport_valid_url` | 
            
              |   | 6616e207 | 2011-11-22T11:17:03 |  | Add a note not to free the result from git_remote_ls | 
            
              |   | 39157563 | 2011-11-22T11:16:44 |  | Free the created refs in git_remote_update_tips | 
            
              |   | a3147114 | 2011-11-22T10:30:30 |  | Set transport to NULL after freeing it | 
            
              |   | b026b00d | 2011-11-21T22:47:59 |  | tests-clay: remove extra semi-colon in clay_libgit2.h, add one to index/rename.c | 
            
              |   | f8026322 | 2011-11-21T22:36:19 |  | Merge pull request #493 from euler0/fix-typos-readme
Fix typos in the README file | 
            
              |   | 9d163937 | 2011-11-22T15:12:57 |  | Fix to follow the Qt trademark policy
Never use the Qt trade mark with both letters capitalized, in the form
"QT".
(http://qt-project.org/trademarkpolicy.html) | 
            
              |   | 5689a8d5 | 2011-11-22T15:04:33 |  | Fix a typo in the README file | 
            
              |   | 4bef3565 | 2011-11-22T02:16:20 |  | remote: Assert things that should be asserted | 
            
              |   | bec92f78 | 2011-11-21T17:12:23 |  | Merge pull request #492 from carlosmn/networking
Networking improvements | 
            
              |   | 2744806f | 2011-11-22T02:10:41 |  | tree: Fix documentation | 
            
              |   | bf038dab | 2011-11-22T02:06:24 |  | clay: Properly initialize filebuf | 
            
              |   | b762e576 | 2011-11-17T15:10:27 |  | filebuf: add GIT_FILEBUF_INIT and protect multiple opens and cleanups
Update all stack allocations of git_filebuf to use GIT_FILEBUF_INIT
and make git_filebuf_open and git_filebuf_cleanup safe to be called
multiple times on the same buffer.
Signed-off-by: Vicent Marti <tanoku@gmail.com> | 
            
              |   | 1d09a1c8 | 2011-11-22T01:41:22 |  | clay: Merge manually @leto's tests from #485
This uses the new Clay code. As you can see, the diff is minimal... It
works! | 
            
              |   | 967617cc | 2011-11-21T16:37:44 |  | Merge pull request #489 from lht/fix-doc-bare-repo
Fix typo in repository documentation | 
            
              |   | 6ac3b707 | 2011-11-21T20:48:59 |  | Add git_remote_connected
Signed-off-by: Carlos Martín Nieto <carlos@cmartin.tk> | 
            
              |   | 4cf01e9a | 2011-11-21T20:44:03 |  | Add git_remote_disconnect
It can be useful to separate disconnecting from actually destroying
the object.
Signed-off-by: Carlos Martín Nieto <carlos@cmartin.tk> | 
            
              |   | a5cd086d | 2011-11-21T11:56:00 |  | reference_rename: don't delete the reflog
reference_rename used to delete an old reflog file when renaming a
reference to not confuse git.git. Don't do this anymore but let the user
take care of writing a reflog entry.
Signed-off-by: schu <schu-github@schulog.org> | 
            
              |   | b7c93a66 | 2011-11-21T13:01:40 |  | Add git_reflog_rename() and git_reflog_delete()
Signed-off-by: schu <schu-github@schulog.org> | 
            
              |   | 64093ce5 | 2011-11-21T11:30:14 |  | reference_rename: make sure to rollback
Actually rollback when we can't create the new reference. Mark the
rolled back reference as loose.
Signed-off-by: schu <schu-github@schulog.org> | 
            
              |   | bdbdefac | 2011-11-21T13:06:07 |  | fileops.h: remove git_futils_mv_atomic prototype
0c49ec2 replaced git_futils_mv_atomic with p_rename without removing its
prototype.
Signed-off-by: schu <schu-github@schulog.org> | 
            
              |   | 0ca7ca3e | 2011-10-09T03:07:53 |  | refspec: allow a simple branchname
A simple branchname as refspec is valid and we shouldn't throw an
error when encountering one.
Signed-off-by: Carlos Martín Nieto <carlos@cmartin.tk> | 
            
              |   | dc9e960f | 2011-10-09T02:59:01 |  | refspec: make the structure more complete
Add a next pointer to make it a linked list and add the 'pattern' and
'matching' flags.
Signed-off-by: Carlos Martín Nieto <carlos@cmartin.tk> | 
            
              |   | 617bfdf4 | 2011-11-18T21:28:07 |  | Add a name to a remote created from the API
Make it a bit more resilient.
Signed-off-by: Carlos Martín Nieto <carlos@cmartin.tk> | 
            
              |   | 95057b85 | 2011-11-18T21:18:39 |  | remote: get rid of git_remote_negotiate
There is no good reason to expose the negotiation as a different step
to downloading the packfile.
Signed-off-by: Carlos Martín Nieto <carlos@cmartin.tk> | 
            
              |   | 40a40e8e | 2011-10-26T18:06:36 |  | net: move the reference storage to common code | 
            
              |   | 28ba94ce | 2011-11-18T17:43:43 |  | Fix typo in repository documentation | 
            
              |   | e4c93a39 | 2011-11-18T02:26:10 |  | Update clay instructions to use -vtap | 
            
              |   | c515b5bf | 2011-11-18T02:16:24 |  | Add test for renaming a file and adding it to the index
Thanks to Emeric. | 
            
              |   | 472d4d85 | 2011-11-17T20:32:04 |  | Don't overwrite existing objects
It's redundant to do this (git doesn't) and Windows doesn't allow us
to overwrite a read-only file (which objects are).
Signed-off-by: Carlos Martín Nieto <carlos@cmartin.tk> | 
            
              |   | 2cbca8b0 | 2011-11-18T01:43:27 |  | include: Unify internal include strategies
Do not add the `git2` path to internal includes, or that will cause
an extra path dependency. | 
            
              |   | d1a721c5 | 2011-11-17T06:01:09 |  | clay: Bump to 0.9.0, add TAP support
Comes with schu's stress tests for config files. Hopefully the diffs
will stay minimal from now on. | 
            
              |   | 2ba14f23 | 2011-11-17T02:13:46 |  | tree: Add payload to `git_tree_walk` | 
            
              |   | 9432af36 | 2011-11-17T01:23:19 |  | Rename `git_tree_frompath` to `git_tree_get_subtree`
That makes more sense to me. | 
            
              |   | 010879d9 | 2011-11-16T20:35:29 |  | Merge pull request #486 from petdance/development
Quoted the asterisk to avoid markdown highlighter confusion | 
            
              |   | a07d8994 | 2011-11-16T17:33:02 |  | Quoted the asterisk to avoid markdown highlighter confusion | 
            
              |   | 68240811 | 2011-11-16T11:45:37 |  | Merge pull request #484 from brodie/packed-refs-perms
refs: permissions-related fixes/improvements | 
            
              |   | 9788e72a | 2011-11-16T11:39:03 |  | refs: move GIT_PACKED_REFS_FILE_MODE to refs.h as GIT_PACKEDREFS_FILE_MODE
This groups the #define with the other ref-related file modes, and it
makes the name consistent with the other packed-refs definitions. | 
            
              |   | 7096d0f9 | 2011-11-16T11:36:13 |  | refs: use 0666 permissions when writing packed-refs, not 0644
This matches stock Git's behavior. | 
            
              |   | b2ae96fd | 2011-11-16T11:34:10 |  | Merge pull request #482 from leto/patch-1
Fix docs about the command to mix the clay tests | 
            
              |   | 7b615610 | 2011-11-16T10:22:13 |  | Fix docs about the command to mix the clay tests | 
            
              |   | a15c550d | 2011-11-16T14:09:44 |  | threads: Fix the shared global state with TLS
See `global.c` for a description of what we're doing.
When libgit2 is built with GIT_THREADS support, the threading system
must be explicitly initialized with `git_threads_init()`. | 
            
              |   | b0b2dd5e | 2011-11-07T12:04:13 |  | Merge pull request #475 from carlosmn/perms
Fix Windows permissions problems | 
            
              |   | 657a3951 | 2011-11-07T20:32:03 |  | Write packed-refs with 0644 permissions
Signed-off-by: Carlos Martín Nieto <carlos@cmartin.tk> | 
            
              |   | 718eb4b8 | 2011-11-07T20:06:01 |  | Reword  packed-refs error messages so they're easier to track down
Signed-off-by: Carlos Martín Nieto <carlos@cmartin.tk> | 
            
              |   | 0c49ec2d | 2011-11-07T19:34:24 |  | Implement p_rename
Move the callers of git_futils_mv_atomic to use p_rename.
Signed-off-by: Carlos Martín Nieto <carlos@cmartin.tk> | 
            
              |   | 38068dc1 | 2011-11-07T06:27:49 |  | Merge pull request #473 from drafnel/bc/update-examples
bc/update examples | 
            
              |   | 3b83bdac | 2011-11-07T06:25:22 |  | Merge pull request #470 from schu/test-helpers-no-assert
test_helpers: do not rely on assert | 
            
              |   | f8e8c8d4 | 2011-11-07T04:38:12 |  | Merge pull request #472 from libgit2/new-references
References! References! References! | 
            
              |   | 0b142c9c | 2011-11-06T20:07:27 |  | examples/network/.gitignore: ignore 'git2' | 
            
              |   | 349532d0 | 2011-11-06T19:44:29 |  | examples/network/git2.c: exit with proper status, and avoid segfault
This function should exit after printing usage information if too few
arguments were specified.
Additionally, it should exit with a failure status if the first argument
supplied is not one in the internal command list. | 
            
              |   | 983562e4 | 2011-11-06T19:43:44 |  | examples/network/git2.c: add newline to usage message | 
            
              |   | faeebd06 | 2011-11-06T19:35:35 |  | examples/network/fetch.c: revert overzealous conversion of free to git__free
Since git__free is not exported (it's actually a macro), it should not be
used in client programs.  Change this call to 'git__free' back to 'free'. | 
            
              |   | 62dd6d16 | 2011-11-06T02:52:43 |  | reflog: Do not free references before time | 
            
              |   | d4a0b124 | 2011-10-30T21:58:33 |  | refs: Partial rewrite for read-only refs
This new version of the references code is significantly faster and
hopefully easier to read.
External API stays the same. A new method `git_reference_reload()` has
been added to force updating a memory reference from disk. In-memory
references are no longer updated automagically -- this was killing us.
If a reference is deleted externally and the user doesn't reload the
memory object, nothing critical happens: any functions using that
reference should fail gracefully (e.g. deletion, renaming, and so on).
All generated references from the API are read only and must be free'd
by the user. There is no reference counting and no traces of generated
references are kept in the library.
There is no longer an internal representation for references. There is
only one reference struct `git_reference`, and symbolic/oid targets are
stored inside an union.
Packfile references are stored using an optimized struct with flex array
for reference names. This should significantly reduce the memory cost of
loading the packfile from disk. | 
            
              |   | 549bbd13 | 2011-08-13T18:14:39 |  | git_reference_rename: cleanup reference renaming
git_reference_rename() didn't properly cleanup old references given by
the user to not break some ugly old tests. Since references don't point
to libgit's internal cache anymore we can cleanup git_reference_rename()
to be somewhat less messy.
Signed-off-by: schu <schu-github@schulog.org> | 
            
              |   | 75abd2b9 | 2011-08-11T19:38:13 |  | Free all used references in the source tree
Since references are not owned by the repository anymore we have to free
them manually now.
Signed-off-by: schu <schu-github@schulog.org> | 
            
              |   | 4fd89fa0 | 2011-07-26T11:17:32 |  | refs: add test case checking "immutable" references
Signed-off-by: schu <schu-github@schulog.org> | 
            
              |   | a46ec457 | 2011-08-10T16:19:42 |  | refs: split internal and external references
Currently libgit2 shares pointers to its internal reference cache with
the user. This leads to several problems like invalidation of reference
pointers when reordering the cache or manipulation of the cache from
user side.
Give each user its own git_reference instead of leaking the internal
representation (struct reference).
Add the following new API functions:
	* git_reference_free
	* git_reference_is_packed
Signed-off-by: schu <schu-github@schulog.org> | 
            
              |   | 54ccc717 | 2011-11-05T18:01:32 |  | examples/general.c: update for recent API renaming of git_config_get_int
git_config_get_int --> git_config_get_int32 | 
            
              |   | ec907944 | 2011-10-30T13:48:00 |  | test_helpers: do not rely on assert
The functions loose_object_mode and loose_object_dir_mode call stat
inside an assert statement which isn't evaluated when compiling in
Release mode (NDEBUG) and leads to failing tests. Replace it.
Signed-off-by: schu <schu-github@schulog.org> | 
            
              |   | d3104fa0 | 2011-10-29T14:06:36 |  | Merge pull request #468 from nulltoken/ntk/fix/issue-465
Status: fix segfault (#465) and order issues | 
            
              |   | e3baa3cc | 2011-10-29T17:45:01 |  | status: Fix a sorting issue in the treewalker
This ensures that entries from the working directory are retrieved according to the following rules:
 - The file "subdir" should appear before the file "subdir.txt"
 - The folder "subdir" should appear after the file "subdir.txt" | 
            
              |   | a1bd78ea | 2011-10-29T21:29:31 |  | status: Add a file in the test repository to cover the correct sorting of entries when the working folder is being read
In this case, "subdir.txt" should be listed before the "subdir" directory. | 
            
              |   | d1db74bf | 2011-10-29T17:40:04 |  | status: Prevent segfaulting when determining the status of a repository
Fixes #465 | 
            
              |   | 89fb8f02 | 2011-10-28T19:04:23 |  | Merge pull request #456 from brodie/perm-fixes
Create objects, indexes, and directories with the right file permissions | 
            
              |   | 3286c408 | 2011-10-28T14:51:13 |  | global: Properly use `git__` memory wrappers
Ensure that all memory related functions (malloc, calloc, strdup, free,
etc) are using their respective `git__` wrappers. | 
            
              |   | da37654d | 2011-10-27T22:33:31 |  | tree: Add traversal in post-order | 
            
              |   | 4849dbb8 | 2011-10-27T17:54:17 |  | Merge branch 'status' of https://github.com/carlosmn/libgit2 into development | 
            
              |   | 1ca715e0 | 2011-10-22T12:36:30 |  | status: move GIT_STATUS_PATH_* into an enum
Their actual values have no meaning, so pack them in an enum.
Signed-off-by: Carlos Martín Nieto <carlos@cmartin.tk> | 
            
              |   | 68a26dfa | 2011-10-22T12:33:49 |  | status: reorder retrieve_head_tree error checks
Signed-off-by: Carlos Martín Nieto <carlos@cmartin.tk> | 
            
              |   | c2892d61 | 2011-10-22T11:46:22 |  | status: remove git_tree_entry_bypos
The only caller has been changed to treat a NULL tree as a special
case and use the existing git_tree_entry_byindex.
Signed-off-by: Carlos Martín Nieto <carlos@cmartin.tk> | 
            
              |   | 899cb7a8 | 2011-10-22T11:36:18 |  | status: remove git_index_entry_bypos
This function is already implemented (better) as git_index_get. Change
the only caller to use that function.
Signed-off-by: Carlos Martín Nieto <carlos@cmartin.tk> | 
            
              |   | a2366c94 | 2011-10-27T15:33:53 |  | Merge pull request #467 from oleganza/oa-config-parse-fix
Fixed crash in config parser when empty value is encountered. | 
            
              |   | 9f861826 | 2011-10-27T16:45:44 |  | Fixed crash in config parser when empty value is encountered.
Example:
key1 = value1
key2 =
In this config the value will be a bad pointer which config object will attempt to free() causing a crash. | 
            
              |   | d533c888 | 2011-10-26T19:25:18 |  | Merge pull request #463 from schu/tests-clay-object-raw
tests-clay: move t01-rawobj.c to clay | 
            
              |   | 11d51ca6 | 2011-10-26T16:43:55 |  | windows: Add support for non-UTF codepages
Our previous assumption that all paths in Windows are encoded in UTF-8
is rather weak, specially when considering that Git is
encoding-agnostic.
These set of functions allow the user to change the library's active
codepage globally, so it is possible to access paths and files on all
international versions of Windows.
Note that the default encoding here is UTF-8 because we assume that 99%
of all Git repositories will be in UTF-8.
Also, if you use non-ascii characters in paths, anywhere, please burn on
a fire. | 
            
              |   | 9ff46db9 | 2011-10-19T13:48:51 |  | tests-clay: move t01-rawobj.c to clay
Signed-off-by: schu <schu-github@schulog.org> | 
            
              |   | c2fbe423 | 2011-10-24T14:43:18 |  | Merge pull request #464 from rtyley/development
Tolerate zlib deflation with window size < 32Kb | 
            
              |   | c51065e3 | 2011-10-24T14:39:03 |  | Tolerate zlib deflation with window size < 32Kb
libgit2 currently identifies loose objects as corrupt if they've been
deflated using a window size less than 32Kb, because the
is_zlib_compressed_data() function doesn't recognise the header
byte as a zlib header. This patch makes the method tolerant of
all valid window sizes (15-bit to 8-bit) - but doesn't sacrifice
it's accuracy in distingushing the standard loose-object format
from the experimental (now abandoned) format. It's based on a patch
which has been merged into C-Git master branch:
https://github.com/git/git/commit/7f684a2aff636f44a506
On memory constrained systems zlib may use a much smaller window
size - working on Agit, I found that Android uses a 4KB window;
giving a header byte of 0x48, not 0x78. Consequently all loose
objects generated by the Android platform appear 'corrupt' :(
It might appear that this patch changes isStandardFormat() to the
point where it could incorrectly identify the experimental format as
the standard one, but the two criteria (bitmask & checksum) can only
give a false result for an experimental object where both of the
following are true:
1) object size is exactly 8 bytes when uncompressed (bitmask)
2) [single-byte in-pack git type&size header] * 256
   + [1st byte of the following zlib header] % 31 = 0 (checksum)
As it happens, for all possible combinations of valid object type
(1-4) and window bits (0-7), the only time when the checksum will be
divisible by 31 is for 0x1838 - ie object type *1*, a Commit - which,
due the fields all Commit objects must contain, could never be as
small as 8 bytes in size.
Given this, the combination of the two criteria (bitmask & checksum)
always correctly determines the buffer format, and is more tolerant
than the previous version.
References:
Android uses a 4KB window for deflation:
http://android.git.kernel.org/?p=platform/libcore.git;a=blob;f=luni/src/main/native/java_util_zip_Deflater.cpp;h=c0b2feff196e63a7b85d97cf9ae5bb258
Code snippet searching for false positives with the zlib checksum:
https://gist.github.com/1118177
Change-Id: Ifd84cd2bd6b46f087c9984fb4cbd8309f483dec0 | 
            
              |   | 4ce16ed8 | 2011-10-22T12:25:55 |  | CMake: use -O0 in debug mode
Otherwise, GCC optimizes variables away and gdb can't tell us what's
in them.
Signed-off-by: Carlos Martín Nieto <carlos@cmartin.tk> | 
            
              |   | 28c1451a | 2011-10-20T02:35:19 |  | tree: Fix name lookups once and for all
Double-pass binary search. Jeez. | 
            
              |   | 8cf2de07 | 2011-10-19T01:34:42 |  | tree: Fix lookups by entry name | 
            
              |   | 5fa1bed0 | 2011-10-15T23:09:05 |  | mwindow: close LRU window properly
Remove a wrong call to git_mwindow_close which caused a segfault if it
ever did run. In that same piece of code, if the LRU was from the
first wiindow in the list in a different file, we didn't update that
list, so the first element had been freed.
Fix these two issues.
Signed-off-by: Carlos Martín Nieto <carlos@cmartin.tk> | 
            
              |   | a014a083 | 2011-10-14T16:32:00 |  | Merge pull request #459 from brodie/test-improvements
tests: propagate errors from open_temp_repo() instead of exiting | 
            
              |   | 252840a5 | 2011-08-11T15:18:04 |  | tests: propagate errors from open_temp_repo() instead of exiting
This makes it slightly easier to debug test failures when one test
opens a repo, has a failure, and doesn't get a chance to close it for
the next test. Now, instead of getting no feedback, we at least see
test failure information. | 
            
              |   | 01ad7b3a | 2011-09-06T15:48:45 |  | *: correct and codify various file permissions
The following files now have 0444 permissions:
- loose objects
- pack indexes
- pack files
- packs downloaded by fetch
- packs downloaded by the HTTP transport
And the following files now have 0666 permissions:
- config files
- repository indexes
- reflogs
- refs
This brings libgit2 more in line with Git.
Note that git_filebuf_commit() and git_filebuf_commit_at() have both
gained a new mode parameter.
The latter change fixes an important issue where filebufs created with
GIT_FILEBUF_TEMPORARY received 0600 permissions (due to mkstemp(3)
usage). Now we chmod() the file before renaming it into place.
Tests have been added to confirm that new commit, tag, and tree
objects are created with the right permissions. I don't have access to
Windows, so for now I've guarded the tests with "#ifndef GIT_WIN32". | 
            
              |   | ce8cd006 | 2011-09-07T15:32:44 |  | fileops/repository: create (most) directories with 0777 permissions
To further match how Git behaves, this change makes most of the
directories libgit2 creates in a git repo have a file mode of
0777. Specifically:
- Intermediate directories created with git_futils_mkpath2file() have
  0777 permissions. This affects odb_loose, reflog, and refs.
- The top level folder for bare repos is created with 0777
  permissions.
- The top level folder for non-bare repos is created with 0755
  permissions.
- /objects/info/, /objects/pack/, /refs/heads/, and /refs/tags/ are
  created with 0777 permissions.
Additionally, the following changes have been made:
- fileops functions that create intermediate directories have grown a
  new dirmode parameter. The only exception to this is filebuf's
  lock_file(), which unconditionally creates intermediate directories
  with 0777 permissions when GIT_FILEBUF_FORCE is set.
- The test runner now sets the umask to 0 before running any
  tests. This ensurses all file mode checks are consistent across
  systems.
- t09-tree.c now does a directory permissions check. I've avoided
  adding this check to other tests that might reuse existing
  directories from the prefabricated test repos. Because they're
  checked into the repo, they have 0755 permissions.
- Other assorted directories created by tests have 0777 permissions. | 
            
              |   | 33127043 | 2011-10-14T14:18:02 |  | fileops/posix: replace usage of "int mode" with "mode_t mode"
Note: Functions exported from fileops take const mode_t, while the
underlying POSIX wrappers take mode_t. | 
            
              |   | 1776f5ab | 2011-10-13T18:08:19 |  | Merge pull request #457 from khalsah/makefile-fix
Update Makefile.embed with http-parser dependency | 
            
              |   | d42eff03 | 2011-10-13T19:05:03 |  | Add src/transports to Makefile sources | 
            
              |   | 7fcddeb6 | 2011-10-13T18:36:43 |  | Update Makefile.embed with http-parser dependency | 
            
              |   | b7e1dd16 | 2011-10-13T14:54:12 |  | Merge pull request #448 from nulltoken/ntk/topic/treeentry-random-access
Add git_tree_frompath() |