fix horrible evil bug update to this revision at once and do a "make sure"

git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@4060 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Anthony Minessale 2007-01-26 17:52:22 +00:00
parent c48449854d
commit 28807552d0
2 changed files with 54 additions and 41 deletions

View File

@ -84,6 +84,8 @@ struct switch_xml {
char **attr; char **attr;
/*! tag character content, empty string if none */ /*! tag character content, empty string if none */
char *txt; char *txt;
/*! path to free on destroy*/
char *free_path;
/*! tag offset from start of parent tag character content */ /*! tag offset from start of parent tag character content */
switch_size_t off; switch_size_t off;
/*! next tag with same name in this section at this depth */ /*! next tag with same name in this section at this depth */

View File

@ -848,33 +848,21 @@ static char *expand_vars(char *buf, char *ebuf, switch_size_t elen, switch_size_
} }
static int preprocess(const char *file, int new_fd, int rlevel) static int preprocess(const char *file, int write_fd, int rlevel)
{ {
int old_fd, close_fd = -1; int read_fd = -1;
char *new_file = NULL;
switch_size_t cur = 0, ml = 0; switch_size_t cur = 0, ml = 0;
char *q, *cmd, buf[2048], ebuf[8192]; char *q, *cmd, buf[2048], ebuf[8192];
if ((old_fd = open(file, O_RDONLY, 0)) < 0) { if ((read_fd = open(file, O_RDONLY, 0)) < 0) {
return old_fd; return read_fd;
} }
if (rlevel > 100) { if (rlevel > 100) {
return -1; return -1;
} }
if (new_fd < 0) { while((cur = read_line(read_fd, buf, sizeof(buf))) > 0) {
if (!(new_file = switch_mprintf("%s%sfreeswitch.registry", SWITCH_GLOBAL_dirs.log_dir, SWITCH_PATH_SEPARATOR))) {
goto done;
}
if ((new_fd = open(new_file, O_WRONLY | O_CREAT | O_TRUNC, S_IRUSR | S_IWUSR)) < 0) {
goto done;
}
close_fd = new_fd;
}
while((cur = read_line(old_fd, buf, sizeof(buf))) > 0) {
char *arg, *e; char *arg, *e;
char *bp = expand_vars(buf, ebuf, sizeof(ebuf), &cur); char *bp = expand_vars(buf, ebuf, sizeof(ebuf), &cur);
@ -894,11 +882,11 @@ static int preprocess(const char *file, int new_fd, int rlevel)
} }
if ((cmd = strstr(bp, "<!--#"))) { if ((cmd = strstr(bp, "<!--#"))) {
write(new_fd, bp, (unsigned)(cmd - bp)); write(write_fd, bp, (unsigned)(cmd - bp));
if ((e = strstr(cmd, "-->"))) { if ((e = strstr(cmd, "-->"))) {
*e = '\0'; *e = '\0';
e += 3; e += 3;
write(new_fd, e, (unsigned)strlen(e)); write(write_fd, e, (unsigned)strlen(e));
} else { } else {
ml++; ml++;
} }
@ -945,7 +933,7 @@ static int preprocess(const char *file, int new_fd, int rlevel)
fme = switch_mprintf("%s%s%s", SWITCH_GLOBAL_dirs.conf_dir, SWITCH_PATH_SEPARATOR, arg); fme = switch_mprintf("%s%s%s", SWITCH_GLOBAL_dirs.conf_dir, SWITCH_PATH_SEPARATOR, arg);
ifile = fme; ifile = fme;
} }
if (preprocess(ifile, new_fd, rlevel + 1) < 0) { if (preprocess(ifile, write_fd, rlevel + 1) < 0) {
fprintf(stderr, "Error including %s (%s)\n", ifile, strerror(errno)); fprintf(stderr, "Error including %s (%s)\n", ifile, strerror(errno));
} }
switch_safe_free(fme); switch_safe_free(fme);
@ -955,38 +943,56 @@ static int preprocess(const char *file, int new_fd, int rlevel)
continue; continue;
} }
write(new_fd, bp, (unsigned)cur); write(write_fd, bp, (unsigned)cur);
} }
close(old_fd); close(read_fd);
return write_fd;
if (close_fd > -1) {
close(close_fd);
new_fd = open(new_file, O_RDONLY, 0);
}
done:
switch_safe_free(new_file);
if (new_fd < 0) {
return old_fd;
}
return new_fd;
} }
// a wrapper for switch_xml_parse_fd that accepts a file name // a wrapper for switch_xml_parse_fd that accepts a file name
SWITCH_DECLARE(switch_xml_t) switch_xml_parse_file(const char *file) SWITCH_DECLARE(switch_xml_t) switch_xml_parse_file(const char *file)
{ {
int fd = -1; int fd = -1, write_fd = -1;
switch_xml_t xml = NULL; switch_xml_t xml = NULL;
char *new_file = NULL;
char *abs;
if ((fd = preprocess(file, -1, 0)) > -1) { if ((abs = strrchr(file, '/')) || (abs = strrchr(file, '\\'))) {
xml = switch_xml_parse_fd(fd); abs++;
close(fd); } else {
abs = file;
} }
if (!(new_file = switch_mprintf("%s%s%s.fsxml", SWITCH_GLOBAL_dirs.log_dir, SWITCH_PATH_SEPARATOR, abs))) {
return NULL;
}
if ((write_fd = open(new_file, O_WRONLY | O_CREAT | O_TRUNC, S_IRUSR | S_IWUSR)) < 0) {
goto done;
}
if (preprocess(file, write_fd, 0) > -1) {
close(write_fd);
write_fd = -1;
if ((fd = open(new_file, O_RDONLY, 0)) > -1) {
if ((xml = switch_xml_parse_fd(fd))) {
xml->free_path = new_file;
new_file = NULL;
}
close(fd);
fd = -1;
}
}
done:
if (write_fd > -1) {
close(write_fd);
}
if (fd > -1) {
close(fd);
}
switch_safe_free(new_file);
return xml; return xml;
} }
@ -1340,6 +1346,11 @@ SWITCH_DECLARE(void) switch_xml_free(switch_xml_t xml)
return; return;
} }
if (xml->free_path) {
unlink(xml->free_path);
switch_safe_free(xml->free_path);
}
switch_xml_free(xml->child); switch_xml_free(xml->child);
switch_xml_free(xml->ordered); switch_xml_free(xml->ordered);