Skip to content

edit [target...]

Edit the source state of targets, which must be files or symlinks. If no targets are given then the working tree of the source directory is opened.

Encrypted files are decrypted to a private temporary directory and the editor is invoked with the decrypted file. When the editor exits the edited decrypted file is re-encrypted and replaces the original file in the source state.

If the operating system supports hard links, then the edit command invokes the editor with filenames which match the target filename, unless the edit.hardlink configuration variable is set to false or the --hardlink=false command line flag is set.

Flags

-a, --apply

Configuration: edit.apply

Apply target immediately after editing. Ignored if there are no targets.

Configuration: edit.hardlink

Invoke the editor with a hard link to the source file with a name matching the target filename. This can help the editor determine the type of the file correctly. This is the default.

--watch

Configuration: edit.watch

Automatically apply changes when files are saved, with the following limitations:

  • Only available when chezmoi edit is invoked with arguments (i.e. argument-free chezmoi edit is not supported).
  • All edited files are applied when any file is saved.
  • Only the edited files are watched, not any dependent files (e.g. .chezmoitemplates and included files in templates are not watched).
  • Only works on operating systems supported by fsnotify.

Common flags

-x, --exclude types

Exclude target state entries of specific types. The default is none.

Types can be explicitly included with the --include flag.

Example

--exclude=scripts will cause the command to not run scripts and --exclude=encrypted will exclude encrypted files.

-i, --include types

Include target state entries of specific types. The default is all.

Types can be explicitly excluded with the --exclude flag.

Example

--include=files specifies all files.

--init

Regenerate and reload the config file from its template before computing the target state.

Examples

$ chezmoi edit ~/.bashrc
$ chezmoi edit ~/.bashrc --apply
$ chezmoi edit