Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
  • Loading branch information
gorhill committed Aug 31, 2016
1 parent 0d7e326 commit 33234fd
Show file tree
Hide file tree
Showing 3 changed files with 73 additions and 5 deletions.
26 changes: 22 additions & 4 deletions platform/firefox/frameModule.js
Original file line number Diff line number Diff line change
Expand Up @@ -319,15 +319,31 @@ var contentObserver = {
}

sandbox.injectScript = function(script) {
var svc = Services;
let svc = Services;
// Sandbox appears void.
// I've seen this happens, need to investigate why.
if ( svc === undefined ) {
return;
}
if ( svc === undefined ) { return; }
svc.scriptloader.loadSubScript(script, sandbox);
};

sandbox.injectCSS = function(sheetURI) {
try {
let wu = win.QueryInterface(Ci.nsIInterfaceRequestor)
.getInterface(Ci.nsIDOMWindowUtils);
wu.loadSheetUsingURIString(sheetURI, wu.USER_SHEET);
} catch(ex) {
}
};

sandbox.removeCSS = function(sheetURI) {
try {
let wu = win.QueryInterface(Ci.nsIInterfaceRequestor)
.getInterface(Ci.nsIDOMWindowUtils);
wu.removeSheetUsingURIString(sheetURI, wu.USER_SHEET);
} catch (ex) {
}
};

// The goal is to have content scripts removed from web pages. This
// helps remove traces of uBlock from memory when disabling/removing
// the addon.
Expand All @@ -337,8 +353,10 @@ var contentObserver = {
sandbox.outerShutdown = function() {
sandbox.removeMessageListener();
sandbox.addMessageListener =
sandbox.injectCSS =
sandbox.injectScript =
sandbox.outerShutdown =
sandbox.removeCSS =
sandbox.removeMessageListener =
sandbox.rpc =
sandbox.sendAsyncMessage = function(){};
Expand Down
40 changes: 40 additions & 0 deletions platform/firefox/vapi-client.js
Original file line number Diff line number Diff line change
Expand Up @@ -437,6 +437,46 @@ vAPI.messaging.start();

/******************************************************************************/

vAPI.userCSS = (function() {
if ( !self.injectCSS ) {
return;
}
var injectCSS = self.injectCSS,
removeCSS = self.removeCSS,
userCSS = '',
sheetURI = '';
var load = function() {
if ( userCSS === '' || sheetURI !== '' ) { return; }
sheetURI = 'data:text/css;charset=utf-8,' + encodeURIComponent(userCSS);
injectCSS(sheetURI);
};
var unload = function() {
if ( sheetURI === '' ) { return; }
removeCSS(sheetURI);
sheetURI = '';
};
var add = function(cssText) {
if ( cssText === '' ) { return; }
if ( userCSS !== '' ) { userCSS += '\n'; }
userCSS += cssText;
unload();
load();
};
var toggle = function(state) {
if ( userCSS === '' ) { return; }
if ( state === undefined ) {
state = sheetURI === '';
}
return state ? load() : unload();
};
return {
add: add,
toggle: toggle
};
})();

/******************************************************************************/

// No need to have vAPI client linger around after shutdown if
// we are not a top window (because element picker can still
// be injected in top window).
Expand Down
12 changes: 11 additions & 1 deletion src/js/contentscript.js
Original file line number Diff line number Diff line change
Expand Up @@ -163,7 +163,8 @@ var allExceptions = Object.create(null),
allSelectors = Object.create(null),
commitTimer = null,
stagedNodes = [],
matchesProp = vAPI.matchesProp;
matchesProp = vAPI.matchesProp,
userCSS = vAPI.userCSS;

// Complex selectors, due to their nature may need to be "de-committed". A
// Set() is used to implement this functionality.
Expand Down Expand Up @@ -428,6 +429,9 @@ var domFilterer = {
document.head.appendChild(styleTag);
}
this.styleTags.push(styleTag);
if ( userCSS ) {
userCSS.add(styleText);
}
}

// Simple selectors: incremental.
Expand Down Expand Up @@ -580,10 +584,16 @@ var domFilterer = {
},

toggleOff: function() {
if ( userCSS ) {
userCSS.toggle(false);
}
this.enabled = false;
},

toggleOn: function() {
if ( userCSS ) {
userCSS.toggle(true);
}
this.enabled = true;
},

Expand Down

0 comments on commit 33234fd

Please sign in to comment.