 3b990aa645
			
		
	
	3b990aa645
	
	
	
		
			
			The previous commit added the necessary machinery to implement the
"--force-if-includes" protection, when "--force-with-lease" is used
without giving exact object the remote still ought to have. Surface
the feature by adding a command line option and a configuration
variable to enable it.
 - Add a flag: "TRANSPORT_PUSH_FORCE_IF_INCLUDES" to indicate that the
   new option was passed from the command line of via configuration
   settings; update command line and configuration parsers to set the
   new flag accordingly.
 - Introduce a new configuration option "push.useForceIfIncludes", which
   is equivalent to setting "--force-if-includes" in the command line.
 - Update "remote-curl" to recognize and pass this option to "send-pack"
   when enabled.
 - Update "advise" to catch the reject reason "REJECT_REF_NEEDS_UPDATE",
   set when the ref status is "REF_STATUS_REJECT_REMOTE_UPDATED" and
   (optionally) print a help message when the push fails.
 - The new option is a "no-op" in the following scenarios:
    * When used without "--force-with-lease".
    * When used with "--force-with-lease", and if the expected commit
      on the remote side is specified as an argument.
Signed-off-by: Srinidhi Kaushik <shrinidhi.kaushik@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
	
		
			
				
	
	
		
			98 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			98 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef ADVICE_H
 | |
| #define ADVICE_H
 | |
| 
 | |
| #include "git-compat-util.h"
 | |
| 
 | |
| extern int advice_fetch_show_forced_updates;
 | |
| extern int advice_push_update_rejected;
 | |
| extern int advice_push_non_ff_current;
 | |
| extern int advice_push_non_ff_matching;
 | |
| extern int advice_push_already_exists;
 | |
| extern int advice_push_fetch_first;
 | |
| extern int advice_push_needs_force;
 | |
| extern int advice_push_unqualified_ref_name;
 | |
| extern int advice_push_ref_needs_update;
 | |
| extern int advice_status_hints;
 | |
| extern int advice_status_u_option;
 | |
| extern int advice_status_ahead_behind_warning;
 | |
| extern int advice_commit_before_merge;
 | |
| extern int advice_reset_quiet_warning;
 | |
| extern int advice_resolve_conflict;
 | |
| extern int advice_sequencer_in_use;
 | |
| extern int advice_implicit_identity;
 | |
| extern int advice_detached_head;
 | |
| extern int advice_set_upstream_failure;
 | |
| extern int advice_object_name_warning;
 | |
| extern int advice_amworkdir;
 | |
| extern int advice_rm_hints;
 | |
| extern int advice_add_embedded_repo;
 | |
| extern int advice_ignored_hook;
 | |
| extern int advice_waiting_for_editor;
 | |
| extern int advice_graft_file_deprecated;
 | |
| extern int advice_checkout_ambiguous_remote_branch_name;
 | |
| extern int advice_submodule_alternate_error_strategy_die;
 | |
| extern int advice_add_ignored_file;
 | |
| extern int advice_add_empty_pathspec;
 | |
| 
 | |
| /*
 | |
|  * To add a new advice, you need to:
 | |
|  * Define a new advice_type.
 | |
|  * Add a new entry to advice_setting array.
 | |
|  * Add the new config variable to Documentation/config/advice.txt.
 | |
|  * Call advise_if_enabled to print your advice.
 | |
|  */
 | |
|  enum advice_type {
 | |
| 	ADVICE_ADD_EMBEDDED_REPO,
 | |
| 	ADVICE_AM_WORK_DIR,
 | |
| 	ADVICE_CHECKOUT_AMBIGUOUS_REMOTE_BRANCH_NAME,
 | |
| 	ADVICE_COMMIT_BEFORE_MERGE,
 | |
| 	ADVICE_DETACHED_HEAD,
 | |
| 	ADVICE_FETCH_SHOW_FORCED_UPDATES,
 | |
| 	ADVICE_GRAFT_FILE_DEPRECATED,
 | |
| 	ADVICE_IGNORED_HOOK,
 | |
| 	ADVICE_IMPLICIT_IDENTITY,
 | |
| 	ADVICE_NESTED_TAG,
 | |
| 	ADVICE_OBJECT_NAME_WARNING,
 | |
| 	ADVICE_PUSH_ALREADY_EXISTS,
 | |
| 	ADVICE_PUSH_FETCH_FIRST,
 | |
| 	ADVICE_PUSH_NEEDS_FORCE,
 | |
| 	ADVICE_PUSH_NON_FF_CURRENT,
 | |
| 	ADVICE_PUSH_NON_FF_MATCHING,
 | |
| 	ADVICE_PUSH_UNQUALIFIED_REF_NAME,
 | |
| 	ADVICE_PUSH_UPDATE_REJECTED_ALIAS,
 | |
| 	ADVICE_PUSH_UPDATE_REJECTED,
 | |
| 	ADVICE_PUSH_REF_NEEDS_UPDATE,
 | |
| 	ADVICE_RESET_QUIET_WARNING,
 | |
| 	ADVICE_RESOLVE_CONFLICT,
 | |
| 	ADVICE_RM_HINTS,
 | |
| 	ADVICE_SEQUENCER_IN_USE,
 | |
| 	ADVICE_SET_UPSTREAM_FAILURE,
 | |
| 	ADVICE_STATUS_AHEAD_BEHIND_WARNING,
 | |
| 	ADVICE_STATUS_HINTS,
 | |
| 	ADVICE_STATUS_U_OPTION,
 | |
| 	ADVICE_SUBMODULE_ALTERNATE_ERROR_STRATEGY_DIE,
 | |
| 	ADVICE_WAITING_FOR_EDITOR,
 | |
| };
 | |
| 
 | |
| int git_default_advice_config(const char *var, const char *value);
 | |
| __attribute__((format (printf, 1, 2)))
 | |
| void advise(const char *advice, ...);
 | |
| 
 | |
| /**
 | |
|  * Checks if advice type is enabled (can be printed to the user).
 | |
|  * Should be called before advise().
 | |
|  */
 | |
| int advice_enabled(enum advice_type type);
 | |
| 
 | |
| /**
 | |
|  * Checks the visibility of the advice before printing.
 | |
|  */
 | |
| void advise_if_enabled(enum advice_type type, const char *advice, ...);
 | |
| 
 | |
| int error_resolve_conflict(const char *me);
 | |
| void NORETURN die_resolve_conflict(const char *me);
 | |
| void NORETURN die_conclude_merge(void);
 | |
| void detach_advice(const char *new_name);
 | |
| 
 | |
| #endif /* ADVICE_H */
 |