CSE 115 - Spring 2008 - Banner
   CSE 115 - Spring 2008 - Introduction to Computer Science for Majors I
CSE 115 - Spring 2008 - Navigation CSE 115 - Spring 2008 - Lab 1

Lab 1

Introduction

In this first lab you will be introduced to the computing environment in the Baldy 21 lab. If you are familiar with Unix you may know how to do some or all of the following tasks. Do them all the same. If you are new to Unix, these exercises will get you up and running with most of the tools you need to successfully complete the lab assignments of this course. Some further tools will be introduced as we need them in later labs.

You should not expect to finish all of these exercises during the allotted lab time. You should plan to return to the lab during open lab hours (hours when the lab is open but there are no formal labs scheduled) to complete your work.

Read through the entire lab before you start working, so that you know what to expect. Make sure you save your work often, and keep track of what you are expected to submit.


Objectives

The objective of this lab is to introduce you to the Unix operating system and some of the tools available to you so that you can work on the labs independently.


Preparatory work

Be sure you completed the preparatory work outlined in the Lab 1 Prep Work.


Lab Tasks

Your instructor has briefly gone through the tasks listed below during lecture to help prepare you for this lab. You must now carry out each of the following tasks on your own in the lab setting. Chapter references are to the Unix book you should have brought with you to the lab.

Logging in - Connecting to the system

Your first lab task is to log in to your CSE computer account. Your CSE account is valid on the computers in Baldy 21. This account is separate from your UBUnix account.

  • If you have not had a CSE account previously, your login name is the same as your UB-IT name. Your password is the same as your UB-IT password was at the time when your CSE account was created.

  • If you have previously had a CSE account (e.g. if you took any other CSE course last year where you received an account), your login name and password should not have changed.

Unix is the name of the operating system that is running on the machines in the Baldy 21 lab. An operating system (or OS) provides basic services to both programs (applications) running on the machine and to users who are working on the machine. Examples of services provided by an OS are a facility to read the contents of a file from a disk, or run multiple programs at one time (multi-task).

Gnome is a windowing system, or graphical user interface (GUI), to the underlying Unix operating system. Gnome is thus separate from the operating system. A windowing system manages windows on a screen and provides a graphical way of interacting with the operating system.

On personal computers it is becoming more and more difficult to distinguish between the operating system and the windowing system as they are becoming more tightly integrated. In the Unix world however, the separation is still clear and it is not uncommon for different users on a given system to use different window systems.

To log in:

  • You should see a welcome screen with a place for your username. Enter your username (UB-IT name), and then press OK.
  • You will then be asked to enter your password. Enter your password, and then press OK.

When Gnome is finished loading, you will be presented with a desktop. There will be a few icons on it that looks like this:

There is a panel across the top of the screen which has two menus on it. This is similar to the Start Menu feature of Microsoft Windows. There is also a panel along the bottom of the screen. If you want to know what anything does, hover your mouse over it and a little description will appear.

In case of emergency where you suddenly need to leave, such as your grandmother dying (it happens a lot in this class), let's discuss how to log out of the system before we go any further.

  • Just click on the "Actions" on the panel at the top of the screen, then select "Log Out".
You will probably receive a message asking if you're sure you want to log out. There's also a checkbox that says "Save current setup". If you want to save your setup (whatever that means), check this box. Then click on "OK" and you will be logged out. Remember to never leave the lab without logging out, even if it is "just for a minute"!

Spend a moment getting comfortable with Gnome.  To move a window with a title bar (for example double click on 'Computer' to get a window), click and hold the left mouse button in the middle of the title bar and drag it to a new position. If you click on the small buttons in the title bars of the windows, different things will happen:

  • The rightmost button on the title bar:
    Left-clicking this will close the window. Try it out: open a window and close it.

  • The button to the left of that (in the middle of the three):
    Clicking this will toggle the window between "maximized" and "unmaximized"/"normal" modes. In maximized mode, the window will take up the full space of the screen. In normal mode, the window is not necessarily the full size of the screen and you have the ability to move it around and see other things on the screen as well. Try maximizing and unmaximizing some window.

  • The button to the left of that (the left side of the three):
    Left-clicking on this will minimize the window. It keeps the program running but hides it from view. Now we need to get it back. Just click on the corresponding item on the panel along the bottom of the screen.

  • The button on the far left of the title bar:
    Clicking on this will bring up a menu of different things you can do to the window. Try it out and see what can be done.

