rc_getline keeps expanding it's malloced buffer until it has read a whole line or EOF. All functions which read into static buffers have been changed to use fhis function to avoid any potential overflows and to ensure we really do read a long long config line.
This commit is contained in:
parent
74e0e58b89
commit
43d0f3fc76
@ -1,34 +0,0 @@
|
|||||||
# Copyright 2007-2008 Roy Marples
|
|
||||||
|
|
||||||
CC ?= gcc
|
|
||||||
AR ?= ar
|
|
||||||
RANLIB ?= ranlib
|
|
||||||
CFLAGS += -O2 -pipe
|
|
||||||
LDFLAGS += -L.
|
|
||||||
PICFLAG = -fPIC
|
|
||||||
|
|
||||||
# GNU Make way of detecting gcc flags we can use
|
|
||||||
check_gcc=$(shell if $(CC) $(1) -S -o /dev/null -xc /dev/null >/dev/null 2>&1; \
|
|
||||||
then echo "$(1)"; else echo "$(2)"; fi)
|
|
||||||
|
|
||||||
# pmake check for extra cflags
|
|
||||||
WEXTRA != for x in -Wdeclaration-after-statement -Wsequence-point -Wextra; do \
|
|
||||||
if $(CC) $$x -S -o /dev/null -xc /dev/null >/dev/null 2>&1; \
|
|
||||||
then echo -n "$$x "; fi \
|
|
||||||
done
|
|
||||||
|
|
||||||
# Loads of nice flags to ensure our code is good
|
|
||||||
CFLAGS += -pedantic -std=c99 \
|
|
||||||
-Wall -Wunused -Wimplicit -Wshadow -Wformat=2 \
|
|
||||||
-Wmissing-declarations -Wno-missing-prototypes -Wwrite-strings \
|
|
||||||
-Wbad-function-cast -Wnested-externs -Wcomment -Winline \
|
|
||||||
-Wchar-subscripts -Wcast-align -Wno-format-nonliteral \
|
|
||||||
$(call check_gcc, -Wdeclaration-after-statement) \
|
|
||||||
$(call check_gcc, -Wsequence-point) \
|
|
||||||
$(call check_gcc, -Wextra) $(WEXTRA)
|
|
||||||
|
|
||||||
# For debugging. -Werror is pointless due to ISO C issues with dlsym
|
|
||||||
#CFLAGS += -ggdb
|
|
||||||
|
|
||||||
TOPDIR = ..
|
|
||||||
include $(TOPDIR)/default.mk
|
|
@ -265,7 +265,7 @@ static bool _match_daemon (const char *path, const char *file,
|
|||||||
const char *mexec, const char *mname,
|
const char *mexec, const char *mname,
|
||||||
const char *mpidfile)
|
const char *mpidfile)
|
||||||
{
|
{
|
||||||
char *buffer;
|
char *line;
|
||||||
char *ffile = rc_strcatpaths (path, file, (char *) NULL);
|
char *ffile = rc_strcatpaths (path, file, (char *) NULL);
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
int lc = 0;
|
int lc = 0;
|
||||||
@ -281,19 +281,14 @@ static bool _match_daemon (const char *path, const char *file,
|
|||||||
if (! mpidfile)
|
if (! mpidfile)
|
||||||
m += 100;
|
m += 100;
|
||||||
|
|
||||||
buffer = xmalloc (sizeof (char) * RC_LINEBUFFER);
|
while ((line = rc_getline (fp))) {
|
||||||
memset (buffer, 0, RC_LINEBUFFER);
|
if (strcmp (line, mexec) == 0)
|
||||||
while ((fgets (buffer, RC_LINEBUFFER, fp))) {
|
|
||||||
int lb = strlen (buffer) - 1;
|
|
||||||
if (buffer[lb] == '\n')
|
|
||||||
buffer[lb] = 0;
|
|
||||||
|
|
||||||
if (strcmp (buffer, mexec) == 0)
|
|
||||||
m += 1;
|
m += 1;
|
||||||
else if (mname && strcmp (buffer, mname) == 0)
|
else if (mname && strcmp (line, mname) == 0)
|
||||||
m += 10;
|
m += 10;
|
||||||
else if (mpidfile && strcmp (buffer, mpidfile) == 0)
|
else if (mpidfile && strcmp (line, mpidfile) == 0)
|
||||||
m += 100;
|
m += 100;
|
||||||
|
free (line);
|
||||||
|
|
||||||
if (m == 111)
|
if (m == 111)
|
||||||
break;
|
break;
|
||||||
@ -302,7 +297,6 @@ static bool _match_daemon (const char *path, const char *file,
|
|||||||
if (lc > 5)
|
if (lc > 5)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
free (buffer);
|
|
||||||
fclose (fp);
|
fclose (fp);
|
||||||
free (ffile);
|
free (ffile);
|
||||||
|
|
||||||
@ -460,7 +454,7 @@ bool rc_service_daemons_crashed (const char *service)
|
|||||||
struct dirent *d;
|
struct dirent *d;
|
||||||
char *path;
|
char *path;
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
char *buffer = NULL;
|
char *line;
|
||||||
char *exec = NULL;
|
char *exec = NULL;
|
||||||
char *name = NULL;
|
char *name = NULL;
|
||||||
char *pidfile = NULL;
|
char *pidfile = NULL;
|
||||||
@ -481,9 +475,6 @@ bool rc_service_daemons_crashed (const char *service)
|
|||||||
return (false);
|
return (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
buffer = xmalloc (sizeof (char) * RC_LINEBUFFER);
|
|
||||||
memset (buffer, 0, RC_LINEBUFFER);
|
|
||||||
|
|
||||||
while ((d = readdir (dp))) {
|
while ((d = readdir (dp))) {
|
||||||
if (d->d_name[0] == '.')
|
if (d->d_name[0] == '.')
|
||||||
continue;
|
continue;
|
||||||
@ -494,17 +485,17 @@ bool rc_service_daemons_crashed (const char *service)
|
|||||||
if (! fp)
|
if (! fp)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
while ((fgets (buffer, RC_LINEBUFFER, fp))) {
|
while ((line = rc_getline (fp))) {
|
||||||
int lb = strlen (buffer) - 1;
|
p = line;
|
||||||
if (buffer[lb] == '\n')
|
if ((token = strsep (&p, "=")) == NULL || ! p) {
|
||||||
buffer[lb] = 0;
|
free (line);
|
||||||
|
|
||||||
p = buffer;
|
|
||||||
if ((token = strsep (&p, "=")) == NULL || ! p)
|
|
||||||
continue;
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if (strlen (p) == 0)
|
if (strlen (p) == 0) {
|
||||||
|
free (line);
|
||||||
continue;
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if (strcmp (token, "exec") == 0) {
|
if (strcmp (token, "exec") == 0) {
|
||||||
if (exec)
|
if (exec)
|
||||||
@ -519,6 +510,7 @@ bool rc_service_daemons_crashed (const char *service)
|
|||||||
free (pidfile);
|
free (pidfile);
|
||||||
pidfile = xstrdup (p);
|
pidfile = xstrdup (p);
|
||||||
}
|
}
|
||||||
|
free (line);
|
||||||
}
|
}
|
||||||
fclose (fp);
|
fclose (fp);
|
||||||
|
|
||||||
@ -563,7 +555,6 @@ bool rc_service_daemons_crashed (const char *service)
|
|||||||
name = NULL;
|
name = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
free (buffer);
|
|
||||||
free (exec);
|
free (exec);
|
||||||
free (name);
|
free (name);
|
||||||
free (dirpath);
|
free (dirpath);
|
||||||
|
@ -124,7 +124,7 @@ rc_depinfo_t *rc_deptree_load (void)
|
|||||||
rc_depinfo_t *deptree = NULL;
|
rc_depinfo_t *deptree = NULL;
|
||||||
rc_depinfo_t *depinfo = NULL;
|
rc_depinfo_t *depinfo = NULL;
|
||||||
rc_deptype_t *deptype = NULL;
|
rc_deptype_t *deptype = NULL;
|
||||||
char buffer [RC_LINEBUFFER];
|
char *line;
|
||||||
char *type;
|
char *type;
|
||||||
char *p;
|
char *p;
|
||||||
char *e;
|
char *e;
|
||||||
@ -133,26 +133,26 @@ rc_depinfo_t *rc_deptree_load (void)
|
|||||||
if (! (fp = fopen (RC_DEPTREE, "r")))
|
if (! (fp = fopen (RC_DEPTREE, "r")))
|
||||||
return (NULL);
|
return (NULL);
|
||||||
|
|
||||||
while (fgets (buffer, RC_LINEBUFFER, fp))
|
while ((line = rc_getline (fp)))
|
||||||
{
|
{
|
||||||
p = buffer;
|
p = line;
|
||||||
e = strsep (&p, "_");
|
e = strsep (&p, "_");
|
||||||
if (! e || strcmp (e, "depinfo") != 0)
|
if (! e || strcmp (e, "depinfo") != 0)
|
||||||
continue;
|
goto next;
|
||||||
|
|
||||||
e = strsep (&p, "_");
|
e = strsep (&p, "_");
|
||||||
if (! e || sscanf (e, "%d", &i) != 1)
|
if (! e || sscanf (e, "%d", &i) != 1)
|
||||||
continue;
|
goto next;
|
||||||
|
|
||||||
if (! (type = strsep (&p, "_=")))
|
if (! (type = strsep (&p, "_=")))
|
||||||
continue;
|
goto next;
|
||||||
|
|
||||||
if (strcmp (type, "service") == 0)
|
if (strcmp (type, "service") == 0)
|
||||||
{
|
{
|
||||||
/* Sanity */
|
/* Sanity */
|
||||||
e = get_shell_value (p);
|
e = get_shell_value (p);
|
||||||
if (! e || strlen (e) == 0)
|
if (! e || strlen (e) == 0)
|
||||||
continue;
|
goto next;
|
||||||
|
|
||||||
if (! deptree)
|
if (! deptree)
|
||||||
{
|
{
|
||||||
@ -167,17 +167,17 @@ rc_depinfo_t *rc_deptree_load (void)
|
|||||||
memset (depinfo, 0, sizeof (rc_depinfo_t));
|
memset (depinfo, 0, sizeof (rc_depinfo_t));
|
||||||
depinfo->service = xstrdup (e);
|
depinfo->service = xstrdup (e);
|
||||||
deptype = NULL;
|
deptype = NULL;
|
||||||
continue;
|
goto next;
|
||||||
}
|
}
|
||||||
|
|
||||||
e = strsep (&p, "=");
|
e = strsep (&p, "=");
|
||||||
if (! e || sscanf (e, "%d", &i) != 1)
|
if (! e || sscanf (e, "%d", &i) != 1)
|
||||||
continue;
|
goto next;
|
||||||
|
|
||||||
/* Sanity */
|
/* Sanity */
|
||||||
e = get_shell_value (p);
|
e = get_shell_value (p);
|
||||||
if (! e || strlen (e) == 0)
|
if (! e || strlen (e) == 0)
|
||||||
continue;
|
goto next;
|
||||||
|
|
||||||
if (! deptype)
|
if (! deptype)
|
||||||
{
|
{
|
||||||
@ -197,6 +197,9 @@ rc_depinfo_t *rc_deptree_load (void)
|
|||||||
deptype->type = xstrdup (type);
|
deptype->type = xstrdup (type);
|
||||||
|
|
||||||
rc_strlist_addsort (&deptype->services, e);
|
rc_strlist_addsort (&deptype->services, e);
|
||||||
|
|
||||||
|
next:
|
||||||
|
free (line);
|
||||||
}
|
}
|
||||||
fclose (fp);
|
fclose (fp);
|
||||||
|
|
||||||
@ -722,7 +725,7 @@ bool rc_deptree_update (void)
|
|||||||
rc_deptype_t *deptype = NULL;
|
rc_deptype_t *deptype = NULL;
|
||||||
rc_deptype_t *dt;
|
rc_deptype_t *dt;
|
||||||
rc_deptype_t *last_deptype = NULL;
|
rc_deptype_t *last_deptype = NULL;
|
||||||
char *buffer = NULL;
|
char *line;
|
||||||
int len;
|
int len;
|
||||||
int i;
|
int i;
|
||||||
int j;
|
int j;
|
||||||
@ -740,20 +743,14 @@ bool rc_deptree_update (void)
|
|||||||
|
|
||||||
deptree = xmalloc (sizeof (rc_depinfo_t));
|
deptree = xmalloc (sizeof (rc_depinfo_t));
|
||||||
memset (deptree, 0, sizeof (rc_depinfo_t));
|
memset (deptree, 0, sizeof (rc_depinfo_t));
|
||||||
buffer = xmalloc (sizeof (char) * RC_LINEBUFFER);
|
|
||||||
memset (buffer, 0, RC_LINEBUFFER);
|
|
||||||
|
|
||||||
/* Phase 2 */
|
/* Phase 2 */
|
||||||
while (fgets (buffer, RC_LINEBUFFER, fp))
|
while ((line = rc_getline (fp)))
|
||||||
{
|
{
|
||||||
/* Trim the newline */
|
depends = line;
|
||||||
if (buffer[strlen (buffer) - 1] == '\n')
|
|
||||||
buffer[strlen(buffer) -1] = 0;
|
|
||||||
|
|
||||||
depends = buffer;
|
|
||||||
service = strsep (&depends, " ");
|
service = strsep (&depends, " ");
|
||||||
if (! service)
|
if (! service)
|
||||||
continue;
|
goto next;
|
||||||
type = strsep (&depends, " ");
|
type = strsep (&depends, " ");
|
||||||
|
|
||||||
for (depinfo = deptree; depinfo; depinfo = depinfo->next)
|
for (depinfo = deptree; depinfo; depinfo = depinfo->next)
|
||||||
@ -778,7 +775,7 @@ bool rc_deptree_update (void)
|
|||||||
|
|
||||||
/* We may not have any depends */
|
/* We may not have any depends */
|
||||||
if (! type || ! depends)
|
if (! type || ! depends)
|
||||||
continue;
|
goto next;
|
||||||
|
|
||||||
/* Get the type */
|
/* Get the type */
|
||||||
if (strcmp (type, "config") != 0) {
|
if (strcmp (type, "config") != 0) {
|
||||||
@ -844,9 +841,11 @@ bool rc_deptree_update (void)
|
|||||||
rc_strlist_delete (&dt->services, depend);
|
rc_strlist_delete (&dt->services, depend);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
next:
|
||||||
|
free (line);
|
||||||
}
|
}
|
||||||
pclose (fp);
|
pclose (fp);
|
||||||
free (buffer);
|
|
||||||
|
|
||||||
/* Phase 3 - add our providors to the tree */
|
/* Phase 3 - add our providors to the tree */
|
||||||
for (depinfo = deptree; depinfo; depinfo = depinfo->next)
|
for (depinfo = deptree; depinfo; depinfo = depinfo->next)
|
||||||
|
@ -105,6 +105,30 @@ char *rc_strcatpaths (const char *path1, const char *paths, ...)
|
|||||||
}
|
}
|
||||||
librc_hidden_def(rc_strcatpaths)
|
librc_hidden_def(rc_strcatpaths)
|
||||||
|
|
||||||
|
char *rc_getline (FILE *fp)
|
||||||
|
{
|
||||||
|
char *line = NULL;
|
||||||
|
size_t len = 0;
|
||||||
|
size_t last = 0;
|
||||||
|
|
||||||
|
if (feof (fp))
|
||||||
|
return (NULL);
|
||||||
|
|
||||||
|
do {
|
||||||
|
len += BUFSIZ;
|
||||||
|
line = xrealloc (line, sizeof (char) * len);
|
||||||
|
fgets (line + last, BUFSIZ, fp);
|
||||||
|
last = strlen (line + last) - 1;
|
||||||
|
} while (! feof (fp) && line[last] != '\n');
|
||||||
|
|
||||||
|
/* Trim the trailing newline */
|
||||||
|
if (line[last] == '\n')
|
||||||
|
line[last] = '\0';
|
||||||
|
|
||||||
|
return (line);
|
||||||
|
}
|
||||||
|
librc_hidden_def(rc_getline)
|
||||||
|
|
||||||
char **rc_config_list (const char *file)
|
char **rc_config_list (const char *file)
|
||||||
{
|
{
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
@ -112,26 +136,12 @@ char **rc_config_list (const char *file)
|
|||||||
char *p;
|
char *p;
|
||||||
char *token;
|
char *token;
|
||||||
char **list = NULL;
|
char **list = NULL;
|
||||||
size_t buflen = BUFSIZ;
|
|
||||||
size_t last;
|
|
||||||
|
|
||||||
if (! (fp = fopen (file, "r")))
|
if (! (fp = fopen (file, "r")))
|
||||||
return (NULL);
|
return (NULL);
|
||||||
|
|
||||||
buffer = xmalloc (sizeof (char) * buflen);
|
while ((p = buffer = rc_getline (fp))) {
|
||||||
buffer[buflen - 1] = '\0';
|
|
||||||
while (fgets (buffer, buflen, fp)) {
|
|
||||||
/* Increase the buffer to read the rest of the line if needed */
|
|
||||||
last = strlen (buffer) - 1;
|
|
||||||
while (! feof (fp) && buffer[last] != '\n') {
|
|
||||||
buflen += BUFSIZ;
|
|
||||||
buffer = xrealloc (buffer, sizeof (char *) * buflen);
|
|
||||||
fgets (buffer + last, BUFSIZ, fp);
|
|
||||||
last = strlen (buffer) - 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Strip leading spaces/tabs */
|
/* Strip leading spaces/tabs */
|
||||||
p = buffer;
|
|
||||||
while ((*p == ' ') || (*p == '\t'))
|
while ((*p == ' ') || (*p == '\t'))
|
||||||
p++;
|
p++;
|
||||||
|
|
||||||
@ -144,8 +154,8 @@ char **rc_config_list (const char *file)
|
|||||||
|
|
||||||
rc_strlist_add (&list, token);
|
rc_strlist_add (&list, token);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
free (buffer);
|
free (buffer);
|
||||||
|
}
|
||||||
fclose (fp);
|
fclose (fp);
|
||||||
|
|
||||||
return (list);
|
return (list);
|
||||||
|
@ -307,7 +307,7 @@ char **rc_service_extra_commands (const char *service)
|
|||||||
char *buffer = NULL;
|
char *buffer = NULL;
|
||||||
char **commands = NULL;
|
char **commands = NULL;
|
||||||
char *token;
|
char *token;
|
||||||
char *p = buffer;
|
char *p;
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
int l;
|
int l;
|
||||||
|
|
||||||
@ -319,13 +319,9 @@ char **rc_service_extra_commands (const char *service)
|
|||||||
snprintf (cmd, l, OPTSTR, svc);
|
snprintf (cmd, l, OPTSTR, svc);
|
||||||
free (svc);
|
free (svc);
|
||||||
if ((fp = popen (cmd, "r"))) {
|
if ((fp = popen (cmd, "r"))) {
|
||||||
buffer = xmalloc (sizeof (char) * RC_LINEBUFFER);
|
p = buffer = rc_getline (fp);
|
||||||
if (fgets (buffer, RC_LINEBUFFER, fp)) {
|
|
||||||
if (buffer[strlen (buffer) - 1] == '\n')
|
|
||||||
buffer[strlen (buffer) - 1] = '\0';
|
|
||||||
while ((token = strsep (&p, " ")))
|
while ((token = strsep (&p, " ")))
|
||||||
rc_strlist_addsort (&commands, token);
|
rc_strlist_addsort (&commands, token);
|
||||||
}
|
|
||||||
pclose (fp);
|
pclose (fp);
|
||||||
free (buffer);
|
free (buffer);
|
||||||
}
|
}
|
||||||
@ -338,12 +334,10 @@ librc_hidden_def(rc_service_extra_commands)
|
|||||||
char *rc_service_description (const char *service, const char *option)
|
char *rc_service_description (const char *service, const char *option)
|
||||||
{
|
{
|
||||||
char *svc;
|
char *svc;
|
||||||
char *cmd = NULL;
|
char *cmd;
|
||||||
char *buffer;
|
|
||||||
char *desc = NULL;
|
char *desc = NULL;
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
int i;
|
int i;
|
||||||
int l;
|
|
||||||
|
|
||||||
if (! (svc = rc_service_resolve (service)))
|
if (! (svc = rc_service_resolve (service)))
|
||||||
return (NULL);
|
return (NULL);
|
||||||
@ -351,24 +345,12 @@ char *rc_service_description (const char *service, const char *option)
|
|||||||
if (! option)
|
if (! option)
|
||||||
option = "";
|
option = "";
|
||||||
|
|
||||||
l = strlen (DESCSTR) + strlen (svc) + strlen (option) + 2;
|
i = strlen (DESCSTR) + strlen (svc) + strlen (option) + 2;
|
||||||
cmd = xmalloc (sizeof (char) * l);
|
cmd = xmalloc (sizeof (char) * i);
|
||||||
snprintf (cmd, l, DESCSTR, svc, option ? "_" : "", option);
|
snprintf (cmd, i, DESCSTR, svc, option ? "_" : "", option);
|
||||||
free (svc);
|
free (svc);
|
||||||
if ((fp = popen (cmd, "r"))) {
|
if ((fp = popen (cmd, "r"))) {
|
||||||
buffer = xmalloc (sizeof (char) * RC_LINEBUFFER);
|
desc = rc_getline (fp);
|
||||||
while (fgets (buffer, RC_LINEBUFFER, fp)) {
|
|
||||||
if (! desc) {
|
|
||||||
desc = xmalloc (strlen (buffer) + 1);
|
|
||||||
*desc = '\0';
|
|
||||||
} else {
|
|
||||||
desc = xrealloc (desc, strlen (desc) + strlen (buffer) + 1);
|
|
||||||
}
|
|
||||||
i = strlen (desc);
|
|
||||||
memcpy (desc + i, buffer, strlen (buffer));
|
|
||||||
memset (desc + i + strlen (buffer), 0, 1);
|
|
||||||
}
|
|
||||||
free (buffer);
|
|
||||||
pclose (fp);
|
pclose (fp);
|
||||||
}
|
}
|
||||||
free (cmd);
|
free (cmd);
|
||||||
@ -547,18 +529,17 @@ librc_hidden_def(rc_service_state)
|
|||||||
char *rc_service_value_get (const char *service, const char *option)
|
char *rc_service_value_get (const char *service, const char *option)
|
||||||
{
|
{
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
char *buffer = NULL;
|
char *line = NULL;
|
||||||
char *file = rc_strcatpaths (RC_SVCDIR, "options", service, option,
|
char *file = rc_strcatpaths (RC_SVCDIR, "options", service, option,
|
||||||
(char *) NULL);
|
(char *) NULL);
|
||||||
|
|
||||||
if ((fp = fopen (file, "r"))) {
|
if ((fp = fopen (file, "r"))) {
|
||||||
buffer = xmalloc (sizeof (char) * RC_LINEBUFFER);
|
line = rc_getline (fp);
|
||||||
fgets (buffer, RC_LINEBUFFER, fp);
|
|
||||||
fclose (fp);
|
fclose (fp);
|
||||||
}
|
}
|
||||||
free (file);
|
free (file);
|
||||||
|
|
||||||
return (buffer);
|
return (line);
|
||||||
}
|
}
|
||||||
librc_hidden_def(rc_service_value_get)
|
librc_hidden_def(rc_service_value_get)
|
||||||
|
|
||||||
|
@ -83,6 +83,7 @@ librc_hidden_proto(rc_deptree_order)
|
|||||||
librc_hidden_proto(rc_deptree_update)
|
librc_hidden_proto(rc_deptree_update)
|
||||||
librc_hidden_proto(rc_deptree_update_needed)
|
librc_hidden_proto(rc_deptree_update_needed)
|
||||||
librc_hidden_proto(rc_find_pids)
|
librc_hidden_proto(rc_find_pids)
|
||||||
|
librc_hidden_proto(rc_getline)
|
||||||
librc_hidden_proto(rc_runlevel_exists)
|
librc_hidden_proto(rc_runlevel_exists)
|
||||||
librc_hidden_proto(rc_runlevel_get)
|
librc_hidden_proto(rc_runlevel_get)
|
||||||
librc_hidden_proto(rc_runlevel_list)
|
librc_hidden_proto(rc_runlevel_list)
|
||||||
|
@ -39,6 +39,7 @@
|
|||||||
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
/*! @name Reserved runlevel names */
|
/*! @name Reserved runlevel names */
|
||||||
#define RC_LEVEL_SYSINIT "sysinit"
|
#define RC_LEVEL_SYSINIT "sysinit"
|
||||||
@ -347,6 +348,9 @@ extern FILE *rc_environ_fd;
|
|||||||
|
|
||||||
/*! @name Configuration
|
/*! @name Configuration
|
||||||
* These functions help to deal with shell based configuration files */
|
* These functions help to deal with shell based configuration files */
|
||||||
|
/*! Return a line from a file, stripping the trailing newline. */
|
||||||
|
char *rc_getline (FILE *fp);
|
||||||
|
|
||||||
/*! Return a NULL terminated list of non comment lines from a file. */
|
/*! Return a NULL terminated list of non comment lines from a file. */
|
||||||
char **rc_config_list (const char *file);
|
char **rc_config_list (const char *file);
|
||||||
|
|
||||||
|
@ -12,6 +12,7 @@ global:
|
|||||||
rc_deptree_update_needed;
|
rc_deptree_update_needed;
|
||||||
rc_environ_fd;
|
rc_environ_fd;
|
||||||
rc_find_pids;
|
rc_find_pids;
|
||||||
|
rc_getline;
|
||||||
rc_runlevel_exists;
|
rc_runlevel_exists;
|
||||||
rc_runlevel_get;
|
rc_runlevel_get;
|
||||||
rc_runlevel_list;
|
rc_runlevel_list;
|
||||||
|
@ -65,9 +65,6 @@
|
|||||||
|
|
||||||
#define RC_PLUGINDIR RC_LIBDIR "/plugins"
|
#define RC_PLUGINDIR RC_LIBDIR "/plugins"
|
||||||
|
|
||||||
/* Max buffer to read a line from a file */
|
|
||||||
#define RC_LINEBUFFER 4096
|
|
||||||
|
|
||||||
#define ERRX fprintf (stderr, "out of memory\n"); exit (1)
|
#define ERRX fprintf (stderr, "out of memory\n"); exit (1)
|
||||||
|
|
||||||
static inline void *xmalloc (size_t size)
|
static inline void *xmalloc (size_t size)
|
||||||
|
@ -181,12 +181,12 @@ void rc_logger_open (const char *level)
|
|||||||
write_time (log, "started");
|
write_time (log, "started");
|
||||||
else {
|
else {
|
||||||
free (logbuf);
|
free (logbuf);
|
||||||
logbuf_size = RC_LINEBUFFER * 10;
|
logbuf_size = BUFSIZ * 10;
|
||||||
logbuf = xmalloc (sizeof (char) * logbuf_size);
|
logbuf = xmalloc (sizeof (char) * logbuf_size);
|
||||||
logbuf_len = 0;
|
logbuf_len = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
buffer = xmalloc (sizeof (char) * RC_LINEBUFFER);
|
buffer = xmalloc (sizeof (char) * BUFSIZ);
|
||||||
selfd = rc_logger_tty > signal_pipe[0] ? rc_logger_tty : signal_pipe[0];
|
selfd = rc_logger_tty > signal_pipe[0] ? rc_logger_tty : signal_pipe[0];
|
||||||
while (1) {
|
while (1) {
|
||||||
FD_ZERO (&rset);
|
FD_ZERO (&rset);
|
||||||
@ -200,15 +200,15 @@ void rc_logger_open (const char *level)
|
|||||||
|
|
||||||
if (s > 0) {
|
if (s > 0) {
|
||||||
if (FD_ISSET (rc_logger_tty, &rset)) {
|
if (FD_ISSET (rc_logger_tty, &rset)) {
|
||||||
memset (buffer, 0, RC_LINEBUFFER);
|
memset (buffer, 0, BUFSIZ);
|
||||||
bytes = read (rc_logger_tty, buffer, RC_LINEBUFFER);
|
bytes = read (rc_logger_tty, buffer, BUFSIZ);
|
||||||
write (STDOUT_FILENO, buffer, bytes);
|
write (STDOUT_FILENO, buffer, bytes);
|
||||||
|
|
||||||
if (log)
|
if (log)
|
||||||
write_log (fileno (log), buffer, bytes);
|
write_log (fileno (log), buffer, bytes);
|
||||||
else {
|
else {
|
||||||
if (logbuf_size - logbuf_len < bytes) {
|
if (logbuf_size - logbuf_len < bytes) {
|
||||||
logbuf_size += RC_LINEBUFFER * 10;
|
logbuf_size += BUFSIZ * 10;
|
||||||
logbuf = xrealloc (logbuf, sizeof (char ) *
|
logbuf = xrealloc (logbuf, sizeof (char ) *
|
||||||
logbuf_size);
|
logbuf_size);
|
||||||
}
|
}
|
||||||
|
@ -238,7 +238,7 @@ char **env_filter (void)
|
|||||||
static bool file_regex (const char *file, const char *regex)
|
static bool file_regex (const char *file, const char *regex)
|
||||||
{
|
{
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
char *buffer;
|
char *line;
|
||||||
regex_t re;
|
regex_t re;
|
||||||
bool retval = false;
|
bool retval = false;
|
||||||
int result;
|
int result;
|
||||||
@ -246,23 +246,22 @@ static bool file_regex (const char *file, const char *regex)
|
|||||||
if (! (fp = fopen (file, "r")))
|
if (! (fp = fopen (file, "r")))
|
||||||
return (false);
|
return (false);
|
||||||
|
|
||||||
buffer = xmalloc (sizeof (char) * RC_LINEBUFFER);
|
|
||||||
if ((result = regcomp (&re, regex, REG_EXTENDED | REG_NOSUB)) != 0) {
|
if ((result = regcomp (&re, regex, REG_EXTENDED | REG_NOSUB)) != 0) {
|
||||||
fclose (fp);
|
fclose (fp);
|
||||||
regerror (result, &re, buffer, RC_LINEBUFFER);
|
line = xmalloc (sizeof (char) * BUFSIZ);
|
||||||
fprintf (stderr, "file_regex: %s", buffer);
|
regerror (result, &re, line, BUFSIZ);
|
||||||
free (buffer);
|
fprintf (stderr, "file_regex: %s", line);
|
||||||
|
free (line);
|
||||||
return (false);
|
return (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
while (fgets (buffer, RC_LINEBUFFER, fp)) {
|
while ((line = rc_getline (fp))) {
|
||||||
if (regexec (&re, buffer, 0, NULL, 0) == 0)
|
if (regexec (&re, line, 0, NULL, 0) == 0)
|
||||||
{
|
|
||||||
retval = true;
|
retval = true;
|
||||||
|
free (line);
|
||||||
|
if (retval)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
free (buffer);
|
|
||||||
fclose (fp);
|
fclose (fp);
|
||||||
regfree (&re);
|
regfree (&re);
|
||||||
|
|
||||||
|
@ -197,10 +197,10 @@ void rc_plugin_run (rc_hook_t hook, const char *value)
|
|||||||
ssize_t nr;
|
ssize_t nr;
|
||||||
|
|
||||||
close (pfd[1]);
|
close (pfd[1]);
|
||||||
buffer = xmalloc (sizeof (char) * RC_LINEBUFFER);
|
buffer = xmalloc (sizeof (char) * BUFSIZ);
|
||||||
memset (buffer, 0, RC_LINEBUFFER);
|
memset (buffer, 0, BUFSIZ);
|
||||||
|
|
||||||
while ((nr = read (pfd[0], buffer, RC_LINEBUFFER)) > 0) {
|
while ((nr = read (pfd[0], buffer, BUFSIZ)) > 0) {
|
||||||
p = buffer;
|
p = buffer;
|
||||||
while (*p && p - buffer < nr) {
|
while (*p && p - buffer < nr) {
|
||||||
token = strsep (&p, "=");
|
token = strsep (&p, "=");
|
||||||
|
19
src/rc/rc.c
19
src/rc/rc.c
@ -479,7 +479,7 @@ static int do_shell_var (int argc, char **argv)
|
|||||||
static char *proc_getent (const char *ent)
|
static char *proc_getent (const char *ent)
|
||||||
{
|
{
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
char *buffer;
|
char *proc;
|
||||||
char *p;
|
char *p;
|
||||||
char *value = NULL;
|
char *value = NULL;
|
||||||
int i;
|
int i;
|
||||||
@ -492,18 +492,11 @@ static char *proc_getent (const char *ent)
|
|||||||
return (NULL);
|
return (NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
buffer = xmalloc (sizeof (char) * RC_LINEBUFFER);
|
if ((proc = rc_getline (fp)) &&
|
||||||
memset (buffer, 0, RC_LINEBUFFER);
|
(p = strstr (proc, ent)))
|
||||||
if (fgets (buffer, RC_LINEBUFFER, fp) &&
|
|
||||||
(p = strstr (buffer, ent)))
|
|
||||||
{
|
{
|
||||||
i = p - buffer;
|
i = p - proc;
|
||||||
if (i == '\0' || buffer[i - 1] == ' ') {
|
if (i == '\0' || proc[i - 1] == ' ') {
|
||||||
/* Trim the trailing carriage return if present */
|
|
||||||
i = strlen (buffer) - 1;
|
|
||||||
if (buffer[i] == '\n')
|
|
||||||
buffer[i] = 0;
|
|
||||||
|
|
||||||
p += strlen (ent);
|
p += strlen (ent);
|
||||||
if (*p == '=')
|
if (*p == '=')
|
||||||
p++;
|
p++;
|
||||||
@ -511,7 +504,7 @@ static char *proc_getent (const char *ent)
|
|||||||
}
|
}
|
||||||
} else
|
} else
|
||||||
errno = ENOENT;
|
errno = ENOENT;
|
||||||
free (buffer);
|
free (proc);
|
||||||
fclose (fp);
|
fclose (fp);
|
||||||
|
|
||||||
return (value);
|
return (value);
|
||||||
|
@ -451,7 +451,7 @@ static bool svc_exec (const char *arg1, const char *arg2)
|
|||||||
}
|
}
|
||||||
|
|
||||||
selfd = MAX (master_tty, signal_pipe[0]) + 1;
|
selfd = MAX (master_tty, signal_pipe[0]) + 1;
|
||||||
buffer = xmalloc (sizeof (char) * RC_LINEBUFFER);
|
buffer = xmalloc (sizeof (char) * BUFSIZ);
|
||||||
while (1) {
|
while (1) {
|
||||||
FD_ZERO (&rset);
|
FD_ZERO (&rset);
|
||||||
FD_SET (signal_pipe[0], &rset);
|
FD_SET (signal_pipe[0], &rset);
|
||||||
@ -467,7 +467,7 @@ static bool svc_exec (const char *arg1, const char *arg2)
|
|||||||
|
|
||||||
if (s > 0) {
|
if (s > 0) {
|
||||||
if (master_tty >= 0 && FD_ISSET (master_tty, &rset)) {
|
if (master_tty >= 0 && FD_ISSET (master_tty, &rset)) {
|
||||||
bytes = read (master_tty, buffer, RC_LINEBUFFER);
|
bytes = read (master_tty, buffer, BUFSIZ);
|
||||||
write_prefix (buffer, bytes, &prefixed);
|
write_prefix (buffer, bytes, &prefixed);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user