CS
2500 Spring 2011
Lab 4
Abstract Data Types and C++ Classes
Please see modifications below
We want  to
create an  ADT that represents a rectangle (similar to the one for
a sphere we saw in class).  Below is a pseudocode 
implementation of the operations for  the  rectangle ADT.
 
+Rectangle()
// Creates a rectangle and initializes its length and width to default
// values.
 
+Rectangle (in length:double, in width:double)
// Creates a rectangle and initilializes its length and width to the
// values received as parameters.
+setLength (in length:double)
// Sets or modifies the length of an existing rectangle.
// Checks to make sure that the new length is greater than 0.
 +setWidth (in width:double)
// Sets or modifies the width of an existing rectangle.
// Checks to make sure that the new width is greater than 0.
+getLength():double {query}
// Returns a rectangle’s length.
+getWidth():double {query}
// Returns a rectangle’s width.
+area():double {query}
// Determines a rectangle’s area.
+perimeter():double {query}
// Determines a rectangle’s perimeter. 
+displayStatistics(){query}
// Displays statistics of a rectangle.
1. Implement
the rectangle ADT in C++, based on the pseudocode above. (Note you will
need to create a header file and an implementation file.)
2. Write a
client program to test your ADT. The client should allow a user to
create some rectangles and manipulate them and then print out the
statistics.
More details on the client
    there are two
options: interact with the user OR hardcoded 
    you will get 10
points of extra credit for doing both
All functionality should be
tested, for example:
    create a
default object and one with length and width specified (hard coded or
by user input) and display statistics
    test get and
set for each changable data value, here is some code you could consider
      
cout << "Setting length to 12\n";
      
myrect.setlength(12);
      
cout << "New length: " << myrect.getlength() << endl;
    display
statistics once you have finished the changes
Do the rectangle first then the
colored rectangle
Script should show the hard coded
output and minimal user interaction
You do need to be able to
demonstrate catching bad input (e.g. negative length values) and
handling it
Part 2, Colored
Rectangle
In order to get
a feel for inheritance, we would like to create a subclass of
Rectangle, called ColoredRectangle.
1. Create a C++
header file and implementation file for your new class. Follow
Carrano's subclass ColoredSphere on pages 151 and 152. For example you
will need to write two new constructors and functions to getColor and
setColor.
2. Modify your
client to use your ColoredRectangle class.
Some
notes on compiling classes and clients:
1. I
have modified Sphere.cpp and SphereDemo.cpp so that they should compile
without warnings. 
2. Here are two
ways to compile a client: 
   
a. compile it with the class: quick, but can compound debugging:
mmartin@sol:(~/2500) g++ SphereDemo.cpp Sphere.cpp
mmartin@sol:(~/2500) a.out
Radius = 1
Diameter = 2
Circumference = 6.2831
Area = 12.5664
Volume = 4.18879
8.4
   
b. Compile the class first (using -c flag), with a named output file
(-o flag):
mmartin@sol:(~/2500)
g++ -c Sphere.cpp -o Sphere.o
this creates an
object file called Sphere.o (like a.out)
if it doesn't
compile you can debug your class before confusing the situation with
possible bugs in the client
       
Now compile your client:
mmartin@sol:(~/2500) g++ SphereDemo.cpp Sphere.o -o SphD.o
mmartin@sol:(~/2500) SphD.o
Radius = 1
Diameter = 2
Circumference = 6.28318
Area = 12.5664
Volume = 4.18879
8.4
This creates
the object file SphD.o.
If you want to
know more about g++, just type man g++ on the command line.
Here is the required
comment format for
significant
functions (courtesy of Dr. Sarraille):
/****************************************
    FUNCTION NAME:
    INPUT: 
    OUTPUT:
    PRECONDITIONS:
    POSTCONDITIONS: 
    CALLERS: 
    CALLEES: 
*****************************************/
What to Submit
Name your files:
    Rectangle.h
    Rectangle.cpp
   
rectangleDemo.cpp
   
ColoredRectangle.h
   
ColoredRectangle.cpp
    script_rectangle
Turn in your programs
and script to the CS Homework Submission System at https://hopper.csustan.edu/cshomework/
            
Choose instructor:  cs2500mm 
            
Choose course: CS2500
            
Choose assignment: Lab4