2005-10-27 17:47:28 -04:00
|
|
|
$OpenBSD: patch-src_parse_c,v 1.5 2005/10/27 21:47:28 sturm Exp $
|
|
|
|
--- src/parse.c.orig Fri Sep 9 01:54:30 2005
|
|
|
|
+++ src/parse.c Fri Oct 21 16:35:56 2005
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -258,7 +258,7 @@ SetStrategies();
|
2004-06-17 07:21:42 -04:00
|
|
|
Debug1("\n\n==============================BEGIN NEW ACTION %s=============\n\n",ACTIONTEXT[action]);
|
|
|
|
|
|
|
|
ACTION = action;
|
|
|
|
-strcpy(ACTIONBUFF,ACTIONTEXT[action]);
|
|
|
|
+(void)strlcpy(ACTIONBUFF,ACTIONTEXT[action],CF_BUFSIZE);
|
|
|
|
|
|
|
|
switch (ACTION)
|
|
|
|
{
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -284,7 +284,7 @@ switch (ACTION)
|
2004-06-17 07:21:42 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
Debug1("\nResetting CLASS to ANY\n\n");
|
|
|
|
-strcpy(CLASSBUFF,CF_ANYCLASS); /* default class */
|
|
|
|
+(void)strlcpy(CLASSBUFF,CF_ANYCLASS,CF_BUFSIZE); /* default class */
|
|
|
|
}
|
|
|
|
|
|
|
|
/*******************************************************************/
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -300,7 +300,7 @@ Debug1("HandleLVALUE(%s) in action %s\n"
|
2004-06-17 07:21:42 -04:00
|
|
|
|
|
|
|
if ((CONTROLVAR = ScanVariable(id)) != nonexistentvar)
|
|
|
|
{
|
|
|
|
- strcpy(CURRENTITEM,id);
|
|
|
|
+ (void)strlcpy(CURRENTITEM,id,CF_BUFSIZE);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
else
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -341,7 +341,7 @@ Debug1("HandleLVALUE(%s) in action %s\n"
|
2004-06-17 07:21:42 -04:00
|
|
|
yyerror("Reserved class name (choose a different name)");
|
|
|
|
}
|
|
|
|
|
|
|
|
- strcpy(GROUPBUFF,id);
|
|
|
|
+ (void)strlcpy(GROUPBUFF,id,CF_BUFSIZE);
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -360,14 +360,14 @@ Debug1("HandleBraceObjectID(%s) in actio
|
2004-06-17 07:21:42 -04:00
|
|
|
switch (ACTION)
|
|
|
|
{
|
|
|
|
case acls:
|
|
|
|
- strcpy(CURRENTOBJECT,id);
|
|
|
|
+ (void)strlcpy(CURRENTOBJECT,id,CF_BUFSIZE);
|
|
|
|
InstallACL(id,CLASSBUFF);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case strategies:
|
|
|
|
if (strlen(STRATEGYNAME) == 0)
|
|
|
|
{
|
|
|
|
- strcpy(STRATEGYNAME,id);
|
|
|
|
+ (void)strlcpy(STRATEGYNAME,id,CF_BUFSIZE);
|
|
|
|
InstallStrategy(id,CLASSBUFF);
|
|
|
|
}
|
|
|
|
else
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -379,7 +379,7 @@ switch (ACTION)
|
2004-06-17 07:21:42 -04:00
|
|
|
case editfiles:
|
|
|
|
if (strlen(CURRENTOBJECT) == 0)
|
|
|
|
{
|
|
|
|
- strcpy(CURRENTOBJECT,id);
|
|
|
|
+ (void)strlcpy(CURRENTOBJECT,id,CF_BUFSIZE);
|
|
|
|
EDITGROUPLEVEL = 0;
|
|
|
|
FOREACHLEVEL = 0;
|
|
|
|
SEARCHREPLACELEVEL = 0;
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -393,7 +393,7 @@ switch (ACTION)
|
2004-06-17 07:21:42 -04:00
|
|
|
case filters:
|
|
|
|
if (strlen(FILTERNAME)==0)
|
|
|
|
{
|
|
|
|
- strcpy(FILTERNAME,id);
|
|
|
|
+ (void)strlcpy(FILTERNAME,id,CF_BUFSIZE);
|
|
|
|
InstallFilter(id);
|
|
|
|
}
|
|
|
|
else
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -419,7 +419,7 @@ switch (ACTION)
|
2004-06-17 07:21:42 -04:00
|
|
|
|
|
|
|
case filters:
|
|
|
|
case strategies:
|
|
|
|
- strcpy(CURRENTITEM,id);
|
|
|
|
+ (void)strlcpy(CURRENTITEM,id,CF_BUFSIZE);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case editfiles:
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -434,7 +434,7 @@ switch (ACTION)
|
2004-06-17 07:21:42 -04:00
|
|
|
HandleEdit(CURRENTOBJECT,id,NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
- strcpy(CURRENTITEM,id);
|
|
|
|
+ (void)strlcpy(CURRENTITEM,id,CF_BUFSIZE);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -470,7 +470,7 @@ else
|
2004-06-17 07:21:42 -04:00
|
|
|
Debug1("Simple class = (%s)\n",id);
|
|
|
|
}
|
|
|
|
|
|
|
|
-strcpy(CLASSBUFF,id);
|
|
|
|
+(void)strlcpy(CLASSBUFF,id,CF_BUFSIZE);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*******************************************************************/
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -487,13 +487,13 @@ switch (ACTION)
|
2004-06-17 07:21:42 -04:00
|
|
|
break;
|
|
|
|
|
|
|
|
case filters:
|
|
|
|
- strcpy(FILTERDATA,qstring);
|
|
|
|
+ (void)strlcpy(FILTERDATA,qstring,CF_BUFSIZE);
|
|
|
|
ACTIONPENDING = true;
|
|
|
|
InstallPending(ACTION);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case strategies:
|
|
|
|
- strcpy(STRATEGYDATA,qstring);
|
|
|
|
+ (void)strlcpy(STRATEGYDATA,qstring,CF_BUFSIZE);
|
|
|
|
ACTIONPENDING = true;
|
|
|
|
InstallPending(ACTION);
|
|
|
|
break;
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -507,7 +507,7 @@ switch (ACTION)
|
2004-06-17 07:21:42 -04:00
|
|
|
{
|
|
|
|
yyerror("Processes syntax error");
|
|
|
|
}
|
|
|
|
- strcpy(RESTART,qstring);
|
|
|
|
+ (void)strlcpy(RESTART,qstring,CF_BUFSIZE);
|
|
|
|
ACTIONPENDING = true;
|
|
|
|
InstallPending(ACTION);
|
|
|
|
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -531,7 +531,7 @@ switch (ACTION)
|
2004-06-17 07:21:42 -04:00
|
|
|
yyerror("Missing process search expression");
|
|
|
|
}
|
|
|
|
Debug1("Installing expression %s\n",qstring);
|
|
|
|
- strcpy(EXPR,qstring);
|
|
|
|
+ (void)strlcpy(EXPR,qstring,CF_BUFSIZE);
|
|
|
|
HAVE_RESTART = false;
|
|
|
|
}
|
|
|
|
else if (HAVE_RESTART)
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -645,7 +645,7 @@ if (!IsDefinedClass(CLASSBUFF))
|
2004-06-17 07:21:42 -04:00
|
|
|
if (IsBuiltinFunction(fn))
|
|
|
|
{
|
|
|
|
local[0] = '\0';
|
|
|
|
- strcpy(local,EvaluateFunction(fn,local));
|
|
|
|
+ (void)strlcpy(local,EvaluateFunction(fn,local),sizeof(local));
|
|
|
|
|
|
|
|
switch (ACTION)
|
|
|
|
{
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -852,8 +852,8 @@ switch (ACTION)
|
2004-06-17 07:21:42 -04:00
|
|
|
InstallPending(ACTION);
|
|
|
|
InitializeAction();
|
|
|
|
Debug1("\nFound SetOptionString\n");
|
|
|
|
- strcpy(CURRENTOBJECT,"SetOptionString");
|
|
|
|
- strcpy(EXPR,"SetOptionString");
|
|
|
|
+ (void)strlcpy(CURRENTOBJECT,"SetOptionString",CF_BUFSIZE);
|
|
|
|
+ (void)strlcpy(EXPR,"SetOptionString",CF_BUFSIZE);
|
|
|
|
}
|
|
|
|
else if (HAVE_RESTART)
|
|
|
|
{
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -898,7 +898,7 @@ Debug("HandleServerRule(%s=%s)\n",object
|
2004-06-17 07:21:42 -04:00
|
|
|
if (*buffer == '/')
|
|
|
|
{
|
|
|
|
Debug("\n\nNew admit/deny object=%s\n",buffer);
|
|
|
|
- strcpy(CURRENTAUTHPATH,object);
|
|
|
|
+ (void)strlcpy(CURRENTAUTHPATH,object,CF_BUFSIZE);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -1038,7 +1038,7 @@ if ((yyin = fopen(filename,"r")) == NULL
|
2004-06-17 07:21:42 -04:00
|
|
|
exit (1);
|
|
|
|
}
|
|
|
|
|
|
|
|
-strcpy(VCURRENTFILE,filename);
|
|
|
|
+(void)strlcpy(VCURRENTFILE,filename,CF_BUFSIZE);
|
|
|
|
|
|
|
|
Debug("\n##########################################################################\n");
|
|
|
|
Debug("# BEGIN PARSING %s\n",VCURRENTFILE);
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -1119,7 +1119,7 @@ void RecordMacroId(char *name)
|
2004-06-17 07:21:42 -04:00
|
|
|
|
|
|
|
{
|
|
|
|
Debug("RecordMacroId(%s)\n",name);
|
|
|
|
-strcpy(CURRENTITEM,name);
|
|
|
|
+(void)strlcpy(CURRENTITEM,name,CF_BUFSIZE);
|
|
|
|
|
|
|
|
if (strcmp(name,"this") == 0)
|
|
|
|
{
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -1149,7 +1149,7 @@ if ((sp=getenv(CF_INPUTSVAR)) != NULL)
|
2004-06-17 07:21:42 -04:00
|
|
|
{
|
|
|
|
if (!IsAbsoluteFileName(filename)) /* Don't prepend to absolute names */
|
|
|
|
{
|
|
|
|
- strcpy(result,sp);
|
|
|
|
+ (void)strlcpy(result,sp,CF_BUFSIZE);
|
|
|
|
|
|
|
|
if (! IsAbsoluteFileName(result))
|
|
|
|
{
|
2005-07-21 11:16:46 -04:00
|
|
|
@@ -1164,13 +1164,13 @@ if ((sp=getenv(CF_INPUTSVAR)) != NULL)
|
2004-06-17 07:21:42 -04:00
|
|
|
{
|
|
|
|
if (!IsAbsoluteFileName(filename)) /* Don't prepend to absolute names */
|
|
|
|
{
|
2005-07-21 11:16:46 -04:00
|
|
|
- strcpy(result,CFWORKDIR);
|
|
|
|
+ (void)strlcpy(result,CFWORKDIR,CF_BUFSIZE);
|
2004-06-17 07:21:42 -04:00
|
|
|
AddSlash(result);
|
|
|
|
- strcat(result,"inputs/");
|
|
|
|
+ (void)strlcat(result,"inputs/",CF_BUFSIZE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
-strcat(result,filename);
|
|
|
|
+(void)strlcat(result,filename,CF_BUFSIZE);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2005-10-27 17:47:28 -04:00
|
|
|
@@ -1201,8 +1201,8 @@ void InitializeAction()
|
2004-06-17 07:21:42 -04:00
|
|
|
HAVE_RESTART = false;
|
|
|
|
VAGE = 99999;
|
|
|
|
strncpy(FINDERTYPE,"*",CF_BUFSIZE);
|
|
|
|
- strcpy(VUIDNAME,"*");
|
|
|
|
- strcpy(VGIDNAME,"*");
|
|
|
|
+ (void)strlcpy(VUIDNAME,"*",CF_MAXVARSIZE);
|
|
|
|
+ (void)strlcpy(VGIDNAME,"*",CF_MAXVARSIZE);
|
|
|
|
HAVE_RESTART = 0;
|
|
|
|
FILEACTION=warnall;
|
|
|
|
PIFELAPSED=-1;
|
2005-10-27 17:47:28 -04:00
|
|
|
@@ -1223,7 +1223,7 @@ void InitializeAction()
|
2004-10-01 17:22:15 -04:00
|
|
|
PARSEMETHODRETURNCLASSES[0] = '\0';
|
2004-06-17 07:21:42 -04:00
|
|
|
METHODFORCE[0] = '\0';
|
|
|
|
CHROOT[0] = '\0';
|
|
|
|
- strcpy(VIFNAME,"");
|
|
|
|
+ (void)strlcpy(VIFNAME,"",sizeof(VIFNAME));
|
|
|
|
PTRAVLINKS = (short) '?';
|
|
|
|
IMAGEBACKUP = 'y';
|
|
|
|
ENCRYPT = 'n';
|
2005-10-27 17:47:28 -04:00
|
|
|
@@ -1266,7 +1266,7 @@ void InitializeAction()
|
2004-06-17 07:21:42 -04:00
|
|
|
memset(ALLCLASSBUFFER,0,CF_BUFSIZE);
|
|
|
|
memset(ELSECLASSBUFFER,0,CF_BUFSIZE);
|
|
|
|
|
|
|
|
- strcpy(CFSERVER,"localhost");
|
|
|
|
+ (void)strlcpy(CFSERVER,"localhost",CF_MAXVARSIZE);
|
|
|
|
|
|
|
|
IMGCOMP = DISCOMP='>';
|
|
|
|
IMGSIZE = DISABLESIZE=CF_NOSIZE;
|