As previously mentioned, Gnome is just a windowing system that interacts with the underlying Unix operating system. To interact directly with Unix, we need what is called a terminal. Here are two ways to bring up a terminal in Gnome:

  1. Right click on an empty space on your desktop and select "Open Terminal" from the menu.
  2. Click on the Applications menu on the panel at the top of the screen. Click on "System Tools", then click on "Terminal".
The terminal window will look like this:

The > symbol is called a prompt.  You will type commands into the prompt to get the Operating System to perform various tasks for you.

Adding the ampersand (&) to the end of a Unix command makes it run in the background. When a command runs in the background (as opposed to the foreground) you get the Unix prompt back so you can type another command if you wish to. In this way you can multi-task (have several applications running at once) without needing a terminal for each application.

The files which you create are stored on a machine called a file server, which is accessible from all of the workstations in the lab. In other words, it doesn't matter which workstation you log in at, you will be able to access exactly the same files. The computer which you will use in the Baldy 21 lab is called styx.cse.buffalo.edu, or just styx for short. This computer shares its files with several systems, one of which is called pollux.cse.buffalo.edu (pollux for short), which you can log into from other places around campus. If you want to work on the CSE servers from the residence halls or off campus, log in to yeager.cse.buffalo.edu.

Changing your Password

It is a good idea to change your password from your default password to something else. You should change your passwords often to help keep your account secure. You must never share your account password with anyone (including your friends and classmates). Read the section in Chapter 1 (pages 11-12) about changing your password. Passwords can only be changed while logged into hadar.cse.buffalo.edu. This is the only operation that you should do while logged into hadar. The rest of your work for this class should be done logged directly onto your machine. Do this now:

To log into hadar, at a prompt type:

ssh hadar
If you receive a message starting with "The authenticity of hose 'hadar (128.205.32.1)'..." type "yes" (without quotes) and hit enter. Ignore the warning that comes up. Then it will ask for your password by saying:
username@hadar's password:

where 'username' is your account name. Type your CSE account password. Nothing will show up, not even asterisks, this is normal. Hit enter and you are now logged on to hadar.cse.buffalo.edu. Follow the instructions in the book on how to change your password. Note: it may take a few minutes for the password change to work. This is normal. When you are done changing it, then type 'exit' at the prompt, and you will see:

Connection to hadar closed.

Because your CSE account is separate from your UBUnix account, changing the password on one account does not automatically change the password on the other. You should change passwords on both accounts on a regular basis.

Unix and utilities

In this section, you will experiment with some basic Unix commands, and learn a little bit about the way in which Unix organizes its file system.

Basic Unix directory structure

Like most file systems, Unix's is tree-structured. The root of the file system is named '/'. As a user on the system you have a home directory, where all your files are stored. Unix has a "shortcut" to represent your home directory. This shortcut is the tilde (~). Whenever you want your home directory, you can just type ~. To find out where your home directory is, type

echo ~

When I do this, I find out that my home directory is /home/csefaculty/adrienne. This means that my home directory adrienne is located in the subdirectory csefaculty, which is a subdirectory of home, which is an immediate subdirectory of the root directory (which is, as mentioned above, designated by '/'). "/home/csefaculty/adrienne" is a path which describes how to get from one directory (in this case the root directory) to another (in this case my home directory). A path can either be absolute (starting at /) or relative (starting at the current directory).

Every directory has two special entries, . and .. The entry . refers to the directory itself, and .. and refers to the directory's parent directory (i.e. the directory of which this one is an immediate subdirectory). The . and the .. are "shortcuts" as well. No matter where you are, if you want to use your parent directory, then you just use ...

The root directory is the only directory in the file system which does not have a parent directory. (Actually, this is not quite accurate. If you inspect the root directory you will find that there is a .. entry. The parent of the root directory turns out to be the root directory itself!)

Running a Program on Unix

At the prompt, type the command /projects/CSE115/Setup/115setup . This command runs a script on the Unix system that does a number of things behind the scenes to get you set up to work on the labs. The one thing that you can immediately notice is the creation of a file called cse115.epf in your home directory. This file will be used when we start developing programs. However, after you type the command and press Enter, you simply get the prompt back. How would you ever know that this file was created? Well, read on and we will see how to navigate the Unix system's file structure to find the file cse115.epf .

