⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 help.def

📁 android-w.song.android.widget
💻 DEF
字号:
This file is help.def, from which is created help.c.It implements the builtin "help" in Bash.Copyright (C) 1987-2009 Free Software Foundation, Inc.This file is part of GNU Bash, the Bourne Again SHell.Bash is free software: you can redistribute it and/or modifyit under the terms of the GNU General Public License as published bythe Free Software Foundation, either version 3 of the License, or(at your option) any later version.Bash is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See theGNU General Public License for more details.You should have received a copy of the GNU General Public Licensealong with Bash.  If not, see <http://www.gnu.org/licenses/>.$PRODUCES help.c$BUILTIN help$FUNCTION help_builtin$DEPENDS_ON HELP_BUILTIN$SHORT_DOC help [-dms] [pattern ...]Display information about builtin commands.Displays brief summaries of builtin commands.  If PATTERN isspecified, gives detailed help on all commands matching PATTERN,otherwise the list of help topics is printed.Options:  -d	output short description for each topic  -m	display usage in pseudo-manpage format  -s	output only a short usage synopsis for each topic matching	PATTERNArguments:  PATTERN	Pattern specifiying a help topicExit Status:Returns success unless PATTERN is not found or an invalid option is given.$END#include <config.h>#if defined (HELP_BUILTIN)#include <stdio.h>#if defined (HAVE_UNISTD_H)#  ifdef _MINIX#    include <sys/types.h>#  endif#  include <unistd.h>#endif#include <errno.h>#include <filecntl.h>#include "../bashintl.h"#include "../shell.h"#include "../builtins.h"#include "../pathexp.h"#include "common.h"#include "bashgetopt.h"#include <glob/strmatch.h>#include <glob/glob.h>#ifndef errnoextern int errno;#endifextern const char * const bash_copyright;extern const char * const bash_license;static void show_builtin_command_help __P((void));static int open_helpfile __P((char *));static void show_desc __P((char *, int));static void show_manpage __P((char *, int));static void show_longdoc __P((int));/* Print out a list of the known functions in the shell, and what they do.   If LIST is supplied, print out the list which matches for each pattern   specified. */inthelp_builtin (list)     WORD_LIST *list;{  register int i;  char *pattern, *name;  int plen, match_found, sflag, dflag, mflag;  dflag = sflag = mflag = 0;  reset_internal_getopt ();  while ((i = internal_getopt (list, "dms")) != -1)    {      switch (i)	{	case 'd':	  dflag = 1;	  break;	case 'm':	  mflag = 1;	  break;	case 's':	  sflag = 1;	  break;	default:	  builtin_usage ();	  return (EX_USAGE);	}    }  list = loptend;  if (list == 0)    {      show_shell_version (0);      show_builtin_command_help ();      return (EXECUTION_SUCCESS);    }  /* We should consider making `help bash' do something. */  if (glob_pattern_p (list->word->word))    {      printf (ngettext ("Shell commands matching keyword `", "Shell commands matching keywords `", (list->next ? 2 : 1)));      print_word_list (list, ", ");      printf ("'\n\n");    }  for (match_found = 0, pattern = ""; list; list = list->next)    {      pattern = list->word->word;      plen = strlen (pattern);      for (i = 0; name = shell_builtins[i].name; i++)	{	  QUIT;	  if ((strncmp (pattern, name, plen) == 0) ||	      (strmatch (pattern, name, FNMATCH_EXTFLAG) != FNM_NOMATCH))	    {	      match_found++;	      if (dflag)		{		  show_desc (name, i);		  continue;		}	      else if (mflag)		{		  show_manpage (name, i);		  continue;		}	      printf ("%s: %s\n", name, _(shell_builtins[i].short_doc));	      if (sflag == 0)		show_longdoc (i);	    }	}    }  if (match_found == 0)    {      builtin_error (_("no help topics match `%s'.  Try `help help' or `man -k %s' or `info %s'."), pattern, pattern, pattern);      return (EXECUTION_FAILURE);    }  fflush (stdout);  return (EXECUTION_SUCCESS);}static intopen_helpfile (name)     char *name;{  int fd;  fd = open (name, O_RDONLY);  if (fd == -1)    {      builtin_error (_("%s: cannot open: %s"), name, strerror (errno));      return -1;    }  return fd;}/* By convention, enforced by mkbuiltins.c, if separate help files are being   used, the long_doc array contains one string -- the full pathname of the   help file for this builtin.  */static voidshow_longdoc (i)     int i;{  register int j;  char * const *doc;  int fd;  doc = shell_builtins[i].long_doc;  if (doc && doc[0] && *doc[0] == '/' && doc[1] == (char *)NULL)    {      fd = open_helpfile (doc[0]);      if (fd < 0)	return;      zcatfd (fd, 1, doc[0]);      close (fd);    }  else    for (j = 0; doc[j]; j++)      printf ("%*s%s\n", BASE_INDENT, " ", _(doc[j]));}static voidshow_desc (name, i)     char *name;     int i;{  register int j;  char **doc, *line;  int fd, usefile;  doc = (char **)shell_builtins[i].long_doc;  usefile = (doc && doc[0] && *doc[0] == '/' && doc[1] == (char *)NULL);  if (usefile)    {      fd = open_helpfile (doc[0]);      if (fd < 0)	return;      zmapfd (fd, &line, doc[0]);      close (fd);    }  else    line = doc ? doc[0] : (char *)NULL;  printf ("%s - ", name);  for (j = 0; line && line[j]; j++)    {      putchar (line[j]);      if (line[j] == '\n')	break;    }    fflush (stdout);  if (usefile)    free (line);}/* Print builtin help in pseudo-manpage format. */static voidshow_manpage (name, i)     char *name;     int i;{  register int j;  char **doc, *line;  int fd, usefile;  doc = (char **)shell_builtins[i].long_doc;  usefile = (doc && doc[0] && *doc[0] == '/' && doc[1] == (char *)NULL);  if (usefile)    {      fd = open_helpfile (doc[0]);      if (fd < 0)	return;      zmapfd (fd, &line, doc[0]);      close (fd);    }  else    line = doc ? _(doc[0]) : (char *)NULL;  /* NAME */  printf ("NAME\n");  printf ("%*s%s - ", BASE_INDENT, " ", name);  for (j = 0; line && line[j]; j++)    {      putchar (line[j]);      if (line[j] == '\n')	break;    }  printf ("\n");  /* SYNOPSIS */  printf ("SYNOPSIS\n");  printf ("%*s%s\n\n", BASE_INDENT, " ", _(shell_builtins[i].short_doc));  /* DESCRIPTION */  printf ("DESCRIPTION\n");  if (usefile == 0)    {      for (j = 0; doc[j]; j++)        printf ("%*s%s\n", BASE_INDENT, " ", _(doc[j]));    }  else    {      for (j = 0; line && line[j]; j++)	{	  putchar (line[j]);	  if (line[j] == '\n')	    printf ("%*s", BASE_INDENT, " ");	}    }  putchar ('\n');  /* SEE ALSO */  printf ("SEE ALSO\n");  printf ("%*sbash(1)\n\n", BASE_INDENT, " ");  /* IMPLEMENTATION */  printf ("IMPLEMENTATION\n");  printf ("%*s", BASE_INDENT, " ");  show_shell_version (0);  printf ("%*s", BASE_INDENT, " ");  printf ("%s\n", _(bash_copyright));  printf ("%*s", BASE_INDENT, " ");  printf ("%s\n", _(bash_license));  fflush (stdout);  if (usefile)    free (line);}static voidshow_builtin_command_help (){  int i, j;  int height, width;  char *t, blurb[128];  printf (_("These shell commands are defined internally.  Type `help' to see this list.\n\Type `help name' to find out more about the function `name'.\n\Use `info bash' to find out more about the shell in general.\n\Use `man -k' or `info' to find out more about commands not in this list.\n\\n\A star (*) next to a name means that the command is disabled.\n\\n"));  t = get_string_value ("COLUMNS");  width = (t && *t) ? atoi (t) : 80;  if (width <= 0)    width = 80;  width /= 2;  if (width > sizeof (blurb))    width = sizeof (blurb);  if (width <= 3)    width = 40;  height = (num_shell_builtins + 1) / 2;	/* number of rows */  for (i = 0; i < height; i++)    {      QUIT;      /* first column */      blurb[0] = (shell_builtins[i].flags & BUILTIN_ENABLED) ? ' ' : '*';      strncpy (blurb + 1, _(shell_builtins[i].short_doc), width - 2);      blurb[width - 2] = '>';		/* indicate truncation */      blurb[width - 1] = '\0';      printf ("%s", blurb);      if (((i << 1) >= num_shell_builtins) || (i+height >= num_shell_builtins))	{	  printf ("\n");	  break;	}      /* two spaces */      for (j = strlen (blurb); j < width; j++)        putc (' ', stdout);      /* second column */      blurb[0] = (shell_builtins[i+height].flags & BUILTIN_ENABLED) ? ' ' : '*';      strncpy (blurb + 1, _(shell_builtins[i+height].short_doc), width - 3);      blurb[width - 3] = '>';		/* indicate truncation */      blurb[width - 2] = '\0';      printf ("%s\n", blurb);    }}#endif /* HELP_BUILTIN */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -