layout | title | parent | nav_order |
---|---|---|---|
default |
Repositories |
Fundamentals |
1 |
A software project is composed of multiple artifacts, such as its source code and tests, the documentation, as well as configuration and installation scripts. If the artifacts of a software project are available publicly, to read and modify, the software is said to be open-source. Software projects across all domains, such as email clients{:target="_blank"}, e-commerce platforms{:target="_blank"}, video games{:target="_blank"}, web browsers{:target="_blank"}, space-robot{:target="_blank"} software, programming languages{:target="_blank"}, and even whole operating system kernels{:target="_blank"}, may be free and open-source (FOSS{:target="_blank"}). Millions of software projects are hosted as code repositories on online platforms such as GitHub{:target="_blank"}, GitLab{:target="_blank"}, Bitbucket{:target="_blank"}, and SourceForge{:target="_blank"}, to name a few{:target="_blank"}. A code repository is the place where contributors work, exchange, discuss and collaborate.
As an example, let us consider the widely-used{:target="_blank"}, open-source text editor called Vim{:target="_blank"}. Vim is freely available through its repository on GitHub{:target="_blank"}. In addition to the actual code that powers Vim, this repository also showcases a comprehensive introduction to this software project. The repository documents how Vim can be built from the source code, guidelines for how individuals can contribute, as well as statistics such as the major programming languages that Vim is implemented in. Much like this repository, the README
file{:target="_blank"}, is usually a very good place to start when first learning about an open-source project. The contents of the README
file within each directory of a project are automatically displayed when browsing through its repository. This is also the case for the feature-rich and powerful Inkspace{:target="_blank"} vector image editing tool, hosted as an open-source repository on GitLab{:target="_blank"}.
Regardless of the specific platform where an open-source project is hosted, browsing through its repository can be an informative and rather fun exercise. It allows us to gain insights into how the project has evolved with time, issues and bugs that have been discovered, those that have been resolved, as well as code contributions made by the open-source community. Moreover, we also learn about other open-source technologies that power the project, which opens up more avenues for exploration{:target="_blank"}.
In this chapter, we learn about
- How individuals contribute to open-source projects
- How we can guage the activity and popularity of open-source projects
- Open-source licenses
- Versioning in open-source software systems
We also encourage you to explore the links throughout the text, the Do-It-Yourself tasks, as well as the resources listed in the references.
A software project typically has multiple contributors. There are various ways in which an individual may contribute to a software project, such as with the implementation of a new feature, to fix a bug, with a new test that verifies an untested behavior, or to improve the documentation, including translations{:target="_blank"} to spoken languages. The open-source movement thrives (see reference 1) as a direct consequence of the contributions made by enthusiasts, users, and developers, who have diverse backgrounds and areas of expertise, and come from different geographical regions.
Open-source software projects maintain a list of individuals who have contributed to them. An individual becomes a contributor to a software project when a submission made by them is adopted into the code-base of the project. The number of contributors of a software project can be useful to guage the maturity{:target="_blank"} of an open-source software project. For example, the node{:target="_blank"} project repository lives on GitHub, and has received contributions from thousand of individual contributors. Incoming contributions to the project are presented on the the pull requests tab{:target="_blank"}. We can also investigate the history of contributions more deeply through the contributors page{:target="_blank"}, which indicates the developers most actively involved in the project.
A majority of open-source projects today use a distributed versioning system called Git{:target="_blank"}, including all the projects hosted on prominent platforms such as GitHub and GitLab. Git is a handy tool with many features that facilitate efficient collaboration among the contributors of a software project. A developer can submit changes to a project incrementally via commits, which are atomic units of contribution in the Git workflow. Git is an essential prerequisite to understanding and contributing to open-source projects. Many excellent resources exist online that introduce its foundations, as well as more advanced usage (see references 2 and 3). The source code of Git itself resides in a GitHub repository{:target="_blank"}, where we can observe the project, including the latest commits{:target="_blank"} to its main development branch. As a rule of thumb, more actively developed and maintained open-source projects have more frequent and recent commits.
In addition to the commits, some more metrics can indicate the popularity of an open-source project. For example, a user can follow the updates made to a project on GitHub by starring its repository, and receive notifications by watching it. Users may also create a copy, or fork, of the project in order to implement some of their own extensions to it, and optionally contribute them back to the original project through pull requests.
In the figure above, we see the GitLab repository of the Tezos{:target="_blank"} blockchain, and the GitHub repository of the MongoDB{:target="_blank"} database. For both projects, we see the number of commits, as well as the number of times they have been starred and forked by users.
Most open-source projects include a license{:target="_blank"}, which is a legal document that defines the terms in which the use of the software is permitted. It also tells the users of the software what their rights are, with respect to the software. For example, the license dictates if a software project may be incorporated only in non-commercial contexts or even in commercial products, used directly without being modified, or may be customized before being used, etc. It is useful to compare{:target="_blank"} between the many available open-source licenses and choose{:target="_blank"} one that is right for a project. The license is usually specified in a file called LICENSE
, as in the case of the NASA worldview{:target="_blank"} project.
In order to keep track of incremental changes in a software project repository, Git assigns unique identifiers to a snapshot of the state of the project at each commit. For example, astropy{:target="_blank"} is a library that provides tools to work with astronomical data in the Python language{:target="_blank"}. Each commit{:target="_blank"} in astropy has its own commit id, as well as a brief description, or commit message, of the changes it includes.
Developers mark important milestones in their software project as it evolves with time. This is achieved by assigning versions to the state of the project at a certain point in time. If a developer fixes an important bug{:target="_blank"} or implements a new feature, a new version{:target="_blank"} of the software is released. A new version is the culmination of smaller changes, such as multiple commits. It is good practice to document the changes{:target="_blank"} included within a new version, so that users of the software are aware of them.
Find two open-source projects, and report the following data for them:
- Name
- Organisation
- Domain
- Link to the project repository
- Main programming language(s)
- Number of commits
- Link to the most recent commit
- License
- Other interesting statistics / information (recent activity, contributors, stars, ...)
- A bug report
- A contribution accepted into the project
- A file with source code
- A file with test code
- Latest release
- Personal experiences using / working with the project
- Mentions on Wikipedia / in the press
- Project website
- Pots of Gold at the End of the Rainbow: What is Success for Open Source Contributors?{:target="_blank"}
- The Git Book{:target="_blank"}
- Learn Git Branching{:target="_blank"}
- The Multibillion Dollar Software Supply Chain of Ethereum{:target="_blank"}