[PATCH v3 0/6] git_config callers rewritten with the new config cache API

2014-07-21 Thread Tanay Abhra
[PATCH v3]: Most of Eric's suggestions has been implemented. See [2] for 
discussion.
Also, new helpers introduced in v7 of the config-set API series have 
been used.
See [1] for the documentation of the new functions.

This series builds on the top of 5def4132 in pu or topic[1] in the mailing list
with name git config cache  special querying API utilizing the cache.

All patches pass every test, but there is a catch, there is slight behaviour
change in most of them where originally the callback returns
config_error_nonbool() when it sees a NULL value for a key causing a die
specified in git_parse_source in config.c.

The die also prints the file name and the line number as,

die(bad config file line %d in %s, cf-linenr, cf-name);

We lose the fine grained error checking when switching to this method.
Still, I will try to correct this anomaly in my next series.

[1]: http://thread.gmane.org/gmane.comp.version-control.git/253862
[2]: http://thread.gmane.org/gmane.comp.version-control.git/252334

Tanay Abhra (6):

 alias.c   | 27 +++
 branch.c  | 24 
 imap-send.c   | 41 +++--
 notes-utils.c | 33 -
 notes.c   | 21 +++--
 pager.c   | 40 +---
 6 files changed, 62 insertions(+), 124 deletions(-)

-- 
1.9.0.GIT

--
To unsubscribe from this list: send the line unsubscribe git in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH v3 0/6] git_config callers rewritten with the new config cache API

2014-07-21 Thread Matthieu Moy
Tanay Abhra tanay...@gmail.com writes:

 [PATCH v3]: Most of Eric's suggestions has been implemented. See [2] for 
 discussion.
   Also, new helpers introduced in v7 of the config-set API series have 
 been used.
   See [1] for the documentation of the new functions.

 This series builds on the top of 5def4132 in pu or topic[1] in the mailing 
 list
 with name git config cache  special querying API utilizing the cache.

It's now called ta/config-set (see last What's cooking in git.git).

 All patches pass every test, but there is a catch, there is slight behaviour
 change in most of them where originally the callback returns
 config_error_nonbool() when it sees a NULL value for a key causing a die
 specified in git_parse_source in config.c.

 The die also prints the file name and the line number as,

   die(bad config file line %d in %s, cf-linenr, cf-name);

 We lose the fine grained error checking when switching to this method.

I think a first step would be something like this:

--- a/config.c
+++ b/config.c
@@ -656,6 +656,15 @@ int git_config_string(const char **dest, const char *var, 
const char *value)
return 0;
 }
 
+// TODO: either make it static or export it properly
+int git_config_string_or_die(const char **dest, const char *var, const char 
*value)
+{
+   if (git_config_string(dest, var, value)  0)
+   die(bad config file (TODO: file/line info));
+   else
+   return 0;
+}
+
 int git_config_pathname(const char **dest, const char *var, const char *value)
 {
if (!value)
@@ -1336,7 +1345,7 @@ int git_configset_get_string(struct config_set *cs, const 
char *key, const char
 {
const char *value;
if (!git_configset_get_value(cs, key, value))
-   return git_config_string(dest, key, value);
+   return git_config_string_or_die(dest, key, value);
else
return 1;
 }

In the original API, git_config_string was called at parsing time, hence
the file/line information was available through cf. Here, we're
querying the cache which doesn't have this information yet.

I initially thought that managing properly file/line information would
be just an addition, but this example shows that it is actually needed
to be feature-complete wrt the old API. And I think we should be
feature-complete (i.e. make the code cleaner without harming the user).

So, I think it now makes sense to resurect your file line info patch:

  http://article.gmane.org/gmane.comp.version-control.git/253123

Now that the series is properly reviewed, avoid modifying existing
patches as much as possible, and add these file/line info on top of the
existing.

I think you need to:

1) Modify the hashmap data structure and the code that fills it in to
   store the file/line info (already done in your previous WIP patch).

2) Add a by-address parameter to git_configset_get_value that allows the
   user to get the file and line information. In your previous patch,
   that would mean returning a pointer to the corresponding struct
   key_source.

