Starting from:

$35

Programming Assignment # Solution

Description




• This is an individual assignment. Please do not collaborate

• If you think that this document does not clearly describes the assignment, ask questions before its too late. This assignment is about using C++ STL, exception handling and/or creating Class templates.

• Your program reads two files:

– data.txt

– commands.txt

• According to content in data.txt, the program utilizes necessary STL classes and/or user-created classes for a catalog representation.

• Your program creates a log file(output.txt) for certain steps of operations performed on catalog.







data.txt




• This file holds information about a catalog. A catalog can be one of the following:




– Book catalog

– Music catalog

– Movie catalog

• The type of the catalog is specified in the first line of data.txt







Book Catalog




• Each line in a book catalog keeps information about a book.

• Format:

<title <authors <year <tags




• Example: Contents of data.txt for a book catalog

1 book

2 "Hilbert Spaces With Applications" "Lokenath Debnathl, Piotr Mikusinski" "2005" "Mathematics,

,→ Set Theory"

3 "The Neolithic Revolution in the Near East: Transforming the Human Landscape" "Alan H. Simmons"

,→ "2011" "Social Science, Anthropology, Cultural, General, Archaeology"

4 "Learning Flask Framework" "Matt Copperwaite, Charles Leifer" "2015" "Computers, Programming

,→ Languages, Python, Internet, Application Development, Web, Web Programming"

5 "Graphics Gems V" "Alan W. Paeth" "1995" ""







Music Catalog




• Each line in a music catalog keeps information about a music album.

• Format:

<title <artists <year <genre




• Example: Contents of data.txt for a music catalog

1 music

2 "Professor Satchafunkilus and the Musterion of Rock" "Joe Satriani" "2008" "Guitar Virtuoso"

3 "Physical Graffiti" "Led Zeppelin" "1975" "Rock"

4 "Witchdoctor's Son" "Okay Temiz, Johnny Dyani" "2017" "Jazz, Fusion"

5 "Return Of The Mother Head's Family Reunion" "Richie Kotzen" "2007" "Rock, Guitar Virtuoso"







Movie Catalog




• Each line in a movie catalog keeps information about a movie.

• Format:

<title <director <year <genre <starring




• Example: Contents of data.txt for a movie catalog

1 movie

2 "The Lord of the Rings: The Fellowship of the Ring" "Peter Jackson" "2001" "Adventure, Drama,

,→ Fantasy" "Elijah Wood, Ian McKellen, Orlando Bloom"

3 "Twelve Monkeys" "Terry Gilliam" "1995" "Mystery, Sci-Fi, Thriller" " Bruce Willis, Madeleine

,→ Stowe, Brad Pitt"

4 "Perfume: The Story of a Murderer" " Tom Tykwer" "2006" "Crime, Drama, Fantasy" "Ben Whishaw,

,→ Dustin Hoffman, Alan Rickman"

5 "Cold Mountain" "Anthony Minghella" "2003" "Adventure, Drama, History" " Jude Law, Nicole

,→ Kidman, Renee Zellweger"







commands.txt




This file includes several commands which work on the catalog information you read from data.txt. Each line is a command. The following should be recognized:




• There are two commands.

search <string in <field

sort <field







search command




• Format:

search <string in <field




• Output:




This command returns a list of matched(partially or fully) entries (one entry in a line). Search should be limited to the field specified. Not found returns no line.




• Example:

search "Joe" in "artists"




This returns the following line:

"Professor Satchafunkilus and the Musterion of Rock" "Joe Satriani" "2008" "Guitar Virtuoso"







sort command




• Format:

sort <field




• Output:

This command returns a list of sorted entries (ascending order)




• Example:

sort "title"




This returns the following lines:

1 "Cold Mountain" "Anthony Minghella" "2003" "Adventure, Drama, History" " Jude Law, Nicole

,→ Kidman, Renee Zellweger"

2 "Perfume: The Story of a Murderer" " Tom Tykwer" "2006" "Crime, Drama, Fantasy" "Ben Whishaw,

,→ Dustin Hoffman, Alan Rickman"

3 "The Lord of the Rings: The Fellowship of the Ring" "Peter Jackson" "2001" "Adventure, Drama,

,→ Fantasy" "Elijah Wood, Ian McKellen, Orlando Bloom"

4 "Twelve Monkeys" "Terry Gilliam" "1995" "Mystery, Sci-Fi, Thriller" " Bruce Willis, Madeleine

,→ Stowe, Brad Pitt"







