[hackers] [dmenu] readstdin: allocate amount of items || Hiltjo Posthuma
 
commit ba1a347dcaba055f824161007dfee60db3ea785b
Author:     Hiltjo Posthuma <hiltjo_AT_codemadness.org>
AuthorDate: Mon Oct 31 11:52:30 2022 +0100
Commit:     Hiltjo Posthuma <hiltjo_AT_codemadness.org>
CommitDate: Mon Oct 31 11:52:30 2022 +0100
    readstdin: allocate amount of items
    
    Keep track of the amount of items (not a total buffer size), allocate an array of
    new items. For now change BUFSIZ bytes to 256 * sizeof(struct item)).
diff --git a/dmenu.c b/dmenu.c
index 8d96b6c..27b7a30 100644
--- a/dmenu.c
+++ b/dmenu.c
_AT_@ -550,14 +550,16 @@ static void
 readstdin(void)
 {
         char *line = NULL;
-	size_t i, junk, size = 0;
+	size_t i, junk, itemsiz = 0;
         ssize_t len;
 
         /* read each line from stdin and add it to the item list */
         for (i = 0; (len = getline(&line, &junk, stdin)) != -1; i++) {
-		if (i + 1 >= size / sizeof *items)
-			if (!(items = realloc(items, (size += BUFSIZ))))
-				die("cannot realloc %zu bytes:", size);
+		if (i + 1 >= itemsiz) {
+			itemsiz += 256;
+			if (!(items = realloc(items, itemsiz * sizeof(*items))))
+				die("cannot realloc %zu bytes:", itemsiz * sizeof(*items));
+		}
                 if (line[len - 1] == '\n')
                         line[len - 1] = '\0';
                 items[i].text = line;
Received on Mon Oct 31 2022 - 11:56:03 CET
This archive was generated by hypermail 2.3.0
: Mon Oct 31 2022 - 12:00:41 CET