3) Pass this information to git_config_string_or_die, and die with the
   right message (with a helper like die_config(struct key_source *ks)
   that takes care of the formatting)

4) apply the same to git_config_get_other than string.

I'd actually add a step 0) before that: add a test that checks your
behavior change. The test should pass without your patches, and fail
with your current patch. Then, it should pass again once you completed
the work.

On a side note, re-reading your previous patch, I found this which
sounds suspicious:

+   struct config_hash_entry *e;
+   struct string_list_item *si;
+   struct key_source *ks = xmalloc(sizeof(*e));

Didn't you mean xmalloc(sizeof(*ks))?
^^

-- 
Matthieu Moy
http://www-verimag.imag.fr/~moy/
--
To unsubscribe from this list: send the line unsubscribe git in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH v3 0/6] git_config callers rewritten with the new config cache API

2014-07-21 Thread Tanay Abhra


On 7/21/2014 6:21 PM, Matthieu Moy wrote:
 Tanay Abhra tanay...@gmail.com writes:
 
 [PATCH v3]: Most of Eric's suggestions has been implemented. See [2] for 
 discussion.
  Also, new helpers introduced in v7 of the config-set API series have 
 been used.
  See [1] for the documentation of the new functions.

 This series builds on the top of 5def4132 in pu or topic[1] in the mailing 
 list
 with name git config cache  special querying API utilizing the cache.
 
 It's now called ta/config-set (see last What's cooking in git.git).


Noted. More below.

 All patches pass every test, but there is a catch, there is slight behaviour
 change in most of them where originally the callback returns
 config_error_nonbool() when it sees a NULL value for a key causing a die
 specified in git_parse_source in config.c.

 The die also prints the file name and the line number as,

  die(bad config file line %d in %s, cf-linenr, cf-name);

 We lose the fine grained error checking when switching to this method.
 
 I think a first step would be something like this:
 
 --- a/config.c
 +++ b/config.c
 @@ -656,6 +656,15 @@ int git_config_string(const char **dest, const char 
 *var, const char *value)
 return 0;
  }
  
 +// TODO: either make it static or export it properly
 +int git_config_string_or_die(const char **dest, const char *var, const char 
 *value)
 +{
 +   if (git_config_string(dest, var, value)  0)
 +   die(bad config file (TODO: file/line info));
 +   else
 +   return 0;
 +}
 +
  int git_config_pathname(const char **dest, const char *var, const char 
 *value)
  {
 if (!value)
 @@ -1336,7 +1345,7 @@ int git_configset_get_string(struct config_set *cs, 
 const char *key, const char
  {
 const char *value;
 if (!git_configset_get_value(cs, key, value))
 -   return git_config_string(dest, key, value);
 +   return git_config_string_or_die(dest, key, value);
 else
 return 1;
  }
 
 In the original API, git_config_string was called at parsing time, hence
 the file/line information was available through cf. Here, we're
 querying the cache which doesn't have this information yet.
 
 I initially thought that managing properly file/line information would
 be just an addition, but this example shows that it is actually needed
 to be feature-complete wrt the old API. And I think we should be
 feature-complete (i.e. make the code cleaner without harming the user).
 
 So, I think it now makes sense to resurect your file line info patch:
 
   http://article.gmane.org/gmane.comp.version-control.git/253123
 
 Now that the series is properly reviewed, avoid modifying existing
 patches as much as possible, and add these file/line info on top of the
 existing.
 
 I think you need to:
 
 1) Modify the hashmap data structure and the code that fills it in to
store the file/line info (already done in your previous WIP patch).
 
 2) Add a by-address parameter to git_configset_get_value that allows the
user to get the file and line information. In your previous patch,
that would mean returning a pointer to the corresponding struct
key_source.

Will this extra complexity be good for git_configset_get_value?
Instead can we provide a function like die_config(char *key)
which prints
die(bad config file line %d in %s, linenr, filename);?
A variation would be die_config_multi(char *key, char *value)
for multi valued keys.

 3) Pass this information to git_config_string_or_die, and die with the
