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:
parent
c48449854d
commit
28807552d0
|
@ -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 */
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue