Lab exercises and development environment for Glasgow SUPA C++ course, winter 2024
Welcome to 2024 SUPA C++ course. This year we are providing a ready-made development environment using github codespaces that should hopefully make things run more smoothly and reduce the number of prerequisites needed to get started.
- A personal github account
- Click here to login or sign up
- A fork of this repository
- Click here or on the button shown below:
On the github page for your fork of this repository, then select:
Green < > Code ▾ icon → Codespaces tab → Create Codespace on main:
This will start spooling up a new codespace instance. This shouldn't take any more than 5-10 minutes but won't be instant as it has to download and compile some packages on a virtual machine for you.
Once built you should be able to stop and start the codespace almost instantly, with all of your files and settings saved automatically.
If you have never seen it before the layout of VScode can seem a bit daunting but it is ultimately very functional. The main components of the interface are highlighted below:
The most important parts for the lab are the file browser tab (where you can see your file structure), the main editor window (where you will write your code), the terminal (where you will compile and run it), and the source control (git) tab on the left.
One slightly unintuitive aspect is that the file browser and terminal are not linked. If you are viewing/opening nested files in the browser, your location in the terminal does not change to match. To run or compile a file somewhere other than the home directory you will need to change directory manually in the terminal using the cd
command, e.g:
cd Exercises2024/Ex1_2/
g++ -std=c++20 -w myScript.cxx -o myScript
The source control tab is used to keep track of any changes you make and is what you will use to submit your final code. In the image above the blue 2 indicates that there are two files that have changed recently.
When you have code you want to submit open this tab, choose all of the files you would like to add, optionally write a commit message at the top.
Finally click commit and sync changes:
- Provided you have a personal github account you should automatically get 60 core-hours of free codespace usage per-month, which should easily be enough for this course.
- If you go over your allowance it may be possible to extend it for free by registering a student github account but I haven't been able to verify this for obvious reasons
- Related to the point above if you close down the tab your codespace is running in it will continue to run, and use up your allocation, for some time until the instance is automatically suspended.
- The codespace itself is a virtual machine hosting an Ubuntu 22.04.3 image and a few pre-compiled packages. The image is linked to a VScode web-instance which acts as the remote-session host.
- Part of the setup process also downloads a few useful VScode extensions, if you have any of your own favourites feel free to download them as you normally would, though beware some extensions do not work on the web-version of VScode (dev)
- Naturally the github extension is also downloaded by default (under source-control in the side-bar). You can use this to upload your final code by adding and commiting your code changes and then pushing them to your fork.