mirror of
https://github.com/mawww/kakoune.git
synced 2024-10-26 13:40:10 +03:00
Compare commits
5 Commits
cbca6f11ae
...
c5fb9b5178
Author | SHA1 | Date | |
---|---|---|---|
|
c5fb9b5178 | ||
|
e0bbd1e7ca | ||
|
8ca7b5815a | ||
|
0a10612786 | ||
|
07000adb9b |
@ -147,6 +147,11 @@ name. Hooks with no description will always use an empty string.
|
|||||||
*SessionRenamed* `<old name>:<new name>`::
|
*SessionRenamed* `<old name>:<new name>`::
|
||||||
executed when a session is renamed using the `rename-session` command
|
executed when a session is renamed using the `rename-session` command
|
||||||
|
|
||||||
|
*EnterDirectory* `path`::
|
||||||
|
executed on startup and when the current working directory is changed
|
||||||
|
using the `change-directory` command. The hook param is an absolute path
|
||||||
|
to the new working directory.
|
||||||
|
|
||||||
*RuntimeError* `error message`::
|
*RuntimeError* `error message`::
|
||||||
an error was encountered while executing a user command
|
an error was encountered while executing a user command
|
||||||
|
|
||||||
|
@ -75,7 +75,7 @@ hook global BufSetOption filetype=(html|xml) %{
|
|||||||
set-option buffer comment_block_end '-->'
|
set-option buffer comment_block_end '-->'
|
||||||
}
|
}
|
||||||
|
|
||||||
hook global BufSetOption filetype=(latex|mercury) %{
|
hook global BufSetOption filetype=(erlang|latex|mercury) %{
|
||||||
set-option buffer comment_line '%'
|
set-option buffer comment_line '%'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2600,13 +2600,15 @@ const CommandDesc change_directory_cmd = {
|
|||||||
cursor_pos, FilenameFlags::OnlyDirectories),
|
cursor_pos, FilenameFlags::OnlyDirectories),
|
||||||
Completions::Flags::Menu };
|
Completions::Flags::Menu };
|
||||||
}),
|
}),
|
||||||
[](const ParametersParser& parser, Context&, const ShellContext&)
|
[](const ParametersParser& parser, Context& ctx, const ShellContext&)
|
||||||
{
|
{
|
||||||
StringView target = parser.positional_count() == 1 ? StringView{parser[0]} : "~";
|
StringView target = parser.positional_count() == 1 ? StringView{parser[0]} : "~";
|
||||||
if (chdir(parse_filename(target).c_str()) != 0)
|
auto path = real_path(parse_filename(target));
|
||||||
|
if (chdir(path.c_str()) != 0)
|
||||||
throw runtime_error(format("unable to change to directory: '{}'", target));
|
throw runtime_error(format("unable to change to directory: '{}'", target));
|
||||||
for (auto& buffer : BufferManager::instance())
|
for (auto& buffer : BufferManager::instance())
|
||||||
buffer->update_display_name();
|
buffer->update_display_name();
|
||||||
|
ctx.hooks().run_hook(Hook::EnterDirectory, path, ctx);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -50,6 +50,7 @@ enum class Hook
|
|||||||
NextKeyIdle,
|
NextKeyIdle,
|
||||||
NormalKey,
|
NormalKey,
|
||||||
ModeChange,
|
ModeChange,
|
||||||
|
EnterDirectory,
|
||||||
RawKey,
|
RawKey,
|
||||||
RegisterModified,
|
RegisterModified,
|
||||||
WinClose,
|
WinClose,
|
||||||
@ -97,6 +98,7 @@ constexpr auto enum_desc(Meta::Type<Hook>)
|
|||||||
{Hook::NextKeyIdle, "NextKeyIdle"},
|
{Hook::NextKeyIdle, "NextKeyIdle"},
|
||||||
{Hook::NormalKey, "NormalKey"},
|
{Hook::NormalKey, "NormalKey"},
|
||||||
{Hook::ModeChange, "ModeChange"},
|
{Hook::ModeChange, "ModeChange"},
|
||||||
|
{Hook::EnterDirectory, "EnterDirectory"},
|
||||||
{Hook::RawKey, "RawKey"},
|
{Hook::RawKey, "RawKey"},
|
||||||
{Hook::RegisterModified, "RegisterModified"},
|
{Hook::RegisterModified, "RegisterModified"},
|
||||||
{Hook::WinClose, "WinClose"},
|
{Hook::WinClose, "WinClose"},
|
||||||
|
@ -842,6 +842,7 @@ int run_server(StringView session, StringView server_init,
|
|||||||
|
|
||||||
{
|
{
|
||||||
Context empty_context{Context::EmptyContextFlag{}};
|
Context empty_context{Context::EmptyContextFlag{}};
|
||||||
|
global_scope.hooks().run_hook(Hook::EnterDirectory, real_path("."), empty_context);
|
||||||
global_scope.hooks().run_hook(Hook::KakBegin, session, empty_context);
|
global_scope.hooks().run_hook(Hook::KakBegin, session, empty_context);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user