-
Notifications
You must be signed in to change notification settings - Fork 2.7k
Get MuseScore's source code
- Fork MuseScore's repository (optional)
- Clone the repository
- Running subsequent commands
- Adding required dependencies
You must have Git installed on your computer (see Set up Developer Environment).
You can skip this step if you never plan to edit MuseScore's source code (you just want to compile it).
A fork is an online (remote) copy of a repository which can be different to the original (unlike a mirror which is the same as the original). You must make a fork if you want to edit the code, even if you plan to contribute your changes back to the official repository.
- Sign-in to GitHub (create a free account if necessary).
- Visit the official repository's page: https://github.com/musescore/MuseScore
- Click the "Fork" button in the top right to create your personal fork.
Your fork exists at https://github.com/[USERNAME]/MuseScore
where [USERNAME]
is your GitHub username (e.g. shoogle's fork is here).
A clone is an offline (local) copy of a repository. If you made a fork then you should clone that, otherwise clone the official repository.
# Everybody should run these commands:
cd ~ # change (go) to your home directory
mkdir src # create new directory for source repos
cd src # change to the new directory
git clone https://github.com/[USERNAME]/MuseScore # add username to this command (see below)
cd MuseScore # change to the MuseScore directory
# Run these only if you made a fork:
git remote add upstream https://github.com/musescore/MuseScore.git
git remote set-url upstream --push disabled # prevent accidental push to official repo (team members only)
# Run this only if you didn't make a fork:
git remote set-url origin --push disabled # prevent accidental push to official repo (team members only)
Replace [USERNAME]
with your GitHub username in the git clone
command. If you skipped the Fork step then you should use musescore
as the username.
Tip: If you did make a fork, consider using its SSH URL [email protected]:[USERNAME]/MuseScore.git
instead of the HTTPS URL with the git clone
command. This requires additional setup, but it means that you don't have to enter your password every time you push code changes to GitHub.
Important information for multi-boot users: Git uses low-level system calls to increase filesystem performance. Always store Git repositories on a filesystem that is native to your operating system (NTFS for Windows, APFS for macOS, BTRFS or EXT4 for Linux). Do not attempt to use a single repository instance with multiple operating systems as doing so decreases Git performance and may lead to data corruptions. You have been warned!
Commands on subsequent pages of the compilation guide start from inside your local copy of MuseScore's repository. Use the following command to get there:
cd ~/src/MuseScore # or wherever you cloned the repo
You'll need to do this every time you open a new terminal window or use the cd
command to move away from MuseScore's directory.
Download the required dependencies here. After you extract the contents, put it inside the MuseScore folder with other folders such as assets, share, src, etc. If you followed the earlier instructions exactly, it will be located at ~/src/MuseScore
Testing
- Manual testing
- Automatic testing
Translation
Compilation
- Set up developer environment
- Install Qt and Qt Creator
- Get MuseScore's source code
- Install dependencies
- Compile on the command line
- Compile in Qt Creator
Beyond compiling
Misc. development
Architecture general
- Architecture overview
- AppShell
- Modularity
- Interact workflow
- Channels and Notifications
- Settings and Configuration
- Error handling
- Launcher and Interactive
- Keyboard Navigation
Audio
Engraving
- Style settings
- Working with style files
- Style parameter changes for 4.0
- Style parameter changes for 4.1
- Style parameter changes for 4.2
- Style parameter changes for 4.3
- Style parameter changes for 4.4
Extensions
- Extensions overview
- Manifest
- Forms
- Macros
- Api
- Legacy plugin API
Google Summer of Code
References