CS6300-Textprocessor

Project Goals

In this project, you will be developing a simple Java application (textprocessor) using an agile, test-driven process involving multiple deliverables. While you will receive one grade for the entire project, each deliverable must be completed by its own due date, and all deliverables will contribute to the overall project grade.

Specification of the textprocessor Utility

textprocessor is a command-line utility written in Java with the following specification.

Summary

textprocessor allows for simple text manipulation of the contents of a file.

Syntax

textprocessor [OPTIONS] FILE

Description

Program textprocessor performs basic text transformations on lines of text from an input FILE. Unless the -o option (see below) is specified, the program writes transformed text to stdout and errors/usage messages to stderr. The FILE parameter is required and must be the last parameter. OPTIONS may be zero or more of the following and may occur in an order:

-o output_file_name
The program writes the output to output_file_name with transformed text instead of writing to stdout. If output_file_name already exists, the program shall result in an error.
-i
Used with the -r flag and -k flag ONLY; the search of -r or -k becomes case-insensitive.
-k substring
Keep only the lines containing substring. The search for substring is case-sensitive, unless option -i is set. This option must be mutually exclusive with -r below.
-r old new
Replaces the first instance of string old in each line with string new. The search for old is case-sensitive, unless option -i is set. This option must be mutually exclusive with -k above.
-s suffix
Adds the string suffix at the end of each line.
-n padding
Add a line number followed by a single space to the beginning of each line, where padding is an integer in the inclusive range of 1 to 9 specifying the minimum padding of the line number field. If the number of digits in the line number is less than the specified padding, zeros are left padded until the minimum padding is reached. If the number of digits in the line number is greater than the specified padding, the line number is never truncated. Line numbering should start at 1. This option must be mutually exclusive with -w below.
-w
Removes all whitespace from lines. For this request, whitespace will count as any spaces, “ “, or tabs, “\t”, in the input file. It must be mutually exclusive with -n above.

NOTES

While the last command-line parameter provided is always treated as the filename, OPTIONS flags can be provided in an order and shall be applied as follows:
Options -o/-i shall be processed first, as the determine global parameters of the computation.
Options -k, -r, -n, -w , and -s, shall be processed in this order. That is: (1) if -k is present, then the file content is filtered based on the specified parameter, using a case insensitive search if -i is present; (2) if -r is present, then replacements are performed based on the option parameters, using a case insensitive search if -i is present; (3) if -n is present, then a line number is applied; (4) if -w is present, then whitespace from the line is removed; (5) if -s is present, then a suffix shall be applied.
To keep this application simple, all errors shall result in display of the standard usage message.
Specifying option -i without having specified option -r or -k shall result in an error.
Specifying option -k with an empty string as the substring parameter should keep all input lines.
Specifying option -r with an empty string as the old parameter or option -s with an empty string as the suffix parameter shall result in an error.
Specifying options -r and -k simultaneously shall result in an error.
Specifying option -n with a non-integer value or an integer out of range shall result in an error.
Specifying options -n and -w simultaneously shall result in an error.
If options are repeated, only their last occurrence is applied.
All program option parameters are required, resulting in an error if omitted.
You shall assume that the command line parameter strings will not contain newline characters (\r, \n, and so on), as the behavior of the program would be platform dependent and may result in errors during grading. Therefore, there should be no test cases using these values as option parameters.
An empty input file shall produce an empty output file.
The last line of a non-empty input file must be newline terminated. Otherwise, the program shall generate an error.

EXAMPLES OF USAGE

Example 1

1
textprocessor -o sample.txt FILE

input FILE:

1
This is the first line of the input file.

output sample.txt:

1
This is the first line of the input file.

stdout: nothing sent to stdout
stderr: nothing sent to stderr

Example 2

1
textprocessor -r 02 two FILE

input FILE:

1
Some words are: "one", "02", and "three"

output file: output file not created
stdout:

1
Some words are: "one", "two", and "three"

stderr: nothing sent to stderr

Example 3

1
textprocessor -i -r the A FILE

input FILE:

1
2
The file
the file

output file: output file not created
stdout:

1
2
A file
A file

stderr: nothing sent to stderr

Example 4

1
textprocessor -s er FILE

input FILE:

1
This is cool

output file: output file not created
stdout:

1
This is cooler

stderr: nothing sent to stderr

Example 5

1
textprocessor -k Java FILE

input FILE:

1
2
3
java is one of the <blank> programming languages.
Java is a programming language.
Programming languages are neat, an example of one is Java.

output file: output file not created
stdout:

1
2
Java is a programming language.
Programming languages are neat, an example of one is Java.

stderr: nothing sent to stderr

Example 6
textprocessor -r Question Exclamation -o text -s ! -w FILE
input FILE:

1
This Sentence Ends In A Question Mark?

output text:

1
ThisSentenceEndsInAExclamationMark?!

stdout: nothing sent to stdout
stderr: nothing sent to stderr

Example 7

1
textprocessor -n 8 -n 2 -s ## -s ! FILE

input FILE:

I wish this line had a line number..
I also wish that..
output file: output file not created
stdout:

1
2
01 I wish this line had a line number..!
02 I also wish that..!

stderr: nothing sent to stderr

Example 8
textprocessor
input FILE:

1
2
3
Today is January 65, 2298.
Yesterday was December 0, 3000.
Tomorrow we will time travel again.

output file: output file not created
stdout: nothing sent to stdout
stderr:

1
Usage: textprocessor [ -o filename | -i | -k substring | -r old new | -n padding | -w | -s suffix ] FILE