These are the contributing guidelines as well as some documentation on how the code is structured. Read up before contributing to make everything as smooth as possible.
Just common sense; do a quick search before posting, someone might already have created an issue (or resolved the problem!). If you're posting a bug; try to include as much relevant information as possible (ungit version, node and npm version, os, any git errors displayed, output from cli console and output from the browser console).
See PLUGINS.md
I do accept pull requests, but I also reserve the right to not do so for things I don't think fit with Ungit. If you are developing anything new you should almost always also provide tests for it, preferably clicktests but it doesn't hurt to write REST-interface tests as well if applicable. Try to post pull requests early, even at a concept stage, to get feedback and increase chances it's merged.
You'll need the same as for Ungit; node, npm and git. You will also need grunt (npm install -g grunt-cli
).
To get started developing on Ungit:
- Make sure you have node.js, npm, git and grunt installed.
- Clone the repository to a local directory.
- Run
npm install
to install dependencies. - Run
grunt
to build (compile templates, css and js). - Type
npm start
to start ungit, ornpm test
to run tests. - (Optional). Run
grunt watch
to automatically rebuild stuff when you change files.
To provide easier access to launch ungit, very early stage of standalone application container using electron is available. Please note this is not yet ready for public release and being developed having several known & unknown limitations.
To get started:
- Follow steps in 'Getting started' to get a development environment ready.
- Run
grunt default && grunt package
. This will compile latest ungit and will create a standalone application package underbuild/
Known limitation:
- Current standalone application does not allow to execute more than one instance.
- There is no installer package neither automatic update mechanism for standalone application in place yet.
Additional notes:
- To create windows package with proper application description on non-windows platform, wine is required to be installed. If not, windows package will be created with default resources.
Ungit has two major parts; the server and the ui. The server exposes a REST interfaces, which enables it to be run on a remote server. The UI is a single-page web-app, built using Knockout.js.
assets/
Raw assets used for development.bin/
"Binary" files, the ungit launcher script and the credentials-helper, which is invoked by git to acquire credentials when using http authentication.clicktests/
Phantom.js clicktest; basically tests that run on the rendered DOM. Since these run all the way, from the DOM down to the server, they're also the most powerful of the tests.components/
This directory contains all view components for Ungit, each of them exposed as an Ungit plugin.public/
The UI web-app.public/css/
CSS generated by the grunt script.public/fonts/
&public/images
Assets, some of which are compiled into the CSS by the grunt script, others (for instance those that are too large to compile into the CSS efficiently) are served directly.public/js/
An ungit.js file generated by the grunt script, as well as raven files which handle exception logging.public/less/
Less files, which are the "source" used to generate the CSS.public/source/
Javascript source code, which is turned into the public/js/ungit.js file by the grunt script.public/vendor/
Various 3rd-party libs.source/
Server and shared (i.e. used by both server and UI) source code.test/
Unit tests and REST interface tests.
grunt test
will run both unit tests, REST-interface tests, and clicktests. grunt unittest
only runs the tests in the test/ folder, grunt clicktest
runs only the tests in the clicktests/ folder. Install mocha (npm install -g mocha
) to run specific tests in the test folder and get better stack traces: mocha test/spec.git-api.js
.
- Try to make everything as touch friendly as possible, for instance no mouse over tooltips (try to make it clear without that). Everything doesn't adhere 100% to that right now but I'm trying to move it more in that direction.
- Write tests. The most important tests to write are usually the clicktests since they will cover the most code (both ui and backend).