fix: clang tidy + made static what could be instead of malloc
This commit is contained in:
parent
de9173a71f
commit
71fadb1b4a
2 changed files with 44 additions and 165 deletions
|
|
@ -4,63 +4,6 @@
|
|||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
||||
struct list *list_prepend(struct list *list, void *value)
|
||||
{
|
||||
struct list *new_elt = malloc(sizeof(struct list));
|
||||
if (new_elt == NULL)
|
||||
{
|
||||
return NULL;
|
||||
}
|
||||
new_elt->next = list;
|
||||
new_elt->data = value;
|
||||
|
||||
return new_elt;
|
||||
}
|
||||
|
||||
size_t list_length(struct list *list)
|
||||
{
|
||||
size_t len = 0;
|
||||
while (list != NULL)
|
||||
{
|
||||
len++;
|
||||
list = list->next;
|
||||
}
|
||||
return len;
|
||||
}
|
||||
|
||||
void list_print(struct list *list)
|
||||
{
|
||||
if (list == NULL)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
while (list != NULL)
|
||||
{
|
||||
if (list->next != NULL)
|
||||
{
|
||||
printf("%p ", list->data);
|
||||
}
|
||||
else
|
||||
{
|
||||
printf("%p\n", list->data);
|
||||
}
|
||||
list = list->next;
|
||||
}
|
||||
}
|
||||
|
||||
void list_destroy(struct list *list)
|
||||
{
|
||||
struct list *elt = list;
|
||||
struct list *next_elt;
|
||||
while (elt != NULL)
|
||||
{
|
||||
next_elt = elt->next;
|
||||
free(elt);
|
||||
elt = next_elt;
|
||||
}
|
||||
}
|
||||
|
||||
struct list *list_append(struct list *list, void *value)
|
||||
{
|
||||
if (list == NULL)
|
||||
|
|
@ -93,36 +36,6 @@ struct list *list_append(struct list *list, void *value)
|
|||
*******************
|
||||
*
|
||||
*/
|
||||
|
||||
struct list *list_insert(struct list *list, void *value, size_t index)
|
||||
{
|
||||
if (list == NULL || index == 0)
|
||||
{
|
||||
struct list *new_elt = malloc(sizeof(struct list));
|
||||
new_elt->data = value;
|
||||
new_elt->next = list;
|
||||
return new_elt;
|
||||
}
|
||||
|
||||
struct list *elt = list;
|
||||
|
||||
for (size_t i = 0; i < index - 1; i++)
|
||||
{
|
||||
if (elt->next == NULL)
|
||||
{
|
||||
break;
|
||||
}
|
||||
elt = elt->next;
|
||||
}
|
||||
|
||||
struct list *new_elt = malloc(sizeof(struct list));
|
||||
new_elt->data = value;
|
||||
new_elt->next = elt->next;
|
||||
elt->next = new_elt;
|
||||
|
||||
return list;
|
||||
}
|
||||
|
||||
struct list *list_remove(struct list *list, size_t index)
|
||||
{
|
||||
struct list *elt = list;
|
||||
|
|
@ -204,40 +117,6 @@ static void swap_next(struct list *elt)
|
|||
elt->next->data = elt->data;
|
||||
elt->data = c;
|
||||
}
|
||||
struct list *list_sort(struct list *list)
|
||||
{
|
||||
// Bubble sort go !
|
||||
if (list == NULL)
|
||||
{
|
||||
return list;
|
||||
}
|
||||
struct list *elt = list;
|
||||
int len = 0;
|
||||
while (elt->next != NULL)
|
||||
{
|
||||
if (elt->data > elt->next->data)
|
||||
{
|
||||
swap_next(elt);
|
||||
}
|
||||
elt = elt->next;
|
||||
len++;
|
||||
}
|
||||
|
||||
for (int i = 1; i < len; i++)
|
||||
{
|
||||
elt = list;
|
||||
while (elt->next != NULL)
|
||||
{
|
||||
if (elt->data > elt->next->data)
|
||||
{
|
||||
swap_next(elt);
|
||||
}
|
||||
elt = elt->next;
|
||||
}
|
||||
}
|
||||
|
||||
return list;
|
||||
}
|
||||
|
||||
// Old proto
|
||||
// WARNING no malloc/free allowed (moulinette issue)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue