From: Teodor Sigaev Date: Mon, 28 Mar 2016 16:32:13 +0000 (+0300) Subject: psql tab-complete for CREATE/DROP ACCESS METHOD X-Git-Tag: REL9_6_BETA1~373 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=559e7a0a6d4450c09825055e3d255d30ee869c67;p=postgresql psql tab-complete for CREATE/DROP ACCESS METHOD Alexander Korotkov --- diff --git a/src/bin/psql/tab-complete.c b/src/bin/psql/tab-complete.c index 6a81416ed1..eb592bb395 100644 --- a/src/bin/psql/tab-complete.c +++ b/src/bin/psql/tab-complete.c @@ -877,6 +877,7 @@ typedef struct #define THING_NO_SHOW (THING_NO_CREATE | THING_NO_DROP) static const pgsql_thing_t words_after_create[] = { + {"ACCESS METHOD", NULL, NULL}, {"AGGREGATE", NULL, &Query_for_list_of_aggregates}, {"CAST", NULL, NULL}, /* Casts have complex structures for names, so * skip it */ @@ -1977,6 +1978,17 @@ psql_completion(const char *text, int start, int end) COMPLETE_WITH_LIST5("HEADER", "QUOTE", "ESCAPE", "FORCE QUOTE", "FORCE NOT NULL"); + /* CREATE ACCESS METHOD */ + /* Complete "CREATE ACCESS METHOD " */ + else if (Matches4("CREATE", "ACCESS", "METHOD", MatchAny)) + COMPLETE_WITH_CONST("TYPE"); + /* Complete "CREATE ACCESS METHOD TYPE" */ + else if (Matches5("CREATE", "ACCESS", "METHOD", MatchAny, "TYPE")) + COMPLETE_WITH_CONST("INDEX"); + /* Complete "CREATE ACCESS METHOD TYPE " */ + else if (Matches6("CREATE", "ACCESS", "METHOD", MatchAny, "TYPE", MatchAny)) + COMPLETE_WITH_CONST("HANDLER"); + /* CREATE DATABASE */ else if (Matches3("CREATE", "DATABASE", MatchAny)) COMPLETE_WITH_LIST9("OWNER", "TEMPLATE", "ENCODING", "TABLESPACE", @@ -2263,6 +2275,7 @@ psql_completion(const char *text, int start, int end) else if (Matches3("DROP", "COLLATION|CONVERSION|DOMAIN|EXTENSION|LANGUAGE|SCHEMA|SEQUENCE|SERVER|TABLE|TYPE|VIEW", MatchAny) || + Matches4("DROP", "ACCESS", "METHOD", MatchAny) || (Matches4("DROP", "AGGREGATE|FUNCTION", MatchAny, MatchAny) && ends_with(prev_wd, ')')) || Matches4("DROP", "EVENT", "TRIGGER", MatchAny) ||