2006-11-13 Jim Meyering <jim@meyering.net>
+ Plug another technically-unimportant leak in sort.
+ * src/sort.c (main): Don't allocate memory for each new key here.
+ (insertkey): Allocate memory for each key here, instead.
+ (key_init): Rename from new_key. Don't allocate.
+
* src/sort.c (main): Plug a tiny memory leak.
Move declaration of local "minus" down to be nearer point of use.
}
}
-/* Insert key KEY at the end of the key list. */
+/* Insert a malloc'd copy of key KEY_ARG at the end of the key list. */
static void
-insertkey (struct keyfield *key)
+insertkey (struct keyfield *key_arg)
{
struct keyfield **p;
+ struct keyfield *key = xmalloc (sizeof *key);
+ *key = *key_arg;
for (p = &keylist; *p; p = &(*p)->next)
continue;
*p = key;
}
static struct keyfield *
-new_key (void)
+key_init (struct keyfield *key)
{
- struct keyfield *key = xzalloc (sizeof *key);
+ memset (key, 0, sizeof *key);
key->eword = SIZE_MAX;
return key;
}
main (int argc, char **argv)
{
struct keyfield *key;
+ struct keyfield key_buf;
struct keyfield gkey;
char const *s;
int c = 0;
{
/* Treat +POS1 [-POS2] as a key if possible; but silently
treat an operand as a file if it is not a valid +POS1. */
- key = new_key ();
+ key = key_init (&key_buf);
s = parse_field_count (optarg + 1, &key->sword, NULL);
if (s && *s == '.')
s = parse_field_count (s + 1, &key->schar, NULL);
break;
case 'k':
- key = new_key ();
+ key = key_init (&key_buf);
/* Get POS1. */
s = parse_field_count (optarg, &key->sword,