Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sublimehq/packages
Syntax highlighting files shipped with Sublime Text and Sublime Merge
https://github.com/sublimehq/packages
sublime sublime-syntax sublime-text syntax-highlighting
Last synced: about 16 hours ago
JSON representation
Syntax highlighting files shipped with Sublime Text and Sublime Merge
- Host: GitHub
- URL: https://github.com/sublimehq/packages
- Owner: sublimehq
- License: other
- Created: 2015-06-13T04:17:44.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2025-01-14T11:28:44.000Z (9 days ago)
- Last Synced: 2025-01-15T23:43:21.401Z (8 days ago)
- Topics: sublime, sublime-syntax, sublime-text, syntax-highlighting
- Language: Shell
- Homepage: https://sublimetext.com
- Size: 12.2 MB
- Stars: 2,957
- Watchers: 107
- Forks: 591
- Open Issues: 208
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Sublime Packages
## Requirements
These packages are developed
against the latest build of Sublime Text
in the [`dev` channel](https://www.sublimetext.com/dev).The latest release of Packages shipped with Sublime Text
should be tagged via git in this repository.
You can find a list at .Bugs may exist on older builds
and the format used is **not compatible**
with builds older than Build 4095.## Installation
To make changes to these packages
and test them locally,
fork this repository.
Then symlink the changed packages
into your [`Packages`][packages] folder.
(Replace `Python` in the following commands
with the name of the syntax to install.)### OS X
```bash
$ git clone https://github.com/sublimehq/Packages.git
$ ln -s `pwd`/Packages/Python ~/Library/Application\ Support/Sublime\ Text/Packages/
```### Linux
```bash
$ git clone https://github.com/sublimehq/Packages.git
$ ln -s `pwd`/Packages/Python ~/.config/sublime-text/Packages/
```### Windows
On Windows,
you can use directory junctions instead of symlinks
(symlinks require administrative rights;
directory junctions don't):```powershell
# Using PowerShell
PS> git clone https://github.com/sublimehq/Packages.git
PS> cmd /c mklink /J "$env:APPDATA/Sublime Text/Packages/Python" (convert-path ./Packages/Python)
```Alternatively, download the portable version
and clone this repository directly as a subdirectory of the `Data` folder.### ⚠️ Things to keep in mind
After you've finished,
keep in mind that you're now overriding a default package.- If other people make upstream changes to an overridden package,
yours will be out-of-date when Sublime Text updates to a new version.
To get the latest version,
pull the changes from this repository.- If you delete/rename files,
but they still exist in the package version
that was shipped with the build of Sublime Text you are using,
those original files will still be picked up by Sublime,
unless you replace the entire shipped package
with an installed package of the same name.For example, if your build of Sublime has a `syntax_test_sql.sql` file
inside the root of `/Packages/SQL.sublime-package`,
then you symlink the SQL folder
from this repository to `/Packages/SQL`,
move that file to a `tests` subfolder,
and then run all syntax tests,
the old syntax test file will still get picked up
in addition to the new one.To prevent this,
you can create an empty zip file
in your `/Installed Packages` directory like `SQL.sublime-package`
and that will cause ST to load this one in place of the shipped one.
In the end, you are just overriding an empty package
instead of merging new files into an existing package.A quick way to create such an empty zip file is via:
```bash
$ printf "PK\x05\x06\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00" > empty.zip
# or
$ touch dummy && zip empty.zip dummy && zip -d empty.zip dummy && rm dummy
```
Optionally, to make your empty packages stand out in directory listings,
you can create them using symlinks to this empty zip file
instead of copying it,
e.g. `ln -s empty.zip SQL.sublime-package`.## Reference
Please refer to the official documentation:
* [Syntax definitions](https://www.sublimetext.com/docs/syntax.html#ver-dev)
* [Scope naming](https://www.sublimetext.com/docs/scope_naming.html)## Pull Requests
Pull requests should:
1. Start with the name of the package in square brackets,
e.g. `[XML]`.
2. Be as small and self-contained as is reasonable.
Smaller changes are quicker to review.
3. Include a new (or enhanced) [syntax test](https://www.sublimetext.com/docs/syntax.html#testing)
when changing a `.sublime-syntax` file.
4. Have multiple syntax tests
and a set of performance measurements (old vs. new)
when making significant changes.
5. Be squashed on merge to keep the commit history linear.### New Packages
Pull requests for new [packages][]
won't be accepted at this stage,
as new packages can cause issues for users
who have a package with the same name
installed via [Package Control][].
There are some planned changes
that will address this in the future.Complex plugins,
such as auto complete systems and linters,
should generally be in a stand-alone package
rather than included in the default set of packages.## Missing Packages
This repository only contains syntax-definition-focused packages.
Notably, packages such as `Default` and `Theme - Default` are not included.[packages]: https://www.sublimetext.com/docs/packages.html
[Package Control]: https://packagecontrol.io/