|   | 58e31a80 | 2022-06-27T18:47:02 |  | build with -Wwrite-strings
Throwing this into the mix for a while, we can always get rid of it
again if it becomes annoying.  No objections from stsp@ | 
            
              |   | bb6672b6 | 2022-04-14T11:51:32 |  | make sure callers of got_object_idset_add() free data. | 
            
              |   | c0df5966 | 2021-12-31T09:33:01 |  | wrap overlong lines | 
            
              |   | 00fe21f2 | 2021-12-31T09:11:21 |  | add "e" (close-on-exec) flag to fopen(3) calls
suggested by millert
ok thomas_adam | 
            
              |   | 42864987 | 2021-11-20T11:14:44 |  | fall back to comparison by name when refs have the same timestamp
This fixes an issue where some references were missing from lists of
references sorted by timestamp. | 
            
              |   | 2d497592 | 2021-11-20T10:40:33 |  | implement got_reflist_sort() which sorts a ref list in-place | 
            
              |   | 0309152a | 2021-11-20T10:39:04 |  | fix uninitialized error from got_ref_cmp_by_commit_timestamp_descending() | 
            
              |   | 7f66531d | 2021-11-16T14:33:26 |  | allow sorting references by timestamp in tog | 
            
              |   | 2c9e323b | 2021-10-10T19:26:26 |  | speed up 'got histedit -l' and 'got rebase -l'
Cache commit timestamps in struct got_reference in case we are sorting
references by commit timestamp. This avoids opening and closing commits
every time we compare two references with each other.
ok thomas.adam | 
            
              |   | 9dd14b99 | 2021-09-28T19:21:34 |  | got_sha1_digest_to_str() writes to char *
ok stsp | 
            
              |   | abc59930 | 2021-09-05T19:41:03 |  | indentation fixes | 
            
              |   | 63e5aa5c | 2021-08-23T10:51:48 |  | Expose got_ref_name_is_valid() for general purpose use.
This will be needed for a future 'got send' command. | 
            
              |   | cce2f485 | 2021-08-22T12:56:14 |  | expose got_ref_resolve_symbolic() at the public library API
This will be needed by a future 'got send' command. | 
            
              |   | 72acb3d8 | 2021-08-06T12:43:33 |  | remove unused 'repo' argument from got_reflist_insert() | 
            
              |   | 3f338f0a | 2021-07-27T13:08:51 |  | track the last modification time of references | 
            
              |   | 5345b4c7 | 2021-07-06T07:39:36 |  | allow lockfiles to be used in cases where we have a dir_fd and a relative path | 
            
              |   | 779e1159 | 2021-06-18T14:14:49 |  | expose the reflist_insert() helper function as got_reflist_insert()
This will be needed by 'gotadmin pack'. | 
            
              |   | 57c18198 | 2021-05-24T18:25:19 |  | validate reference names in open_ref()
This catches invalid reference names passed to 'got ref -l' and will also be
needed to validate reference names passed to a future 'gotadmin pack' command.
ok naddy@ | 
            
              |   | af8a5c4a | 2021-05-21T20:16:17 |  | plug a memory leak in got_ref_list_free()
Code which inserts a reference into a reflist passes ownership of
this reference to the list. However, got_ref_list_free() never
closed such references, which resulted in a memory leak.
ok tracey | 
            
              |   | e600f124 | 2021-03-21T19:09:35 |  | ensure that old commits remain referenced after rebase and histedit
Create automatic "backup" references which ensure that objects from
the pre-rebase or pre-histedit state remain in the repository.
A new -l option for 'got rebase' and 'got histedit' lists old commits.
This makes it easier to recover from botched rebase or histedit operations.
Removal of such objects currently requires got ref -d and git-gc.
This will be made more convenient in the future.
testing and ok jrick | 
            
              |   | 56b63ca4 | 2021-01-22T11:04:47 |  | make fclose(3) failure checks consistent; check 'fclose() == EOF' everywhere
ok millert, naddy | 
            
              |   | 7a90b680 | 2021-01-02T20:57:19 |  | oops, initialize linesize before calling getline(3); from millert | 
            
              |   | 9bdd68dd | 2021-01-02T20:46:01 |  | replace fparseln(3) with getline(3), for better portability
ok stsp | 
            
              |   | f0ff8d4c | 2020-12-26T23:14:26 |  | fix tag object leak introduced in previous commit | 
            
              |   | 24202e46 | 2020-12-26T23:08:51 |  | add tagged object IDs to reference list object ID map
Fixes display of "/tags/..." commit ID decorators in tog which was
broken in previous commits. | 
            
              |   | a53af95f | 2020-12-26T23:04:46 |  | fix error return from got_reflist_object_id_map_create() | 
            
              |   | f193b038 | 2020-12-26T22:39:55 |  | rename got_reflist_object_map_free to got_reflist_object_id_map_free | 
            
              |   | d9dff0e5 | 2020-12-26T21:32:01 |  | switch reflist to TAILQ; insert elements more efficiently for sorted input
ok naddy | 
            
              |   | 7b5b670e | 2020-12-25T21:38:17 |  | implement an object ID map for reference lists
