CIIP C++ Course
Welcome to the CIIP course Concepts of C++ programming!
You will use this git repository for solving and submitting homeworks.
Table of Contents
[[TOC]]
You will have to work with multiple git repos:
upstream
remote: new assignments provided by us on GitLaborigin
remote: your code submissions on GitLab- the local repo on your computer: where you create and commit your work.
origin
is your personal "fork" of the base repo.
origin
is used for your grading, and it's stored on GitLab as (your-username_tasks
).
You will pull new assignments from our base repo (upstream
) and push your changes to your personal repo (origin
) to submit your solutions.
That way, you "download" our new assignment from the base repo to your computer and then "upload" your solution to your GitLab repo for grading.
Getting and Submitting new Homeworks
We will publish new homeworks (and bugfixes :) in the base repo, which you then merge into your repo (your-username_tasks
).
If everything is setup correctly it is as simple as (pseudo code!):
$ git pull upstream master # get the new homework assignment from us
# ~~ do the homework ~~
$ git status # see how git thinks about your files
$ git add .... # add the changes you want to commit
$ git commit -m "my submission" # create the commit
$ git push origin master # upload the changes to your GitLab repository
Pushing the changes will trigger our automatic build server, which compiles your code and runs the unit tests (CI). At the end of each assignment period, we will collect your submission, verify your solution and then notify you in an issue if your submission passed or not.
This section explains how you set everything up on your machine. If you have any questions, post it on Zulip so that we can help you and other students can refer to it.
You can automate the GitLab login by using an SSH key:
Instead of always typing your username and password when communicating with GitLab using git, we recommend to set up an SSH key.
- Generate an SSH key pair
- Add an SSH key to your GitLab account
- Now you can clone, fetch and push repos without typing usernames and passwords
Optionally: Configure your computer's ssh
to use a specific SSH key for logins on GitLab:
- In your home folder (
~/
on Mac/Linux andC:\Users\You
on Windows) you should now see the.ssh
(hidden) folder, containing the new SSH-Key (provided you saved the file in the default directory). - To instruct SSH to use a specific key file with LRZ GitLab, you can create a new file in that directory named
.ssh/config
(without any file suffix) and add this content:
Host gitlab.lrz.de
Preferredauthentications publickey
IdentityFile ~/.ssh/#your-private-key-file#
You don't need this config change when you generated the SSH key in step 1 at its default location.
You'll need git
in order to interact with your repository. This tutorial,
will show you the installation process for most operating systems.
- On GitLab you get your remote link by clicking on
Clone
on the main page of your repository. - Choose the link under Clone with SSH.
- Navigate to the directory where you want to download your project and use
git clone <your-link>
, i.e use:git clone [email protected]:cppcourse/ws2023/your-username_tasks.git
- alternative:
git clone https://gitlab.lrz.de/cppcourse/ws2023/your-username_tasks.git
if you don't want to usessh
, buthttps
instead
In order to regularly pull the new assignments and any other changes (bugfixes), you must add the original base repo as upstream
remote.
To do this, navigate to your cloned project's directory and use the following commands from the console:
First check the original setup with:
$ git remote -v
The output should be:
> origin [email protected]:cppcourse/ws2023/your-username_tasks.git (fetch)
> origin [email protected]:cppcourse/ws2023/your-username_tasks.git (push)
which tells us, that your local git repo knows a remote git repo with the name origin
, which is your personal GitLab repo.
Now you need to add "the course organizer's" repo so you can get new tasks from us. To register it as a new remote repo, run:
$ git remote add upstream [email protected]:cppcourse/ws2023/tasks.git
Now you've added our git base repo as upstream
.
Again, you can verify that it was added:
$ git remote -v
> origin [email protected]:cppcourse/ws2023/your-username_tasks.git (fetch)
> origin [email protected]:cppcourse/ws2023/your-username_tasks.git (push)
> upstream [email protected]:cppcourse/ws2023/tasks.git (fetch)
> upstream [email protected]:cppcourse/ws2023/tasks.git (push)
With this configuration, your local git
repo can now talk to two independent remote git
repositories:
origin
is your repo on GitLab, where you commit your homework resultsupstream
is our repo on GitLab, where we publish new assignments
So you're now dealing with 3 repos: Your local repo, your submission remote repo, and the new-tasks remote repo.
If you want to get the new assignments or other changes, go to your project directory and use:
$ git pull upstream master # download and merge our changes to your local repo
This first connects to our server and downloads the information from the base project, where we publish the homeworks to.
Then, it merges our upstream/master
contents into your local master
branch.
For new assignments, we always use new files, so this should work without any merge conflicts.
However, if both of us changed the same file, a merge conflict might happen if the changes aren't compatible, in which case you need to resolve the conflict before you can start working.
We're cannot stress enough that your lecture experience using Windows will most likely be painful. You should really consider installing Linux (e.g. Ubuntu) (also possible alongside Windows), or at least use Linux on Windows (the WSL).
As we'll be covering modern C++ (C++23) you need a recent compiler, otherwhise your project will not compile.
Recommended compilers are:
- GNU GCC 13 and higher (Linux: install
g++
with your package manager, Windows) - LLVM Clang 16 and higher (Linux: install
clang
with your package manager) - (If you really want to, the latest Visual Studio supporting the latest C++ standard)
We will be testing with GCC 13 and Clang 16 on Linux. It therefore could be possible that you encounter errors with other versions.
For later assignments we use the CMake build system. It takes care of building/compiling everything in the right order and hooking everything up, rather than forcing us to manually manage (and possibly forget) some elements or links. Follow this tutorial to install CMake.
You can use any text editor you are comfortable with. We use Doom Emacs (unifies the advantages of Vim and Emacs) and vim/neovim. If you don't have any preference yet, we recommend CLion or VSCode.
To ensure the tests are unmodified for grading, we check if the file content hashes are correct.
During the CI run, we validate that /CMakeLists.txt
and the tests/
directory are as expected, but we can't pre-check /.gitlab-ci.yml
without breaking the universe.
Do not modify these files - otherwise your homework can't be graded!
If you do modify them and get an error message, you must keep your repo history (so no git force-push
) - you can only ever add new things to your repo history, not delete old history elements.
You can always make sure the files are in the "correct" state by running:
# if you want, inspect what you've changed
git diff upstream/master..HEAD CMakeLists.txt tests/ .gitlab-ci.yml
# undo the changes
git restore -s upstream/master CMakeLists.txt tests/ .gitlab-ci.yml
# and commit what is needed to undo your changes
git add CMakeLists.txt tests/ .gitlab-ci.yml
git commit -m "restore important files i should not have modified"