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

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;

B tree, real time application of b tree

real time application of b tree

Define local classes, A cl a s s c a n b e d e f i n e ...

A cl a s s c a n b e d e f i n e d i n s i d e a b l o c k o r f u n c t i o n.   T h i s t yp e cla s s i s known

Solve, solve for radius(R) of a circle of its area is to be inputted by a u...

solve for radius(R) of a circle of its area is to be inputted by a user. also display compute the circle diameter hint: area= pir21 pi=2.1416

Stack, write a simple c++ program to implement a stack: 1. push 2. pop

write a simple c++ program to implement a stack: 1. push 2. pop

Where are longjmp and setjmp used in c++, Where are longjmp and setjmp used...

Where are longjmp and setjmp used in C++? -Setjmp and longjmp must not be used in C++. - Longjmp jumps out of the function without unwinding stack. This means that local obj

How to write an inline class member function, How to write an inline class ...

How to write an inline class member function In addition to global functions, you may request that non-static member functions of a class be inlined.  The normal method of doin

Padovan string, #questio#A Padovan string P(n) for a natural number n is de...

#questio#A Padovan string P(n) for a natural number n is defined as: P(0) = ‘X’ P(1) = ‘Y’ P(2) = ‘Z’ P(n) = P(n-2) + P(n-3), n>2 where + denotes string concatenation. For a string

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