ok naddy | 
            
              |   | 4c4ce67b | 2020-12-25T21:38:17 |  | fix assignment to wrong pointer in got_ref_dup()
ok naddy | 
            
              |   | 16aeacf7 | 2020-11-26T12:54:19 |  | use size_t for loop indices to avoid signedness warnings; from emaste@freebsd | 
            
              |   | 3818e3c4 | 2020-11-01T16:28:46 |  | convert all remaining instances of chmod(2) to fchmod(2)
ok stsp | 
            
              |   | a1c4175c | 2020-09-22T00:42:02 |  | there is no need to grab locks when opening refs in got_ref_delete() | 
            
              |   | 48cae60d | 2020-09-22T00:03:02 |  | make dangling symbolic references show up in 'got ref -l'
Storing a resolved ID for each reference list item was a bad idea.
This ID cannot be resolved if a symbolic references points to a reference
which does not exist. Such symrefs were skipped by got ref -l as a result.
Just let users of reference lists resolve the IDs as needed. | 
            
              |   | 2a104ff6 | 2020-09-21T23:37:54 |  | make 'got ref -d' delete both loose and packed representations of the reference | 
            
              |   | 81a12da5 | 2020-09-09T19:35:32 |  | do not rely on <zlib.h> to pull in <unistd.h>
ok stsp | 
            
              |   | 20ccae39 | 2020-07-21T14:19:32 |  | cope with directory entries returned from readdir(3) with type DT_UNKNOWN
Such directory entries need special handling to make our directory traversal
code work on filesystems that do not support the d_type optimization.
I found this problem because references stored in the refs/ directory were
not shown by 'got log' and 'tog log' when a repository is mounted over NFS.
helpful feedback + ok millert@ | 
            
              |   | d7b899ab | 2020-03-25T15:55:22 |  | fix got_ref_change_symref(); it changed the ref's name instead of its target | 
            
              |   | 75236079 | 2020-03-25T14:30:15 |  | handle refs/remotes/origin/HEAD properly; reported by Matthias aka _xhr_ | 
            
              |   | b2070a3f | 2020-03-22T14:21:07 |  | allow for limiting output of 'got ref -l' to a single ref or a namespace | 
            
              |   | e8a967e0 | 2020-03-21T22:44:07 |  | make replacing symrefs actually work in 'got fetch' | 
            
              |   | 9f142382 | 2020-03-21T22:06:00 |  | properly lock references when 'got fetch' needs to update them | 
            
              |   | f68a7890 | 2020-03-19T09:07:46 |  | make got_ref_list() work on a fresh repository created with got_repo_init() | 
            
              |   | 7fa81f88 | 2020-02-21T01:06:03 |  | allow 'got ref' to manipulate refs which do not have a slash in their name | 
            
              |   | d1f16636 | 2020-01-15T22:05:49 |  | move got_repo_cmp_tags() to got_ref_cmp_tags() | 
            
              |   | 56e0773d | 2019-11-28T02:32:58 |  | convert tree entries from SIMPLEQ to an array | 
            
              |   | c30018ad | 2019-10-21T09:04:57 |  | ignore empty files in refs directory; convert parse_ref_file() to getline(3) | 
            
              |   | 24b5452a | 2019-10-09T06:50:28 |  | show bad reference names in error messages to make such errors more clear | 
            
              |   | cdb8f1fa | 2019-08-28T18:50:20 |  | fix possible NULL deref in alloc_symref() | 
            
              |   | 6aeab596 | 2019-08-28T14:51:42 |  | fix deletion of branches stored in packed-refs
broken since 29606af7a3a58767bf817a38035490899609d13e | 
            
              |   | b8bad2ba | 2019-08-23T20:01:06 |  | make 'got tag -l' list tags by time stamp in descending order | 
            
              |   | 29606af7 | 2019-08-23T18:42:27 |  | allow got_ref_list() to restrict returned refs to a particular namespace | 
            
              |   | 29e86f7a | 2019-08-13T00:32:42 |  | introuce a hard limit on recursion through symbolic references | 
            
              |   | d572f586 | 2019-08-02T15:42:42 |  | eliminate strlen() calls during fileindex rb tree searches | 
            
              |   | 6e472252 | 2019-07-22T10:35:46 |  | remove pointless call to got_path_normalize() | 
            
              |   | aaf88317 | 2019-07-10T18:08:23 |  | introduce got_ref_alloc_symref() and got_ref_get_symref_target() | 
            
              |   | 0f148cb7 | 2019-05-13T17:28:57 |  | revert c191ed664f6c437ebc3e0c859c53e48b445401f1
