ChromeREPL
A Sublime Text plugin to execute JavaScript in Google Chrome
Details
Installs
- Total 3K
- Win 2K
- Mac 534
- Linux 277
Sep 13 | Sep 12 | Sep 11 | Sep 10 | Sep 9 | Sep 8 | Sep 7 | Sep 6 | Sep 5 | Sep 4 | Sep 3 | Sep 2 | Sep 1 | Aug 31 | Aug 30 | Aug 29 | Aug 28 | Aug 27 | Aug 26 | Aug 25 | Aug 24 | Aug 23 | Aug 22 | Aug 21 | Aug 20 | Aug 19 | Aug 18 | Aug 17 | Aug 16 | Aug 15 | Aug 14 | Aug 13 | Aug 12 | Aug 11 | Aug 10 | Aug 9 | Aug 8 | Aug 7 | Aug 6 | Aug 5 | Aug 4 | Aug 3 | Aug 2 | Aug 1 | Jul 31 | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Windows | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 |
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 | 2 | 1 | 1 | 1 | 1 | 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 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
Readme
- Source
- raw.githubusercontent.com
ChromeREPL
A SublimeText 3 Plugin to use Chrome as your REPL.
Execute JavaScript in your browser. Interact with your running webapps. Live code your brains out!
Why?
Because Chrome ain't no text editor. Anything longer than a line is a pain, and so is recalling what you typed earlier.
Installation
Via Package Control (recommended! 👍👍👍)
Alternatively, clone this repo into your Packages
directory. e.g. ~/Library/Application Support/Sublime Text 3/Packages/
on macOS. If you do this you will need to open the Command Palette and run Package Control: Satisfy Dependencies
.
Starting Chrome
Chrome needs to be started with a special flag 🏳️ (--remote-debugging-port
).
Don't worry, commands are provided to do this for you 😅.
Run them by opening the Command Pallete (macOS: cmd shift P
, win/lin: ctrl shift P
).
- If you haven't opened Chrome, use the
Chrome REPL: Start Chrome
command. - If Chrome is already running, use
Chrome REPL: Restart Chrome with remote debugging
*
*this will quit and re-open Chrome, if you want to preserve your tabs, make sure you have set this behaviour in Chrome's settings:
On start-up: Continue where you left off
.
🚨 Security Warning: New User Profile 🚨
When Chrome restarts, it will use a new Chrome user profile. This is because the Chrome DevTools protocol (that is used for communication) opens a port for communication, but also exposes your cookies. To prevent people on your network from sniffing your important cookies (e.g. website logins), a temporary Chrome user profile is used.
Usage
- Start/Restart Chrome as above
- Run the
Chrome REPL: Connect to Tab
command - Select the tab you want to connect to
- You should see
"Sublime Text connected"
in the Chrome Developer Tools console - Use Shift Enter in Sublime Text to execute JavaScript code:
- If you have nothing selected it will execute the current line
- With code selected it will execute just the selection
Note: Each Sublime tab can be connected to one Chrome tab. The connected tab is displayed in Sublime in the status bar at the bottom of tab.
Additional commands
Clear Console
Cmd/Ctrl Shift CReload Page
Cmd/Ctrl Shift RReload Page (Ignore Cache)
Cmd/Ctrl Shift Alt R
Settings
- 📁 Path to Chrome (can be Chrome, Canary, or Chromium)
- 👀 Automatically focus on connected Chrome tab (requires
wmctrl
on Linux) - 🔧 Automatically opening the Developer Tools for every new window
- 🏳️ Additional chrome flags
- ⌨️ Enabling the Command Line API
- 🏠 Custom hostname and port
Thanks
The project was inspired by SublimeWebInspector, but is far less ambitious, not as opinionated, and thus easier to maintain.
This uses a ever so slightly modified version of PyChromeDevTools, and a stripped down version of Sublime Goto Window.
Known Issues
This plugin relies on psutil. The latest version of psutil requires Python 3.4. This means we are stuck with 5.4.1 which has a known issue on macOS to do with zombie processes. If the only option in the command palette is Restart Chrome
then you may need to reboot your machine to clear the issue.
Author
Arthur Carabott - arthurcarabott.com