psql / tab-completion.c : patch proposals

From: Ian Barwick <barwick(at)gmx(dot)net>
To: pgsql-patches(at)postgresql(dot)org
Subject: psql / tab-completion.c : patch proposals
Date: 2003-03-24 00:11:33
Message-ID: 200303240111.33838.barwick@gmx.net
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-patches

Attached are two patches for psql's tab-completion.c.

The first cleans up a couple of minor errors and ommissions
and adds tab completion support to more slash commands, e.g.
\dv.

The second is an attempt to add tab completion for schemas
and fully qualified relation names (e.g. public.mytable ).
I think this covers the TODO-item:
"Allow psql to do table completion for SELECT * FROM schema_part and table
completion for SELECT * FROM schema_name."

This happens via union selects querying:
- relation_name in current search path;
- schema_name;
- schema.relation_name
matching the current input string.

E.g:
SELECT p[TAB]
will produce a list of all appropriate relation names in the current search
path which begin with 'p', and also all schema names which begin with 'p';
\d pub[TAB]
will produce any relation names in the current search path and also
any schema names beginning with 'pub';
\d public.[TAB]
will produce a list of all relations in the schema 'public';
\d public.my[TAB]
produces all relation names beginning with 'my' in schema 'public'.

It seems to work for me; comments, suggestions, particularly regarding
the coding and queries, are very welcome.

Note that tables, indexes, views and sequences relations in the
'pg_catalog' namespace are excluded even though they are in
the current search path. I found not doing this produced annoying behaviour
when expanding names beginning with 'p'. People who work with system
tables a lot may not like this though; I can look for another solution
if necessary.

The second patch must be applied after the first patch; it will not
apply against CVS. Can supply one big patch but feel it more sensible
to break up the changes into more digestible units.

Ian Barwick
barwick(at)gmx(dot)net

Attachment Content-Type Size
tab-complete.c.diff.1 text/x-diff 16.7 KB
tab-complete.c.diff.2 text/x-diff 35.6 KB

Responses

Browse pgsql-patches by date

  From Date Subject
Next Message Christopher Kings-Lynne 2003-03-24 03:28:23 Doc patch for func.sgml
Previous Message Kevin Brown 2003-03-23 23:30:04 Re: SQL99 ARRAY support proposal