mirror of
git://git.code.sf.net/p/zsh/code
synced 2025-01-01 05:16:05 +01:00
468 lines
16 KiB
C
468 lines
16 KiB
C
/*
|
|
* comp.h - header file for completion
|
|
*
|
|
* This file is part of zsh, the Z shell.
|
|
*
|
|
* Copyright (c) 1992-1997 Paul Falstad
|
|
* All rights reserved.
|
|
*
|
|
* Permission is hereby granted, without written agreement and without
|
|
* license or royalty fees, to use, copy, modify, and distribute this
|
|
* software and to distribute modified versions of this software for any
|
|
* purpose, provided that the above copyright notice and the following
|
|
* two paragraphs appear in all copies of this software.
|
|
*
|
|
* In no event shall Paul Falstad or the Zsh Development Group be liable
|
|
* to any party for direct, indirect, special, incidental, or consequential
|
|
* damages arising out of the use of this software and its documentation,
|
|
* even if Paul Falstad and the Zsh Development Group have been advised of
|
|
* the possibility of such damage.
|
|
*
|
|
* Paul Falstad and the Zsh Development Group specifically disclaim any
|
|
* warranties, including, but not limited to, the implied warranties of
|
|
* merchantability and fitness for a particular purpose. The software
|
|
* provided hereunder is on an "as is" basis, and Paul Falstad and the
|
|
* Zsh Development Group have no obligation to provide maintenance,
|
|
* support, updates, enhancements, or modifications.
|
|
*
|
|
*/
|
|
|
|
typedef struct cmatcher *Cmatcher;
|
|
typedef struct cmlist *Cmlist;
|
|
typedef struct cpattern *Cpattern;
|
|
typedef struct menuinfo *Menuinfo;
|
|
typedef struct cexpl *Cexpl;
|
|
typedef struct cmgroup *Cmgroup;
|
|
typedef struct cmatch *Cmatch;
|
|
|
|
/* This is for explantion strings. */
|
|
|
|
struct cexpl {
|
|
int always; /* display even without matches */
|
|
char *str; /* the string */
|
|
int count; /* the number of matches */
|
|
int fcount; /* number of matches with fignore ignored */
|
|
};
|
|
|
|
/* This describes a group of matches. */
|
|
|
|
struct cmgroup {
|
|
char *name; /* the name of this group */
|
|
Cmgroup prev; /* previous on the list */
|
|
Cmgroup next; /* next one in list */
|
|
int flags; /* see CGF_* below */
|
|
int mcount; /* number of matches */
|
|
Cmatch *matches; /* the matches */
|
|
int lcount; /* number of things to list here */
|
|
int llcount; /* number of line-displays */
|
|
char **ylist; /* things to list */
|
|
int ecount; /* number of explanation string */
|
|
Cexpl *expls; /* explanation strings */
|
|
int ccount; /* number of compctls used */
|
|
LinkList lexpls; /* list of explanation string while building */
|
|
LinkList lmatches; /* list of matches */
|
|
LinkList lfmatches; /* list of matches without fignore */
|
|
LinkList lallccs; /* list of used compctls */
|
|
int num; /* number of this group */
|
|
int nbrbeg; /* number of opened braces */
|
|
int nbrend; /* number of closed braces */
|
|
int new; /* new matches since last permalloc() */
|
|
/* The following is collected/used during listing. */
|
|
int dcount; /* number of matches to list in columns */
|
|
int cols; /* number of columns */
|
|
int lins; /* number of lines */
|
|
int width; /* column width */
|
|
int *widths; /* column widths for listpacked */
|
|
int totl; /* total length */
|
|
int shortest; /* length of shortest match */
|
|
Cmgroup perm; /* perm. alloced version of this group */
|
|
#ifdef ZSH_HEAP_DEBUG
|
|
Heapid heap_id;
|
|
#endif
|
|
};
|
|
|
|
|
|
#define CGF_NOSORT 1 /* don't sort this group */
|
|
#define CGF_LINES 2 /* these are to be printed on different lines */
|
|
#define CGF_HASDL 4 /* has display strings printed on separate lines */
|
|
#define CGF_UNIQALL 8 /* remove all duplicates */
|
|
#define CGF_UNIQCON 16 /* remove consecutive duplicates */
|
|
#define CGF_PACKED 32 /* LIST_PACKED for this group */
|
|
#define CGF_ROWS 64 /* LIST_ROWS_FIRST for this group */
|
|
#define CGF_FILES 128 /* contains file names */
|
|
|
|
/* This is the struct used to hold matches. */
|
|
|
|
struct cmatch {
|
|
char *str; /* the match itself */
|
|
char *orig; /* the match string unquoted */
|
|
char *ipre; /* ignored prefix, has to be re-inserted */
|
|
char *ripre; /* ignored prefix, unquoted */
|
|
char *isuf; /* ignored suffix */
|
|
char *ppre; /* the path prefix */
|
|
char *psuf; /* the path suffix */
|
|
char *prpre; /* path prefix for opendir */
|
|
char *pre; /* prefix string from -P */
|
|
char *suf; /* suffix string from -S */
|
|
char *disp; /* string to display (compadd -d) */
|
|
char *autoq; /* closing quote to add automatically */
|
|
int flags; /* see CMF_* below */
|
|
int *brpl; /* places where to put the brace prefixes */
|
|
int *brsl; /* ...and the suffixes */
|
|
char *rems; /* when to remove the suffix */
|
|
char *remf; /* shell function to call for suffix-removal */
|
|
int qipl; /* length of quote-prefix */
|
|
int qisl; /* length of quote-suffix */
|
|
int rnum; /* group relative number */
|
|
int gnum; /* global number */
|
|
mode_t mode; /* mode field of a stat */
|
|
char modec; /* LIST_TYPE-character for mode or nul */
|
|
mode_t fmode; /* mode field of a stat, following symlink */
|
|
char fmodec; /* LIST_TYPE-character for fmode or nul */
|
|
};
|
|
|
|
#define CMF_FILE (1<< 0) /* this is a file */
|
|
#define CMF_REMOVE (1<< 1) /* remove the suffix */
|
|
#define CMF_ISPAR (1<< 2) /* is paramter expansion */
|
|
#define CMF_PARBR (1<< 3) /* paramter expansion with a brace */
|
|
#define CMF_PARNEST (1<< 4) /* nested parameter expansion */
|
|
#define CMF_NOLIST (1<< 5) /* should not be listed */
|
|
#define CMF_DISPLINE (1<< 6) /* display strings one per line */
|
|
#define CMF_HIDE (1<< 7) /* temporarily hide this one */
|
|
#define CMF_NOSPACE (1<< 8) /* don't add a space */
|
|
#define CMF_PACKED (1<< 9) /* prefer LIST_PACKED */
|
|
#define CMF_ROWS (1<<10) /* prefer LIST_ROWS_FIRST */
|
|
#define CMF_MULT (1<<11) /* string appears more than once */
|
|
#define CMF_FMULT (1<<12) /* first of multiple equal strings */
|
|
#define CMF_ALL (1<<13) /* a match representing all other matches */
|
|
#define CMF_DUMMY (1<<14) /* unselectable dummy match */
|
|
#define CMF_MORDER (1<<15) /* order by matches, not display strings */
|
|
|
|
/* Stuff for completion matcher control. */
|
|
|
|
struct cmlist {
|
|
Cmlist next; /* next one in the list of global matchers */
|
|
Cmatcher matcher; /* the matcher definition */
|
|
char *str; /* the string for it */
|
|
};
|
|
|
|
struct cmatcher {
|
|
int refc; /* reference counter */
|
|
Cmatcher next; /* next matcher */
|
|
int flags; /* see CMF_* below */
|
|
Cpattern line; /* what matches on the line */
|
|
int llen; /* length of line pattern */
|
|
Cpattern word; /* what matches in the word */
|
|
int wlen; /* length of word pattern, or:
|
|
-1: word pattern is one asterisk
|
|
-2: word pattern is two asterisks */
|
|
Cpattern left; /* left anchor */
|
|
int lalen; /* length of left anchor */
|
|
Cpattern right; /* right anchor */
|
|
int ralen; /* length of right anchor */
|
|
};
|
|
|
|
/* Flags for cmatcher::flags */
|
|
/* Upon match, insert the string from the line rather than the string
|
|
* from the trial completion ("word"). */
|
|
#define CMF_LINE 1
|
|
/* Match with an anchor on the left. */
|
|
#define CMF_LEFT 2
|
|
/* Match with an anchor on the right. */
|
|
#define CMF_RIGHT 4
|
|
/* ... */
|
|
#define CMF_INTER 8
|
|
|
|
/*
|
|
* Types of cpattern structure.
|
|
* Note freecpattern() assumes any <= CPAT_EQUIV have string.
|
|
*/
|
|
enum {
|
|
CPAT_CCLASS, /* [...]: ordinary character class */
|
|
CPAT_NCLASS, /* [!...]: ordinary character class, negated */
|
|
CPAT_EQUIV, /* {...}: equivalence class */
|
|
CPAT_ANY, /* ?: any character */
|
|
CPAT_CHAR /* Single character given explicitly */
|
|
};
|
|
|
|
/*
|
|
* A pattern element in a matcher specification.
|
|
* Unlike normal patterns this only presents one character in
|
|
* either the test completion or the word on the command line.
|
|
*/
|
|
struct cpattern {
|
|
Cpattern next; /* next sub-pattern */
|
|
int tp; /* type of object as above */
|
|
union {
|
|
char *str; /* if a character class, the objects
|
|
* in it in a similar form to normal
|
|
* pattern matching (a metafied string
|
|
* with tokens).
|
|
* Note the allocated length may be longer
|
|
* than the null-terminated string.
|
|
*/
|
|
convchar_t chr; /* if a single character, it */
|
|
} u;
|
|
};
|
|
|
|
/*
|
|
* For now this just handles single-byte characters.
|
|
* TODO: this will change.
|
|
*/
|
|
#ifdef MULTIBYTE_SUPPORT
|
|
#define PATMATCHRANGE(r, c, ip, mtp) \
|
|
mb_patmatchrange(r, c, ZMB_VALID, ip, mtp)
|
|
#define PATMATCHINDEX(r, i, cp, mtp) mb_patmatchindex(r, i, cp, mtp)
|
|
#define CONVCAST(c) ((wchar_t)(c))
|
|
#define CHR_INVALID (WEOF)
|
|
#else
|
|
#define PATMATCHRANGE(r, c, ip, mtp) patmatchrange(r, c, ip, mtp)
|
|
#define PATMATCHINDEX(r, i, cp, mtp) patmatchindex(r, i, cp, mtp)
|
|
#define CONVCAST(c) (c)
|
|
#define CHR_INVALID (-1)
|
|
#endif
|
|
|
|
/* This is a special return value for parse_cmatcher(), *
|
|
* signalling an error. */
|
|
|
|
#define pcm_err ((Cmatcher) 1)
|
|
|
|
/* Information about what to put on the line as the unambiguous string.
|
|
* The code always keeps lists of these structs up to date while
|
|
* matches are added (in the aminfo structs below).
|
|
* The lists have two levels: in the first one we have one struct per
|
|
* word-part, where parts are separated by the anchors of `*' patterns.
|
|
* These structs have pointers (in the prefix and suffix fields) to
|
|
* lists of cline structs describing the strings before or after the
|
|
* the anchor. */
|
|
|
|
typedef struct cline *Cline;
|
|
|
|
struct cline {
|
|
Cline next;
|
|
int flags;
|
|
char *line;
|
|
int llen;
|
|
char *word;
|
|
int wlen;
|
|
char *orig;
|
|
int olen;
|
|
int slen;
|
|
Cline prefix, suffix;
|
|
int min, max;
|
|
};
|
|
|
|
#define CLF_MISS 1
|
|
#define CLF_DIFF 2
|
|
#define CLF_SUF 4
|
|
#define CLF_MID 8
|
|
#define CLF_NEW 16
|
|
#define CLF_LINE 32
|
|
#define CLF_JOIN 64
|
|
#define CLF_MATCHED 128
|
|
#define CLF_SKIP 256
|
|
|
|
/* Information for ambiguous completions. One for fignore ignored and *
|
|
* one for normal completion. */
|
|
|
|
typedef struct aminfo *Aminfo;
|
|
|
|
struct aminfo {
|
|
Cmatch firstm; /* the first match */
|
|
int exact; /* if there was an exact match */
|
|
Cmatch exactm; /* the exact match (if any) */
|
|
int count; /* number of matches */
|
|
Cline line; /* unambiguous line string */
|
|
};
|
|
|
|
/* Information about menucompletion stuff. */
|
|
|
|
struct menuinfo {
|
|
Cmgroup group; /* position in the group list */
|
|
Cmatch *cur; /* match currently inserted */
|
|
int pos; /* begin on line */
|
|
int len; /* length of inserted string */
|
|
int end; /* end on the line */
|
|
int we; /* non-zero if the cursor was at the end */
|
|
int insc; /* length of suffix inserted */
|
|
int asked; /* we asked if the list should be shown */
|
|
char *prebr; /* prefix before a brace, if any */
|
|
char *postbr; /* suffix after a brace */
|
|
};
|
|
|
|
/* Flags for compadd and addmatches(). */
|
|
|
|
#define CAF_QUOTE 1 /* compadd -Q: positional arguments already quoted */
|
|
#define CAF_NOSORT 2 /* compadd -V: don't sort */
|
|
#define CAF_MATCH 4 /* compadd without -U: do matching */
|
|
#define CAF_UNIQCON 8 /* compadd -2: don't deduplicate */
|
|
#define CAF_UNIQALL 16 /* compadd -1: deduplicate */
|
|
#define CAF_ARRAYS 32 /* compadd -a or -k: array/assoc parameter names */
|
|
#define CAF_KEYS 64 /* compadd -k: assoc parameter names */
|
|
#define CAF_ALL 128 /* compadd -C: _all_matches */
|
|
|
|
/* Data for compadd and addmatches() */
|
|
|
|
typedef struct cadata *Cadata;
|
|
|
|
struct cadata {
|
|
char *ipre; /* ignored prefix (-i) */
|
|
char *isuf; /* ignored suffix (-I) */
|
|
char *ppre; /* `path' prefix (-p) */
|
|
char *psuf; /* `path' suffix (-s) */
|
|
char *prpre; /* expanded `path' prefix (-W) */
|
|
char *pre; /* prefix to insert (-P) */
|
|
char *suf; /* suffix to insert (-S) */
|
|
char *group; /* name of the group (-[JV]) */
|
|
char *rems; /* remove suffix on chars... (-r) */
|
|
char *remf; /* function to remove suffix (-R) */
|
|
char *ign; /* ignored suffixes (-F) */
|
|
int flags; /* CMF_* flags (-[fqn]) */
|
|
int aflags; /* CAF_* flags (-[QUa]) */
|
|
Cmatcher match; /* match spec (parsed from -M) */
|
|
char *exp; /* explanation (-X) */
|
|
char *apar; /* array to store matches in (-A) */
|
|
char *opar; /* array to store originals in (-O) */
|
|
char *dpar; /* array to delete non-matches in (-D) */
|
|
char *disp; /* array with display lists (-d) */
|
|
char *mesg; /* message to show unconditionally (-x) */
|
|
int dummies; /* add that many dummy matches */
|
|
};
|
|
|
|
/* List data. */
|
|
|
|
typedef struct cldata *Cldata;
|
|
|
|
struct cldata {
|
|
int zterm_columns; /* screen width */
|
|
int zterm_lines; /* screen height */
|
|
int menuacc; /* value of global menuacc */
|
|
int valid; /* no need to calculate anew */
|
|
int nlist; /* number of matches to list */
|
|
int nlines; /* number of lines needed */
|
|
int hidden; /* != 0 if there are hidden matches */
|
|
int onlyexpl; /* != 0 if only explanations to print */
|
|
int showall; /* != 0 if hidden matches should be shown */
|
|
};
|
|
|
|
typedef void (*CLPrintFunc)(Cmgroup, Cmatch *, int, int, int, int);
|
|
|
|
/* Flags for fromcomp. */
|
|
|
|
#define FC_LINE 1
|
|
#define FC_INWORD 2
|
|
|
|
/* Flags for special parameters. */
|
|
|
|
#define CPN_WORDS 0
|
|
#define CP_WORDS (1 << CPN_WORDS)
|
|
#define CPN_REDIRS 1
|
|
#define CP_REDIRS (1 << CPN_REDIRS)
|
|
#define CPN_CURRENT 2
|
|
#define CP_CURRENT (1 << CPN_CURRENT)
|
|
#define CPN_PREFIX 3
|
|
#define CP_PREFIX (1 << CPN_PREFIX)
|
|
#define CPN_SUFFIX 4
|
|
#define CP_SUFFIX (1 << CPN_SUFFIX)
|
|
#define CPN_IPREFIX 5
|
|
#define CP_IPREFIX (1 << CPN_IPREFIX)
|
|
#define CPN_ISUFFIX 6
|
|
#define CP_ISUFFIX (1 << CPN_ISUFFIX)
|
|
#define CPN_QIPREFIX 7
|
|
#define CP_QIPREFIX (1 << CPN_QIPREFIX)
|
|
#define CPN_QISUFFIX 8
|
|
#define CP_QISUFFIX (1 << CPN_QISUFFIX)
|
|
#define CPN_COMPSTATE 9
|
|
#define CP_COMPSTATE (1 << CPN_COMPSTATE)
|
|
/* See comprpms */
|
|
#define CP_REALPARAMS 10
|
|
#define CP_ALLREALS ((unsigned int) 0x3ff)
|
|
|
|
|
|
#define CPN_NMATCHES 0
|
|
#define CP_NMATCHES (1 << CPN_NMATCHES)
|
|
#define CPN_CONTEXT 1
|
|
#define CP_CONTEXT (1 << CPN_CONTEXT)
|
|
#define CPN_PARAMETER 2
|
|
#define CP_PARAMETER (1 << CPN_PARAMETER)
|
|
#define CPN_REDIRECT 3
|
|
#define CP_REDIRECT (1 << CPN_REDIRECT)
|
|
#define CPN_QUOTE 4
|
|
#define CP_QUOTE (1 << CPN_QUOTE)
|
|
#define CPN_QUOTING 5
|
|
#define CP_QUOTING (1 << CPN_QUOTING)
|
|
#define CPN_RESTORE 6
|
|
#define CP_RESTORE (1 << CPN_RESTORE)
|
|
#define CPN_LIST 7
|
|
#define CP_LIST (1 << CPN_LIST)
|
|
#define CPN_INSERT 8
|
|
#define CP_INSERT (1 << CPN_INSERT)
|
|
#define CPN_EXACT 9
|
|
#define CP_EXACT (1 << CPN_EXACT)
|
|
#define CPN_EXACTSTR 10
|
|
#define CP_EXACTSTR (1 << CPN_EXACTSTR)
|
|
#define CPN_PATMATCH 11
|
|
#define CP_PATMATCH (1 << CPN_PATMATCH)
|
|
#define CPN_PATINSERT 12
|
|
#define CP_PATINSERT (1 << CPN_PATINSERT)
|
|
#define CPN_UNAMBIG 13
|
|
#define CP_UNAMBIG (1 << CPN_UNAMBIG)
|
|
#define CPN_UNAMBIGC 14
|
|
#define CP_UNAMBIGC (1 << CPN_UNAMBIGC)
|
|
#define CPN_UNAMBIGP 15
|
|
#define CP_UNAMBIGP (1 << CPN_UNAMBIGP)
|
|
#define CPN_INSERTP 16
|
|
#define CP_INSERTP (1 << CPN_INSERTP)
|
|
#define CPN_LISTMAX 17
|
|
#define CP_LISTMAX (1 << CPN_LISTMAX)
|
|
#define CPN_LASTPROMPT 18
|
|
#define CP_LASTPROMPT (1 << CPN_LASTPROMPT)
|
|
#define CPN_TOEND 19
|
|
#define CP_TOEND (1 << CPN_TOEND)
|
|
#define CPN_OLDLIST 20
|
|
#define CP_OLDLIST (1 << CPN_OLDLIST)
|
|
#define CPN_OLDINS 21
|
|
#define CP_OLDINS (1 << CPN_OLDINS)
|
|
#define CPN_VARED 22
|
|
#define CP_VARED (1 << CPN_VARED)
|
|
#define CPN_LISTLINES 23
|
|
#define CP_LISTLINES (1 << CPN_LISTLINES)
|
|
#define CPN_QUOTES 24
|
|
#define CP_QUOTES (1 << CPN_QUOTES)
|
|
#define CPN_IGNORED 25
|
|
#define CP_IGNORED (1 << CPN_IGNORED)
|
|
/* See compkpms */
|
|
#define CP_KEYPARAMS 26
|
|
#define CP_ALLKEYS ((unsigned int) 0x3ffffff)
|
|
|
|
/* Hooks. */
|
|
|
|
#define INSERTMATCHHOOK (comphooks + 0)
|
|
#define MENUSTARTHOOK (comphooks + 1)
|
|
#define COMPCTLMAKEHOOK (comphooks + 2)
|
|
#define COMPCTLCLEANUPHOOK (comphooks + 3)
|
|
#define COMPLISTMATCHESHOOK (comphooks + 4)
|
|
|
|
/* compctl hook data struct */
|
|
|
|
struct ccmakedat {
|
|
char *str;
|
|
int incmd;
|
|
int lst;
|
|
};
|
|
|
|
/* Data given to offered hooks. */
|
|
|
|
typedef struct chdata *Chdata;
|
|
|
|
struct chdata {
|
|
Cmgroup matches; /* the matches generated */
|
|
int num; /* the number of matches */
|
|
int nmesg; /* the number of messages */
|
|
Cmatch cur; /* current match or NULL */
|
|
};
|
|
|
|
/* The number of columns to leave empty between rows of matches. */
|
|
|
|
#define CM_SPACE 2
|
|
|