right message (with a helper like die_config(struct key_source *ks)
that takes care of the formatting)

No need for passing if we use the above method. We will just call die_config()
inside it for NULL values

 4) apply the same to git_config_get_other than string.

 I'd actually add a step 0) before that: add a test that checks your
 behavior change. The test should pass without your patches, and fail
 with your current patch. Then, it should pass again once you completed
 the work.


Noted, I will add it.

 On a side note, re-reading your previous patch, I found this which
 sounds suspicious:
 
 + struct config_hash_entry *e;
 + struct string_list_item *si;
 + struct key_source *ks = xmalloc(sizeof(*e));
 
 Didn't you mean xmalloc(sizeof(*ks))?


Yikes, Thanks.
--
To unsubscribe from this list: send the line unsubscribe git in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH v3 0/6] git_config callers rewritten with the new config cache API

2014-07-21 Thread Matthieu Moy
Tanay Abhra tanay...@gmail.com writes:

 On 7/21/2014 6:21 PM, Matthieu Moy wrote:
 2) Add a by-address parameter to git_configset_get_value that allows the
user to get the file and line information. In your previous patch,
that would mean returning a pointer to the corresponding struct
key_source.

 Will this extra complexity be good for git_configset_get_value?
 Instead can we provide a function like die_config(char *key)
 which prints
   die(bad config file line %d in %s, linenr, filename);?

Where would you call this function, and where would you take linenr and
filename?

-- 
Matthieu Moy
http://www-verimag.imag.fr/~moy/
--
To unsubscribe from this list: send the line unsubscribe git in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH v3 0/6] git_config callers rewritten with the new config cache API

2014-07-21 Thread Tanay Abhra


On 7/21/2014 7:15 PM, Matthieu Moy wrote:
 Tanay Abhra tanay...@gmail.com writes:
 
 On 7/21/2014 6:21 PM, Matthieu Moy wrote:
 2) Add a by-address parameter to git_configset_get_value that allows the
user to get the file and line information. In your previous patch,
that would mean returning a pointer to the corresponding struct
key_source.

 Will this extra complexity be good for git_configset_get_value?
 Instead can we provide a function like die_config(char *key)
 which prints
  die(bad config file line %d in %s, linenr, filename);?
 
 Where would you call this function, and where would you take linenr and
 filename?


Usage can be like this,

if(!git_config_get_value(k, v)) {
if (!v) {
config_error_nonbool(k);
die_config(k);
/* die_config calls git_config_get_value_multi for 'k',
 * gets the string list with the util pointer containing
 * the linenr and the file name, dies printing the message.
 */
} else
/* do work */
}

Above example works just like the current code. Currently the callbacks
does not have the access to the linenr and file name anyway.
--
To unsubscribe from this list: send the line unsubscribe git in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH v3 0/6] git_config callers rewritten with the new config cache API

2014-07-21 Thread Matthieu Moy
Tanay Abhra tanay...@gmail.com writes:

 On 7/21/2014 7:15 PM, Matthieu Moy wrote:
 Tanay Abhra tanay...@gmail.com writes:
 
 On 7/21/2014 6:21 PM, Matthieu Moy wrote:
 2) Add a by-address parameter to git_configset_get_value that allows the
user to get the file and line information. In your previous patch,
that would mean returning a pointer to the corresponding struct
key_source.

 Will this extra complexity be good for git_configset_get_value?
 Instead can we provide a function like die_config(char *key)
 which prints
 die(bad config file line %d in %s, linenr, filename);?
 
 Where would you call this function, and where would you take linenr and
 filename?


 Usage can be like this,

 if(!git_config_get_value(k, v)) {
   if (!v) {
   config_error_nonbool(k);
   die_config(k);
   /* die_config calls git_config_get_value_multi for 'k',
* gets the string list with the util pointer containing
* the linenr and the file name, dies printing the message.
*/
   } else
   /* do work */
 }

OK, so you query the cache twice (which is OK, it's cheap and happens
just once before dying). That would work too.

-- 
Matthieu Moy
http://www-verimag.imag.fr/~moy/
--
To unsubscribe from this list: send the line unsubscribe git in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html