Getting started with Unix
Below I have listed some basic Unix commands. Read the description of each, and carry out any exercises given.
  • ls - This command gives a listing of the files in a directory. Without any arguments, it provides a listing of the files in the current directory, and is therefore equivalent to

    ls .

    If you specify a directory using a path, ls will respond with a listing of the contents of the specified directory. Try typing ls at the Unix prompt. When you do, you should notice the file named cse115.epf . There may be other files in your directory as well. If you do not see the file named cse115.epf in your directory, you need to run the /projects/CSE115/Setup/115setup command again.

  • cd - This command changes the current directory. Without any arguments, it changes the current directory to your home directory, and is therefore equivalent to

    cd ~

    If you specify a directory using a path, cd will set the current directory to the specified directory. One neat thing is that using .. as an argument to cd moves you to the parent directory. More examples of using cd are found on pages 15-16.

  • Using wildcards - Wildcard characters are used in patterns to match filenames. For example, the wildcard character ? matches any single character. Another wildcard that will be useful is the * this character, which matches multiple characters. Page 21 of the Unix book gives some more examples on the use of wildcards.

  • man - The man command brings up a manual page (help screen) for a specified command. Let's get the man page for the finger command by typing man finger. More examples for man are given on pages 26-27 of the Unix book.

Directories and files
Next is a list of some fundamental commands which allow you to manipulate and organize files in a Unix file system. Read the description of each, and carry out any exercises given.
  • mkdir - This command creates the specified subdirectory. Follow the example on pages 30-31 to make your own subdirectory named NewDirectory.

  • cp - This command copies a file to a new location, leaving the original unchanged. Type

    cp NewDirectory temp

    How many files does ls report now? Look at the examples on pages 34-35 for more ways to use cp.

  • More fun with ls - Pages 36-37 talk about the different ways you can use ls to get different information about files. Figure 2.1 on page 36 will help those who have not used Unix before understand what gets displayed to the screen when you type ls -l at the prompt.

  • mv - This command moves a file from one location to another. But beware, because of the way file systems work, moving a file is very similar to renaming. The mv command is also the rename command. For example we can rename the file called temp by:

    mv temp notsotemp
    Now you can move the file into the directory we created:
    mv notsotemp NewDirectory
    A directory is just a special type of file to Unix, so we can rename the directory we just created before by moving it to a new location. Type
    mv NewDirectory MyDir
    to rename the directory. Now type ls to see what has happened. See the examples on page 38.

  • rm - The command rm removes a file. Type rm -i temp followed by ls. How many files does ls report now? Read more about rm on pages 39-41.

  • rmdir - This command removes the specified subdirectory. Type rmdir myDir. Read pages 42-43 for more examples of removing directories.

  • find and ln - The sections on find and ln are interesting to read about - especially when you are looking for a file and can't remember which directory it is in. Read pages 44-50 for more information about these two commands.

The command shell

Chapter 3 of the Unix book talks about shell command interpreters (often referred to as just shells). You interact with the shell when you type commands at the prompt. You should read this chapter. It is important to know that there are different shells available and understand what some of the differences are amongst these various shells. This chapter also leads nicely into Chapters 8, 9 & 10 that deal with running and writing basic programs that can work with the shell and also with configuring the shell. These topics are a little more advanced than you need for this course. When you are ready to delve deeper into the world of Unix these chapters are a good place to start.

Creating a file

Chapter 4 of the Unix book mentions two editing programs you can use to create and edit files. This semester, we will develop our Java files in an editor called Eclipse, which is an environment designed specifically for creating programs. However, it has the ability to create files that are not related to programming. (If you have Eclipse installed on a Windows machine, you can edit Word and Excel documents using Eclipse!) In this exercise we will use Eclipse to create a simple text file. In the rest of the labs this semester, we will use Eclipse to create our programs.

 

Web browser

The next thing you might want to do is start a web browser. The web browser installed on these systems is Firefox. Start the firefox web browser by selecting "Applications" from the panel at the top of the screen. Then select "Internet" and then "Firefox Web Browser":

When you first start firefox, you might get a window that looks like this:
Just click on "Next >", then in the following window, click "Finish".

Navigate to the course website at http://www.cse.buffalo.edu/faculty/adrienne/SP2008/cse115, and browse around to get a feel for the types of information available to you. You are expected to check the main page of the web site for announcements on a regular basis. Note that this lab assignment (and all future lab assignments) is available from the course website.

