rabbitmq-server/deps/rabbitmq_cli/lib/rabbitmq/cli/auto_complete.ex

95 lines
2.8 KiB
Elixir
Raw Normal View History

2016-07-29 00:46:37 +08:00
## The contents of this file are subject to the Mozilla Public License
## Version 1.1 (the "License"); you may not use this file except in
## compliance with the License. You may obtain a copy of the License
## at http://www.mozilla.org/MPL/
##
## Software distributed under the License is distributed on an "AS IS"
## basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
## the License for the specific language governing rights and
## limitations under the License.
##
## The Original Code is RabbitMQ.
##
## The Initial Developer of the Original Code is GoPivotal, Inc.
2019-01-20 11:10:59 +08:00
## Copyright (c) 2007-2019 Pivotal Software, Inc. All rights reserved.
2016-07-29 00:46:37 +08:00
2016-11-15 01:52:08 +08:00
defmodule Rabbitmq.CLI.AutoComplete do
2018-07-23 13:06:18 +08:00
alias RabbitMQ.CLI.Core.{CommandModules, Parser}
2016-07-29 00:46:37 +08:00
@spec complete(String.t, [String.t]) :: [String.t]
def complete(_, []) do
[]
end
def complete(script_name, args) do
case Parser.parse_global(args) do
{_, %{script_name: _args_script_name}, _} ->
complete(args);
_ ->
complete(["--script-name", script_name | args])
2016-07-29 00:46:37 +08:00
end
end
defp complete(tokens) do
{command, command_name, _, _, _} = Parser.parse(tokens)
last_token = List.last(tokens)
case {command, command_name} do
## No command provided
{_, ""} -> complete_default_opts(last_token);
## Command is not found/incomplete
{:no_command, command_name} ->
complete_command_name(command_name);
{{:suggest, _}, command_name} ->
complete_command_name(command_name);
## Command is found
{command, _} ->
complete_command_opts(command, last_token)
end
|> Enum.sort
end
defp complete_default_opts(opt) do
2016-07-29 00:46:37 +08:00
Parser.default_switches
|> Keyword.keys
|> Enum.map(fn(sw) -> "--" <> to_string(sw) end)
|> select_starts_with(opt)
|> format_options
2016-07-29 00:46:37 +08:00
end
defp complete_command_name(command_name) do
module_map = CommandModules.module_map
case module_map[command_name] do
nil ->
module_map
2016-07-29 00:46:37 +08:00
|> Map.keys
|> select_starts_with(command_name)
_ ->
command_name
2016-07-29 00:46:37 +08:00
end
end
defp complete_command_opts(command, <<"-", _ :: binary>> = opt) do
2016-07-29 00:46:37 +08:00
switches = command.switches
|> Keyword.keys
|> Enum.map(fn(sw) -> "--" <> to_string(sw) end)
# aliases = command.aliases
# |> Keyword.keys
# |> Enum.map(fn(al) -> "-" <> to_string(al) end)
select_starts_with(switches, opt)
|> format_options
2016-07-29 00:46:37 +08:00
end
defp complete_command_opts(_, _) do
2016-07-29 00:46:37 +08:00
[]
end
defp select_starts_with(list, prefix) do
Enum.filter(list, fn(el) -> String.starts_with?(el, prefix) end)
end
defp format_options(options) do
options
|> Enum.map(fn(opt) -> String.replace(opt, "_", "-") end)
end
2017-01-10 22:42:40 +08:00
end