summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStig Thormodsrud <stig@vyatta.com>2008-02-19 18:46:03 -0800
committerStig Thormodsrud <stig@vyatta.com>2008-02-19 18:46:03 -0800
commitd73e3f8a10192a928efc80fcf91e58218aeac4d6 (patch)
tree210c60aef7e4e4fbabda3b7d0cceb6a34dbf613e
parentacb8eea0301ad69c1653b389be4a86ada8721290 (diff)
parent4e0206da1f3080f0c0729e6b6f252a147cf2a9cb (diff)
downloadvyatta-cfg-d73e3f8a10192a928efc80fcf91e58218aeac4d6.tar.gz
vyatta-cfg-d73e3f8a10192a928efc80fcf91e58218aeac4d6.zip
Merge branch 'glendale' of http://git.vyatta.com/vyatta-cfg into glendale
-rw-r--r--.gitignore1
-rw-r--r--Makefile.am2
-rw-r--r--debian/lintian2
-rw-r--r--src/check_tmpl.c69
-rw-r--r--src/set.c6
5 files changed, 75 insertions, 5 deletions
diff --git a/.gitignore b/.gitignore
index 358c973..765492c 100644
--- a/.gitignore
+++ b/.gitignore
@@ -27,6 +27,7 @@ libtool
/src/my_commit
/src/my_set
/src/my_delete
+/src/check_tmpl
/src/cli_def.c
/src/cli_parse.c
/src/cli_parse.h
diff --git a/Makefile.am b/Makefile.am
index ef92de7..9e55aa1 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -25,9 +25,11 @@ LDADD = src/libvyatta-cfg.la
sbin_PROGRAMS = src/my_commit
sbin_PROGRAMS += src/my_delete
sbin_PROGRAMS += src/my_set
+sbin_PROGRAMS += src/check_tmpl
src_my_commit_SOURCES = src/commit.c
src_my_delete_SOURCES = src/delete.c
src_my_set_SOURCES = src/set.c
+src_check_tmpl_SOURCES = src/check_tmpl.c
sbin_SCRIPTS = scripts/xorp_tmpl_tool
sbin_SCRIPTS += scripts/vyatta-validate-type.pl
diff --git a/debian/lintian b/debian/lintian
index ad0df30..70110bf 100644
--- a/debian/lintian
+++ b/debian/lintian
@@ -3,4 +3,4 @@ vyatta-cfg: dir-or-file-in-opt
vyatta-cfg: binary-or-shlib-defines-rpath ./opt/vyatta/sbin/my_set /opt/vyatta/lib
vyatta-cfg: binary-or-shlib-defines-rpath ./opt/vyatta/sbin/my_commit /opt/vyatta/lib
vyatta-cfg: binary-or-shlib-defines-rpath ./opt/vyatta/sbin/my_delete /opt/vyatta/lib
-vyatta-cfg: binary-or-shlib-defines-rpath ./opt/vyatta/sbin/rl_passwd /opt/vyatta/lib
+vyatta-cfg: binary-or-shlib-defines-rpath ./opt/vyatta/sbin/check_tmpl /opt/vyatta/lib
diff --git a/src/check_tmpl.c b/src/check_tmpl.c
new file mode 100644
index 0000000..8be1a7f
--- /dev/null
+++ b/src/check_tmpl.c
@@ -0,0 +1,69 @@
+#include <stdlib.h>
+#include <stdio.h>
+
+#include "cli_val.h"
+
+int
+check_line_continuation(FILE *ftmpl)
+{
+ char buf[256];
+ int line = 0;
+ while (fgets(buf, 256, ftmpl) != NULL) {
+ int len = strlen(buf);
+ ++line;
+ if (len < 2 || buf[len - 1] != '\n' || !isblank(buf[len - 2])) {
+ continue;
+ }
+ len -= 3;
+ while (len >= 0 && isblank(buf[len])) {
+ --len;
+ }
+ if (len >= 0 && buf[len] == '\\') {
+ printf("Warning: \"backslash + space\" detected at the end of line %d.\n"
+ " This will not work as line continuation.\n",
+ line);
+ continue;
+ }
+ }
+ return 0;
+}
+
+int
+main(int argc, char **argv)
+{
+ int status = 0;
+ vtw_def def;
+ FILE *ftmpl = NULL;
+
+ if (argc != 2) {
+ printf("Usage: check_tmpl <tmpl_file>\n");
+ exit(-1);
+ }
+
+ memset(&def, 0, sizeof(def));
+ status = parse_def(&def, argv[1], 0);
+ if (status == -5) {
+ printf("Cannot open [%s]\n", argv[1]);
+ exit(-1);
+ } else if (status != 0) {
+ printf("Parse error in [%s]\n", argv[1]);
+ exit(-1);
+ }
+
+ if ((ftmpl = fopen(argv[1], "r")) == NULL) {
+ printf("Cannot open [%s]\n", argv[1]);
+ exit(-1);
+ }
+
+ /* check for other errors */
+ if (check_line_continuation(ftmpl) != 0) {
+ exit(-1);
+ }
+ fseek(ftmpl, 0, SEEK_SET);
+
+ fclose(ftmpl);
+
+ printf("OK\n");
+ return 0;
+}
+
diff --git a/src/set.c b/src/set.c
index 44f1263..d961fb8 100644
--- a/src/set.c
+++ b/src/set.c
@@ -336,10 +336,8 @@ handle_default(vtw_path *mpath, vtw_path *tpath, char *exclude)
}
memset(&def, 0, sizeof(def));
if ((status = parse_def(&def, tpath->path, FALSE))) {
- fprintf(stderr, "parse error in [%s]\n", tpath->path);
- pop_path(tpath); /* definition */
- pop_path(tpath); /* child */
- continue;
+ /* template parse error. abort. */
+ bye("Parse error in [%s]\n", tpath->path);
}
if (def.def_default) {
push_path(mpath, uename);