A Community-led Hyper-Hackable Text Editor
Go to file
Kevin Sawicki 8c0f443c75 Call window.shutdown when native window is closed
The root view will now be serialized and saved to local
storage when the window is closed or the application is
terminated.
2012-10-11 13:07:13 -07:00
.atom Add wrap guide and markdown preview to default config 2012-10-02 10:43:49 -07:00
benchmark Update benchmark suite 2012-09-24 15:47:33 -07:00
bundles Remove TextMate bundles from Atom source 2012-10-09 10:44:07 -07:00
cef Update CEF to CEF3 trunk 2012-09-18 15:01:09 -07:00
docs Doc how line highlighting can be tweaked 2012-10-01 15:59:41 -07:00
native Call window.shutdown when native window is closed 2012-10-11 13:07:13 -07:00
notes Move old wiki page to notes folder 2012-09-30 15:00:45 -07:00
script make cibuild work on updated build machine 2012-09-27 11:38:15 -07:00
spec Fix linemap translation when an atomic token is at the end of a line. 2012-10-10 14:45:47 -07:00
src Add up/down event support for keybindings view 2012-10-10 17:41:14 -07:00
static Merge remote-tracking branch 'origin/master' into status-bar-buffer-modified-indicator 2012-10-07 09:13:08 -10:00
themes Add bundles and themes 2012-08-27 13:20:22 -07:00
tools Move scripts in cef/mac to tools/mac since we have tools dir anyway for gyp 2012-08-10 16:11:09 -06:00
vendor rake test now obeys fdescribe and fit. 2012-10-09 17:23:01 -07:00
.github Doc how line highlighting can be tweaked 2012-10-01 15:59:41 -07:00
.gitignore Ignore .nvm-version 2012-09-19 16:09:15 -07:00
.pairs Add kevin to .pairs file 2012-10-01 15:44:56 -07:00
atom.gyp Add native OnigScanner, which handles matching multiple regexes on a line 2012-09-27 13:04:14 -06:00
package.json Make npm and rake play nicely 2012-09-13 11:41:35 -07:00
Rakefile Clone c bundle during rake install 2012-10-10 17:29:31 -07:00
README.md More 💄 2012-09-25 09:26:11 -07:00

Atom — Futuristic Text Editing

atomic

Building from source

Be forwarned: Atom is pre-alpha software!

Requirements

Mountain Lion

The Setup™

Xcode (Get Xcode from the App Store (ugh, I know))

  1. gh-setup atom

  2. cd ~/github/atom && rake install

Atom is installed! Type atom [path] from the commmand line or find it in /Applications/Atom.app

Your ~/.atom Directory

A basic ~/.atom directory is installed when you run rake install. Take a look at ~/.atom/atom.coffee for more information.

Basic Keyboard shortcuts

Atom doesn't have much in the way of menus yet. Use these keyboard shortcuts to explore features.

cmd-o : open file/directory

cmd-n : new window

cmd-t : open fuzzy file finder

cmd-: : open command prompt

cmd-f : open command prompt with /

cmd-g : repeat the last search

cmd-r : reload the current window

cmd-alt-ctrl-s : run specs

cmd-alt-arrows : split screen in direction of arrow

cmd-alt-w : toggle word wrap

cmd-alt-f : fold selected lines

Most default OS X keybindings also work.

Init Script

Atom will require ~/.atom/atom.coffee whenever a window is opened or reloaded if it is present in your home directory. This is a rudimentary jumping off point for your own customizations.

Command Panel

A partial implementation of the Sam command language

Examples

, selects entire file

1,4 selects lines 1-4

/pattern selects the first match after the cursor/selection

s/pattern/replacement replace first text matching pattern in current selection

s/pattern/replacement/g replace all text matching pattern in current selection

,s/pattern/replacement/g replace all text matching pattern in file

1,4s/pattern/replacement replace all text matching pattern in lines 1-4

x/pattern selects all matches in the current selections

,x/pattern selects all matches in the file

,x/pattern1/ x/pattern2 "structural regex" - selects all matches of pattern2 inside matches of pattern1

Key Bindings

Atom has a CSS based key binding scheme. We will add a nicer loading mechanism, but for now you can bind keys by calling window.keymap.bindKeys with a CSS selector and a hash of key-pattern -> event mappings.

window.keymap.bindKeys '.editor'
  'ctrl-p': 'party-time'
  'ctrl-q': 'open-dialog-q'

When a keypress matches a pattern on an element that matches the selector, it will be translated to the named event, which will bubble up the DOM from the site of the keypress. Extension code can listen for the named event and react to it.