Skip to content

Latest commit

 

History

History
195 lines (144 loc) · 8.72 KB

CONTRIBUTING.md

File metadata and controls

195 lines (144 loc) · 8.72 KB

Contributing to SOS

Looking for a first issue? You might want to start out by looking at issues tagged "easy". These are issues that, while important, will probably require less knowledge of Rust, systems programming in general, or SOS, and might make good jumping-off points for potential contibutors.

Table of Contents

What do I need to know before contributing?

Code of Conduct

This project adheres to the Contributor Covenant code of conduct. By participating, you are expected to uphold this code. Please report unacceptable behavior to [email protected].

Licensing

SOS is dual-licensed under the MIT and Apache 2 open-source licenses. By contributing code to SOS, you agree to waive all copyright claims on your contribution and allow it to be distributed under these licenses.

Setting Up a Dev Environment

Building an OS is often a fairly difficult process, and can require a number of specific tools, libraries, and other dependencies installed and configured on the host system. In order to make contributing to SOS as easy as possible, we've tried to streamline the development environment setup process as much as possible, but there are still a few steps required before you can build SOS. Please see BUILDING.md for detailed instructions on how to build SOS.

In addition, the tools to assist with coding style section in this document provides information on optional tools that can be used to ensure your contributions conform to SOS' preferred coding style.

Project Goals & Objectives

  • Minimise assembly language code
    • Ideally, files ending in .asm should be used ONLY for the boot sequence
    • When platform-specific assembly code is required after the boot sequence, it should be placed in inline assembly in Rust functions, not in .asm files.
    • This has the following advantages:
      • It requires less linker configuration and makes building SOS much less of a pain.
      • It makes it much easier for Rust code to call code written in assembly language without mucking around with FFI.
      • It encourages us to write as much code as possible in a safe, high-level language, and write assembly only when it is strictly required.
  • Eventually, be able to boot on x86, x86_64, and ARMv7 machines.
  • Move as much out of kernel space as seems reasonable.

Conventions & Style Guides

Git Conventions

Pull requests

In order to be accepted and merged, a pull request must meet the following conditions.

Pull requests MUST
  • Build successfully on Travis
  • Include RustDoc comments for any public-facing API functions or types
  • Include tests for any added features
  • Reference any closed issues with the text "Closes #XX" or "Fixes #XX" in the pull request description
Pull requests MUST NOT
  • Include any failing tests
  • Decrease overall project test coverage
  • Have any outstanding changes requested by a reviewer.

Commit messages

Commit messages should follow the Angular.js Commit Message Conventions. We use clog for automatically generating changelogs, and commit messages must be in a format that clog can parse.

It is recommended that contributors read the linked documentation for the Angular commit message convention in full –– it's not that long. For the impatient, here are some of the most important guidelines:

Commit messages MUST
  • Be in present tense
  • Follow the form <type>(<scope>): <subject>
    • where <type> is one of:
      • feat: A new feature
      • fix: A bug fix
      • docs: Documentation only changes
      • style: Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc)
      • refactor: A code change that neither fixes a bug or adds a feature
      • perf: A code change that improves performance
      • test: Adding missing tests
      • chore: Changes to the build process or auxiliary tools and libraries such as documentation generation
    • and <scope> (optionally) specifies the specific element or component of the project that was changed.
Commit messages MUST NOT
  • Include lines exceeding 100 characters
Commit messages MAY
  • Include the text [skip ci] if changing non-Rustdoc documentation.
    • This will cause Travis CI to skip building that commit.
    • Commits which change RustDoc documentation in .rs source code files should still be built on CI -- [skip ci] should only be used for commits which change external documentation files such as README.md
    • Commits which change configuration files for tools not used by Travis may also skip the CI build, at the discretion of the committer.

Code Style

Rust code should:

The following deviations from the style guide are permitted:

  • Comma-first style may be used for all comma-delimited constructs. For example:

    let a_list = [ a
                 , b
                 , c
                 ];

    and

    let a_list = [ a, b, c, d
                 , e, f, g, h
                 ];

    are considered good style.

  • When wrapping where clauses, place them at the same indentation level as the corresponding fn or impl statement. For example:

    // Considered good style
    fn foo<A>(a: A) where A: Something {
        ...
    }

    and

    // Considered good style
    fn bar<A, B>(a: A) -> B
    where A: Something
        , B: Something + SomethingElse {
        ...
    }

    are considered good style, while

    // NOT considered good style
    fn baz<A, B>(a: A) -> B
        where A: Something
            , B: SomethingElse {
                ...
            }

    is not.

Tools to Assist With Coding Style

EditorConfig

An .editorconfig file is available for compatible text editors. If the EditorConfig plugin is installed in your text editor, it will use this file to automatically configure certain formatting settings for the an-editor repository.

rustfmt

rustfmt is a tool for automatically formatting Rust source code according to style guidelines. This repository provides a rustfmt.toml file for automatically configuring rustfmt to use our style guidelines.

rustfmt may be installed by running

$ cargo install rustfmt

and invoked on a crate by running

$ cargo fmt

Additionally, there are rustfmt plugins available for many popular editors and IDEs.

rustfmt may also be added as a git pre-commit hook to ensure that all commits conform to the style guidelines.