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

Listenr

by cbumgard ST2

plugin for sublime text 2 that listens on all code editing events and logs to a server for fun audio/visual representation

Details

  • 2013.01.06.06.55.23
  • github.​com
  • github.​com
  • 12 years ago
  • 4 weeks ago
  • 12 years ago

Installs

  • Total 291
  • Win 164
  • Mac 89
  • Linux 38
Mar 14 Mar 13 Mar 12 Mar 11 Mar 10 Mar 9 Mar 8 Mar 7 Mar 6 Mar 5 Mar 4 Mar 3 Mar 2 Mar 1 Feb 28 Feb 27 Feb 26 Feb 25 Feb 24 Feb 23 Feb 22 Feb 21 Feb 20 Feb 19 Feb 18 Feb 17 Feb 16 Feb 15 Feb 14 Feb 13 Feb 12 Feb 11 Feb 10 Feb 9 Feb 8 Feb 7 Feb 6 Feb 5 Feb 4 Feb 3 Feb 2 Feb 1 Jan 31 Jan 30 Jan 29
Windows 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
Mac 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
Linux 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Readme

Source
raw.​githubusercontent.​com

SublimeListenr

Listens for any code editing events in Sublime Text 2. Logs them to a server for fun & profit. Or more specifically for a fun experiment in capturing and visualizing code activity. And ideally turning it into something cool, like generative ambient sounds. No personal/confidential information is captured, although to make this more fun & useful you can set your github username in the settings file in order to do stats on your activity. This plugin is intended for fun, creative endeavors :)

Example

On Client

Here's a sample activity message (captured as JSON) when typing a character into a Python file:

{"t":1357441371196,"e":6,"i":28,"b":26,"l":0,"d":0,"r":0,"f":"py","s":4564,"h":"6a75228602aaaa8d473afff7a4163d2a","g":"cbumgard"}

On Server

Which is transformed to the following on the server and persisted in MongoDB to look like:

{
  "time_gmt_ms" : ISODate("2013-01-06T03:00:56.203Z"),
  "event" : "on_selection_modified",
  "id" : 28,
  "buffer_id" : 26,
  "is_loading" : false,
  "is_dirty" : false,
  "is_read_only" : false,
  "file_ext" : ".py",
  "size" : 4564,
  "file_name_hash" : "6a75228602aaaa8d473afff7a4163d2a",
  "github_username" : "cbumgard",
  "client_ip" : "127.0.0.1",
  "created" : ISODate("2013-01-06T03:00:56.508Z"),
  "__v" : 0,
  "_id" : ObjectId("50e8e8e87f0bba0000000014")
}

Settings

Add your github username to monitor, aggregate, or play with your data by changing the setting “github_username” in the settings file.

Captured Activity

The following events are captured:

  • on_new(view) None Called when a new buffer is created.
  • on_clone(view) None Called when a view is cloned from an existing one.
  • on_load(view) None Called when the file is finished loading.
  • on_close(view) None Called when a view is closed (note, there may still be other views into the same buffer).
  • on_pre_save(view) None Called just before a view is saved.
  • on_post_save(view) None Called after a view has been saved.
  • on_modified(view) None Called after changes have been made to a view.
  • on_selection_modified(view) None Called after the selection has been modified in a view.
  • on_activated(view) None Called when a view gains input focus.
  • on_deactivated(view) None Called when a view loses input focus.

Taken from Sublime Text Plugin Docs

License

This module is MIT licensed here.