This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
haas:fall2014:data:projects:node1 [2014/09/21 21:31] – [Your task] wedge | haas:fall2014:data:projects:node1 [2014/09/21 22:02] (current) – [node library] wedge | ||
---|---|---|---|
Line 204: | Line 204: | ||
None of these files denote an entire runnable program. These are merely standalone functions. The various programs under the **testing/ | None of these files denote an entire runnable program. These are merely standalone functions. The various programs under the **testing/ | ||
+ | You will also notice there are function prototypes for these node library functions in the **node.h** header file, located in the **inc/** subdirectory, | ||
+ | |||
+ | The prototypes (taken right from **inc/ | ||
+ | |||
+ | <code c> | ||
+ | Node *mknode(int | ||
+ | Node *rmnode(Node *); // deallocate node | ||
+ | Node *cpnode(Node *); // duplicate node | ||
+ | </ | ||
+ | |||
+ | This is your API for the node library. In order to use the node library three things need to happen: | ||
+ | |||
+ | * you must **#include " | ||
+ | * you must link against **lib/ | ||
+ | * you must call the functions providing the appropriate arguments and handling the return values | ||
+ | |||
+ | In general, this is no different than what you've already done, each and every time you've used **printf()**, | ||
+ | |||
+ | The compiler does a lot of behind-the-scenes work (linking against the C standard library by default, so all you have to do is include **stdio.h** and/or **stdlib.h**). | ||
+ | |||
+ | If you've ever played with the math library, you've had a slightly closer look, as such code wouldn' | ||
+ | |||
+ | Again, same details apply here, only the Makefile system automates the library linking. All we have to do is **# | ||
====Node library unit tests==== | ====Node library unit tests==== | ||
In **testing/ | In **testing/ | ||
Line 317: | Line 340: | ||
This project has you making changes to 3 files, all in the **testing/ | This project has you making changes to 3 files, all in the **testing/ | ||
+ | * **node-app-arrtolist.c** - convert an existing array to a linked list | ||
+ | * **node-app-display2.c** | ||
+ | * **node-app-test3.c** | ||
+ | |||
+ | In addition to the stated tasks, you are to convert the code in these 3 programs to use node library functions (i.e. once complete, you should no longer be calling **malloc()** to create new nodes, and you shouldn' | ||
+ | |||
+ | =====node-app-test3===== | ||
+ | A big aspect of the **node0** and **node1** projects is to get you acclimated to the overall structure of the project organization, | ||
+ | |||
+ | So, along that path, your task with **node-app-test3** is to re-implement the functionality of **node-app-test2** (previously provided as a complete running program in the **node0** project), and to convert it over to using node library functions. | ||
+ | |||
+ | That means: | ||
+ | |||
+ | * no more explicit **malloc()** calls, value initializations to 0, initial next pointers to NULL; use **mknode()** instead | ||
+ | * use of **cpnode()** where you have instances of duplicated nodes (this DOES happen in **node-app-test2**. | ||
+ | |||
+ | You are to get a program that produces the same functional output (obviously with different displayed addresses), by using the node library and its functions. | ||
+ | |||
+ | The skeleton is there, you just need to adapt the code. | ||
+ | |||
+ | =====node-app-arrtolist===== | ||
+ | As a means of testing your understanding, | ||
+ | |||
+ | Your task is to add in logic that builds a list, one node at a time, containing the same values (and in the same order) as is found in that array, and to then display the linked list to STDOUT, where we should see identical information. | ||
+ | |||
+ | Sample output of completed code should look like: | ||
<cli> | <cli> | ||
- | 6 -> 17 -> 23 -> 4 -> 56 -> 2 -> NULL | + | lab46: |
+ | Array: 3 1 4 1 5 9 2 6 5 3 5 8 9 7 | ||
+ | List: 3 1 4 1 5 9 2 6 5 3 5 8 9 7 | ||
+ | lab46: | ||
</ | </ | ||
- | It needs to work for whatever | + | As the array is defined with set values, your output, when complete and correct, should always be the same. This tends to be a good exercise in demonstrating you understand conceptually what is going on and can perform the necessary node manipulations |
+ | |||
+ | Again, be sure to use node library functions (like **mknode()**) in this program. | ||
+ | |||
+ | =====node-app-display2===== | ||
+ | In the **node0** project we had to implement the display functionality for the list being built. | ||
+ | |||
+ | Here, we work with that same idea, only we change a few things around structurally in the program- the final output should still be the same, but the code to produce it will be different. | ||
+ | |||
+ | Basically, there are three items for you to address: | ||
- | You need to display | + | * convert your raw **malloc()** calls and node initializations |
+ | * switch | ||
+ | * your display functionality can remain a **while** | ||
+ | * move your display code into a dedicated **display()** function, which takes as a parameter a Node pointer pointing | ||
+ | * This starts warming us up to future projects, where we'll be using and calling lots of functions | ||
- | Finally, when you have exhausted your list, display | + | The output should be the same as experienced in **node-app-display**, the first version |
=====Submission Criteria===== | =====Submission Criteria===== | ||
Line 332: | Line 397: | ||
* Code must compile cleanly (no warnings or errors) | * Code must compile cleanly (no warnings or errors) | ||
+ | * **node-app-test3**, | ||
* Executed programs must display in a manner similar to provided output | * Executed programs must display in a manner similar to provided output | ||
* Processing must be correct based on input given and output requested | * Processing must be correct based on input given and output requested |