Setting up Eclipse so you can work on the rest of the labs

Create a directory in your home directory named cse115.

Change directories into that directory (using cd).

Make a directory named workspace.

Now you need to open Eclipse. There are a few ways in which you can do this. You can type the command to launch the program into the prompt. That command is /util/eclipse/eclipse &

This is perhaps a bit tedious, we will show you how to make a "shortcut" for this command a little later in this lab, but for right now, you should consider making a shortcut on your desktop for Eclipse. To do this:

Right click on your desktop and get the following menu. Select Create Launcher:

Then you will get the Create Launcher dialog. Make your Dialog look like the one below and click "OK":

Now you will see an icon on your desktop for Eclipse. You can double-click on it to run Eclipse.

When you start up Eclipse, you will see the following screen:

Then you will see a Window that will ask you which workspace you want to open. By default, it will probably say something like this:

You do not want to use this default workspace. Use the Browse button to make the workspace point to the directory you just made named workspace, like this:

Be sure to check the box "Use as default and don't ask me again", and then click "OK".

You will then see a screen that looks like this. You will choose the arrow to take you to the Eclipse workbench.

You will then see the default workbench setup. The TAs will talk about customizing this and changing it around throughout the semester. You don't ever have to customize the Eclipse workbench, but we have some suggestions for making life easier when working on projects for this course.

Import preferences file

Next you need do tell Eclipse a few things about how you want it to behave. This is a one-time process. In other words, once you have successfully carried out these steps you will NOT need to repeat them in lab.

Earlier while working on this lab, you ran a script from the prompt. This script put a file in your home directory named cse115.epf. You should check to see that this file is in your directory by typing ls again. If you do not have the file, you should run the script again by doing the following:

At the prompt, type /projects/CSE115/Setup/115setup and hit Enter. After you do this, the file named cse115.epf should be in your home directory.

To import the file, you will first need to open the Import dialog. Do this by selecting "Import..." from the "File" menu. It is common practice to abbreviate menu selections that you need to make in instructions like these. For example, we can abbreviate

select "Import..." from the "File" menu
by simply writing "File" -> "Import". This time we'll show the screen shot of the menu item being selected, but from now on we'll simply write menu selections using this abbreviated method. Your teaching assistant can help you if you have trouble locating the correct menu selections.

An "Import" dialog window should appear.

Select the + sign (or the > symbol depending on your OS) and expand the "General" Folder. Note that there is now an option for t "Preferences", as below. Select it and then click "Next".

This opens up an "Import Preferences" dialog window. Browse to the file cse115.epf in your home directory and select it.

The rest of the options should be OK as they are (they should be as in the screenshot above - if not, make them the same). Click "Finish".

 

Seeing the connections to code repositories

If you do not have a tab in the lower portion of your screen that says "CVS Repositories", you should open that View so that you can see what Repositories you have connections to. To do this, select Window -> Show View -> Other. You should then select to expand the entry for CVS and select CVS Repositories and click OK. You will now see a view tab on the bottom of your screen that shows which repositories you have access to:

Notice that in the repositories tab, you will see repositories for the lecture code that your instructor has been working on in class as well as the code you will need for the assignments this semester. At any time, you can view any of the code we have been using in class.

 

Make local plug-ins available

We want to work with the same tools in the lab as we have been using in the classroom. In order to do this, we need to make our UML tool (Green) and the Dr. Java plugins available to our Eclipse session. To do this, go to "Help" -> "Software Updates" -> "Manage Configuration".

This will open up the "Product Configuration" window.

Select "Add an Extension Location" from the right-hand window. You will see the following window:

Click on "Filesystem" in the left-hand pane and browse to /projects/CSE115/eclipse

Once you've done this, click "OK". After you click "OK" Eclipse will ask whether to restart the workbench:

Click "Yes" to restart the workbench. When you do, your Eclipse window will disappear for a little while, then Eclipse will start up again.

To make sure you have set this up correctly, you should start up the Dr. Java Interactions pane. To do this, select Window->Open Perspective->Other... This will open the "Open Perspective" dialog window. Select "DrJava" and click "OK". If everything is installed correctly, you should have the DrJava "Interactions Pane" along the bottom of your Eclipse window, and inside the "Interactions Pane" you should see the following text:

Welcome to DrJava.
>

