We implicitly rely on `the_repository` when editing a file interactively because we call `git_path()`. Adapt the function to instead take a `struct repository` as a parameter so that we can remove this hidden dependency. Signed-off-by: Patrick Steinhardt <ps@pks.im> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			36 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
#ifndef EDITOR_H
 | 
						|
#define EDITOR_H
 | 
						|
 | 
						|
struct repository;
 | 
						|
struct strbuf;
 | 
						|
 | 
						|
const char *git_editor(void);
 | 
						|
const char *git_sequence_editor(void);
 | 
						|
int is_terminal_dumb(void);
 | 
						|
 | 
						|
/**
 | 
						|
 * Launch the user preferred editor to edit a file and fill the buffer
 | 
						|
 * with the file's contents upon the user completing their editing. The
 | 
						|
 * third argument can be used to set the environment which the editor is
 | 
						|
 * run in. If the buffer is NULL the editor is launched as usual but the
 | 
						|
 * file's contents are not read into the buffer upon completion.
 | 
						|
 */
 | 
						|
int launch_editor(const char *path, struct strbuf *buffer,
 | 
						|
		  const char *const *env);
 | 
						|
 | 
						|
int launch_sequence_editor(const char *path, struct strbuf *buffer,
 | 
						|
			   const char *const *env);
 | 
						|
 | 
						|
/*
 | 
						|
 * In contrast to `launch_editor()`, this function writes out the contents
 | 
						|
 * of the specified file first, then clears the `buffer`, then launches
 | 
						|
 * the editor and reads back in the file contents into the `buffer`.
 | 
						|
 * Finally, it deletes the temporary file.
 | 
						|
 *
 | 
						|
 * If `path` is relative, it refers to a file in the `.git` directory.
 | 
						|
 */
 | 
						|
int strbuf_edit_interactively(struct repository *r, struct strbuf *buffer,
 | 
						|
			      const char *path, const char *const *env);
 | 
						|
 | 
						|
#endif
 |