mirror of
https://github.com/gorhill/uBlock.git
synced 2026-03-11 09:04:36 +00:00
This feature is hidden behind the "Developer mode" setting in the dashboard. When "Developer mode" is enabled, a tab named "Develop" will become available in the dashboard. This tab is meant to contain tools for technical users. At the moment, the "Develop" pane allows to create custom DNR rules through a (CodeMirror-based) editor. For the sake of convenience, the DNR rule must be entered in YAML-like format. The format is not really full compliant YAML, just YAML-like, and very strict in order to ensure the parser stays simple enough. Lines starting with `#` are comments and will be ignored by the parser. Any line which do not match the parser's expectation will be marked as invalid, and the whole DNR rule containing such invalid lines will be discarded. There must not be empty lines inside a rule definition. Each DNR rule must be separated with a `---` line, which is known as a YAML document separator. String values must not be quoted, otherwise the quotes will be considered part of the value. There is one exception: `''` will be parsed as "an empty string". The editor will attempt to auto-complete known DNR keywords. That feature will improve over time. Though the parser will identify some errors, not all invalid DNR rules are currently identified by the parser, and these will be reported when the rules are registered through the DNR API. Better identifying invalid DNR rules at edit time will improve over time. The editor will report `regexFilter` values which are not supported by the DNR engine on the current platform. The editor reacts to instances of `regexFilter: ...` to report whether a regex value is supported. This means you can test for a regex value by using `# regexFilter: ...` so that you do not have to create an actual DNR rules just for the sake of testing. Custom DNR rules can be exported into a JSON file (a format known by the DNR API as a "static ruleset"). JSON-based ruleset can be imported, the content will be converted to YAML-like syntax. The editor will attempt to convert to YAML pasted content which can be JSON-parsed. It's possible to paste partially or wholly JSON-based rulesets. When disabling "Developer mode", all custom DNR rules will be unregistered from the DNR API. The DNR rules content will be left intact in such case. Existing DNR rules will be registered into the DNR API when re-enabling "Developer mode". Administrators can prevent "Developer mode" from being enabled by adding `develop` token to `disabledFeatures` setting. Related discussion: https://github.com/uBlockOrigin/uBOL-home/discussions/323 The main motivation is to give list maintainers a tool to assist with resolving filter issues. Custom DNR rules can assist in crafting and validating filters meant to work with uBOL. A secondary motivation is to provide technical users the ability to further customize their content blocker. More conveniences will be added over time, this is a first version.
122 lines
3.2 KiB
Makefile
122 lines
3.2 KiB
Makefile
# https://stackoverflow.com/a/6273809
|
|
run_options := $(filter-out $@,$(MAKECMDGOALS))
|
|
|
|
.PHONY: all clean cleanassets test lint chromium opera firefox npm dig \
|
|
mv3-chromium mv3-firefox mv3-edge mv3-safari ubol-codemirror \
|
|
compare maxcost medcost mincost modifiers record wasm
|
|
|
|
sources := ./dist/version $(shell find ./assets -type f) $(shell find ./src -type f)
|
|
platform := $(wildcard platform/*/*)
|
|
assets := dist/build/uAssets
|
|
mv3-sources := \
|
|
$(shell find ./src -type f) \
|
|
$(wildcard platform/mv3/*) \
|
|
$(shell find ./platform/mv3/extension -name codemirror-ubol -prune -o -type f) \
|
|
platform/mv3/extension/lib/codemirror/codemirror-ubol/dist/cm6.bundle.ubol.min.js
|
|
mv3-data := $(shell find ./dist/build/mv3-data -type f)
|
|
|
|
mv3-edge-deps := $(wildcard platform/mv3/edge/*)
|
|
mv3-safari-deps := $(wildcard platform/mv3/safari/*)
|
|
|
|
all: chromium firefox npm
|
|
|
|
dist/build/uBlock0.chromium: tools/make-chromium.sh $(sources) $(platform) $(assets)
|
|
tools/make-chromium.sh
|
|
|
|
# Build the extension for Chromium.
|
|
chromium: dist/build/uBlock0.chromium
|
|
|
|
dist/build/uBlock0.opera: tools/make-opera.sh $(sources) $(platform) $(assets)
|
|
tools/make-opera.sh
|
|
|
|
# Build the extension for Opera.
|
|
opera: dist/build/uBlock0.opera
|
|
|
|
dist/build/uBlock0.firefox: tools/make-firefox.sh $(sources) $(platform) $(assets)
|
|
tools/make-firefox.sh all
|
|
|
|
# Build the extension for Firefox.
|
|
firefox: dist/build/uBlock0.firefox
|
|
|
|
dist/build/uBlock0.npm: tools/make-nodejs.sh $(sources) $(platform) $(assets)
|
|
tools/make-npm.sh
|
|
|
|
npm: dist/build/uBlock0.npm
|
|
|
|
# Dev tools
|
|
node_modules:
|
|
npm install
|
|
|
|
init: node_modules
|
|
|
|
lint: init
|
|
npm run lint
|
|
|
|
test: npm
|
|
cd dist/build/uBlock0.npm && npm run test
|
|
|
|
test-full-battery: npm
|
|
cd dist/build/uBlock0.npm && npm run test-full-battery
|
|
|
|
check-leaks: npm
|
|
cd dist/build/uBlock0.npm && npm run check-leaks
|
|
|
|
dist/build/uBlock0.dig: tools/make-nodejs.sh $(sources) $(platform) $(assets)
|
|
tools/make-dig.sh
|
|
|
|
dig: dist/build/uBlock0.dig
|
|
cd dist/build/uBlock0.dig && npm install
|
|
|
|
dig-snfe: dig
|
|
cd dist/build/uBlock0.dig && npm run snfe $(run_options)
|
|
|
|
dist/build/mv3-data:
|
|
mkdir -p dist/build/mv3-data
|
|
|
|
ubol-codemirror:
|
|
$(MAKE) -sC platform/mv3/extension/lib/codemirror/codemirror-ubol/ ubol.bundle
|
|
|
|
dist/build/uBOLite.chromium: tools/make-mv3.sh $(mv3-sources) $(platform) $(mv3-data) dist/build/mv3-data
|
|
tools/make-mv3.sh chromium
|
|
|
|
mv3-chromium: ubol-codemirror dist/build/uBOLite.chromium
|
|
|
|
dist/build/uBOLite.firefox: tools/make-mv3.sh $(mv3-sources) $(platform) $(mv3-data) dist/build/mv3-data
|
|
tools/make-mv3.sh firefox
|
|
|
|
mv3-firefox: ubol-codemirror dist/build/uBOLite.firefox
|
|
|
|
dist/build/uBOLite.edge: tools/make-mv3.sh $(mv3-sources) $(mv3-edge-deps) $(mv3-data) dist/build/mv3-data
|
|
tools/make-mv3.sh edge
|
|
|
|
mv3-edge: ubol-codemirror dist/build/uBOLite.edge
|
|
|
|
dist/build/uBOLite.safari: tools/make-mv3.sh $(mv3-sources) $(mv3-safari-deps) $(mv3-data) dist/build/mv3-data
|
|
tools/make-mv3.sh safari
|
|
|
|
mv3-safari: ubol-codemirror dist/build/uBOLite.safari
|
|
|
|
dist/build/uAssets:
|
|
tools/pull-assets.sh
|
|
|
|
clean:
|
|
rm -rf dist/build tmp/node_modules node_modules
|
|
|
|
cleanassets:
|
|
rm -rf dist/build/mv3-data dist/build/uAssets
|
|
|
|
# Not real targets, just convenient for auto-completion at shell prompt
|
|
compare:
|
|
@echo
|
|
maxcost:
|
|
@echo
|
|
medcost:
|
|
@echo
|
|
mincost:
|
|
@echo
|
|
modifiers:
|
|
@echo
|
|
record:
|
|
@echo
|
|
wasm:
|
|
@echo
|