output.txt




This file keeps the log of the operations. The following events should be recorded in the specified format:

• catalog read

• output of commands







catalog read




• First specify the type of the catalog.

• At the end, state the number of unique entries.

Catalog Read: music

4 unique entries







output of commands




• State the command.

• Append its output.

search "Joe" in "artists"

"Professor Satchafunkilus and the Musterion of Rock" "Joe Satriani" "2008" "Guitar Virtuoso"







Exceptions




• Your program should catch certain exceptions and create log entries for them.




• You need to catch the following exceptions:







Missing field exception




• If any of the field in any entries is missing your program should omit that line and create an exception record in the log file.

Exception: missing field

Duplicate entry exception




• If the first field of any entries fully match, your program should create an exception for each repetition and log these instances in the log file.

Exception: duplicate entry







Wrong command exception




• If the command is not in the expected format(unrecognized field name, extra information etc. . . ), log this instance as an exception.

Exception: command is wrong







A full example.




• Suppose we are given the following data.txt file and commands.txt file:

• data.txt

1 movie

2 "The Lord of the Rings: The Fellowship of the Ring" "Peter Jackson" "2001" "Adventure, Drama,

,→ Fantasy" "Elijah Wood, Ian McKellen, Orlando Bloom"

3 "Twelve Monkeys" "Terry Gilliam" "1995" "Mystery, Sci-Fi, Thriller" " Bruce Willis, Madeleine

,→ Stowe, Brad Pitt"

4 "Twelve Monkeys" "" "" "Sci-Fi, Thriller" " Bruce Willis, Madeleine Stowe, Brad Pitt"

5 "Perfume: The Story of a Murderer" " Tom Tykwer" "2006" "Crime, Drama, Fantasy" "Ben Whishaw,

,→ Dustin Hoffman, Alan Rickman"

6 "Twelve Monkeys" "" "" "Mystery, Sci-Fi, Thriller" " Bruce Willis, Madeleine Stowe, Brad Pitt"

7 "Cold Mountain" "Anthony Minghella" "2003" "Adventure, Drama, History"




• commands.txt

1 search "Monkeys" in "title"

2 search "Spice" in "genre"

3 sort "year"




• The first line is movie. This means your application will going to run in movie organiser mode.




• Following is the log file for this example:

• output.txt

1 Catalog Read: movie

2 Exception: duplicate entry

3 "Twelve Monkeys" "" "" "Sci-Fi, Thriller" " Bruce Willis, Madeleine Stowe, Brad Pitt"

4 Exception: duplicate entry

5 "Twelve Monkeys" "" "" "Mystery, Sci-Fi, Thriller" " Bruce Willis, Madeleine Stowe, Brad Pitt"

6 Exception: missing field

7 "Cold Mountain" "Anthony Minghella" "2003" "Adventure, Drama, History"

8 3 unique entries

9 search "Monkeys" in "title"

10 "Twelve Monkeys" "Terry Gilliam" "1995" "Mystery, Sci-Fi, Thriller" " Bruce Willis, Madeleine

,→ Stowe, Brad Pitt"

11 Exception: command is wrong

12 search "Spice" in "genre"

13 sort "year"

14 "Twelve Monkeys" "Terry Gilliam" "1995" "Mystery, Sci-Fi, Thriller" " Bruce Willis, Madeleine

,→ Stowe, Brad Pitt"

15 "The Lord of the Rings: The Fellowship of the Ring" "Peter Jackson" "2001" "Adventure, Drama,

,→ Fantasy" "Elijah Wood, Ian McKellen, Orlando Bloom"

16 "Perfume: The Story of a Murderer" " Tom Tykwer" "2006" "Crime, Drama, Fantasy" "Ben Whishaw,

,→ Dustin Hoffman, Alan Rickman"







Remarks




• Be careful with the order of exceptions. If an entry has a missing field and it has the same first field with another entry, you should throw missing field exception.

• Assume no other errors will be present in the files.

• Try to generalize your program. (you can use templates).

• Efficiency is important. (try to use the existing (STL) containers and their methods for sorting etc. . . )







Turn in:




• Source code of a complete C++ program and a suitable makefile. You should use c++11 standard. Your code will be tested in a linux-gcc environment.

• A script will be used in order to check the correctness of your results. So, be careful not to violate the expected output format.

• Provide comments unless you are not interested in partial credit. (If I cannot easily understand your design, you may loose points.)




• You cannot get full credit if your implementation contradicts with the statements in this document.

More products