| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  | This file is test.def, from which is created test.c. | 
					
						
							|  |  |  | It implements the builtin "test" in Bash. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-22 19:11:26 -05:00
										 |  |  | Copyright (C) 1987-2010 Free Software Foundation, Inc. | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | This file is part of GNU Bash, the Bourne Again SHell. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 13:36:28 +00:00
										 |  |  | 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. | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 13:36:28 +00:00
										 |  |  | 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. | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 13:36:28 +00:00
										 |  |  | You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  | along with Bash.  If not, see <http://www.gnu.org/licenses/>. | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | $PRODUCES test.c | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | $BUILTIN test | 
					
						
							|  |  |  | $FUNCTION test_builtin | 
					
						
							|  |  |  | $SHORT_DOC test [expr] | 
					
						
							| 
									
										
										
										
											2009-01-12 13:36:28 +00:00
										 |  |  | Evaluate conditional expression. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-07-17 14:10:11 +00:00
										 |  |  | Exits with a status of 0 (true) or 1 (false) depending on | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  | the evaluation of EXPR.  Expressions may be unary or binary.  Unary | 
					
						
							|  |  |  | expressions are often used to examine the status of a file.  There | 
					
						
							| 
									
										
										
										
											2011-11-22 19:11:26 -05:00
										 |  |  | are string operators and numeric comparison operators as well. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The behavior of test depends on the number of arguments.  Read the | 
					
						
							|  |  |  | bash manual page for the complete specification. | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | File operators: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 13:36:28 +00:00
										 |  |  |   -a FILE        True if file exists. | 
					
						
							|  |  |  |   -b FILE        True if file is block special. | 
					
						
							|  |  |  |   -c FILE        True if file is character special. | 
					
						
							|  |  |  |   -d FILE        True if file is a directory. | 
					
						
							|  |  |  |   -e FILE        True if file exists. | 
					
						
							|  |  |  |   -f FILE        True if file exists and is a regular file. | 
					
						
							|  |  |  |   -g FILE        True if file is set-group-id. | 
					
						
							|  |  |  |   -h FILE        True if file is a symbolic link. | 
					
						
							|  |  |  |   -L FILE        True if file is a symbolic link. | 
					
						
							|  |  |  |   -k FILE        True if file has its `sticky' bit set. | 
					
						
							|  |  |  |   -p FILE        True if file is a named pipe. | 
					
						
							|  |  |  |   -r FILE        True if file is readable by you. | 
					
						
							|  |  |  |   -s FILE        True if file exists and is not empty. | 
					
						
							|  |  |  |   -S FILE        True if file is a socket. | 
					
						
							|  |  |  |   -t FD          True if FD is opened on a terminal. | 
					
						
							|  |  |  |   -u FILE        True if the file is set-user-id. | 
					
						
							|  |  |  |   -w FILE        True if the file is writable by you. | 
					
						
							|  |  |  |   -x FILE        True if the file is executable by you. | 
					
						
							|  |  |  |   -O FILE        True if the file is effectively owned by you. | 
					
						
							|  |  |  |   -G FILE        True if the file is effectively owned by your group. | 
					
						
							|  |  |  |   -N FILE        True if the file has been modified since it was last read. | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-17 19:52:44 +00:00
										 |  |  |   FILE1 -nt FILE2  True if file1 is newer than file2 (according to | 
					
						
							|  |  |  |                    modification date). | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   FILE1 -ot FILE2  True if file1 is older than file2. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   FILE1 -ef FILE2  True if file1 is a hard link to file2. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | String operators: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 13:36:28 +00:00
										 |  |  |   -z STRING      True if string is empty. | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 13:36:28 +00:00
										 |  |  |   -n STRING | 
					
						
							|  |  |  |      STRING      True if string is not empty. | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 13:36:28 +00:00
										 |  |  |   STRING1 = STRING2 | 
					
						
							|  |  |  |                  True if the strings are equal. | 
					
						
							|  |  |  |   STRING1 != STRING2 | 
					
						
							|  |  |  |                  True if the strings are not equal. | 
					
						
							|  |  |  |   STRING1 < STRING2 | 
					
						
							|  |  |  |                  True if STRING1 sorts before STRING2 lexicographically. | 
					
						
							|  |  |  |   STRING1 > STRING2 | 
					
						
							|  |  |  |                  True if STRING1 sorts after STRING2 lexicographically. | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | Other operators: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 13:36:28 +00:00
										 |  |  |   -o OPTION      True if the shell option OPTION is enabled. | 
					
						
							| 
									
										
										
										
											2011-11-22 19:11:26 -05:00
										 |  |  |   -v VAR	 True if the shell variable VAR is set | 
					
						
							| 
									
										
										
										
											2009-01-12 13:36:28 +00:00
										 |  |  |   ! EXPR         True if expr is false. | 
					
						
							|  |  |  |   EXPR1 -a EXPR2 True if both expr1 AND expr2 are true. | 
					
						
							|  |  |  |   EXPR1 -o EXPR2 True if either expr1 OR expr2 is true. | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 13:36:28 +00:00
										 |  |  |   arg1 OP arg2   Arithmetic tests.  OP is one of -eq, -ne, | 
					
						
							|  |  |  |                  -lt, -le, -gt, or -ge. | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | Arithmetic binary operators return true if ARG1 is equal, not-equal, | 
					
						
							|  |  |  | less-than, less-than-or-equal, greater-than, or greater-than-or-equal | 
					
						
							|  |  |  | than ARG2. | 
					
						
							| 
									
										
										
										
											2009-01-12 13:36:28 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | Exit Status: | 
					
						
							|  |  |  | Returns success if EXPR evaluates to true; fails if EXPR evaluates to | 
					
						
							|  |  |  | false or an invalid argument is given. | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  | $END | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | $BUILTIN [ | 
					
						
							|  |  |  | $DOCNAME test_bracket | 
					
						
							|  |  |  | $FUNCTION test_builtin | 
					
						
							|  |  |  | $SHORT_DOC [ arg... ] | 
					
						
							| 
									
										
										
										
											2009-01-12 13:36:28 +00:00
										 |  |  | Evaluate conditional expression. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | This is a synonym for the "test" builtin, but the last argument must | 
					
						
							|  |  |  | be a literal `]', to match the opening `['. | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  | $END | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1996-12-23 17:02:34 +00:00
										 |  |  | #include <config.h> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if defined (HAVE_UNISTD_H) | 
					
						
							| 
									
										
										
										
											1998-04-17 19:52:44 +00:00
										 |  |  | #  ifdef _MINIX | 
					
						
							|  |  |  | #    include <sys/types.h> | 
					
						
							|  |  |  | #  endif | 
					
						
							| 
									
										
										
										
											1996-12-23 17:02:34 +00:00
										 |  |  | #  include <unistd.h> | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "../bashansi.h" | 
					
						
							| 
									
										
										
										
											2009-01-12 13:36:28 +00:00
										 |  |  | #include "../bashintl.h" | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "../shell.h" | 
					
						
							| 
									
										
										
										
											1998-04-17 19:52:44 +00:00
										 |  |  | #include "../test.h" | 
					
						
							| 
									
										
										
										
											1996-12-23 17:02:34 +00:00
										 |  |  | #include "common.h" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  | extern char *this_command_name; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* TEST/[ builtin. */ | 
					
						
							|  |  |  | int | 
					
						
							|  |  |  | test_builtin (list) | 
					
						
							|  |  |  |      WORD_LIST *list; | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   char **argv; | 
					
						
							|  |  |  |   int argc, result; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* We let Matthew Bradburn and Kevin Braunsdorf's code do the | 
					
						
							|  |  |  |      actual test command.  So turn the list of args into an array | 
					
						
							| 
									
										
										
										
											1996-12-23 17:02:34 +00:00
										 |  |  |      of strings, since that is what their code wants. */ | 
					
						
							|  |  |  |   if (list == 0) | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |       if (this_command_name[0] == '[' && !this_command_name[1]) | 
					
						
							| 
									
										
										
										
											1999-02-19 17:11:39 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2009-01-12 13:36:28 +00:00
										 |  |  | 	  builtin_error (_("missing `]'")); | 
					
						
							| 
									
										
										
										
											1999-02-19 17:11:39 +00:00
										 |  |  | 	  return (EX_BADUSAGE); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |       return (EXECUTION_FAILURE); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1996-12-23 17:02:34 +00:00
										 |  |  |   argv = make_builtin_argv  (list, &argc); | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  |   result = test_command (argc, argv); | 
					
						
							| 
									
										
										
										
											1996-12-23 17:02:34 +00:00
										 |  |  |   free ((char *)argv); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1996-08-26 18:22:31 +00:00
										 |  |  |   return (result); | 
					
						
							|  |  |  | } |