2023-04-11 15:41:57 +08:00
|
|
|
#ifndef EDITOR_H
|
|
|
|
#define EDITOR_H
|
|
|
|
|
2024-08-13 17:13:25 +08:00
|
|
|
struct repository;
|
2023-04-11 15:41:57 +08:00
|
|
|
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.
|
|
|
|
*/
|
2024-08-13 17:13:25 +08:00
|
|
|
int strbuf_edit_interactively(struct repository *r, struct strbuf *buffer,
|
|
|
|
const char *path, const char *const *env);
|
2023-04-11 15:41:57 +08:00
|
|
|
|
|
|
|
#endif
|