| 
									
										
										
										
											1996-12-23 17:02:34 +00:00
										 |  |  | /* Sample builtin to be dynamically loaded with enable -f and create a new
 | 
					
						
							|  |  |  |    builtin. */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* See Makefile for compilation details. */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-26 09:36:43 -05:00
										 |  |  | /*
 | 
					
						
							|  |  |  |    Copyright (C) 1999-2009 Free Software Foundation, Inc. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    This file is part of GNU Bash. | 
					
						
							|  |  |  |    Bash is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |    it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  |    the 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 of | 
					
						
							|  |  |  |    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |    GNU General Public License for more details. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |    along with Bash.  If not, see <http://www.gnu.org/licenses/>.
 | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-02-19 17:11:39 +00:00
										 |  |  | #include <config.h>
 | 
					
						
							| 
									
										
										
										
											1996-12-23 17:02:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if defined (HAVE_UNISTD_H)
 | 
					
						
							|  |  |  | #  include <unistd.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <stdio.h>
 | 
					
						
							| 
									
										
										
										
											1999-02-19 17:11:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1996-12-23 17:02:34 +00:00
										 |  |  | #include "builtins.h"
 | 
					
						
							|  |  |  | #include "shell.h"
 | 
					
						
							| 
									
										
										
										
											1999-02-19 17:11:39 +00:00
										 |  |  | #include "bashgetopt.h"
 | 
					
						
							| 
									
										
										
										
											1996-12-23 17:02:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* A builtin `xxx' is normally implemented with an `xxx_builtin' function.
 | 
					
						
							|  |  |  |    If you're converting a command that uses the normal Unix argc/argv | 
					
						
							| 
									
										
										
										
											1999-02-19 17:11:39 +00:00
										 |  |  |    calling convention, use argv = make_builtin_argv (list, &argc) and call | 
					
						
							| 
									
										
										
										
											1996-12-23 17:02:34 +00:00
										 |  |  |    the original `main' something like `xxx_main'.  Look at cat.c for an | 
					
						
							|  |  |  |    example. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Builtins should use internal_getopt to parse options.  It is the same as | 
					
						
							|  |  |  |    getopt(3), but it takes a WORD_LIST *.  Look at print.c for an example | 
					
						
							|  |  |  |    of its use. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    If the builtin takes no options, call no_options(list) before doing | 
					
						
							|  |  |  |    anything else.  If it returns a non-zero value, your builtin should | 
					
						
							|  |  |  |    immediately return EX_USAGE.  Look at logname.c for an example. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    A builtin command returns EXECUTION_SUCCESS for success and | 
					
						
							|  |  |  |    EXECUTION_FAILURE to indicate failure. */ | 
					
						
							| 
									
										
										
										
											2001-11-13 17:56:06 +00:00
										 |  |  | int | 
					
						
							| 
									
										
										
										
											1996-12-23 17:02:34 +00:00
										 |  |  | hello_builtin (list) | 
					
						
							|  |  |  |      WORD_LIST *list; | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   printf("hello world\n"); | 
					
						
							|  |  |  |   fflush (stdout); | 
					
						
							|  |  |  |   return (EXECUTION_SUCCESS); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* An array of strings forming the `long' documentation for a builtin xxx,
 | 
					
						
							| 
									
										
										
										
											2009-01-12 13:36:28 +00:00
										 |  |  |    which is printed by `help xxx'.  It must end with a NULL.  By convention, | 
					
						
							|  |  |  |    the first line is a short description. */ | 
					
						
							| 
									
										
										
										
											1996-12-23 17:02:34 +00:00
										 |  |  | char *hello_doc[] = { | 
					
						
							| 
									
										
										
										
											2009-01-12 13:36:28 +00:00
										 |  |  | 	"Sample builtin.", | 
					
						
							|  |  |  | 	"", | 
					
						
							| 
									
										
										
										
											1996-12-23 17:02:34 +00:00
										 |  |  | 	"this is the long doc for the sample hello builtin", | 
					
						
							|  |  |  | 	(char *)NULL | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* The standard structure describing a builtin command.  bash keeps an array
 | 
					
						
							|  |  |  |    of these structures.  The flags must include BUILTIN_ENABLED so the | 
					
						
							|  |  |  |    builtin can be used. */ | 
					
						
							|  |  |  | struct builtin hello_struct = { | 
					
						
							|  |  |  | 	"hello",		/* builtin name */ | 
					
						
							|  |  |  | 	hello_builtin,		/* function implementing the builtin */ | 
					
						
							|  |  |  | 	BUILTIN_ENABLED,	/* initial flags for builtin */ | 
					
						
							|  |  |  | 	hello_doc,		/* array of long documentation strings. */ | 
					
						
							| 
									
										
										
										
											1999-02-19 17:11:39 +00:00
										 |  |  | 	"hello",		/* usage synopsis; becomes short_doc */ | 
					
						
							| 
									
										
										
										
											1996-12-23 17:02:34 +00:00
										 |  |  | 	0			/* reserved for internal use */ | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 	 |