mirror of
				https://git.proxmox.com/git/libgit2
				synced 2025-10-26 20:32:14 +00:00 
			
		
		
		
	config: allow setting multivars when none exist yet
Adding a multivar when there are no variables with that name set should set the variable instead of failing.
This commit is contained in:
		
							parent
							
								
									8f24e65ff6
								
							
						
					
					
						commit
						e5a27f039e
					
				| @ -481,8 +481,10 @@ static int config_set_multivar( | ||||
| 
 | ||||
| 	pos = git_strmap_lookup_index(b->values, key); | ||||
| 	if (!git_strmap_valid_index(b->values, pos)) { | ||||
| 		/* If we don't have it, behave like a normal set */ | ||||
| 		result = config_set(cfg, name, value); | ||||
| 		git__free(key); | ||||
| 		return GIT_ENOTFOUND; | ||||
| 		return result; | ||||
| 	} | ||||
| 
 | ||||
| 	var = git_strmap_value_at(b->values, pos); | ||||
|  | ||||
| @ -97,6 +97,22 @@ void test_config_multivar__add(void) | ||||
| 	git_config_free(cfg); | ||||
| } | ||||
| 
 | ||||
| void test_config_multivar__add_new(void) | ||||
| { | ||||
| 	const char *var = "a.brand.new"; | ||||
| 	git_config *cfg; | ||||
| 	int n; | ||||
| 
 | ||||
| 	cl_git_pass(git_config_open_ondisk(&cfg, "config/config11")); | ||||
| 
 | ||||
| 	cl_git_pass(git_config_set_multivar(cfg, var, "", "variable")); | ||||
| 	n = 0; | ||||
| 	cl_git_pass(git_config_get_multivar(cfg, var, NULL, cb, &n)); | ||||
| 	cl_assert(n == 1); | ||||
| 
 | ||||
| 	git_config_free(cfg); | ||||
| } | ||||
| 
 | ||||
| void test_config_multivar__replace(void) | ||||
| { | ||||
| 	git_config *cfg; | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Carlos Martín Nieto
						Carlos Martín Nieto