Program for implementation of a data storage system, C/C++ Programming

Assignment Help:

Introduction: 

This assignment requires a knowledge of variables (integers, char types), loops, conditionals, switch, functions, char arrays, string arrays, number arrays, structs, character input and output, file I/O, string functions, static and function calls.   

The assignment:

Develop and submit an original implementation of a Data Storage System. The user will be presented with a login screen based on the solution to assignment 2. Once logged in, the user will be presented with a menu offering the following options:

New Application

View Applications

Delete Application

New User

New Application added functionality of data storage in a loan file. Assume that all data fields are compulsory. View Applications will present a numbered list of 1-line summaries of each stored application. Only the name and application date will be displayed. The user can select an application (by typing its number) to see the entire application.

Delete will display the same numbered list, but the application data will be deleted from the loan file if the user selects an entry.  New User will prompt for a user name and password.  The user name must not already be in use.  The new user name and password hash will be written to the passwd file.      

  • This assignment must be written in C and must compile and run on BA computer lab PCs using Quincy 2005 v1.3. Build options must include Strict ANSI/ISO compliance, C99 support and must compile with no warnings when the All Warnings option is selected.
  • Your code must have appropriate comments including your names and student numbers, the name of the .c file, the purpose of the program, brief explanations of variables and explanations of any code which is not obvious to another programmer.
  • All code can be placed in user-defined functions. The main function should only contain the opening menu system and relevant function calls.
  • Bonus marks (5% of the total mark for the assignment) will be awarded if the arrays of loan and applicant structs are allocated dynamically (using malloc(). The alternative (without the bonus marks) is to use conventional arrays of structs.

Hints:  

1. Adapt the code from assignment 2 to either give access to or deny access to the menu

2. Write a simple switch-based menu routine which calls functions (see the lecture on switch)

3. Store the sample loan information in a text file.  

4. Define a struct to hold the applicant information

5. Define a struct to hold the loan information

6. Create two arrays of structs - one of type Applicant, and one of type Loan

7. Create an int which holds the number of applications in the arrays (int no_elements = 0)

8. To read in the applications from file, 

  • declare a Loan and an Applicant variable
  • write a function which reads the first loan information into the Applicant and Loan structs
  • Add these structs to the relevant arrays (at index no_elements) and increment the no_elements variable for the arrays by 1
  • repeat until all of the test data has been read into the arrays.

9. Write a function to display the list of applications. 

  • Use a for loop to change the index from 0 to the number of elements.:
  • Use the . syntax to access each member of each array element
  • i.e. printf(.... , applicant[i].firstName, applicant[i].surname...)
  • Each application should be numbered

10. Write a function to display the contents of a pair of loan and applicant structs (after prompting for the index).   

11. Write a delete function which 

  • calls the display function
  • prompts for the element to be deleted
  • deletes it (see slide on deleting things from an array - array lecture)

12. Write a function to create a new application - this should use code from assignment to populate a pair of empty Applicant and Loan structs

13. Write a function to write the contents of the two struct arrays back to the file in the same format they were read. 

14. Write a function which changes a password - prompts for a user name and password, and writes the name and hashed password to the end of the password file (use "a" in fopen).


Related Discussions:- Program for implementation of a data storage system

I need website with built in scraper, I need Website with built in scraper ...

I need Website with built in scraper Project Description: The coding skills mentioned above are just possibly ones that will be used. Skills required are ASP, C++ Programm

What are some ways try / catch / throw can develop software , Q: What are s...

Q: What are some ways try / catch / throw can develop software quality? A: By removing one of the reasons for if statements. The commonly utilized alternative to try / catch

Decoding, how to decode a number from mobile keypad

how to decode a number from mobile keypad

Produce an executable file, Requirements Create a "makefile" that w...

Requirements Create a "makefile" that will manage the construction of a program The name of the makefile must be: makefile The make file must produce an executable

Webcam driver static library or dll required for windows, Webcam Driver sta...

Webcam Driver static library or DLL required for Windows I want a .dll or .lib file using which i will take a snapshot from the webcam and it can't turn on the webcam LED while

C program to compute the factorial, Write a C program to compute the factor...

Write a C program to compute the factorial of  5 i.e 1x2x3x4x5 etc #include stdio.h   void main()   {   char promt;      int factor;   factor = 1*2*3*4*5;   printf("The fac

Differences between a pointer and a reference, Differences between a pointe...

Differences between a pointer and a reference 1.  A reference must always point to some object where as this restriction is not imposed on a pointer. e.g. int *pi = 0;

Palindrome, string S convert it to a palindrome by doing chara, C/C++ Progr...

string S convert it to a palindrome by doing chara, C/C++ Programming

Poop, hwat is the area fsdjlakl;aeklfjtealrtl;gka

hwat is the area fsdjlakl;aeklfjtealrtl;gka

Data structyres, What data structure would you mostly likely see in a nonre...

What data structure would you mostly likely see in a nonrecursive implementation of a recursive algorithm?Minimum 100 words accepted#

Write Your Message!

Captcha
Free Assignment Quote

Assured A++ Grade

Get guaranteed satisfaction & time on delivery in every assignment order you paid with us! We ensure premium quality solution document along with free turntin report!

All rights reserved! Copyrights ©2019-2020 ExpertsMind IT Educational Pvt Ltd