Source code for the Linux-In-The-Browser project used in the CS 241 (System Programming) course at UIUC. View it live here.
Use the issue tracker to submit bug reports and feature requests. If you would like to work on this project, continue reading to get started.
sysbuild/
├── app/ Application source code
│ ├── images/ Images/pictures
│ ├── jor1k/ The jor1k project source copied by grunt during setup
│ ├── scripts/ Javascript files
│ └── styles/ SASS and CSS files
├── dist/ The distributable application output by the build process
├── bower_components/ Dependencies installed by Bower
├── node_modules/ Dependencies installed by npm
├── sys-gh-pages-config/ Config for the application deployed on production
└── test/ Tests
└── spec/
This project was scaffolded using the Yeoman webapp generator.
-
Set up Git and install node.js. Node's package manager (npm) comes bundled.
-
Globally install Bower and Grunt. You might need to use
sudo
or run the command as an Administrator if it fails due to missing permissions, because of the location npm installs global packages in.
npm install -g bower grunt-cli
-
Fork this repository. Clone your forked git repository.
git clone https://github.com/YOUR-USERNAME/sysbuild.git
-
Change to the project directory.
cd sysbuild/
-
Configure Git to sync your fork with the original repository.
git remote add upstream https://github.com/cs-education/sysbuild.git
-
Install dependencies and set up the project.
npm install
-
Run a development server. Automatically launches default browser. Also supports live reloading, which means changes automatically show up without the need to refresh the page. Files are also watched for changes - JSHint is automatically run on the changed JS files, changed SASS files are automatically compiled, etc.
grunt serve
-
If you add a new bower component, you might want to automatically inject supported Bower components into the HTML file.
grunt bowerInstall
-
Run JSHint.
grunt jshint
-
Run JSCS.
grunt jscs
-
Run tests.
grunt test
-
Run a local test server, to run the tests in a browser. Navigate to
http://localhost:9001
after running the following.
grunt testserver
-
Make sure your fork is up to date with the upstream repository. See https://help.github.com/articles/syncing-a-fork/.
git fetch upstream
git checkout master
git merge upstream/master
git push origin master
-
Create a new branch to make changes or add a new feature.
git checkout -b my_awesome_feature_branch
-
Stage your changes before committing. Type the following for every added/modified/deleted file.
git add path/to/modified_file
-
Commit your changes. Do this often.
git commit -m "I changed this to that and fixed bla."
-
Push the branch to origin so that others can see it.
git push origin my_awesome_feature_branch
-
Create a pull request for merging into the upstream
master
. Wait for someone to review your code and merge your changes. Make sure you followed the code guidelines below. If you were working on an issue, you can have the issue closed automatically when the pull request is merged.
-
We have an editor config file for maintaining a consistent coding style. Read more and download plugins at http://editorconfig.org.
-
Please include tests whenever possible.
-
Keep accessibility in mind when writing HTML.
-
Make sure there are no JSHint/JSCS errors.
-
Make sure all tests pass.
-
Avoid pushing changes to
master
. Most changes should be in their own branch, which should then be merged intoupstream/master
through a pull request. Your fork'smaster
should always be in sync withupstream/master
. If you made your changes in yourmaster
branch and your pull request gets rejected, yourmaster
branch will be ahead ofupstream/master
and it is hard to cleanup. Therefore, always make changes in a new branch. -
We use Travis CI for continuous integration. Every time you open a pull request and make commits onto it, a build is triggered. Sometimes you will make commits which do not need a build to be created (for example, editing the README or non-code changes). In that case, just add
[skip ci]
somewhere in your commit message. Learn more.
We use GitHub Pages for hosting the application. The production repository is https://github.com/cs-education/sys and the staging repository is https://github.com/cs-education/sys-staging. You will need push access to the appropriate repository before you can deploy.
-
Build the distributable project (output in the
dist/
folder).
grunt build
-
Deploy to staging.
grunt deploy:staging
-
Deploy to production.
grunt deploy:prod
Dr. Lawrence Angrave github.com/angrave
Anant Singh github.com/anant-singh
Eric Ahn github.com/wchill
Joseph Tran github.com/jdtran23
Keagan McClelland github.com/CaptJakk
Neelabh Gupta github.com/neelabhg
Scott Walters github.com/scowalt
Siddharth Seth github.com/siddharth-seth
The Virtual Machine is powered by the jor1k project.
The code editor is powered by Ace.
This project is licensed under a modified version of the University of Illinois/NCSA Open Source License. See LICENSE.md for license, attribution and other legal information.