Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/tests/lib/libcurses tests/libcurses: remove include path han...
details: https://anonhg.NetBSD.org/src/rev/ee73375ece28
branches: trunk
changeset: 1018669:ee73375ece28
user: rillig <rillig%NetBSD.org@localhost>
date: Sat Feb 13 08:00:07 2021 +0000
description:
tests/libcurses: remove include path handling
All include commands in the current test suite use relative paths.
Instead of a fixed include path, interpret the included filename
relative to the including file.
diffstat:
tests/lib/libcurses/director/director.c | 17 +----------
tests/lib/libcurses/director/testlang_conf.l | 41 ++++++++++++++-------------
tests/lib/libcurses/t_curses.sh | 1 -
3 files changed, 23 insertions(+), 36 deletions(-)
diffs (152 lines):
diff -r 45ca8129d139 -r ee73375ece28 tests/lib/libcurses/director/director.c
--- a/tests/lib/libcurses/director/director.c Sat Feb 13 07:57:09 2021 +0000
+++ b/tests/lib/libcurses/director/director.c Sat Feb 13 08:00:07 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: director.c,v 1.23 2021/02/13 07:32:19 rillig Exp $ */
+/* $NetBSD: director.c,v 1.24 2021/02/13 08:00:07 rillig Exp $ */
/*-
* Copyright 2009 Brett Lymn <blymn%NetBSD.org@localhost>
@@ -51,7 +51,6 @@
#define DEF_SLAVE "./slave"
const char *def_check_path = "./"; /* default check path */
-const char *def_include_path = "./"; /* default include path */
extern size_t nvars; /* In testlang_conf.y */
saved_data_t saved_output; /* In testlang_conf.y */
@@ -62,7 +61,6 @@
int check_file_flag; /* control check-file generation */
const char *check_path; /* path to prepend to check files for output
validation */
-const char *include_path; /* path to prepend to include files */
char *cur_file; /* name of file currently being read */
void init_parse_variables(int); /* in testlang_parse.y */
@@ -142,11 +140,8 @@
verbose = 0;
check_file_flag = 0;
- while ((ch = getopt(argc, argv, "vgfC:I:p:s:t:T:")) != -1) {
+ while ((ch = getopt(argc, argv, "vgfC:p:s:t:T:")) != -1) {
switch (ch) {
- case 'I':
- include_path = optarg;
- break;
case 'C':
check_path = optarg;
break;
@@ -199,14 +194,6 @@
check_path = def_check_path;
}
- if (include_path == NULL)
- include_path = getenv("INCLUDE_PATH");
- if ((include_path == NULL) || (include_path[0] == '\0')) {
- warnx("$INCLUDE_PATH not set, defaulting to %s",
- def_include_path);
- include_path = def_include_path;
- }
-
signal(SIGCHLD, slave_died);
if (setenv("TERM", term, 1) != 0)
diff -r 45ca8129d139 -r ee73375ece28 tests/lib/libcurses/director/testlang_conf.l
--- a/tests/lib/libcurses/director/testlang_conf.l Sat Feb 13 07:57:09 2021 +0000
+++ b/tests/lib/libcurses/director/testlang_conf.l Sat Feb 13 08:00:07 2021 +0000
@@ -1,5 +1,5 @@
%{
-/* $NetBSD: testlang_conf.l,v 1.18 2021/02/08 23:54:03 rillig Exp $ */
+/* $NetBSD: testlang_conf.l,v 1.19 2021/02/13 08:00:07 rillig Exp $ */
/*-
* Copyright 2009 Brett Lymn <blymn%NetBSD.org@localhost>
@@ -45,7 +45,6 @@
int yylex(void);
extern size_t line;
-extern char *include_path; /* from director.c */
extern char *cur_file; /* from director.c */
static int include_stack[MAX_INCLUDES];
@@ -175,7 +174,7 @@
<incl>[ \t]* /* eat the whitespace */
<incl>[^ \t\n]+ { /* got the include file name */
- char inc_file[MAXPATHLEN];
+ char *inc_file;
if (include_ptr > MAX_INCLUDES) {
fprintf(stderr,
@@ -184,23 +183,27 @@
exit(2);
}
- if (yytext[0] != '/') {
- if (strlcpy(inc_file, include_path, sizeof(inc_file))
- >= sizeof(inc_file))
- err(2, "CHECK_PATH too long");
- if ((include_path[strlen(include_path) - 1] != '/') &&
- ((strlcat(inc_file, "/", sizeof(inc_file))
- >= sizeof(inc_file))))
- err(2, "Could not append / to include file path");
+ const char *dir_begin;
+ int dir_len;
+ if (yytext[0] == '/') {
+ dir_begin = "";
+ dir_len = 0;
} else {
- inc_file[0] = '\0';
+ dir_begin = cur_file;
+ const char *dir_end = strrchr(cur_file, '/');
+ if (dir_end != NULL) {
+ dir_len = (int)(dir_end + 1 - dir_begin);
+ } else {
+ dir_begin = ".";
+ dir_len = 1;
+ }
}
- if (strlcat(inc_file, yytext, sizeof(inc_file))
- >= sizeof(inc_file))
- err(2, "Path to include file path overflowed");
+ if (asprintf(&inc_file, "%.*s%s",
+ dir_len, dir_begin, yytext) == -1)
+ err(2, "Cannot construct include path");
- yyin = fopen(inc_file, "r" );
+ yyin = fopen(inc_file, "r");
if (!yyin)
err(1, "Error opening %s", inc_file);
@@ -209,9 +212,7 @@
include_stack[include_ptr] = line;
include_files[include_ptr++] = cur_file;
- cur_file = strdup(inc_file);
- if (cur_file == NULL)
- err(2, "Cannot allocate new include file string");
+ cur_file = inc_file;
line = 1;
BEGIN(INITIAL);
}
@@ -336,7 +337,7 @@
rv = yylval.retval->data_value;
for (i = 0; i < len; i += 2)
*rv++ = (str[i] << 8) | str[i+1];
- *rv = __NORMAL | '\0'; /* terminates chtype array */
+ *rv = __NORMAL | '\0'; /* terminates chtype array */
yylval.retval->data_type = data_byte;
yylval.retval->data_len = chlen;
return BYTE;
diff -r 45ca8129d139 -r ee73375ece28 tests/lib/libcurses/t_curses.sh
--- a/tests/lib/libcurses/t_curses.sh Sat Feb 13 07:57:09 2021 +0000
+++ b/tests/lib/libcurses/t_curses.sh Sat Feb 13 08:00:07 2021 +0000
@@ -25,7 +25,6 @@
$(atf_get_srcdir)/director $2 \
-T $(atf_get_srcdir) \
-t atf \
- -I $(atf_get_srcdir)/tests \
-C $(atf_get_srcdir)/check_files \
-s $(atf_get_srcdir)/slave $file || atf_fail "test ${file} failed"
}
Home |
Main Index |
Thread Index |
Old Index