aboutsummaryrefslogtreecommitdiffstats
path: root/extension
diff options
context:
space:
mode:
authorOmar Rizwan <omar.rizwan@gmail.com>2018-11-28 21:43:00 -0800
committerOmar Rizwan <omar.rizwan@gmail.com>2018-11-28 21:43:00 -0800
commited5419ae41747a7a6b0597f0f100f71057898cb3 (patch)
tree236ba75cb98e632f901bac0756bbe64f07977e57 /extension
parente734173e6f5df2fc9df39dc8b98a03e8b83d889f (diff)
Toolbar icon! Simplify file defns! Pretty cool!
Diffstat (limited to 'extension')
-rw-r--r--extension/background.js63
-rw-r--r--extension/manifest.json2
2 files changed, 37 insertions, 28 deletions
diff --git a/extension/background.js b/extension/background.js
index 25575ca..8588275 100644
--- a/extension/background.js
+++ b/extension/background.js
@@ -1,4 +1,24 @@
-const ws = new WebSocket("ws://localhost:8888");
+let ws;
+function tryConnect() {
+ ws = new WebSocket("ws://localhost:8888");
+ updateToolbarIcon();
+ ws.onopen = ws.onclose = updateToolbarIcon;
+}
+
+function updateToolbarIcon() {
+ if (ws && ws.readyState == 1) { // OPEN
+ chrome.browserAction.setBadgeBackgroundColor({color: 'blue'});
+ chrome.browserAction.setBadgeText({text: 'f'});
+ } else {
+ chrome.browserAction.setBadgeBackgroundColor({color: 'red'});
+ chrome.browserAction.setBadgeText({text: '!'});
+ }
+}
+
+tryConnect();
+chrome.browserAction.onClicked.addListener(function() {
+ tryConnect();
+});
const unix = {
EPERM: 1,
@@ -61,6 +81,7 @@ const fhManager = (function() {
// tabs/by-id/ID/mem (?)
// tabs/by-id/ID/cpu (?)
// tabs/by-id/ID/screenshot.png
+// tabs/by-id/ID/text.txt
// tabs/by-id/ID/printed.pdf
// tabs/by-id/ID/control
// tabs/by-id/ID/sources/
@@ -80,38 +101,16 @@ const router = {
"*": {
"url": {
- async getattr() {
- return {
- st_mode: unix.S_IFREG | 0444,
- st_nlink: 1,
- st_size: 100 // FIXME
- };
- },
- async open(path) {
- return 0;
- },
async read(path, fh, size, offset) {
const tab = await getTab(parseInt(pathComponent(path, -2)));
return (tab.url + "\n").substr(offset, size);
- },
- async release(path, fh) {}
+ }
},
"title": {
- async getattr() {
- return {
- st_mode: unix.S_IFREG | 0444,
- st_nlink: 1,
- st_size: 1000 // FIXME
- };
- },
- async open(path) {
- return 0;
- },
async read(path, fh, size, offset) {
const tab = await getTab(parseInt(pathComponent(path, -2)));
return (tab.title + "\n").substr(offset, size);
- },
- async release(path, fh) {}
+ }
},
}
}
@@ -133,7 +132,15 @@ async function getattr(path) {
let route = findRoute(path);
if (route.getattr) {
return route.getattr(path);
+ } else if (route.read) {
+ // default file attrs
+ return {
+ st_mode: unix.S_IFREG | 0444,
+ st_nlink: 1,
+ st_size: 100 // FIXME
+ };
} else {
+ // default dir attrs
return {
st_mode: unix.S_IFDIR | 0755,
st_nlink: 3
@@ -150,6 +157,7 @@ async function readdir(path) {
async function open(path) {
let route = findRoute(path);
if (route.open) return route.open(path);
+ else return 0; // empty fd
}
async function read(path, fh, size, offset) {
@@ -159,7 +167,7 @@ async function read(path, fh, size, offset) {
async function release(path, fh) {
let route = findRoute(path);
- if (route.read) return route.release(path, fh);
+ if (route.release) return route.release(path, fh);
}
ws.onmessage = async function(event) {
@@ -192,8 +200,7 @@ ws.onmessage = async function(event) {
const buf = await read(req.path, req.fh, req.size, req.offset)
response = {
op: 'read',
- buf,
- size: buf.length
+ buf
};
} else if (req.op === 'release') {
diff --git a/extension/manifest.json b/extension/manifest.json
index b523910..ac424f1 100644
--- a/extension/manifest.json
+++ b/extension/manifest.json
@@ -7,6 +7,8 @@
"permissions": ["tabs", "debugger"],
+ "browser_action": {},
+
"background": {
"scripts": ["background.js"],
"persistent": true