forked from github/server
review some flawfinder warnings
This commit is contained in:
parent
6f771ace3e
commit
ebe1df4cb9
2 changed files with 16 additions and 18 deletions
|
@ -164,10 +164,10 @@ static void free_functions(void)
|
||||||
|
|
||||||
void add_function(const char *symbol, evalfun parse)
|
void add_function(const char *symbol, evalfun parse)
|
||||||
{
|
{
|
||||||
char token[64];
|
char token[64]; /* Flawfinder: ignore */
|
||||||
size_t len = strlen(symbol);
|
size_t len = strlen(symbol);
|
||||||
|
|
||||||
assert(len + 1 + sizeof(parse) <= sizeof(token));
|
assert(len + sizeof(parse) < sizeof(token));
|
||||||
len = cb_new_kv(symbol, len, &parse, sizeof(parse), token);
|
len = cb_new_kv(symbol, len, &parse, sizeof(parse), token);
|
||||||
cb_insert(&functions, token, len);
|
cb_insert(&functions, token, len);
|
||||||
}
|
}
|
||||||
|
@ -193,15 +193,17 @@ static const char *parse_symbol(opstack ** stack, const char *in,
|
||||||
*/
|
*/
|
||||||
{
|
{
|
||||||
bool braces = false;
|
bool braces = false;
|
||||||
char symbol[32];
|
char symbol[32]; /* Flawfinder: ignore */
|
||||||
char *cp = symbol; /* current position */
|
char *cp = symbol; /* current position */
|
||||||
|
|
||||||
if (*in == '{') {
|
if (*in == '{') {
|
||||||
braces = true;
|
braces = true;
|
||||||
++in;
|
++in;
|
||||||
}
|
}
|
||||||
while (isalnum(*in) || *in == '.')
|
while (isalnum(*in) || *in == '.') {
|
||||||
*cp++ = *in++;
|
*cp++ = *in++;
|
||||||
|
assert(cp < symbol + sizeof(symbol));
|
||||||
|
}
|
||||||
*cp = '\0';
|
*cp = '\0';
|
||||||
/* symbol will now contain the symbol name */
|
/* symbol will now contain the symbol name */
|
||||||
if (*in == '(') {
|
if (*in == '(') {
|
||||||
|
@ -371,7 +373,7 @@ const char *translate(const char *format, const void *userdata,
|
||||||
{
|
{
|
||||||
unsigned int i = 0;
|
unsigned int i = 0;
|
||||||
const char *ic = vars;
|
const char *ic = vars;
|
||||||
char symbol[32];
|
char symbol[32]; /* Flawfinder: ignore */
|
||||||
char *oc = symbol;
|
char *oc = symbol;
|
||||||
opstack *stack = NULL;
|
opstack *stack = NULL;
|
||||||
const char *rv;
|
const char *rv;
|
||||||
|
@ -383,11 +385,15 @@ const char *translate(const char *format, const void *userdata,
|
||||||
assert(*ic == 0 || isalnum(*ic));
|
assert(*ic == 0 || isalnum(*ic));
|
||||||
while (*ic) {
|
while (*ic) {
|
||||||
*oc++ = *ic++;
|
*oc++ = *ic++;
|
||||||
|
assert(oc < symbol + sizeof(symbol));
|
||||||
if (!isalnum(*ic)) {
|
if (!isalnum(*ic)) {
|
||||||
|
size_t len;
|
||||||
variant x = args[i++];
|
variant x = args[i++];
|
||||||
*oc = '\0';
|
*oc = '\0';
|
||||||
|
len = oc - symbol + 1;
|
||||||
|
str_strlcpy(oc = balloc(len), symbol, len);
|
||||||
|
add_variable(oc, x);
|
||||||
oc = symbol;
|
oc = symbol;
|
||||||
add_variable(strcpy(balloc(strlen(symbol) + 1), symbol), x);
|
|
||||||
while (*ic && !isalnum(*ic))
|
while (*ic && !isalnum(*ic))
|
||||||
++ic;
|
++ic;
|
||||||
}
|
}
|
||||||
|
@ -452,22 +458,15 @@ static void eval_if(opstack ** stack, const void *userdata)
|
||||||
UNUSED_ARG(userdata);
|
UNUSED_ARG(userdata);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void eval_strlen(opstack ** stack, const void *userdata)
|
|
||||||
{ /* string -> int */
|
|
||||||
const char *c = (const char *)opop_v(stack);
|
|
||||||
opush_i(stack, c ? (int)strlen(c) : 0);
|
|
||||||
UNUSED_ARG(userdata);
|
|
||||||
}
|
|
||||||
|
|
||||||
#include "base36.h"
|
#include "base36.h"
|
||||||
static void eval_int(opstack ** stack, const void *userdata)
|
static void eval_int(opstack ** stack, const void *userdata)
|
||||||
{
|
{
|
||||||
int i = opop_i(stack);
|
int i = opop_i(stack);
|
||||||
const char *c = itoa10(i);
|
const char *c = itoa10(i);
|
||||||
size_t len = strlen(c);
|
size_t size = strlen(c) + 1; /* Flawfinder: ignore */
|
||||||
variant var;
|
variant var;
|
||||||
|
|
||||||
var.v = strcpy(balloc(len + 1), c);
|
str_strlcpy(var.v = balloc(size), c, size);
|
||||||
opush(stack, var);
|
opush(stack, var);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -477,7 +476,6 @@ void translation_init(void)
|
||||||
add_function("eq", &eval_eq);
|
add_function("eq", &eval_eq);
|
||||||
add_function("int", &eval_int);
|
add_function("int", &eval_int);
|
||||||
add_function("add", &eval_add);
|
add_function("add", &eval_add);
|
||||||
add_function("strlen", &eval_strlen);
|
|
||||||
add_function("if", &eval_if);
|
add_function("if", &eval_if);
|
||||||
add_function("isnull", &eval_isnull);
|
add_function("isnull", &eval_isnull);
|
||||||
}
|
}
|
||||||
|
|
|
@ -91,7 +91,7 @@ static int a_readdirection(variant *var, void *owner, struct gamedata *data)
|
||||||
{
|
{
|
||||||
struct storage *store = data->store;
|
struct storage *store = data->store;
|
||||||
spec_direction *d = (spec_direction *)(var->v);
|
spec_direction *d = (spec_direction *)(var->v);
|
||||||
char lbuf[32];
|
char lbuf[32]; /* Flawfinder: ignore */
|
||||||
|
|
||||||
(void)owner;
|
(void)owner;
|
||||||
READ_INT(store, &d->x);
|
READ_INT(store, &d->x);
|
||||||
|
@ -130,7 +130,7 @@ region *find_special_direction(const region * r, const char *token)
|
||||||
{
|
{
|
||||||
attrib *a;
|
attrib *a;
|
||||||
|
|
||||||
if (strlen(token) == 0)
|
if (*token == '\0')
|
||||||
return NULL;
|
return NULL;
|
||||||
for (a = a_find(r->attribs, &at_direction); a && a->type == &at_direction;
|
for (a = a_find(r->attribs, &at_direction); a && a->type == &at_direction;
|
||||||
a = a->next) {
|
a = a->next) {
|
||||||
|
|
Loading…
Reference in a new issue