1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325
|
-*- org -*-
#+TITLE: Guile-Git NEWS - history of user-visible changes
Copyright © 2018, 2019, 2020 Erik Edrosa
Copyright © 2021, 2024 Ludovic Courtès
Copying and distribution of this file, with or without modification,
are permitted in any medium without royalty provided the copyright
notice and this notice are preserved. This file is offered as-is,
without any warranty.
* Changes in 0.9.0 (since 0.8.0)
** New functionality
*** New procedures in =(git settings)=
Connection timeouts can now be queried with ~server-connection-timeout~
and ~server-timeout~, and configured with ~set-server-timeout!~ and
~set-server-connection-timeout!~. Note that these have no effect when
using libgit2 < 1.7.
Other new procedures to set global options include:
- ~user-agent~ and ~set-user-agent!~;
- ~user-agent-product~ and ~set-user-agent-product!~;
- ~home-directory~ and ~set-home-directory!~.
These procedures throw an exception when the underlying libgit2 is too
old and does not support them.
* Changes in 0.8.0 (since 0.7.0)
** New functionality
*** New procedures in =(git config)=
The module mow provides ~config-entry-backend-type~ and
~config-entry-origin-path~ which return, respectively, the type of
backend the config entry comes from and the name of the file it appears
in. This functionality requires libgit2 1.8 or later.
** Support for libgit2 1.8 added
** Support for Guile 2.0 dropped
* Changes in 0.7.0 (since 0.6.0)
** New functionality
*** New procedures in =(git config)=
The module now provides new procedures: ~set-config-string~,
~set-config-integer~, and ~set-config-boolean~ to modify or add
key/value pairs to a repository’s configuration file.
*** New ~repository-common-directory~ procedure
This procedure returns the shared common directory of a repository—the
one that contains the ~.git~ directory, in the presence of worktrees.
* Changes in 0.6.0 (since 0.5.2)
** Updated requirements
Guile-Git now requires libgit2 >= 1.3.0.
** New functionality
*** Support libgit2 up to 1.7.x
*** Support for checkout options
Checkout options can be created with ~make-checkout-options~ and passed
to ~checkout-head~, ~checkout-index~, etc.
*** New ~remote-connect/detached~ procedure
Lets you connect to a detached remote.
*** New ~(git ignore)~ module and ~ignored-file?~ procedure
The ~ignored-file?~ returns true when a file is ignored according to the
ignore rules.
*** New ~owner-validation?~ and ~set-owner-validation!~ procedures
These procedures let you query and set repository directory ownership
validation, which raises an error when attempting to access a repository
not owned by the current user.
*** New ~describe-checkout~ procedure
The procedure returns a pretty description of a checkout, similar to
the ~git describe~ command.
** Bug fixes
*** Always use native endianness when interpreting ~size_t~ pointers
(<https://gitlab.com/guile-git/guile-git/-/issues/20>)
*** Add missing argument to C call made by ~repository-index~
*** Clone-over-SSH tests now ignores =~/.ssh/known_hosts= validation
(<https://gitlab.com/guile-git/guile-git/-/issues/29>)
*** Fix various binary interface incompatibility issues
Running ~make check-abi~ now flags application binary interface (ABI)
issues.
* Changes in 0.5.2 (since 0.5.1)
** Bug fix
*** Fix crash when fetching multiple sub-modules
This bug was reported at <https://issues.guix.gnu.org/48855>. It could
lead to crashes via SIGSEGV or SIGILL while fetching multiple
sub-modules in a row.
* Changes in 0.5.1 (since 0.5.0)
** Bug fix
*** Fix crash when using ‘config-foreach’ or ‘config-fold’
This bug was reported at <https://issues.guix.gnu.org/47808>. It could
lead to segmentation faults in ~tests/config.scm~ while running ~make
check~.
* Changes in 0.5.0 (since 0.4.0)
** New functionality
*** New diff bindings in (git diff)
These bindings allow you to compute and print a diff between two
different trees.
*** New configuration parsing support in (git config)
This new module provides an interface to obtain configuration value as
you would do on with the ~git config~ command.
As a corollary, it introduces an incompatible change: the internal
module previously known as ~(git config)~ has been renamed to
~(git configuration)~. It is not meant to be used directly by
applications though, so you should not notice it.
*** New tag procedures: ‘tag-fold’, ‘tag-foreach’
*** New tree procedures: ‘tree-entry-byname’, ‘tree-entry-type’
*** New remote procedures: ‘remote-url’, ‘remote-set-url!’
*** Submodule interface changes
The ~submodule-update~ procedure accepts the new ~#:allow-fetch?~ and
~#:fetch-options~ arguments. The latter allows you to specify “fetch
options”, such as the URL of an HTTP/HTTPS proxy.
There’s also a new ~submodule-set-url!~ procedure.
** Bug fixes
*** commit: Prevent dangling repository references
https://gitlab.com/guile-git/guile-git/-/issues/21
*** Fix “make check” for tests involving SSH
* Changes in 0.4.0 (since 0.3.0)
** New Functionality
*** Support for HTTP and HTTPS proxies
One can now specify the HTTP and HTTPS via the ~#:proxy-url~ parameter
of ~make-fetch-options~. Those fetch options must then be passed to
~fetch~, or they can be added to the clone options passed to ~clone~.
*** Support for progress report
Clones and fetches can take some time and you may want to tell users
what’s going on. To help with that, ~make-fetch-options~ now takes a
~#:transfer-progress~ option; it should be either ~#f~ or a one-argument
procedure that will be called with an ~<indexer-progress>~ record every
time progress is made. This record contains information about the total
number of objects being processed, the number of objects already
retrieved, and the number of objects already indexed.
** Bug Fixes
*** Fix typo that made ~repository-index~ and ~repository-refdb~ unusable
* Changes in 0.3.0 (since 0.2.0)
** New Functionality
*** Add new (git tag) procedures
Four new procedures were added to (git tag) related to creating tags
in a git repository.
~tag-create~ and ~tag-create!~ are used to create what is known as
"annotated" tags in git which contain a creation date, creator's
signature, and a message. The ~tag-create!~ procedure can replace
existing references with the same name.
~tag-create-lightweight~ and ~tag-create-lightweight!~ are used to
create lightweight tags in git which just create a reference that
points directly to a git object.
*** Add (git signature) module
The (git signature) module adds three new procedures related to
signatures. Signatures are objects which identify a name, email, and
time that are found on many git objects. You would need to create a
signature if you want to use the ~tag-create~ procedure mentioned
above.
~signature-default~ creates a signature by looking up the ~user.name~
and ~user.email~ from the repository's configuration. It also uses the
current time.
~signature-new~ creates a signature with the passed in name, email,
time and timezone offset.
~signature-now~ creates a signature with the passed in name and
email. The time will use the current time.
*** Add (git describe) module
The (git describe) module adds several new procedures used to create
human readable names for objects based on an available references.
*** Support for Guile 3.0
Upgrade the configure script to be able to find Guile 3.0.
*** Add accessor and setter for the download tags of ~fetch-options~
The (git structs) module has added ~fetch-options-download-tags~ and
~set-fetch-options-download-tags!~ procedures for accessing and
setting the download tags field of ~fetch-options~. This field
determines the tag download policy when fetching from a remote.
*** Add ~CREDTYPE-*~ variables
(git cred) module has added several new variables which are used to
represent a bitmask for the supported credential types.
*** Add ssh authentication support
Add ssh auth support to ~clone~ and ~remote-fetch~ procedures with an
authentication method from the new module (git auth).
*** Add (git blob) module
(git blob) module adds several procedures for accessing and
interacting with blobs.
** Changes
*** ~repository-state~ return a symbols instead of an int
The ~repository-state~ procedure used to return an integer to
represent a state like none, merge, revert. It now returns the
following symbols based on the state of the repository
- ~repository-state/none~
- ~repository-state/merge~
- ~repository-state/revert~
- ~repository-state/revert-sequence~
- ~repository-state/cherrypick~
- ~repository-state/cherrypick-sequence~
- ~repository-state/bisect~
- ~repository-state/rebase~
- ~repository-state/rebase-interactive~
- ~repository-state/rebase-merge~
- ~repository-state/apply-mailbox~
- ~repository-state/apply-mailbox-or-rebase~
*** Rename ~foo-init-options~ procedures to be more idiomatic
Several procedures named like ~foo-init-options~ were renamed to be
more idiomatic like ~make-foo-options~. The previous functions are
deprecated and will be removed in a future version of Guile Git. The
functions renamed are:
- ~clone-init-options~ renamed to ~make-clone-options~
- ~fetch-init-options~ renamed to ~make-fetch-options~
- ~status-init-options~ renamed to ~make-status-options~
** Bug Fixes
* Changes in 0.2.0 (since 0.1.0)
** New Functionality
*** Add (git submodule) module
Add some initial bindings to libgit2's submodule functions. These
include ~git_submodule_name~, ~git_submodule_path~,
~git_submodule_owner~, ~git_submodule_head_id~,
~git_submodule_lookup~, ~git_submodule_init~, ~git_submodule_reload~,
~git_submodule_add_setup~, ~git_submodule_add_finalize~,
~git_submodule_add_to_index~, ~git_submodule_set_branch~, and
~git_submodule_update~.
** Bug fixes
*** Fix experience in REPL
When in the ~(git)~ module, you can use ~,use~ and ~,apropos~ in the
Guile REPL to get module and bindings in the module.
*** Correctly export ~repository-working-directory~
~(git repository)~ was exporting the incorrectly named
~repository-workdir~.
|