Jellyfin Qt
QML Library for interacting with the Jellyfin multimedia server
Loading...
Searching...
No Matches
Contributing

All resources for (potential) contributors.

This page should contain all resources for people who'd like to contribute to the project. If that happens to be you, thank you for considering to contribute to this project! This page will describe how the process goes, what code style this project uses and more useful information.

Development process

Development happens at GitHub. Currently, both the library Jellyfin-Qt and the Sailfish OS app named Sailfin are developed in the same repository.

Create or find an issue to work on

If you want to contribute code, please check if an issue exists. Otherwise, create an issue describing what feature you'd like to develop before creating a merge request.

Start working on your code

Clone the git repo and create a new branch. If you have commit access to the repository, please create a branch in the form of <issue-number>-<issue-title>. For example, 36-control-remote-jellyfin-sessions.

Now you can start writing your code and create commits. Please create focussed commits, that is, do not commit anything not related to the issue you are working on. Also state what you're changing in the commit message and add an entry in the file rpm/harbour-sailfin.changes.

If this is your first time contributing to the project, don't be shy and feel free to add your name to the contributors list in sailfish/qml/pages/AboutPage.qml!

Submit a merge request

Now that you have finalised your commit, you can create a merge request on the repository. Make sure that you have followed the contribution guidelines on this page. Someone will review it and if all is good, they will merge it in.

Congratulations on your contribution!

Code style guidelines

The code should follow the Sailfish OS Code Conventions with the following exceptions:

Exceptions for C++

  • Put curly braces on the same line as the declaration, example:
    int foo() {
    // implementation
    }
    instead of
    int foo()
    {
    // implementation
    }
    Rationale: I hate pressing enter and am used to the former. Moreover, it is already all over the place. Bad rationale, I know.
  • Close namespace brackets with a comment in the form // NS Jellyfin, example:
    namespace Jellyfin {
    namespace Nested {
    // Content
    } // NS Nested
    } // NS Jellyfin
    Rationale: Easy to know what namespace the bracket closes, since namespaces tend to span over large portions of a file.
  • Use include guards in the form of NAMESPACE_CLASSNAME_H. Example:
    #ifndef JELLYFIN_MODEL_USER_H
    #define JELLYFIN_MODEL_USER_H
    namespace Jellyfin {
    namespace Model {
    class User {
    // Methods etc
    };
    } // NS Model
    } // NS Jellyfin
    DTO::UserDto User
    Definition apimodel.cpp:33