* [PATCH 2/2] ls-remote: create option to sort by versions
[not found] <[PATCH] ls-remote: create option to sort by versions>
@ 2018-04-02 3:23 ` Harald Nordgren
2018-04-02 20:07 ` [PATCH] ls-remote: create '--sort' option Harald Nordgren
1 sibling, 0 replies; 5+ messages in thread
From: Harald Nordgren @ 2018-04-02 3:23 UTC (permalink / raw)
To: git; +Cc: Harald Nordgren
Updating tests and documentation
Signed-off-by: Harald Nordgren <haraldnordgren@gmail.com>
---
Documentation/git-ls-remote.txt | 5 +++++
t/t5512-ls-remote.sh | 19 ++++++++++++++++++-
2 files changed, 23 insertions(+), 1 deletion(-)
diff --git a/Documentation/git-ls-remote.txt b/Documentation/git-ls-remote.txt
index 5f2628c8f..81c518a90 100644
--- a/Documentation/git-ls-remote.txt
+++ b/Documentation/git-ls-remote.txt
@@ -30,6 +30,11 @@ OPTIONS
both, references stored in refs/heads and refs/tags are
displayed.
+-V::
+--version-sort::
+ Sort ref names by version semantics, so that refs/tags/v1.2 is sorted
+ before refs/tags/v1.10.
+
--refs::
Do not show peeled tags or pseudorefs like HEAD in the output.
diff --git a/t/t5512-ls-remote.sh b/t/t5512-ls-remote.sh
index 02106c922..680a31223 100755
--- a/t/t5512-ls-remote.sh
+++ b/t/t5512-ls-remote.sh
@@ -10,6 +10,9 @@ test_expect_success setup '
test_tick &&
git commit -m initial &&
git tag mark &&
+ git tag mark1.1 &&
+ git tag mark1.2 &&
+ git tag mark1.10 &&
git show-ref --tags -d | sed -e "s/ / /" >expected.tag &&
(
echo "$(git rev-parse HEAD) HEAD"
@@ -39,6 +42,17 @@ test_expect_success 'ls-remote self' '
test_cmp expected.all actual
'
+test_expect_success 'ls-remote --version-sort --tags self' '
+ cat >expect <<-\EOF &&
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark1.1
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark1.2
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark1.10
+ EOF
+ git ls-remote --version-sort --tags self >actual &&
+ test_cmp expect actual
+'
+
test_expect_success 'dies when no remote specified and no default remotes found' '
test_must_fail git ls-remote
'
@@ -131,7 +145,7 @@ test_expect_success 'Report no-match with --exit-code' '
test_expect_success 'Report match with --exit-code' '
git ls-remote --exit-code other.git "refs/tags/*" >actual &&
- git ls-remote . tags/mark >expect &&
+ git ls-remote . tags/mark* >expect &&
test_cmp expect actual
'
@@ -178,6 +192,9 @@ test_expect_success 'ls-remote --symref' '
1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/remotes/origin/HEAD
1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/remotes/origin/master
1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark1.1
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark1.10
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark1.2
EOF
git ls-remote --symref >actual &&
test_cmp expect actual
--
2.14.3 (Apple Git-98)
^ permalink raw reply related [flat|nested] 5+ messages in thread
* [PATCH] ls-remote: create '--sort' option
[not found] <[PATCH] ls-remote: create option to sort by versions>
2018-04-02 3:23 ` [PATCH 2/2] ls-remote: create option to sort by versions Harald Nordgren
@ 2018-04-02 20:07 ` Harald Nordgren
2018-04-02 20:12 ` Junio C Hamano
2018-04-02 21:19 ` Jeff King
1 sibling, 2 replies; 5+ messages in thread
From: Harald Nordgren @ 2018-04-02 20:07 UTC (permalink / raw)
To: git; +Cc: Harald Nordgren
Create a '--sort' option for ls-remote. This is useful e.g. for the Go
repository after the release of version 1.10, where by default v1.10 is
sorted before v1.2. See:
$ git ls-remote -t https://go.googlesource.com/go
...
205f850ceacfc39d1e9d76a9569416284594ce8c refs/tags/go1.1
d260448f6b6ac10efe4ae7f6dfe944e72bc2a676 refs/tags/go1.1.1
1d6d8fca241bb611af51e265c1b5a2e9ae904702 refs/tags/go1.1.2
bf86aec25972f3a100c3aa58a6abcbcc35bdea49 refs/tags/go1.10
ac7c0ee26dda18076d5f6c151d8f920b43340ae3 refs/tags/go1.10.1
9ce6b5c2ed5d3d5251b9a6a0c548d5fb2c8567e8 refs/tags/go1.10beta1
594668a5a96267a46282ce3007a584ec07adf705 refs/tags/go1.10beta2
5348aed83e39bd1d450d92d7f627e994c2db6ebf refs/tags/go1.10rc1
20e228f2fdb44350c858de941dff4aea9f3127b8 refs/tags/go1.10rc2
1c5438aae896edcd1e9f9618f4776517f08053b3 refs/tags/go1.1rc2
46a6097aa7943a490e9bd2e04274845d0e5e200f refs/tags/go1.1rc3
402d3590b54e4a0df9fb51ed14b2999e85ce0b76 refs/tags/go1.2
9c9802fad57c1bcb72ea98c5c55ea2652efc5772 refs/tags/go1.2.1
...
Signed-off-by: Harald Nordgren <haraldnordgren@gmail.com>
---
Documentation/git-ls-remote.txt | 12 +++++++++++-
builtin/ls-remote.c | 27 +++++++++++++++++++++++++--
t/t5512-ls-remote.sh | 41 ++++++++++++++++++++++++++++++++++++++++-
3 files changed, 76 insertions(+), 4 deletions(-)
diff --git a/Documentation/git-ls-remote.txt b/Documentation/git-ls-remote.txt
index 5f2628c8f..17fae7218 100644
--- a/Documentation/git-ls-remote.txt
+++ b/Documentation/git-ls-remote.txt
@@ -10,7 +10,7 @@ SYNOPSIS
--------
[verse]
'git ls-remote' [--heads] [--tags] [--refs] [--upload-pack=<exec>]
- [-q | --quiet] [--exit-code] [--get-url]
+ [-q | --quiet] [--exit-code] [--get-url] [--sort=<key>]
[--symref] [<repository> [<refs>...]]
DESCRIPTION
@@ -60,6 +60,16 @@ OPTIONS
upload-pack only shows the symref HEAD, so it will be the only
one shown by ls-remote.
+--sort=<key>::
+ Sort based on the key given. Prefix `-` to sort in
+ descending order of the value. You may use the --sort=<key> option
+ multiple times, in which case the last key becomes the primary
+ key. Also supports "version:refname" or "v:refname" (tag
+ names are treated as versions). The "version:refname" sort
+ order can also be affected by the "versionsort.suffix"
+ configuration variable.
+ The keys supported are the same as those in `git for-each-ref`.
+
<repository>::
The "remote" repository to query. This parameter can be
either a URL or the name of a remote (see the GIT URLS and
diff --git a/builtin/ls-remote.c b/builtin/ls-remote.c
index 540d56429..5521c72f4 100644
--- a/builtin/ls-remote.c
+++ b/builtin/ls-remote.c
@@ -1,6 +1,7 @@
#include "builtin.h"
#include "cache.h"
#include "transport.h"
+#include "ref-filter.h"
#include "remote.h"
static const char * const ls_remote_usage[] = {
@@ -47,6 +48,8 @@ int cmd_ls_remote(int argc, const char **argv, const char *prefix)
struct remote *remote;
struct transport *transport;
const struct ref *ref;
+ struct ref_array array;
+ static struct ref_sorting *sorting = NULL, **sorting_tail = &sorting;
struct option options[] = {
OPT__QUIET(&quiet, N_("do not print remote URL")),
@@ -60,6 +63,8 @@ int cmd_ls_remote(int argc, const char **argv, const char *prefix)
OPT_BIT(0, "refs", &flags, N_("do not show peeled tags"), REF_NORMAL),
OPT_BOOL(0, "get-url", &get_url,
N_("take url.<base>.insteadOf into account")),
+ OPT_CALLBACK(0 , "sort", sorting_tail, N_("key"),
+ N_("field name to sort on"), &parse_opt_ref_sorting),
OPT_SET_INT_F(0, "exit-code", &status,
N_("exit with exit code 2 if no matching refs are found"),
2, PARSE_OPT_NOCOMPLETE),
@@ -68,6 +73,8 @@ int cmd_ls_remote(int argc, const char **argv, const char *prefix)
OPT_END()
};
+ memset(&array, 0, sizeof(array));
+
argc = parse_options(argc, argv, prefix, options, ls_remote_usage,
PARSE_OPT_STOP_AT_NON_OPTION);
dest = argv[0];
@@ -108,9 +115,25 @@ int cmd_ls_remote(int argc, const char **argv, const char *prefix)
continue;
if (!tail_match(pattern, ref->name))
continue;
+
+ struct ref_array_item *item;
+ FLEX_ALLOC_MEM(item, refname, ref->name, strlen(ref->name));
+ item->symref = ref->symref;
+ item->objectname = ref->old_oid;
+
+ REALLOC_ARRAY(array.items, array.nr + 1);
+ array.items[array.nr++] = item;
+ }
+
+ if (sorting) {
+ ref_array_sort(sorting, &array);
+ }
+
+ for (int i = 0; i < array.nr; i++) {
+ const struct ref_array_item *ref = array.items[i];
if (show_symref_target && ref->symref)
- printf("ref: %s\t%s\n", ref->symref, ref->name);
- printf("%s\t%s\n", oid_to_hex(&ref->old_oid), ref->name);
+ printf("ref: %s\t%s\n", ref->symref, ref->refname);
+ printf("%s\t%s\n", oid_to_hex(&ref->objectname), ref->refname);
status = 0; /* we found something */
}
return status;
diff --git a/t/t5512-ls-remote.sh b/t/t5512-ls-remote.sh
index 02106c922..66370cd88 100755
--- a/t/t5512-ls-remote.sh
+++ b/t/t5512-ls-remote.sh
@@ -10,6 +10,9 @@ test_expect_success setup '
test_tick &&
git commit -m initial &&
git tag mark &&
+ git tag mark1.1 &&
+ git tag mark1.2 &&
+ git tag mark1.10 &&
git show-ref --tags -d | sed -e "s/ / /" >expected.tag &&
(
echo "$(git rev-parse HEAD) HEAD"
@@ -39,6 +42,39 @@ test_expect_success 'ls-remote self' '
test_cmp expected.all actual
'
+test_expect_success 'ls-remote --sort="version:refname" --tags self' '
+ cat >expect <<-\EOF &&
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark1.1
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark1.2
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark1.10
+ EOF
+ git ls-remote --sort="version:refname" --tags self >actual &&
+ test_cmp expect actual
+'
+
+test_expect_success 'ls-remote --sort="-version:refname" --tags self' '
+ cat >expect <<-\EOF &&
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark1.10
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark1.2
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark1.1
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark
+ EOF
+ git ls-remote --sort="-version:refname" --tags self >actual &&
+ test_cmp expect actual
+'
+
+test_expect_success 'ls-remote --sort="-refname" --tags self' '
+ cat >expect <<-\EOF &&
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark1.2
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark1.10
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark1.1
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark
+ EOF
+ git ls-remote --sort="-refname" --tags self >actual &&
+ test_cmp expect actual
+'
+
test_expect_success 'dies when no remote specified and no default remotes found' '
test_must_fail git ls-remote
'
@@ -131,7 +167,7 @@ test_expect_success 'Report no-match with --exit-code' '
test_expect_success 'Report match with --exit-code' '
git ls-remote --exit-code other.git "refs/tags/*" >actual &&
- git ls-remote . tags/mark >expect &&
+ git ls-remote . tags/mark* >expect &&
test_cmp expect actual
'
@@ -178,6 +214,9 @@ test_expect_success 'ls-remote --symref' '
1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/remotes/origin/HEAD
1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/remotes/origin/master
1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark1.1
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark1.10
+ 1bd44cb9d13204b0fe1958db0082f5028a16eb3a refs/tags/mark1.2
EOF
git ls-remote --symref >actual &&
test_cmp expect actual
--
2.14.3 (Apple Git-98)
^ permalink raw reply related [flat|nested] 5+ messages in thread
* Re: [PATCH] ls-remote: create '--sort' option
2018-04-02 20:07 ` [PATCH] ls-remote: create '--sort' option Harald Nordgren
@ 2018-04-02 20:12 ` Junio C Hamano
2018-04-02 21:14 ` Harald Nordgren
2018-04-02 21:19 ` Jeff King
1 sibling, 1 reply; 5+ messages in thread
From: Junio C Hamano @ 2018-04-02 20:12 UTC (permalink / raw)
To: Harald Nordgren; +Cc: git
Harald Nordgren <haraldnordgren@gmail.com> writes:
> Subject: Re: [PATCH] ls-remote: create '--sort' option
It would be more helpful to mark as [PATCH v2] a rerolled patch like
this.
> Create a '--sort' option for ls-remote. This is useful e.g. for the Go
> repository after the release of version 1.10, where by default v1.10 is
> sorted before v1.2. See:
>
> $ git ls-remote -t https://go.googlesource.com/go
Does this sample command line also need updating for the refined
design?
> ...
> 205f850ceacfc39d1e9d76a9569416284594ce8c refs/tags/go1.1
> d260448f6b6ac10efe4ae7f6dfe944e72bc2a676 refs/tags/go1.1.1
> 1d6d8fca241bb611af51e265c1b5a2e9ae904702 refs/tags/go1.1.2
> bf86aec25972f3a100c3aa58a6abcbcc35bdea49 refs/tags/go1.10
> ac7c0ee26dda18076d5f6c151d8f920b43340ae3 refs/tags/go1.10.1
> ...
> + git ls-remote --sort="-version:refname" --tags self >actual &&
> + test_cmp expect actual
> +...
> + git ls-remote --sort="-refname" --tags self >actual &&
These both look sensible (also the variant without the dash prefix
which I omitted from the quote).
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] ls-remote: create '--sort' option
2018-04-02 20:12 ` Junio C Hamano
@ 2018-04-02 21:14 ` Harald Nordgren
0 siblings, 0 replies; 5+ messages in thread
From: Harald Nordgren @ 2018-04-02 21:14 UTC (permalink / raw)
To: Junio C Hamano; +Cc: git
I shortened the commit message. Since we already have this feature for
other sub-commands I guess I don't have to explain what version
semantics are.
Have to say I'm a bit confused about 'git send-mail'. This time I tried
git send-email --subject-prefix="PATCH v4"
--in-reply-to='20180402005248.52418-1-haraldnordgren@gmail.com'
--compose -1
...and the supplied 'git@vger.kernel.org' on the prompt. hopefully
everyone received the latest patches. However, at least what it looks
like from Gmail / Google Inbox, the discussion is now split into two
threads. Hopefully the patches still make sense though.
I will post replies to the original email chain after this message.
On Mon, Apr 2, 2018 at 10:12 PM, Junio C Hamano <gitster@pobox.com> wrote:
> Harald Nordgren <haraldnordgren@gmail.com> writes:
>
>> Subject: Re: [PATCH] ls-remote: create '--sort' option
>
> It would be more helpful to mark as [PATCH v2] a rerolled patch like
> this.
>
>> Create a '--sort' option for ls-remote. This is useful e.g. for the Go
>> repository after the release of version 1.10, where by default v1.10 is
>> sorted before v1.2. See:
>>
>> $ git ls-remote -t https://go.googlesource.com/go
>
> Does this sample command line also need updating for the refined
> design?
>
>> ...
>> 205f850ceacfc39d1e9d76a9569416284594ce8c refs/tags/go1.1
>> d260448f6b6ac10efe4ae7f6dfe944e72bc2a676 refs/tags/go1.1.1
>> 1d6d8fca241bb611af51e265c1b5a2e9ae904702 refs/tags/go1.1.2
>> bf86aec25972f3a100c3aa58a6abcbcc35bdea49 refs/tags/go1.10
>> ac7c0ee26dda18076d5f6c151d8f920b43340ae3 refs/tags/go1.10.1
>> ...
>> + git ls-remote --sort="-version:refname" --tags self >actual &&
>> + test_cmp expect actual
>> +...
>> + git ls-remote --sort="-refname" --tags self >actual &&
>
> These both look sensible (also the variant without the dash prefix
> which I omitted from the quote).
>
>
>
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] ls-remote: create '--sort' option
2018-04-02 20:07 ` [PATCH] ls-remote: create '--sort' option Harald Nordgren
2018-04-02 20:12 ` Junio C Hamano
@ 2018-04-02 21:19 ` Jeff King
1 sibling, 0 replies; 5+ messages in thread
From: Jeff King @ 2018-04-02 21:19 UTC (permalink / raw)
To: Harald Nordgren; +Cc: git
On Mon, Apr 02, 2018 at 10:07:36PM +0200, Harald Nordgren wrote:
> @@ -108,9 +115,25 @@ int cmd_ls_remote(int argc, const char **argv, const char *prefix)
> continue;
> if (!tail_match(pattern, ref->name))
> continue;
> +
> + struct ref_array_item *item;
We don't allow mixed declarations and code; this line needs to go at the
top of the block.
> + FLEX_ALLOC_MEM(item, refname, ref->name, strlen(ref->name));
> + item->symref = ref->symref;
> + item->objectname = ref->old_oid;
> +
> + REALLOC_ARRAY(array.items, array.nr + 1);
> + array.items[array.nr++] = item;
> + }
This will grow by one each time, which ends up doing quadratic work in
the number of items (although it can often be less if the realloc is
able to just extend the block). It should probably use ALLOC_GROW()
to move it more aggressively.
Interestingly, the ref-filter code itself seems to have the same
problem, but I couldn't measure any speedup. So either my analysis is
totally wrong, or we end up reusing the block most of the time in
practice.
> +
> + if (sorting) {
> + ref_array_sort(sorting, &array);
> + }
Minor style nit: we usually omit the braces for a one-liner block.
The ref-filter code lets you sort on any arbitrary field. So you could
do:
git ls-remote --sort=committerdate
What should that do?
With your patch, I think we'll just get something like:
fatal: missing object 468165c1d8a442994a825f3684528361727cd8c0 for HEAD
which is perhaps the best we can do (it might even work if you've
recently fetched from the other side).
-Peff
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2018-04-02 21:19 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
[not found] <[PATCH] ls-remote: create option to sort by versions>
2018-04-02 3:23 ` [PATCH 2/2] ls-remote: create option to sort by versions Harald Nordgren
2018-04-02 20:07 ` [PATCH] ls-remote: create '--sort' option Harald Nordgren
2018-04-02 20:12 ` Junio C Hamano
2018-04-02 21:14 ` Harald Nordgren
2018-04-02 21:19 ` Jeff King
Code repositories for project(s) associated with this public inbox
https://80x24.org/mirrors/git.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).