1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | #include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>
#include <assert.h>
// From questions after lecture. Untested illustration.
// OKAY TO COPY/ADAPT ANYTHING IN THIS FILE.
static void _destroy_do_nothing(void const* value) {
// This is for lists where the value is not on the heap.
}
static int _test_list_of_size_1() {
mu_start();
//────────────────────
Node* head = NULL;
int value = 10;
stack_push(&head, &value); // Note: passing 'value' (without '*') would not work.
// Now, we have a list of size 1: [10|∙]→NULL
mu_check(head != NULL);
mu_check(head -> value == value);
mu_check(head -> next == NULL);
destroy_list(&head);
mu_check(head == NULL); // make sure destroy_list(…) set head to NULL to prevent us
// from accidentally using that memory after it has been freed.
//────────────────────
mu_end();
}
int main(int argc, char* argv[]) {
return EXIT_SUCCESS;
}
/* vim: set tabstop=4 shiftwidth=4 fileencoding=utf-8 noexpandtab: */
|
© Copyright 2022 Alexander J. Quinn This content is protected and may not be shared, uploaded, or distributed.