If you encounter problems, ask your recitation TA for help.

Exercise 1 (35%)

Using the rm command without the -i flag can lead to disasterous results, especially if you execute the command and have a typo. Suppose you wanted to delete all files with the file extension .txt (rm *.txt), but when you typed the command, you accidently typed rm * and now you have deleted all the files in the directory, including the files for the project that is due in 15 minutes for CSE 115!

To help avoid these calamities, we are encouraging you to alias the rm command to actually execute the rm -i command. This way, the system will prompt you to ensure that you really want to delete the files you requested. You can read about the alias command on pages 190-191 of the Unix book. Note, however, that for our systems you format your alias command like this (note that this is different than the book):

alias rm 'rm -i'

The general form of the command is alias alternateName actualName

You can alias as many commands as you wish, but for the purposes of the exercise, we are most concerned with you alias-ing the rm command. You will do this by creating a file named .alias, then opening the file using Eclipse's text editor.

Eclipse likes to keep files that you create from scratch in a "project". You will learn how to create a project in Eclipse a bit later on this semester. For now, it will be easier if you create an empty file named .alias in your home directory, and then modify that file using Eclipse's text editor. Here's an easy way to create a new and empty file named .alias in your home directory:

touch ~/.alias

Run Eclipse. Use File->Open File... to browse to and open the .alias file you created in your home directory. You will need to right-click in the filename list and select "Show Hidden Files" to show also those files whose names begin with "." (the so-called "hidden files"). You may also want to click on the "Home" icon in the far upper left corner of the "Open File" dialog (this is not the same as the "home" that might appear above the file list, but the one that is above the "Desktop" icon) to get the file list to show the files in your home directory.

Files whose names begin with a period, like .alias and .cshrc , are called "hidden files" because by default the ls does not display them. The reason is that these files are typically configuration files which most users do not need to worry about. However, if you want ls to show you all files, you should use the "-a" option, as in

ls -a

You can place any aliases that you wish to create for yourself in this file. Save this file.

Next, create a backup of your .cshrc file by copying the file to a file named .cshrcBack. Creating a backup copy of a system file is always a good idea before attempting to modify it. This way, if you do not like the settings you changed or if you broke something, you can simply revert back to the original settings before the changes.

Now open the original .cshrc file in the Eclipse text editor ( File->Open File... ), selecting "Show Hidden Files" again, and then browse to the file. Once your .cshrc file is opened, type the following at the bottom of the file:

source ~/.alias

Save and close the file. Next time you log into styx, your aliases will take effect.

You might also want to create an alias for Eclipse at this point. You will be using Eclipse a lot this semester and a shortcut to starting up the program is nice. Also, it will be of benefit if you stop by office hours or are working from home. You can add the following to your .alias file:

alias eclipse '/util/eclipse/eclipse &'

Now when you want to run Eclipse, you can simply type eclipse at the prompt.

E-mail

Since you have a UB-IT account (i.e. an ACSU or UBUnix account) you also have an e-mail address @buffalo.edu. You cannot receive e-mail at this account until you enable it (even though you can send e-mail from this account without needing to do anything special). You should have enabled your UBUnix e-mail account before coming to your lab session. If you have not already enabled this e-mail account, do so now by visiting http://mailcluster.acsu.buffalo.edu/newuser.html, entering your UB-IT name and clicking the "Submit" button.

The CSE e-mail system is separate from the main UB e-mail system. You can choose to maintain two separate and parallel e-mail systems for yourself (make sure you read e-mail at both sites). An alternative is to designate one as your primary e-mail system, and to forward your e-mail from your secondary e-mail service to your primary. When you account was created, it automatically forwards your CSE email to your UBUnix account. If you would like to maintain two separate email accounts, just delete the .forward file in your home directory.

If you coose to maintain two separate email accounts, you can use Thunderbird to read your email. The information you will need to setup Thunderbird is located here.

Exercise 2 (30%)

Send an e-mail to the grading TA for the course (Ran Xu: ranxu@cse.buffalo.edu). Make sure you send a copy to yourself by including your e-mail address in the list of recipients in the "To:" or the "CC:" line. It is strongly suggested that you use UBMail. The email should be received from your buffalo or CSE mail address, no other email addresses will be accepted. (Resist most strongly the urge to send a copy of this e-mail to your lecture instructor or the teaching TA that is in the lab with you now.) The subject of your e-mail must be: `CSE 115: Lab 1 your name and person number'. For example, `CSE 115: Lab 1 Frodo Baggins 13572468'.