'got ref' should only work with naked ref names;
implicitly putting things into 'refs/heads' is a job for
something like a 'got branch' command. | 
            
              |   | 6e472abb | 2019-05-13T17:27:39 |  | fix a segfault in got_ref_open() | 
            
              |   | aedda007 | 2019-05-13T17:09:11 |  | make open_ref() tolerate missing reference dirs and files | 
            
              |   | c191ed66 | 2019-05-13T17:08:16 |  | allow single-component reference names with got_ref_alloc() | 
            
              |   | 638f9024 | 2019-05-13T12:40:57 |  | rename got_error_prefix_errno() to got_error_from_errno() | 
            
              |   | f5c58ad1 | 2019-05-12T18:05:59 |  | fix leftover lockfiles from parse_ref_file() | 
            
              |   | a875589a | 2019-05-12T17:55:03 |  | fix locking of packed ref file in got_ref_open() | 
            
              |   | 0885ce8f | 2019-05-12T17:48:22 |  | handle well-known refs more obviously in got_ref_open() | 
            
              |   | 5b575c25 | 2019-05-12T17:45:10 |  | don't hide errors in got_ref_open() | 
            
              |   | 2f17228e | 2019-05-11T21:18:39 |  | lock branch reference file during 'got commit' to prevent a race | 
            
              |   | 656b1f76 | 2019-05-11T14:26:12 |  | while (1) -> for (;;) | 
            
              |   | 230a42bd | 2019-05-11T13:04:38 |  | got_error_from_errno -> got_error_prefix_errno
also add got_error_prefix_errno2 and got_error_prefix_errno3 which
should hopefully all be merged into a single function with variadic
args (but can't alloc mem) | 
            
              |   | 324d37e7 | 2019-05-11T09:14:30 |  | make got path APIs available to library consumers | 
            
              |   | b249b824 | 2019-05-09T13:47:59 |  | add APIs to change references | 
            
              |   | 57b6f99a | 2019-04-13T16:06:37 |  | handle non-existent reference in got_ref_resolve() error path | 
            
              |   | 598a8b91 | 2019-03-15T13:38:49 |  | implement support for packed refs in 'got ref -d' | 
            
              |   | 6249107b | 2019-03-15T13:35:47 |  | fix uninitialized variable in insert_ref() | 
            
              |   | 80d5fc1f | 2019-03-15T13:24:51 |  | use sizeof instead of SHA1_DIGEST_LENGTH in memcpy | 
            
              |   | 6fdbf7b0 | 2019-03-15T13:14:08 |  | better malloc size idiom in insert_ref() | 
            
              |   | c0a1c016 | 2019-03-15T13:11:20 |  | move assignment closer to check in parse_ref_file() | 
            
              |   | 505287be | 2019-03-15T13:06:47 |  | properly handle duplicates when calling insert_ref() | 
            
              |   | 27a1ed03 | 2019-03-15T12:59:35 |  | don't leak 'new' in insert_ref() | 
            
              |   | 0bb4abae | 2019-03-15T12:50:27 |  | better fparseln error handling and memory leak fix in got_ref_list() | 
            
              |   | 7ab0422a | 2019-03-15T12:49:08 |  | better foarseln() error handling in open_packed_ref() | 
            
              |   | c980e470 | 2019-03-15T12:47:15 |  | plug memleak in alloc_ref() | 
            
              |   | c53671d0 | 2019-03-15T12:45:56 |  | plug memleak in got_ref_resolve() | 
            
              |   | f9267c9a | 2019-03-15T11:09:41 |  | set an is_packed flag on refs parsed from packed-refs file | 
            
              |   | e09d28b1 | 2019-03-15T11:09:02 |  | plug two memory leaks when refs get closed | 
            
              |   | d1667f0d | 2019-03-11T20:22:28 |  | introduce got_path_dirname() | 
            
              |   | 5e1c9f23 | 2019-03-11T20:13:26 |  | fix dirname() usage errors around got_path_mkdir() | 
            
              |   | 49c7094f | 2019-03-11T20:02:10 |  | fix broken error checking in got_ref_write() | 
            
              |   | 0cd1c46a | 2019-03-11T18:07:33 |  | create references to base commits of got worktrees | 
            
              |   | e2e879a0 | 2019-03-11T16:58:21 |  | introduce got_ref_list_free() and use it in got and tog | 
            
              |   | 2d2e1378 | 2019-03-11T16:34:33 |  | add got_ref_delete(); only loose refs supported for now | 
            
              |   | 8fa2f096 | 2019-03-11T16:28:11 |  | fix off-by-one in fwrite() check in got_ref_write() | 
            
              |   | 0fd469ce | 2019-03-11T16:27:15 |  | make got_ref_write() work for refs which do not exist yet | 
            
              |   | 58908ed0 | 2019-03-11T16:25:39 |  | fix path construction with empty subdir in open_ref() | 
            
              |   | 9e672c74 | 2019-03-11T14:56:04 |  | implement got_ref_write() | 
            
              |   | f77a24b0 | 2019-03-11T14:20:46 |  | validate ref names | 
            
              |   | 5892cdd6 | 2019-03-10T16:17:12 |  | introduce got_ref_alloc() | 
            
              |   | fb43ecf1 | 2019-02-11T11:59:09 |  | check for errors from fclose() | 
            
              |   | e135804e | 2019-02-10T19:15:13 |  | make got_ref_open() search on-disk refs before packed-refs | 
            
              |   | 7a3c76f5 | 2019-02-05T14:41:20 |  | fix insert_ref() to provide ordering similar to path lists | 
            
              |   | 3ca16530 | 2019-02-04T18:48:07 |  | append to tail of reflist, not to the head of the list |