1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
|
This file is testdef, from which is created testc
It implements the builtin "test" in Bash
Copyright (C) 1987-2002 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 modify it under
the terms of the GNU General Public License as published by the Free
Software Foundation; either version 2, 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; see the file COPYING If not, write to the Free Software
Foundation, 59 Temple Place, Suite 330, Boston, MA 02111 USA
$PRODUCES testc
$BUILTIN test
$FUNCTION test_builtin
$SHORT_DOC test [expr]
Exits with a status of 0 (true) or 1 (false) depending on
the evaluation of EXPR Expressions may be unary or binary Unary
expressions are often used to examine the status of a file There
are string operators as well, and numeric comparison operators
File operators:
-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
FILE1 -nt FILE2 True if file1 is newer than file2 (according to
modification date).
FILE1 -ot FILE2 True if file1 is older than file2
FILE1 -ef FILE2 True if file1 is a hard link to file2
String operators:
-z STRING True if string is empty
-n STRING
STRING True if string is not empty
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
Other operators:
-o OPTION True if the shell option OPTION is enabled
! 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
arg1 OP arg2 Arithmetic tests OP is one of -eq, -ne,
-lt, -le, -gt, or -ge
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
$END
$BUILTIN [
$DOCNAME test_bracket
$FUNCTION test_builtin
$SHORT_DOC [ arg.. ]
This is a synonym for the "test" builtin, but the last
argument must be a literal `]', to match the opening `['.
$END
#include <configh
#if defined (HAVE_UNISTD_H)
# ifdef _MINIX
# include <sys/typesh
# endif
# include <unistdh
#endif
#include "../bashansih"
#include "../shellh"
#include "../testh"
#include "commonh"
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
of strings, since that is what their code wants */
if (list == 0)
{
if (this_command_name[0] == '[' && !this_command_name[1])
{
builtin_error ("missing `]'");
return (EX_BADUSAGE);
}
return (EXECUTION_FAILURE);
}
argv = make_builtin_argv (list, &argc);
result = test_command (argc, argv);
free ((char *)argv);
return (result);
}
|