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:19] – [Your task] wedge | haas:fall2014:data:projects:node1 [2014/09/21 22:02] (current) – [node library] wedge | ||
---|---|---|---|
Line 187: | Line 187: | ||
As such, it is most advisable to have completed work on **node1** before upgrading to the **sll0** project, so any work you've done will be immediately available to build upon in the next project (the projects will be comprehensive to one another-- **sll0** will rely on work completed in **node1**, **sll1** (the project after **sll0**) will rely on the work done in **sll0**, etc.). | As such, it is most advisable to have completed work on **node1** before upgrading to the **sll0** project, so any work you've done will be immediately available to build upon in the next project (the projects will be comprehensive to one another-- **sll0** will rely on work completed in **node1**, **sll1** (the project after **sll0**) will rely on the work done in **sll0**, etc.). | ||
- | =====Project | + | =====Project |
- | In **testing/ | + | |
- | Take a look at the code already there. Figure out what is going on, make sure you understand it. It builds a list of nodes based on user input. | + | ====node library==== |
+ | In **src/ | ||
- | If you look at the bottom of the program, you' | + | Take a look at the code there. These are the files that contain functions which will be compiled and archived into the node library (**libnode.a**) we will be using in this and future projects. |
+ | |||
+ | Figure out what is going on, make sure you understand it. | ||
+ | |||
+ | There are 3 functions in the node library: | ||
+ | |||
+ | * **mknode()** - creates and initializes a new node, eliminating your need to manually run **malloc()** for new nodes | ||
+ | * **cpnode()** - duplicates an existing node | ||
+ | * **rmnode()** - removes/ | ||
+ | |||
+ | None of these files denote an entire runnable | ||
+ | |||
+ | 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> | <code c> | ||
- | // Display list from start to end | + | Node *mknode(int |
+ | Node *rmnode(Node *); // deallocate node | ||
+ | Node *cpnode(Node *); // duplicate node | ||
</ | </ | ||
- | It is here I would like for you to add code that will display | + | 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==== | ||
+ | In **testing/ | ||
+ | |||
+ | * **unit-cpnode.c** - unit test for **cpnode()** library function | ||
+ | * **unit-mknode.c** - unit test for **mknode()** library function | ||
+ | * **unit-rmnode.c** - unit test for **rmnode()** library function | ||
+ | |||
+ | These are complete runnable programs (when compiled, and linked against | ||
+ | |||
+ | Of particular importance, I want you to take a close look at: | ||
+ | |||
+ | * the source code to each of these unit tests | ||
+ | * the purpose | ||
+ | * follow the logic | ||
+ | * make sure you understand what is going on | ||
+ | * ask questions to get clarification! | ||
+ | * the output | ||
+ | * analyze the output | ||
+ | * make sure you understand what is going on | ||
+ | * ask questions | ||
+ | |||
+ | ====Node application programs==== | ||
+ | Once again we find ourselves in **testing/ | ||
+ | |||
+ | * **node-app-arrtolist.c** | ||
+ | * **node-app-display2.c** | ||
+ | * **node-app-test3.c** | ||
+ | Take a look at these new additions. Your task for this project will involve implementing requested functionality/ | ||
====Building the code==== | ====Building the code==== | ||
You've made changes to **node-app-display2.c**, | You've made changes to **node-app-display2.c**, | ||
Line 253: | Line 309: | ||
====Run the program==== | ====Run the program==== | ||
- | To run **node-app-display**, we'd do the following (specify a relative path to the executable): | + | To run **node-app-display2**, we'd do the following (specify a relative path to the executable): |
<cli> | <cli> | ||
Line 282: | Line 338: | ||
======Your task====== | ======Your task====== | ||
- | You are specifically responsible | + | 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 | ||
<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 298: | 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 |