-
Notifications
You must be signed in to change notification settings - Fork 5
Home
A plugin for the Sublime Text editor which marks the current cursor position(s) using dynamic rulers.
-
It can be used for alignment purposes in places where Sublime Text's built-in indent guides aren't able to show up. For example, inside multiple rows of single-line comments or multiple assignment statements across different code blocks.
-
When used alongside line highlighting it creates a crosshair effect which can be a useful visual aid.
-
Use multiple dynamic rulers to create different highlighting styles including a "thickening" effect which can be used to simulate column highlighting.
-
Option to synchronize rulers when using multiple views of the same file.
-
Supports multiple cursors.
-
Toggle activation through the command palette.
-
Compatible with Sublime Text 2 and Sublime Text 3.
The easiest way to install CursorRuler is through Package Control.
After installing Package Control, restart Sublime Text and bring up the Command Palette (Command+Shift+P
on OS X and Control+Shift+P
on Linux/Windows). Select Package Control: Install Package
, wait while Package Control fetches the latest package list, then select CursorRuler when the list appears.
Download the latest source from GitHub and then copy the CursorRuler folder to your Sublime Text's packages folder.
Clone the CursorRuler repository while in your Sublime Text's packages folder:
git clone https://github.com/icylace/CursorRuler.git
-
OS X:
~/Library/Application Support/Sublime Text 2/Packages ~/Library/Application Support/Sublime Text 3/Packages
-
Linux:
~/.Sublime Text 2/Packages ~/.Sublime Text 3/Packages
-
Windows:
%APPDATA%\Sublime Text 2\Packages %APPDATA%\Sublime Text 3\Packages
Another way of getting the path of the packages folder is to open up Sublime Text's Python console by pressing Ctrl+``` (backtick) and then typing
sublime.packages_path()` in it's input field and then pressing enter.
Having the plugin enabled is all that's required to start seeing your cursors have rulers track them.
CursorRuler: Toggle Enabled/Disabled
- Turns CursorRuler off if it's on and vice versa.
CursorRuler: Wrap Lines
- Does proper line wrapping. For details look here.
The default settings file may be accessed through the menu by going to Preferences
-> Package Settings
-> CursorRuler
-> Settings – Default
. The Settings – User
option may be used to either open up the custom user-specific settings file or to create it if it doesn't exist yet.
The following settings are available. They are shown here with their default values.
{
"cursor_rulers": [-0.1, 0.2],
"enabled": true,
"synchronized": true
}
To use custom settings first create a file called CursorRuler.sublime-settings
in your User
folder which should be located within your packages folder. Then copy the aforementioned default settings into this file, make your adjustments, and then save the file. Your changes should take effect the next time the cursor is moved on an open non-previewed file.
A list of column positions relative to the cursor position where dynamic cursor rulers appear. They can be any decimal number. 0 represents the current cursor position so
{
"cursor_rulers": [0]
}
means display a single dynamic ruler exactly where the cursor is. You could experiment with something like
{
"cursor_rulers": [-0.1, 0, 0.2]
}
if you wanted something thicker. The default (what I personally use) which is
{
"cursor_rulers": [-0.1, 0.2]
}
tries to be thick without being too distracting. You could also try something like
{
"cursor_rulers": [0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9]
}
if you wanted to simulate column highlighting! It's not perfect and can look a little odd at larger font sizes but it's the next-best thing to the real thing.
Now for some crazy stuff. The following examples illustrate the silliness that's possible with multiple cursor rulers.
It's possible there might be some people who would consider this first example useful:
{
"cursor_rulers": [-4, -0.1, 0, 0.2, 4]
}
The potential usefulness comes from ability to know at a glance what is cleanly indented and outdented relative to the cursor. In this case the indent spacing is assumed to be 4. The disadvantage here is that it looks visually cluttered (at least to me).
This next example illustrates a much more experimental "gradient" highlighting style:
{
"cursor_rulers": [-2.4, -1.7, -1.2, -0.8, -0.4, -0.2, -0.1]
}
It shows several rulers trailing to the left of your cursor. It may ultimately be too showy to be practical but it does have its own feel once you get used to it.
This final example is yet another experimental highlighting style. This one doesn't highlight the cursor position directly but instead creates a "tunnel" which is centered around the cursor:
{
"cursor_rulers": [-4.7, -4, -3.4, -3.1, -3, 3, 3.2, 3.5, 4.1, 4.7]
}
As you can see, a variety of sometimes useful, sometimes strange highlighting possibilities are out there.
If you have it normally disabled you can enable it for when you need it by using the CursorRuler: Toggle Enabled/Disabled
command from the Command Palette. Use the same command again to turn it back off.
Multiple views of the same file will show cursor rulers that move together in synchronized fashion. This is most useful when using the Rows: 2
, Rows: 3
, or Grid: 4
layout and having multiple views of the same file being used in different groups.
You may want to distinguish the cursor rulers from any normal static rulers you may have set. Unfortunately, I'm not aware of a way to set different visual styles for different rulers. However, one option to workaround this is to set multiple rulers around where a single ruler would normally be. For example, if your rulers setting in your user preferences was set like this:
{
"rulers": [80, 150]
}
then you could do this:
{
"rulers": [80, 80.25, 150, 150.25]
}
to make your normal rulers "thicker" and therefore distinguishable from the cursor rulers.
Also, you may instead consider making your cursor rulers have a thicker style than your normal rulers.
Speaking of ruler visual style, there's apparently no way to set the color of rulers directly. Rulers get their colors from your color scheme's foreground and background settings. The background setting overrides the foreground setting.
Despite the current lack of ability to directly set colors for rulers (as of ST2 build 2219 and ST3 build 3030) there's thankfully a workaround for it described here.
Basically, you need to change the overall default foreground color and/or background color of your color scheme and then add a rule for the text
and source
scopes which is used to override the default colors. For example, if we had a default foreground color which is meant to be used as the ruler and gutter foreground color:
<key>foreground</key>
<string>#00FFFF77</string>
then we would add
<dict>
<key>name</key>
<string>Text and Source Base Colors</string>
<key>scope</key>
<string>text, source</string>
<key>settings</key>
<dict>
<key>foreground</key>
<string>#E6E1DC</string>
</dict>
</dict>
in order for us to define our actual default foreground color.
As a sidenote, gutter text foreground color can be defined directly:
<key>gutterForeground</key>
<string>#0000FF77</string>
as well as the gutter text background color:
<key>gutter</key>
<string>#0000FF33</string>
-
In ST3 the standard shortcut key for the
Wrap Paragraph at Ruler
menu item (⌥⌘Q
on OS X,Alt+Q
on Linux and Windows) is rebound to instead use theCursorRuler: Wrap Lines
command for doing proper line wrapping. However, using theWrap Paragraph at Ruler
menu item without the shortcut key still uses the normal wrapping command. It seems there isn't a way to override ST's default menu items in that sort of way. For details look here. -
While moving a selected group of text with the mouse the insertion-point cursor is not shown with its own dynamic ruler. Though, this is probably preferable since this distinguishes the editing cursors from the insertion-point cursors.
-
The positioning of the cursor rulers is scaled according to the font size. The larger the font size the greater the chance that gaps will get introduced into "thick" cursor ruler styles like the column highlighting style. The size of the gaps are also dependent upon the font size.
-
Using the column-like highlighting style while using a variable-width font looks strange. Perhaps this should considered a bug?
-
In ST3 build 3012 and older the
add_on_change()
method was not implemented and therefore CursorRuler will not use it. In ST2 and also ST3 build 3013 and later it is available and CursorRuler will use it. -
After you save changes to your user settings or your CursorRuler settings the changes take effect once the cursor state changes.
-
If CursorRuler is added to the
ignored_packages
list in the user preferences then upon saving the preferences any open files that have cursor rulers on them will retain those rulers as permanent static rulers. The only way to remove those static rulers would be to either no longer ignore the plugin or reopen the files that are affected. -
On ST2 it doesn't work on previewed files. Perhaps this is beneficial as an indicator for when you're looking at previewed files?
Cross - I just found out about this today (2013-02-20). This predates CursorRuler by about a month.
Have fun !
License: MIT