From e8ae8fbeab89beb43138e26465965d3510edd1c7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EA=A6=8C=20=EA=A6=AB=EA=A6=B6=20=EA=A6=8F=EA=A7=80?= =?UTF-8?q?=EA=A6=A6=EA=A6=BF=20=EA=A6=A7=20=EA=A6=AE=20=EA=A6=91=20?= =?UTF-8?q?=EA=A6=A9=20=EA=A6=AD=EA=A7=80?= Date: Tue, 22 Oct 2019 18:07:36 +0800 Subject: Corrected qsort and bsearch usages --- client.c | 25 +++++++++++++++---------- 1 file changed, 15 insertions(+), 10 deletions(-) diff --git a/client.c b/client.c index 4ead161..d796d6e 100644 --- a/client.c +++ b/client.c @@ -43,32 +43,37 @@ void icclient_allproducts(size_t (*handler)(void *, size_t, size_t, void *) static int prodcmp(const void *product1, const void *product2) { - return strcmp(((icclient_product *)product1)->sku - , ((icclient_product *)product2)->sku); + return strcmp((*(icclient_product * const *)product1)->sku + , (*(icclient_product * const *)product2)->sku); } static int itemcmp(const void *item1, const void *item2) { - return strcmp(((icclient_ord_item *)item1)->product->sku - , ((icclient_ord_item *)item2)->product->sku); + return strcmp((*(icclient_ord_item * const *)item1)->product->sku + , (*(icclient_ord_item * const *)item2)->product->sku); } void icclient_order(icclient_ord_order **orderptr, const char *sku , icclient_catalog *catalog) { icclient_product **products = catalog->products; - qsort(products, catalog->length, sizeof(icclient_product), prodcmp); - icclient_product *product = bsearch(sku, products, catalog->length - , sizeof(icclient_product), prodcmp); + qsort(products, catalog->length, sizeof(icclient_product *), prodcmp); + icclient_product *key = malloc(sizeof(icclient_product)); + key->sku = malloc(strlen(sku) + 1); + strcpy(key->sku, sku); + icclient_product *product = bsearch(&key, products, catalog->length + , sizeof(icclient_product *), prodcmp); + free(key->sku); + free(key); icclient_ord_order *order = *orderptr; icclient_ord_item *item = NULL; if (order && order->nitems) { icclient_ord_item **items = order->items; - qsort(items, order->nitems, sizeof(icclient_ord_item), itemcmp); - item = bsearch(sku, items, order->nitems, sizeof(icclient_ord_item) - , itemcmp); + qsort(items, order->nitems, sizeof(icclient_ord_item *), itemcmp); + item = bsearch(sku, items, order->nitems + , sizeof(icclient_ord_item *), itemcmp); } else { *orderptr = malloc(sizeof(icclient_ord_order)); order = *orderptr; -- cgit v1.2.3