Release Date: | Wednesday, September 3. |
Acceptance Deadline: | Tuesday, September 9, 11:59 pm (same as due date for Project 0 only). |
Due Date: | Tuesday, September 9, 11:59 pm. |
Collaboration Policy: | Level 1 |
Group Policy: | Individual |
This warmup project will get your computing environment properly configured for the rest of the course and give you an opportunity to review working in a Unix/Linux environment. Nothing in this project should be difficult, but completing these steps now will avoid any systems-related issues once the first real project is underway.
First, read the class syllabus so that you are aware of important course policies. If you have questions or need clarifications on anything in the syllabus, please let me know! Going forward, I will assume that everyone has read and is familiar with all policies and procedures detailed in the syllabus.
Somewhere within the syllabus is a code (unique to you) that you'll need to submit later in this project. Read carefully so that you don't miss your code!
Questions, discussions, and announcements in this class will all make use of Slack, which is a channel-based messaging platform. Slack will provide a convenient, efficient way to communicate with me, your classmates, and your team (for group assignments).
Slack will be used in preference to all other written forms of communication outside of class, including (and especially) email. As a general rule, once you have Slack set up, don't send me email; send direct message (DMs) on Slack instead! Similarly, I will post important announcements and information to Slack instead of sending email. Therefore, it is critical that you are configured to receive Slack notifications so you do not miss important information from me. Follow these steps to get set up:
The Slack contains five public channels (visible to everyone): assignments
(for discussion of projects), general
(for announcements and general discussion), inclass
(for discussion of in-class material), random
(for anything off-topic), and scheduling
(for the regular office hour schedule and any temporary schedule changes). You can also create (private) DM threads with multiple participants. To post anonymously in a channel, just type your message like so: /anonymous This is an anonymous message
(but note that you cannot reply anonymously inside a message thread). Messages can also be edited or deleted after posting.
Now that you are set up in Slack, you should rarely, if ever, need to send class-related email! Just send Slack DMs instead.
One caveat to be aware of: due to how Slack operates free workspaces, messages are automatically archived (and not easily retrieved) 90 days after being sent. As a result, the class Slack should not be used for any long-term storage. Note that 90 days is a bit less than the length of the semester, so messages sent during the first few weeks of the semester will start to become inaccessible towards the end of the semester.
This section will overview the server environment you will use to complete the projects in this course. Most of these topics should be review from CSCI 2330.
This class will make heavy use of the Linux command-line. You should already have some comfort with the command line, but if you need or want a refresher, you should refer to the Command-Line Unix Crash Course.
We will also be making use of the git
version control system (and GitHub) to facilitate collaboration. If you are new to git
or just want to brush up, refer to the Git Essential Training Companion Guide. Note that the third part of the guide is especially relevant to group collaboration using Git. As all subsequent projects in this class will be completed in groups, going through the third part of the training is a good idea if you haven't done so previously.
You have been provided an account on the class Linux server that will allow you to work on and submit your projects. You are strongly encouraged to do your coding on the class server. The name of the class server is hopper.bowdoin.edu
(or if you are on-campus, just hopper
for short). The server provides a full-fledged Linux environment with all the standard development tools (editors, compilers, version control, etc) preinstalled. If there is any software that you would like to use that is not already installed on the server, please let me know. Access to your server account is by SSH key only (no password access). You should have received your keyfiles from me via email (if not, let me know promptly). For instructions on using your key, refer to the relevant section of the Unix tutorial.
Starter code for the projects will be distributed via GitHub. For each project, your group will have a personal
git
repository accessible only by your group and myself in which you will complete your work. At the start of each project, an invitation link will be posted to Slack that will initialize your group's project repository on GitHub and add any starter files. Once your project repository is initialized, you can clone it to hopper
and then begin to work.
It is strongly recommended that you configure your GitHub account to use your SSH key for authentication, which will allow you to interact with GitHub without needing to repeatedly type your username or password. Refer to the Git tutorial for instructions.
To make sure that your environment is properly configured and that you understand how to operate it, perform the tasks given below.
First, accept the Project 0 GitHub repository and clone it to hopper
. Then, from hopper
, add a new text file called code.txt
containing your Slack code from Part 0 to the repository. Commit the new file and push to GitHub. Once your repository reflects your new file and code, you have "submitted" Project 0. As a sanity check, you can browse to your repository via GitHub to make sure that your code.txt
file is showing (and contains your code).
If you aren't sure about how to do any part of the above, refer to the previous parts of this writeup to review. Reviewing these topics now will mean that you don't have to later!
This project will be marked pass/fail only based on the presence of your repository on hopper
and GitHub and the existence and content of your code.txt
file.