syntax-clip v1.0.0
Overview
This module will syntax-highlight any text on your clipboard, so you can paste pretty-looking code snippets into any rich text editor (e-mail, doc, etc.). Specifically, the module will:
- Grab any plain text from your clipboard.
- Normalize indentation (strip excess leading whitespace).
- Perform syntax highlighting via highlight.js.
- Inline all CSS rules, for a portable HTML blob.
- Save the formatted HTML back onto your clipboard.
You can customize the language (default is auto-detect, supports many), font family (defaults to Courier, monospace), font size (defaults to inherit), and theme (defaults to atom-one-light, supports many).  See the command-line options below for details.
Note that this module currently only works on macOS. Also note that Visual Studio Code already does this trick natively when you copy code to the clipboard, so this module is probably useless to you if you use that app.
Usage
First, make sure you have Node.js installed on your Mac. Then, use npm to install the module as a command-line executable like so:
npm install -g syntax-clipDepending on your machine and folder permissions, you might have to run the above command with sudo.
Now, try copying some code to your clipboard, and enter the following command into the Terminal:
syntax-clipThat's it! Now try pasting into a rich text editor, and you will see your beautiful, syntax-highlighted code.
Command-Line Options
The following command-line options are available:
--language
By default, the language is automatically detected by the code on your clipboard.  However, you can force it by specifying a --language argument.  The accepted languages are listed here (omit the .js extension).  Example:
syntax-clip --language javascriptLive previews are available here.
--style
By default, the atom-one-light style is used.  However, you can specify any of the themes listed here (omit the .css extension), by specifying a --style argument.  Example:
syntax-clip --style tomorrowLive previews are available here.
--font
By default, the font family used is Courier,monospace.  To customize this, use the --font argument.  You can also specify multiple fallback fonts, comma separated.  Example:
syntax-clip --font "Inconsolata,Monaco,monospace"Please note that custom fonts are not embedded into the HTML, so you should use universally supported fonts, and always append ,monospace at the end for a universal generic fallback.
--size
By default, no size is specified, so the code snippet will inherit whatever size your document is currently using.  To customize this, add a --size argument, and use any of the CSS size units like pt or px.  Example:
syntax-clip --size 14pxGlobal Keyboard Shortcut
To add a global keyboard shortcut on macOS, you first need to wrap the call to syntax-clip in an AppleScript.  To do this, open the Script Editor application (located in Applications/Utilities), and enter this text:
do shell script "/usr/local/bin/node /usr/local/bin/syntax-clip"Please note that the location of your Node.js binary may be different than mine, so change /usr/local/bin/node to the correct location.  To determine what this should be, open Terminal and type which node.  This is important because AppleScripts run without a proper shell environment, so they are often missing things like your standard PATH variable.
Also note that the location of the installed syntax-clip binary may differ from mine, so change /usr/local/bin/syntax-clip to the correct location.  To determine what this should be, open Terminal and type which syntax-clip.
Once this is complete, save your AppleScript somewhere central such as in ~/Library/Scripts/.
Next, you need to assign a global keyboard shortcut to the script. To do this, you can either use a commercial application such as Alfred, Keyboard Maestro, or FastScripts, or you can do it the manual way...
- Open Automator (located in your /Applications folder).
- In the dialog that pops up, select Quick Action and click the Choose button.
- In the search field on the left sidebar, enter applescript.
- Drag the Run AppleScript action to the right-hand pane.
- Paste the do shell script...line into the text field, replacing all the demo code.
- From the menu bar, select File → Save... and give it a name such as Syntax Clip.
- Quit Automator.
- Open System Preferences, then click on the Keyboard icon.
- Click on the Shortcuts tab, then click on ⚙️Services on the left side.
- Scroll down the right pane until you see your Quick Action (should be under General).
- Click on your action and you should see a Add Shortcut button appear. Click it.
- Type your desired keyboard shortcut.
- Quit System Preferences.
Note: These instructions are for macOS Mojave specifically. Things may be quite different in older or newer OS versions.
License (MIT)
The MIT License
Copyright (c) 2019 Joseph Huckaby.
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
6 years ago