ctrl+shift+p filters: :st2 :st3 :win :osx :linux
Browse

Colorcoder

by vprimachenko ST2/ST3

Semantic highlight for Sublime Text

Details

  • 3 2014.12.23.19.17.54
    2 2014.11.13.15.03.21
  • github.​com
  • github.​com
  • 5 years ago
  • 3 minutes ago
  • 5 years ago

Installs

  • Total 124K
  • Win 82K
  • OS X 23K
  • Linux 18K
Jun 25 Jun 24 Jun 23 Jun 22 Jun 21 Jun 20 Jun 19 Jun 18 Jun 17 Jun 16 Jun 15 Jun 14 Jun 13 Jun 12 Jun 11 Jun 10 Jun 9 Jun 8 Jun 7 Jun 6 Jun 5 Jun 4 Jun 3 Jun 2 Jun 1 May 31 May 30 May 29 May 28 May 27 May 26 May 25 May 24 May 23 May 22 May 21 May 20 May 19 May 18 May 17 May 16 May 15 May 14 May 13 May 12 May 11
Windows 1 37 26 18 25 50 36 40 50 37 27 49 43 38 34 44 20 31 39 29 27 27 27 27 25 31 40 32 37 41 42 28 50 35 42 30 27 20 29 46 26 35 23 46 34 37
OS X 0 5 3 6 7 6 6 7 6 3 6 12 9 7 6 9 5 2 9 4 3 8 7 3 2 1 7 5 12 5 0 2 9 5 5 10 2 3 4 16 6 10 3 7 7 1
Linux 0 5 3 6 2 9 6 4 6 9 6 7 1 6 4 4 3 6 6 6 8 6 8 4 5 6 11 4 2 4 3 3 10 3 3 3 3 2 7 6 6 8 5 2 4 4

Readme

Source
raw.​githubusercontent.​com

Colorcoder

This plugin for Sublime Text will highlight every variable in its own, consistent color — feature known as semantic highlighting, variable-name highlighting, contextual highlighting — you name it.

Notice how all instances of m_nValue share the same color

Motivation

  • “Coding in color” by Evan Brooks
  • actually thought about something to improve the current highlighting system and accent the data flow
  • help dysgraphic/dyslexic coder

it is important to note i use a crc8 hash of the variable name to give similar named variables distinct colors to improve typo recognition

Installation

Download the zip-ball and unpack to sublime\data\packages or via packageControl. Please make sure to name the resulting folder Colorcoder not Sublime-Colorcoder.

To properly work Colorcoder needs an appropriately modified color scheme. On the first run plugin will try its best to automatically modify your current scheme. :grey_exclamation: the plugin will not actually modify the scheme but create a modified copy in its own directory and apply it. You can use ToolsPackagesColorcoderTweak Colorcode on current color scheme (or CTRLSHIFTP it) to modify the colors a bit (you can change the lightness and saturation). Colorcoder also needs a “good” language definition, which it does not activate automatically but leaves you the choice to do so, read below for more.

Supported Languages

As the few language definitions provided by Sublime are insufficient for optimal Colorcoder results I bundle tailored definitions. So far it's

  • C++
  • Python
  • Lua
  • Go
  • Ruby
  • CoffeeScript (via by @aponxi)

for JavaScript please use the JavaScript Next package.

You can set them up as default via language menuOpen all with current extension asColorcoder… (Colorcoded) or copy them to appropriate folder (erg. Packages/Colorcoder/Python (Colorcoded).tmLanguage to Packages/Python/Python.tmLanguage.

You can also add more scopes for the plugin to colorize via the scopes setting. Colorcoder comes with a handy command colorcoder_inspect_scope which will print the scope of the token under text cursor to the console. You can bind it to a key (e.g. CTRLF12) by adding following to PreferencesKey Bindings – User

{ "keys": ["ctrl+f12"], "command": "colorcoder_inspect_scope"},

Sometimes things we are interested in don't have distinct scope e.g. the variables in Javascript are only source.js. You would need to modify the .tmLanguage.

  • First you need to obtain it - it is inside the same names .sublime-package file, which is a zip-archive
  • now locate the first instance of

    <key>patterns</key>
    <array>
    

it should be somewhere within the first 50–100 lines - use code folding to find where according </array> is - place following right before it

<dict>
        <key>comment</key>
        <string>colorize everything</string>
        <key>match</key>
        <string>\b\w+\b</string>
        <key>name</key>
        <string>colorize</string>
    </dict>

or modify the bundled .tmLanguage files, you probably would only need to replace the keywords

Options

You can turn the highlighting off per view via ViewColorcode this view. Colorcoder also might slow down the editor when highlighting huge files, so it will turn itself off once the file has exceeded the max_size (the check happens when you save the file or reactivate the view). You can force it to highlight the file nevertheless via said menu item (which will read Colorcoding may hurt performance, File is large now) Default (faster) highlighting method makes the undo work letterwise, you can change this by setting use_fast_highlighting_but_undo_typing_letterwise to false. Colorcoder will then use alternative engine, which does not interfer with undo, but work somewhat slower on large files. You might want to tune max_size lower then. Colorcoder allows you to specify white- and blacklist for file-types to highlight: the settings are enabled_for and disabled_for. If enabled_for is present in the config only those file-types will be highlighted, disabled_for won't be highlighted even if present in whitelist. Finally :exclamation: if you use some plugins which change the color scheme based on time, or filename, or modify the schemes you better turn the auto_apply_on_scheme_change off, or the plugin conflict may result in an endless loop which will lock the editor. You can always change the settings even when sublime is not running.

Contact

You can reach me via email: vprimachenko@ya.ru, twitter: @vprimachenko or visit the official irc channel freenode.net#colorcoder (webchat). If Colorcoder was usefull to you i greatly appreciate a donation via Bitcoin 1DzZ1thGTHubRzoxEeDCJnJZwgFpna6jQk.