This shows you the differences between two versions of the page.
Next revision | Previous revision | ||
haas:fall2022:data:projects:dll1 [2017/10/22 22:29] – created - external edit 127.0.0.1 | haas:fall2022:data:projects:dll1 [2022/10/15 12:18] (current) – [OVERVIEW] wedge | ||
---|---|---|---|
Line 4: | Line 4: | ||
</ | </ | ||
- | ======Project: DLL1====== | + | ======PROJECT: Lists - Doubly-Linked Lists of Nodes (DLL1)====== |
- | =====Errata===== | + | =====OBJECTIVE===== |
- | This section will document any updates applied to the project | + | To continue our journey on doubly-linked data structures, and collaboratively authoring and documenting |
- | * __revision #__: < | + | =====OVERVIEW===== |
+ | We continue now delving into the realm of doubly-linked data structures. This project: we complete on our doubly-linked list implementation. | ||
- | =====Objective===== | + | =====UPGRADING===== |
- | In this project, | + | To assist with consistency across all implementations, |
- | =====Procedure to Obtain dll1===== | + | Simply go into the project |
- | As this project | + | |
<cli> | <cli> | ||
- | lab46: | + | lab46: |
- | ... | + | |
</ | </ | ||
- | =====Project Overview===== | + | =====EDIT===== |
+ | You will want to go [[/ | ||
- | As we started with the last project, we're implementing the remaining functions of our new doubly linked list implementation. | + | * [[/ |
- | As such, new function prototypes have been added to the list.h header file: | + | {{page> |
- | <code c> | + | =====SUBMISSION===== |
- | code_t | + | To be successful in this project, the following criteria (or their equivalent) must be met: |
- | code_t | + | |
- | code_t | + | * Late submissions will lose 33% credit per day, with the submission window closing on the 3rd day following the deadline. |
+ | * All code must compile cleanly | ||
+ | | ||
+ | * all requested functionality | ||
+ | * Executed programs must display in a manner similar to provided output | ||
+ | * output | ||
+ | * Processing must be correct based on input given and output requested | ||
+ | * Output, if applicable, must be correct based on values input | ||
+ | * Code must be nicely and consistently indented | ||
+ | * Code must be consistently written, to strive for readability from having a consistent style throughout | ||
+ | * Code must be commented | ||
+ | * Any "to be implemented" | ||
+ | * these " | ||
+ | * Sufficient | ||
+ | * No global variables (without instructor approval), no goto statements, no calling of main()! | ||
+ | * Track/version the source code in your lab46 semester repository | ||
+ | | ||
- | code_t | + | ====Submit Tool Usage==== |
+ | Let' | ||
+ | submit, you would do the following: | ||
- | code_t | + | < |
- | code_t | + | lab46:~/src/SEMESTER/DESIG/PROJECT$ make submit |
- | </code> | + | </cli> |
- | These functions will also make use of the status/ | + | You should get some sort of confirmation indicating successful submission |
+ | if all went according to plan. If not, check for typos and or locational | ||
+ | mismatches. | ||
- | The recommended order of implementation is: | + | =====RUBRIC===== |
+ | I'll be evaluating the project based on the following criteria: | ||
- | - **obtain()** | + | < |
- | - **empty()** | + | 91: |
- | - **rmlist()** | + | *: |
- | - **compare()** | + | *:dll1:clean compile, no compiler messages [13/13] |
- | - **swapnode()** | + | *: |
- | | + | *: |
- | + | *: | |
- | Implementing them out of order will likely result in unnecessary duplication of efforts, and I really don't want to see a half dozen half-baked **obtain()** implementations dribbled throughout your code. | + | *: |
- | + | ||
- | ====list operation status codes==== | + | |
- | Just as with dll0, you'll notice the presence of a set of # | + | |
- | + | ||
- | They are not exclusive- in some cases, multiple states can be applied. The intent is that you will OR together all pertinent states and return that from the function. | + | |
- | + | ||
- | * **DLL_SUCCESS** - everything went according | + | |
- | * **DLL_MALLOC_FAIL** - memory allocation failed (considered in error) | + | |
- | * **DLL_ALREADY_ALLOC** - memory has already been allocated (considered in error) | + | |
- | * **DLL_NULL** - result is NULL (probably in error) | + | |
- | * **DLL_EMPTY** - result is an empty list (may or may not be in error) | + | |
- | * **DLL_DEFAULT_FAIL** - default state of unimplemented functions (default error) | + | |
- | * **DLL_ERROR** - some error occurred | + | |
- | * **DLL_INVALID** - invalid list condition | + | |
- | + | ||
- | For example, in the case of " | + | |
- | * DLL_ERROR (a problem has occurred) | + | |
- | * DLL_MALLOC_FAIL (a problem has occurred when using malloc()) | + | |
- | * DLL_NULL (no memory allocated, so list cannot be anything but NULL) | + | |
- | + | ||
- | ALL THREE states must be returned from the function in question should such an occurrence take place. | + | |
- | + | ||
- | ===compare status codes=== | + | |
- | dll1 introduces additional status codes for one of its functions: **compare()** | + | |
- | + | ||
- | Those codes are as follows: | + | |
- | + | ||
- | <code c> | + | |
- | ////////////////////////////////////////////////////////////////////// | + | |
- | // | + | |
- | // Status codes for the doubly-linked list compare() function | + | |
- | // | + | |
- | # | + | |
- | # | + | |
- | # | + | |
- | # | + | |
- | # | + | |
- | # | + | |
- | # | + | |
- | # | + | |
- | # | + | |
- | # | + | |
- | # | + | |
</ | </ | ||
- | ====list library==== | ||
- | In **src/ | ||
- | Figure out what is going on, the connections, | + | ===Pertaining to the collaborative authoring of project documentation=== |
- | Be sure to focus on implementing | + | * each class member is to participate in the contribution of relevant information and formatting of the documentation |
+ | * minimal member contributions consist of: | ||
+ | * near the class average edits (a value of at least four productive edits) | ||
+ | * near the average class content change average (a value of at least 256 bytes (absolute value of data content change)) | ||
+ | * near the class content contribution average (a value of at least 1kiB) | ||
+ | * no adding in one commit then later removing in its entirety for the sake of satisfying edit requirements | ||
+ | * adding and formatting data in an organized fashion, aiming to create an informative and readable document that anyone in the class can reference | ||
+ | * content contributions | ||
+ | * no contributions, | ||
+ | * less than minimum contributions is 0.75 | ||
+ | * met minimum contribution threshold is 1.00 | ||
- | ====List library unit tests==== | + | ===Additionally=== |
- | In **unit/ | + | |
- | * **unit-obtain.c** - unit test for **obtain()** library function | + | * Solutions not abiding |
- | * **unit-empty.c** - unit test for **empty()** library function | + | * Solutions |
- | * **unit-rmlist.c** - unit test for **rmlist()** library function | + | * Solutions not utilizing indentation |
- | * **unit-compare.c** - unit test for **compare()** library function | + | * Solutions |
- | * **unit-swap.c** - unit test for **swapnode()** library function | + | |
- | * **unit-sort.c** - unit test for **sortlist()** library function | + | |
- | + | ||
- | Enhancements | + | |
- | + | ||
- | There are also corresponding | + | |
- | + | ||
- | These are complete runnable programs (when compiled, | + | |
- | + | ||
- | Of particular importance, I want you to take a close look at: | + | |
- | + | ||
- | * the source code to each of these unit tests | + | |
- | * the purpose of these programs is to validate the correct functionality of the respective library functions | + | |
- | * follow the logic | + | |
- | * make sure you understand what is going on | + | |
- | * ask questions to get clarification! | + | |
- | * the output from these programs once compiled and ran | + | |
- | * analyze the output | + | |
- | * make sure you understand what is going on | + | |
- | * ask questions to get clarification! | + | |
- | + | ||
- | Also note that, while considerable effort was made to ensure a broad range of tests were incorporated into each unit test, they are by no means a complete nor exhaustive battery of tests. There may be scenarios the unit tests do not currently check for. You are welcome | + | |
- | + | ||
- | ====List library applications==== | + | |
- | + | ||
- | ===palindrome=== | + | |
- | Now that we've completed our doubly-linked list functionality, | + | |
- | + | ||
- | Our endeavor here will be to revisit that of palindromes (ie words/ | + | |
- | + | ||
- | This implementation will be considered an extra credit opportunity, | + | |
- | + | ||
- | It is also highly recommended to undertake as it will give you further experience working with these concepts. | + | |
- | + | ||
- | =====Expected Results===== | + | |
- | To assist you in verifying a correct implementation, | + | |
- | + | ||
- | ====list library==== | + | |
- | Here is what you should get for list: | + | |
- | + | ||
- | < | + | |
- | lab46: | + | |
- | ====================================================== | + | |
- | = Verifying Doubly-Linked | + | |
- | ====================================================== | + | |
- | [obtain] Total: | + | |
- | | + | |
- | [rmlist] Total: | + | |
- | | + | |
- | [swapnode] Total: | + | |
- | [sortlist] Total: | + | |
- | ====================================================== | + | |
- | | + | |
- | ====================================================== | + | |
- | lab46: | + | |
- | </ | + | |
- | =====Submission===== | + | |
- | {{page> | + | |