This repository, including the following content of this "README" file, is a part of ECE220 course content for Fall 2021 semester. The assignments are only for reference. Everything you do with this repo should follow MIT liscense and academic integrity, and the codes of both Zhejiang University and The University of Illinois Urbana-Champaign.
Due to my personal skills, some part of my work may contain bugs and may not be complete. By referring to my work, you agree that you know the risks of using other people's code may introduce extra errors to your own work.
YOU SHOULD NEVER COPY AND PASTE ANYTHING FROM THIS REPOSITORY. PLEASE FOLLOW THE ACADEMIC INTEGRITY.
Thanks for Dr. Steve Lumetta and Dr. Pavel Loskot's instruction. Dr. Steve Lumetta is a professor in The University of Illinois Urbana Champaign, and Dr. Pavel Loskot is an assistant professor in Zhejiang University.
The following content is a part of the course distribution.
ECE 220 Release Repository
Welcome to ECE220! This repository contains all the lab assignments and machine problems that will be completed for the course. The following sections list some Git resources, explain the organization of this repository, how to retrieve/submit assignments, and how to view your grades.
More information about the course itself can be found at the course website
Git is a distributed version control system to track and manage changes to files. This course uses Git for assignment distribution and submission.
We strongly encourage you to follow these 'best practices' for Git (or any version control systems). Although Git will be used in a somewhat limited scope in this class, it is beneficial to develop good habits early on.
You will be interacting with two repositories in this course:
release
. This repository contains all lab assignments and machine problems for the course. Each individual assignment will be released under master branch at an appropriate time. All branches can be viewed through Github by selecting on the drop-down label Branch: master
.Before the start of every assignment, the course staff will push assignments to the release
repository. You will have to merge the newly pushed assignments into your own repository. Once you have completed working on the assignments, you will commit and push your submission. The course staff will grade your lastest submission before the late deadline and post your grades to a grade
branch in your own repository.
To ensure that this workflow will work properly please follow the instructions below.
This course uses Git and Github as the primary means of distributing materials. If you are unfamiliar with git, please take a look at the links below to learn more about Git and its workflow:
The above list is only a very small fraction of the Git resources that are available online. We encourage you to research other resources as well.
To create a repository for the class, first login at UIUC's Github at https://github-dev.cs.illinois.edu. Next, visit https://edu.cs.illinois.edu/create-ghe-repo/ece220-fa21-zjui/ to create a repository for this class. Now, if you navigate to https://github-dev.cs.illinois.edu/ece220-fa21-zjui, you will see a repository under your NetID. Click on your NetID and you will be shown a page that shows the contents of your repository. Initially, this repository will be empty but don't worry about that because it will be populated soon.
On the upper-left side of the page, there is a button Clone or download. Click on the button and make sure it says Clone with HTTPS. If not, click on the Use HTTPS text. Copy the link shown in the window which should be of the form https://github-dev.cs.illinois.edu/ece220-fa21-zjui/NetID.git. In a terminal, navigate to the location where you would like to keep your files for ECE220. Type and paste the copied URL:
git clone https://github-dev.cs.illinois.edu/ece220-fa21-zjui/NetID.git
This will clone the remote repository to your computer where you will be able to retrieve/submit/work on assignments.
Release
RemoteTo retrieve assignments from the release
repository you have to add it as a remote:
cd NetID
git remote add release https://github-dev.cs.illinois.edu/ece220-fa21-zjui/_release.git
Check that the remote was added:
git remote -v
You should see four lines of output, two for origin and two for release:
origin https://github-dev.cs.illinois.edu/ece220-fa21-zjui/NetID.git (fetch)
origin https://github-dev.cs.illinois.edu/ece220-fa21-zjui/NetID.git (push)
release https://github-dev.cs.illinois.edu/ece220-fa21-zjui/_release.git (fetch)
release https://github-dev.cs.illinois.edu/ece220-fa21-zjui/_release.git (push)
It is important that you configure your repository correctly! If the following configuration parameters are not set, the auto-grader may not pull the correct versions of your submission and you may receive a lower score on your assignment. Regardless of which device you choose to work on your assignments (lab and/or personal machines), please set the configuration parameters described below.
Set your name and email for your class repository:
git config user.name "Your Name"
git config user.email "NetID@illinois.edu"
Verify that your name and email have been correctly set:
git config --local --list
To retrieve (or update) released assignments, run:
git fetch release
git merge release/master -m "<some comment>"
git push origin master
where <some comment>
is a comment of your choice. The last command pushes the
newly merged files to your remote repository. If something ever happens to your
repository and you need to go back in time, you will be able to revert your
repository to when you first retrieved an assignment.
To submit (or update) completed assignments, familiarize yourself with the process below.
There are a couple of states that files may be in as you are working on your assignment:
To see all modified tracked and untracked files in your Git workspace, run:
git status
To stage any modified tracked or untracked files/directories for a commit, run:
git add <file/directory> <file/directory> ...
To commit any staged modified tracked or untracked files/directories to your local repository run:
git commit <-a> -m "<some comment>"
Rather than individually staging any modified tracked files, you can stage them
all at once using the <-a>
option with the above command. Note that this will
not stage any untracked files. Which commands to use to stage files/directories
depends on the situation. Individually staging files with git add
gives you
more control over which changes will be part of the next commit whereas using
the <-a>
option reduces the amount of typing necessary to stage all modified
tracked files.
Finally, push the committed file/directories in your local repository to the remote repository with:
git push origin master
Verify that your submission are visible in the remote repository through a web browser. If you can see your changes, then the auto-grader can as well.
To avoid issues with having to pull code from the remote repository, a new
branch called 'grade' will be created for you once the first assignment has been
graded. You can view your grades through the web browser by navigating to
https://github-dev.cs.illinois.edu/ece220-fa21-zjui/NetID.git (replacing NetID with
your own) and clicking on the button that says Branch: master
. A dropdown with
all available branches will appear. Click on the grade
option. This will
display a list of directories corresponding to each of your assignments. Inside
these directories, you will find a grade.txt
file with your score.
To be added soon.
You may choose to work on class assignments on your own personal device rather than on lab machines. However, you should always verify that your submission works on D-331 machines because the D-331 environment is used by the auto-grader. If you do decide to use your own machine, you will have to learn how to pull your own code from your class repository and how to resolve potential merge conflicts.
Suppose that you have cloned your repository on both your lab machine and your personal device. At some point, you may have made edits and pushed these edits from one of the machines and wish to work on the other machine. To do so, you will first need to pull the changes from your class repository:
git pull origin master
This will bring in the edits you made from the other machine unto the current machine.
If there were any changes in the repository on your current machine, then Git may tell you that there are merge conflicts. To see the merge conflicts, run:
git status
There will be a list of files under the heading 'Unmerged paths' for any merge conflicts. For each merge conflict, do the following:
<<<<<<< HEAD
i += 1;
=======
i += 2;
>>>>>>> origin/master
i += 3;
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。