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.