Beta stage warning

We're currently working hard to provide the most complete documentation possible so that everyone can enjoy the hidden and not-so-hidden features of our great editor.

So, this section will actually be a work-in-progress for quite a long time, with things added, removed and tweaked all the time.

In case you need some help, regarding a function not being currently documented, or if you've noticed a particular bug, or even if you have anything to share (feedback, ideas, feature requests are all welcome!), please feel free to let us know about it. We're all ears!

Peppermint is a multi-purpose JavaScript/CoffeeScript-able code editor for your everyday coding needs. What you want to do with it is entirely up to you:

  • Write a simple script / application in any of its 50+ supported languages
  • Manage big projects, by simply adding them to your sidebar
  • Click'n'run your scripts, preview your HTML, or obfuscate your JavaScript, without ever leaving Peppermint
  • Use one of the dozens of plugins (or user plugins) to boost your productivity
  • Program Peppermint live, by using its Live Console and the powerful Peppermint API
  • Write your own themes and plugins, personalize your editor and share with the community

The Interface

A picture is worth a thousand words

Unknown

Installing new themes

Where can I find extra themes?

Peppermint comes with 10+ "official" beautiful dark and bright themes. And they're 100% open-source (find them on GitHub). Now what if you want even more?

Peppermint themes are highly compatible with existing Textmate/Sublime/Ace themes. So if you need a specific template, why not contact us and we'll gladly convert it for you! Or even create and share your own creations!

You can also browse through our Themes section and pick the one you like.

Installing a themes is as simple as 3 easy steps, like installing a plugin:

  • Find your ppTheme
  • Go to Extensions > Manage > Install New Theme
  • Select the theme you need to install.

And that was it! You have just added a new theme, and access it either via the View > Theme.


Creating your own themes

Here's the default Classic Peppermint style.less code:


