GRU - Generic Reusable Utilities
Loading...
Searching...
No Matches
string/gru_serialize_test.c

String serialization example.

String serialization example

/*
* Copyright 2017 Otavio Piske <angusyoung@gmail.com>.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include <stdio.h>
#include <stdlib.h>
int main(int argc, char **argv) {
gru_list_t *list = gru_list_new(&status);
gru_list_append(list, "fedora");
gru_list_append(list, "freebsd");
gru_list_append(list, "gentoo");
gru_list_append(list, "debian");
gru_list_append(list, "ubuntu");
gru_list_append(list, "red hat");
char *str = gru_str_serialize(list, ',', &status);
if (strcmp(str, "fedora,freebsd,gentoo,debian,ubuntu,red hat") != 0) {
fprintf(
stderr, "The returned string '%s' does not match the expected one\n", str);
return EXIT_FAILURE;
}
return EXIT_SUCCESS;
}
void gru_dealloc_string(char **obj)
Deallocate a block of memory used by a char * and set its pointer to NULL.
Definition: gru_alloc.c:32
const gru_node_t * gru_list_append(gru_list_t *list, const void *data)
Appends an item in the list.
Definition: gru_list.c:100
gru_list_t * gru_list_new(gru_status_t *status)
Creates a new list.
Definition: gru_list.c:18
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
char * gru_str_serialize(gru_list_t *list, char sep, gru_status_t *status)
Serializes a string list.
Definition: gru_util.c:103
Definition: gru_list.h:41
Status type.
Definition: gru_status.h:47