The contents of your message should describe, in 50 words or less, why you want to take CSE 115. You should also create an attachment to this email that is the file you created named .alias that contains your defintion of the rm alias and any other aliases you wished to create. In order to do this, you must manually type in the location of the .alias file (remember it is in your home directory, so it is ~/.alias. Verify that you can read the mail once you receive it.

Use the Tools You Have Been Given

One of the most important lessons that you can learn as a computer scientist is how to make the resources available to you, work for you. The same is true of the resources of this class. Information is always given during lectures and recitations and you are most strongly encouraged to attend all lectures and recitations throughout the semester. There is a wealth of information available on the course website to help you with the material of this course.

Another resource that is available to you is the staff of the course, which includes both the instructors and the teaching assistants. There are office hours available at many times throughout the week for you to go and receive extra help on an assignment or simply have some questions answered about the week's material. No appointments are needed to come to office hours.

Exercise 3 (35%)

To ensure that you will be able to use the resources of this course, you will spend some time this week visiting office hours. You will also use the resources of this website to help you on your journey.

Go to an office hour

Find the times and locations of the office hours for any member of the teaching staff, not the grading TAs. You should only see the grading TAs about grading issues. Therefore, you can see your instructor, Mark, Leah, or Kari. Decide on a time that you could visit every week if needed.

For this first week, visit the office hour that best fits into your schedule and attend the office hour. While you are there, you are required to ask a question of the person in office hours. Feel free to ask any questions that you may have about the course or the material of the course so far. When you are there, the person holding the office hour will mark your attendance in our attendance book for the course.

 

Miscellaneous topics (from Unix book)

If you wish to explore Unix further you are encouraged to read the Unix book in its entirety.

Chapter 5 deals with some of the security features implemented on Unix. It talks about how users are allowed access to some files, but not to others. This is important especially if you are creating a webpage. In order for everyone to view your page, you need to make sure that the files are readable to everyone. It also discusses groups and group permissions to files - so that everyone does not have access, but rather only those members of a specific group.

Chapter 6 deals with manipulating parts of files, and comparison between them.

Chapter 7 talks about getting information out of the system, such things like who else is on the system at the same time you are. All of these chapters have useful information in them, but this lab would get much longer than it already is if we went through every page. You are encouraged to read these chapters and learn the material in them.

Chapter 12 talks about some basic issues related to the Internet, Unix, remote systems, how to communicate with users and how to tranfer files. This book suggests using lynx to surf the web. Lynx is a text-based browser available on our systems. I would, however, strongly suggest that you use a graphical web browser instead. The only currently supported browswers on our Unix system are Netscape and Firefox.

Chapter 14 deals with installing software onto the system. At this time, you will not need to do this, all of the software needed for this class has already been installed on the system for you.

Chapter 15 talks about some handy utilities available on the Unix system, like a calendar (we have a graphical version called xcalendar; also useful is plain old cal), a calculator (we have a graphical calculator named xcalc), spell checkers, and history keepers. This is a valuable chapter for making working with Unix more enjoyable.

Chapter 16 talks about system administration by being logged in as root. You can only log in as yourself on our systems.

Chapter 17 talks about some more advanced Unix tricks that are nice to know, such as mail sorting and multiple file replacement.

Appendix A is a recap in short tabular form of all the commands discussed in the book - a good quick reference guide.

Appendix B talks about the main file structure for a Unix system.

Appendix C gives a list of many Unix commands and the flags that can be used on them. It also gives a description of what all of those things do. For example, in the command ls -l, the -l is called a flag (or option) on the ls command


Due dates

You have one week from the meeting of your lab to submit the solution to any electronic parts of the lab. For example, if your recitation meets on Wednesday, January 23rd then you must submit the lab by 11:59 pm on Tuesday, January 29th. The due dates are summarized in the table below.  If you submit more than once, the later submission will simply overwrite the previous one.

 

Date of lab Due date for electronic submission
Tuesday, January 22 Monday, January 28
Wednesday, January 23 Tuesday, January 29
Thursday, January 24 Wednesday, January 30
Friday, January 25 Thursday, Janury 31

 

CSE 115 - Spring 2008 - Footer

 

 
Page Maintained by: Adrienne Decker