mirror of
git://git.code.sf.net/p/cdesktopenv/code
synced 2025-03-09 15:50:02 +00:00
Make the 'history' and 'r' commands builtins (#76)
With this change no more preset aliases exist, so the preset alias tables can be safely removed. All ksh commands can now be used without 'unalias -a' removing them, even in interactive shells. Additionally, the history and r commands are no longer limited to being used in interactive shells. src/cmd/ksh93/bltins/hist.c: - Implement the history and r commands as builtins. Also guarantee lflag is set to one by avoiding 'lflag++'. src/cmd/ksh93/Makefile, src/cmd/ksh93/Mamfile, src/cmd/ksh93/sh/main.c, src/cmd/ksh93/sh/init.c, src/cmd/ksh93/data/aliases.c: - Remove the table of predefined aliases because the last few have been removed. During init the alias tree is now initialized the same way as the function tree. src/cmd/ksh93/bltins/typeset.c: - Remove the bugfix for unsetting predefined aliases because it is now a no-op. Aliases are no longer able to have the NV_NOFREE attribute. src/cmd/ksh93/tests/alias.sh: - Remove the regression test for unsetting predefined aliases since those no longer exist. src/cmd/ksh93/data/builtins.c: - Update sh_opthist[] for 'hist --man', etc. src/cmd/ksh93/sh.1: - Remove the list of preset aliases since those no longer exist. - Document history and r as builtins instead of preset aliases. Co-authored-by: Martijn Dekker <martijn@inlv.org>
This commit is contained in:
parent
17f81ebedb
commit
03224ae3af
13 changed files with 47 additions and 100 deletions
|
@ -58,6 +58,13 @@ int b_hist(int argc,char *argv[], Shbltin_t *context)
|
|||
NOT_USED(argc);
|
||||
if(!sh_histinit((void*)shp))
|
||||
errormsg(SH_DICT,ERROR_system(1),e_histopen);
|
||||
|
||||
/* 'history' and 'r' builtins */
|
||||
if(argv[0][0] == 'r') /* <r> */
|
||||
edit = "-";
|
||||
else if(argv[0][0] == 'h' && argv[0][4] == 'o') /* hist<o>ry (argv[0][4] is zero when called as 'hist') */
|
||||
lflag = 1;
|
||||
|
||||
hp = shp->gd->hist_ptr;
|
||||
while((flag = optget(argv,sh_opthist))) switch(flag)
|
||||
{
|
||||
|
@ -68,7 +75,7 @@ int b_hist(int argc,char *argv[], Shbltin_t *context)
|
|||
nflag++;
|
||||
break;
|
||||
case 'l':
|
||||
lflag++;
|
||||
lflag = 1;
|
||||
break;
|
||||
case 'r':
|
||||
rflag++;
|
||||
|
|
|
@ -1328,12 +1328,7 @@ static int unall(int argc, char **argv, register Dt_t *troot, Shell_t* shp)
|
|||
}
|
||||
/* The alias has been unset by call to _nv_unset, remove it from the tree */
|
||||
else if(troot==shp->alias_tree)
|
||||
{
|
||||
if(nv_isattr(np, NV_NOFREE))
|
||||
nv_delete(np,troot,NV_NOFREE); /* The alias is in read-only memory (shtab_aliases) */
|
||||
else
|
||||
nv_delete(np,troot,0);
|
||||
}
|
||||
nv_delete(np,troot,0);
|
||||
#if 0
|
||||
/* causes unsetting local variable to expose global */
|
||||
else if(shp->var_tree==troot && shp->var_tree!=shp->var_base && nv_search((char*)np,shp->var_tree,HASH_BUCKET|HASH_NOSCOPE))
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue