String splitting (second) example.
#include <stdio.h>
#include <stdlib.h>
int main(
int argc,
char **argv) {
fprintf(stderr,
"%s\n", status.
message);
goto err_failure;
}
for (uint32_t i = 0; i < argc - 3; i++) {
char *data = (
char *) node->
data;
printf("%d = %s\n", i, data);
if (strcmp(data, argv[i + 3]) != 0) {
fprintf(stderr, "Expected %s but got %s\n", argv[i + 3], data);
goto err_failure;
}
}
return EXIT_SUCCESS;
err_failure:
return EXIT_FAILURE;
}
const gru_node_t * gru_list_get(const gru_list_t *list, uint32_t position)
Gets a node from the list at the given position.
Definition: gru_list.c:214
void gru_list_destroy(gru_list_t **list)
Ensures that the list is properly destroyed.
Definition: gru_list.c:35
int main(int argc, char **argv)
Definition: gru_list_test.c:198
gru_export gru_status_t gru_status_new()
Copyright 2016 Otavio Rodolfo Piske.
Definition: gru_status.c:18
bool gru_status_error(const gru_status_t *status)
Checks for error status.
Definition: gru_status.c:83
gru_list_t * gru_split(const char *str, char sep, gru_status_t *status)
Split a string.
Definition: gru_util.c:78
void gru_split_clean(gru_list_t *list)
Cleans a string list returned by gru_split and free's the memory used by the strings created for each...
Definition: gru_util.c:99
Definition: gru_list.h:41
Definition: gru_node.h:25
const void * data
Definition: gru_node.h:28
Status type.
Definition: gru_status.h:47
char * message
Definition: gru_status.h:48