#peppermint {

	/***************************
	 General styling
	 ***************************/

	font-family: Menlo;
	color: #E6E1DC;
	background-color: #202020;

	#normal-mode .cursor-layer {
		z-index: 0;
	}

	.gutter {
		background-color: #3d3d3d;
		background-image: -moz-linear-gradient(left, #3d3d3d, #333333);
		background-image: -ms-linear-gradient(left, #3d3d3d, #333333);
		background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#3d3d3d), to(#333333));
		background-image: -webkit-linear-gradient(left, #3d3d3d, #333333);
		background-image: -o-linear-gradient(left, #3d3d3d, #333333);
		background-image: linear-gradient(left, #3d3d3d, #333333);
		background-repeat: repeat-x;
		border-right: 1px solid #4d4d4d;
		text-shadow: 0px 1px 1px #4d4d4d;
		color: #222;

		&-layer 		{ background: repeat left top; background-image: url(''); }
		&-active-line 	{ background-color: #3F3F3F; }
		&-cell:hover 	{ color: #666; }
	}

	.fold {

		background-color: #AC885B;
		border-color: #f8f8f8;

		&-widget {
			text-align: center;

			&:hover { color: #777; }

			&.start:after 	{ content: '▾'; }
			&.end:after 	{ content: '▴'; }
			&.closed:after 	{ content: '‣'; }

			&.start, &.end,& .closed {
				background: none;
				border: none;
				box-shadow: none;
			}
		}

	}

	.print-margin {
		border-left: 1px dotted #2D2D2D;
		right: 0;
		background: #262626;
	}

	.scroller {
		-webkit-box-shadow: inset 0 0 10px black;
		-moz-box-shadow: inset 0 0 10px black;
		-o-box-shadow: inset 0 0 10px black;
		box-shadow: inset 0 0 10px black;
	}

	.cursor { border-left: 2px solid #FF852E; }

	.overwrite-cursors {

		.cursor {
			border: 1px solid #FFE300;
			background: #766B13;
		}

	}

	.text-layer { background-image: url(''); }

	.marker-layer {

		.selection { background: rgba(221, 240, 225, 0.2); }

		.selected-word {
			border-radius: 4px;
			border: 8px solid #3f475d;
			box-shadow: 0 0 4px black;
		}

		.step { background: #c6dbae; }

		.bracket {
			margin: -1px 0 0 -1px;
			border: 1px solid rgba(255, 255, 255, 0.25);
		}
		.active-line { background: rgba(255, 255, 255, 0.031); }
	}

	.indent-guide { background: url('') right repeat-y; }
	.error { background-image: url(''); }
	.warning { background-image: url(''); }

	.tooltip {
		background-image: none;
		background-color: rgba(255, 255, 255, 0.9);
		border: none;
		border-radius: 0px;
		font-family: Helvetica;
	}

	.breakpoint {
		border-radius: 20px 0px 0px 20px;
		box-shadow: 0px 0px 1px 1px #191919 inset;
	}

	/***************************
	 Syntax Highlighting
	 ***************************/

	.invisible { color: rgba(255, 255, 255, 0.25); }

	.invalid {
		&.illegal { 
			color: #F8F8F8;
			background-color: rgba(86, 45, 86, 0.75); 
		}

		&.deprecated {
			text-decoration: underline;
			font-style: italic;
			color: #d2a8a1;
		}
	}

	.support { color: #9b859d; }

	.support.function {
		color: #ffec60;
	}
	.string {
		color: #bbff08;

		&.regexp { color: #e9c062; }
	}

	.comment { font-style: italic; color: #3f3a40; }
	.variable { color: #7587a6; }
	.xml-pe { color: #494949; }

	.keyword, .meta { color: #ffb537; }
	.constant, .constant.character, .constant.character.escape, .constant.other, .heading, .markup.heading, .support.constant { color: #ff501c; }
	.list, .markup.list, .storage { color: #f9ee98; }
	.entity.name.function, .meta.tag, .variable { color: #ac885b; }

}

What is a Plugin?

A plugin is an easy way to extend the core functionalities of Peppermint.

Written in the JavaScript/CoffeeScript Peppermint API, plugins - either global ones (valid for any language mode) or language-specific - are the best way to take Peppermint to another level. We've done all the groundwork for you - and even provided lots of built-in plugins for various essential functions.

So, let your imagination run wild and make the most out of it!

Installing new plugins

Where can I find extra plugins?

Peppermint has, by design, a "batteries included" philosophy and comes packed with dozens of open-source plugins - elegantly extending its core functionality.

However, if you still need more than what's included, there's still hope! Why not have a look into our Plugins section?

Or, even better, develop your own plugins with the super-charged Peppermint API?

Installing a plugin is as simple as 3 easy steps:

  • Find your ppPlugin
  • Go to Extensions > Manage > Install New Plugin
  • Select the plugin you need to install.

And that was it. You have just added a new plugin, and access it either via the Extensions main menu, or via the extensions menu () in your status bar!


Building your own plugins

Every plugin consists of two core files, packed in a Your Plugin Name.ppPlugin bundle :

info.json A general description of the plugin, for identification purposes, also providing the entry point of the plugin.
script.coffee (or script.js - if a script.js file is found, this is the one to picked The main script to be executed, written in CoffeeScript (or JavaScript) and the Peppermint API

The name of your .ppPlugin bundle is the one appearing the plugins menu!

Step-by-step

  1. Create a folder name Your Plugin Name.ppPlugin
  2. Create an info.json file inside the plugin folder, and specify the entry point
  3. Create a script.coffee file inside the plugin folder
  4. Code your plugin's functionality
  5. Install and have fun!

info.json

Here's an example info.json, taken from the Run plugin for PHP:

{
	"name"			: "php_run",
	"category"		: "",
	"author"		: "Dr.Kameleon",
	"author_email"	: "drkameleon@gmail.com",
	"last_update"	: "16-09-2014",
	"shortcut"		: "@+R"
}

Shortcuts

Shortcuts can be easily specified in the form of MODIFIERS(without spaces)+KEY

The available list of modifiers:

  • @
  • $
  • ~
  • ^Ctrl

Scope

For User plugins, an extra scope variable has to be set.

For global scope, set scope to global, while - if you want to attach it to a specific language Spec - then set it like: "scope":"C++"


script.coffee

Here's a generic skeleton/example script.coffee:


# Your class name is the entry point as specified in the `name` field
# of your info.json file

Class MyNewAmazingPlugin extends $Plugin

	# The entry function. This is the one called
	# when your plugin is initialized for the first time
  	init:->
  		$Terminal.echo("Plugin initialised. Yay!");
  		$Terminal.echo("My name is #{ @name }");
  		$Terminal.echo("My path is #{ @path }");

  		# Let's set some private variable
  		@counter = 1;

  		# Let's open the Utility view with a local index.html
  		$Utility.load("My Amazing Plugin Preview", "#{ @path }/index.html");

  	# Do we also need a Utility menu?
  	# This is the place - and is being called automatically upon 'init'
	menu:-> {
		"My first menu item"	:=> $Terminal.echo("First menu item clicked!")
		"My second menu item"	:=> $Terminal.echo("Second menu item clicked!")
	}

  	# The main function.
	# Executed every time the user runs your plugin
  	run:->

  		$Terminal.echo("OK, here we are.");
  		$Terminal.echo("Counter value is #{ @counter }");

  		# Let's get some user input
  		$Dialog.input("Give me a number:", (number)=>
  			if number>10
  				$Terminal.echo("Number is greater than 10");
  			else
  				$Terminal.echo("Number is less or equal to 10");

  			# Let's call another private function
  			# from inside this callback
  			@doSomethingElse(number);
  		);

  	# Another private function
  	doSomethingElse: (number)->
  		$Terminal.echo("Your number was #{ number }, right?");

  		# OK, let's do something more useful...
  		docPath = $Document.info().path;

  		$Terminal.echo("Your current document's location: #{ docPath }");

  		# We can also play a bit with the UI
  		$Editor.option.gutter(false); 	# And we've just hidden the gutter!

  		# Let's attach an event handler
  		# to keep checking if the document has been changed

  		@on.documentChanged(()=>
  			$Terminal.echo("Document jst changed!");
  		);

  	# Called automatically
  	# when plugin is to be terminated
	halt:->
		$Terminal.echo("Plugin is being terminated");
		$Terminal.echo("Do some cleanup perhaps?");

		# We could do a `@on.documentChanged(null)` here to remove the handler
		# but the halt function automagically takes care of that!


You may structure your plugins any way you want, without necessarily following the specific format. In any case, make sure your plugin_name.init() and plugin_name.run() is callable!

What is the API?

The Peppermint API is a set of powerful objects giving programming access to the core of Peppermint, making it easier for you to tweak it, write plugins, or even program the editor as you go!

The exposed global objects can be accessed accessed from anywhere, the console or a plugin:

  • $Dialog
  • $Document
  • $Editor
  • $Fs
  • $Preview
  • $Terminal
  • $Utility
  • $Workspace

The $Plugin class is also exposed, but only in order to be extended when creating a new plugin.

Beta stage warning

Some of the features & classes are only available beginning from version 1.5

Dialog

The Dialog object - used to invoke dialogs


alertMETHOD

Display an alert dialog

title * string The main dialog title
info string Related information
callback function The function to be called, when the dialog closes

$Dialog.alert("Finished!","The operation has finished")

inputMETHOD

Show an input dialog and get user input

title * string The title/prompt of the dialog
callback * function The function to be called, with the input, when the dialog closes
null

$Dialog.input("Enter a number:", (number)=>
$Terminal.echo("Got : #{ number }");	
);

Document

The current Document object


label stringPROPERTY

The document's label as seen in Peppermint

path stringPROPERTY

The full path of the document

filename stringPROPERTY

The document's pure filename

folder stringPROPERTY

The document's pure folder name

extension stringPROPERTY

The document's file extension

writeMETHOD

Create or update document with contents

path * string The document's absolute path
content * string The document's contents

$Document.write("/some/path/to/doc.js", "console.log('done');");

infoMETHOD

Get/Update Info of current document and/or create a temporary copy for processing

ext string Force a particular extension (if document is to be created)
Document A copy of the updated Document object, with all its properties populated

path = $Document.info().path

tempMETHOD

Create temporary document instance with contents

content * string The document's content
Document A Document object, with all its properties populated

temp = $Document.temp("my contents");
path = temp.path;

Editor

The main Event-handling object


bindMETHOD

Create or Destroy and editor Key Binding

key * string Key combination
callback function Callback on key combination (null to destroy)
null

$Editor.bind("Cmd+R", ()=>
$Terminal.echo("Running");
);

contentMETHOD

Get/Set editor content

value string New editor content
undoable boolean Set if change will be undoable (default: true)
null or string The content of the editor

currentContent = $Editor.content();
# Let's change it 
$Editor.content("New content");

selectionMETHOD

Get/Set current editor selection

value string Replace current selection with value
null or string The currently selected text

currentContent = $Editor.content();
# Let's change it 
$Editor.content("New content");

option.gutterMETHOD

Get/Set Gutter state

onoff boolean True/False
null or boolean

option.printMarginMETHOD

Get/Set Print Margin state

onoff boolean True/False
null or boolean

option.indentGuidesMETHOD

Get/Set Indentation Guides state

onoff boolean True/False
null or boolean

option.invisiblesMETHOD

Get/Set Invisibles state

onoff boolean True/False
null or boolean

option.softTabsMETHOD

Get/Set Soft Tabs state

onoff boolean True/False
null or boolean

option.wordWrapMETHOD

Get/Set Word Wrap state

onoff boolean True/False
null or boolean

option.tabSizeMETHOD

Get/Set Tab Size

size number Tab size in characters
null or number

option.wrapLimitMETHOD

Get/Set Wrap Limit

size number Wrap Limit in characters
null or number

Fs

The global File System object


fileExistsMETHOD

Check if path exists

path * string The path to check
boolean True or False

fileExists = $Fs.fileExists("/some/path/to/some/file.txt");

isFolderMETHOD

Check if file at path is a folder

path * string The path to check
boolean True or False

isFolder = $Fs.isFolder("/some/path/to/some/file");

fileSizeMETHOD

Get file size for file at path

path * string The path to check
number Path's file size in bytes

fileSize = $Fs.fileSize("/some/path/to/some/file.txt");

pathContentsMETHOD

Get contents for path (if folder)

path * string The path to check
array Array of content paths

pathContents = $Fs.pathContents("/some/path/to/some/folder");

fileContentsMETHOD

Get contents of file at path

path * string The path to check
string The contents

fileContents = $Fs.fileContents("/some/path/to/some/file.txt");

createFolderMETHOD

Create folder at path

path * string The folder path to be created
null

$Fs.createFolder("/some/path/to/some/folder");

fileCopyMETHOD

Copy file at path to new path

path * string The original path
destination * string The destination path
null

$Fs.fileCopy("/some/path/to/some/file.txt","/another/path/to/some/file.txt");

fileMoveMETHOD

Move file at path to new path

path * string The original path
destination * string The destination path
null

$Fs.fileMove("/some/path/to/some/file.txt","/another/path/to/some/file.txt");

fileRenameMETHOD

Rename file at path to new path

path * string The original path
destination * string The destination path
null

$Fs.fileRename("/some/path/to/some/file.txt","/another/path/to/some/file.txt");

fileDeleteMETHOD

Delete file at path

path * string The file path to be deleted
null

$Fs.fileDelete("/some/path/to/some/file.txt");

On

The main Event-handling object


documentChangedMETHOD

Set callback to be executed, when document changes

callback * function The callback to be executed, or null to remove handler
null

init: ()->
@x = 1;
@on.documentChanged(()=>
	$Terminal.echo("Document changed");
	$Terminal.echo("x = " + @x++);
);
 
halt: ()->
@on.documentChanged(null);

documentSavedMETHOD

Set callback to be executed, when document is saved

callback * function The callback to be executed, or null to remove handler
null

@on.documentSaved(()=>
# do something
)

cursorChangedMETHOD

Set callback to be executed, when document changes

callback * function The callback to be executed, or null to remove handler
null

@on.cursorChanged(()=>
# do something
)

Preview

The main Preview object - representing the Preview Panel on the right side of the Peppermint window


loadMETHOD

Load html tool in the Preview View

title * string The new title for the Preview View
source * string Path to the .html file to be loaded or html source
base string Base path to be used
null

$Preview.load("My great tool", "#{ @path }/index.html")

loadDocumentMETHOD

Load custom document in the Preview View

title * string The new title for the Preview View
content * string The script's contents
spec * string The spec to be used for highlighting
null

$Preview.loadDocument("My PHP Script", "done", "php")

Terminal

The main Terminal object - representing the console panel


verbose booleanPROPERTY

Display more info (Default: false)

showMETHOD

Show the terminal panel, if not already open

null

$Terminal.show()

clearMETHOD

Clear the terminal panel

null

$Terminal.clear()

echoMETHOD

Echoes given string to the terminal

message * string The message to be displayed
attributes string A style attribute string
null

$Terminal.echo("Hello world!")

execMETHOD

Asynchronously execute task and print output in terminal

args * string... Command/Arguments to be passed
completed callback Callback to be executed when task is completed
string The execution result

$Terminal.exec("php","--version")

execSilentMETHOD

Execute command in terminal (either synchronously, or async)

args * string... Command/Arguments to be passed
action callback Callback to be executed when any data is served
completed callback Callback to be executed when task is completed
string The execution result

$Terminal.execSilent("php","--version")
	@example # This is pretty much like `$Terminal.exec()`
$Terminal.execSilent("php","myscript.php", (output)=>
$Terminal.echo("Got output: #{ output }");
,(result)=>
$Terminal.echo("Task terminated!");
); 

setVarMETHOD

Set custom environment variable

variable * string The name of the variable
value * string The value of the variable
null

$Terminal.setVar("MYVAR","VALUE");

killMETHOD

Kill existing async process being executed

null

$Terminal.kill();

Utility

The main Utility object - with various utility functions


Open a link in the browser

null

$Utility.openLink("http://www.osxpeppermint.com");

showFileMETHOD

Show a file in Finder

null

$Utility.showFile("/some/path/to/some/file.txt");

Workspace

The global Workspace object


files arrayPROPERTY

Array of single files within the Workspace

projects arrayPROPERTY

Array of projects within the Workspace

currentProject string or booleanPROPERTY

Path to current/active project, or false

infoMETHOD

Get info of current workspace

Workspace A copy of the updated Workspace object, with all its properties populated

currentProjects = $Workspace.info().projects