На старых версиях работать не будет
Vitaliy V.
Очень рады вас видеть! Огромное спасибо за новую версию.
Вопрос. Какая минимальная версия будет работать с новой сборкой?
Отредактировано unter_officer (03-03-2024 15:25:21)
«The Truth Is Out There»
Отсутствует
-
Отредактировано Vitaliy V. (08-08-2024 15:03:19)
Отсутствует
Полноценно с 117, но можно в 115 запустить, не будут работать некоторые стили (в том числе настройках)
Спасибо за ответ. Я уже успел интереса ради немного потестировать на 115 ESR.
В целом работает нормально, но проблемки со стилями, как вы и сказали, присутствуют.
Глубже копать не стал. Откатился на старую версию UCF.
«The Truth Is Out There»
Отсутствует
-
Отредактировано Vitaliy V. (08-08-2024 15:03:06)
Отсутствует
Хорошо т. к. 128 ESR выйдет в июле судя по графику, сделал патч для 115 ESR,
заменить файлы css из этого архива https://github.com/VitaliyVstyle/Vitali … 15_ESR.zip
Vitaliy V., большое спасибо за патч. Теперь на 115 ESR всё нормально.
Что касается 128 ESR, то для этого надо переходить на Win10+, а я пока этого не планирую.
«The Truth Is Out There»
Отсутствует
вот эта кнопка отвалиться когда выпилят jsm?
В этом смысле — вроде не должна.
Vitaliy V.
Насчёт UcfPrefs.mjs. Сперва по Fluent'у.
Лис 124 ru. Поставил langpack'и uk и de.
STR: Включаю de, рестарт. Открываю «Настройки UserChromeFiles»,
окно локализировано как ru, это нормально, сборка ведь ru, а de отсутствует.
Теперь переключаюсь на uk.
ER: Локализация в окне меняется на uk, ведь uk есть.
AR: Ничего не происходит, локализация остаётся ru.
Да, я понимаю, что STR довольно экзотичен.
Но, может быть, заменить appLocalesAsBCP47 на availableLocales
И по коду.
Первая строка var global = Cu.getGlobalForObject({}); Разве это не globalThis?
И, UcfPrefs.global да, полезно пробросить, но почему геттер, а не просто значение?
UcfPrefs.defineGlobalGetters есть, но в само́м UCF нигде не используется.
UcfPrefs.defineLazyGlobalGetters есть, но нужно ли это?
Вот, добавил в config.js, в самое начало, ещё до антиподписячего (мне можно),
чтобы не было никаких сомнений, что там что-то появится только когда-то позже.
// (globalProperties => { var result = []; var global = Cu.getGlobalForObject(Cu); var max = Math.max(...globalProperties.map(prop => prop.length)) + 2; for(var name of globalProperties) { var desc = global.Object.getOwnPropertyDescriptor(global, name); if (desc) { for(var key in desc) { var type = typeof desc[key]; if (type != "boolean") desc[key] = type; } } result.push(name.padEnd(max) + JSON.stringify(desc)); } Services.obs.addObserver(async function test(win, topic) { Services.obs.removeObserver(test, topic); await win.gBrowserInit.idleTasksFinishedPromise; var text = encodeURIComponent(result.join("\n")); var url = "data:text/plain;charset=utf-8," + text; var gb = win.gBrowser; gb.selectedTab = gb.addTrustedTab(url); }, "browser-delayed-startup-finished"); })([ "atob", "btoa", "Blob", "CSS", "CSSRule", "DOMParser", "Event", "File", "FileReader", "InspectorUtils", "URL", "XMLHttpRequest", "fetch", "L10nFileSource", "L10nRegistry", "Localization", // test non-existens "absent", "alert", // candidates "TextEncoder", "TextDecoder", ]);
Насколько я вижу, все свойства уже есть, и у всех сразу value (не get).
Таким образом, lazy-фикация представляется излишней,
можно просто сразу пробросить ссылки, и все дела.
Кстати, почему только эти.
Мне вот за Text{En, De}coder особенно обидно было ещё в прошлом UCF.
Отредактировано Dumby (04-03-2024 08:13:09)
Отсутствует
UserChromeFiles обнова https://github.com/VitaliyVstyle/Vitali … hromeFiles
Сделал всё по инструкции ...никаких изменений. Видимо чего-то не понимаю. 125.0a1 (2024-03-03) (64-разрядный)
Отредактировано grom17 (04-03-2024 13:01:50)
Отсутствует
Сделал всё по инструкции ...никаких изменений.
В v124.0beta6 работает. Кэш автозапуска очищал? Сразу должны быть видны три кнопки доп. тулбаров и доступны Промежуток и Разделитель. Зайди в настройки UCF и в нижней части проставь все птички, по умолчанию они все сняты. Не все скрипты, работающие в Aris-t2, работают в UCF.
Добавлено 04-03-2024 14:17:46
А вот кнопку "Open settings" button я так и не смог отыскать, она, видимо, открывает настройки UCF в сепаратном окне.
Отредактировано fuchsfan (04-03-2024 14:17:46)
Отсутствует
AR: Ничего не происходит, локализация остаётся ru.
Да, я понимаю, что STR довольно экзотичен.
Но, может быть, заменить appLocalesAsBCP47 на availableLocales
Т. е. не происходит без перезагрузки ? Так и не было цели чтобы локали изменялись без перезагрузки, на панелях и кнопках UCF вообще ничего не происходит там просто при старте браузера один раз выбирается наиболее подходящая локаль и все, DOMLocalization не следит за ними.
А appLocalesAsBCP47 вполне достаточно для этого
Первая строка var global = Cu.getGlobalForObject({}); Разве это не globalThis?
И, UcfPrefs.global да, полезно пробросить, но почему геттер, а не просто значение?
В XPCOMUtils.sys.mjs так и записано
и да Cu.getGlobalForObject({}) == globalThis
В чем проблемма геттера?
UcfPrefs.defineGlobalGetters есть, но в само́м UCF нигде не используется.
Это я хотел использовать но потом не потребовалось, но оставил может пригодится для использования в пользовательском коде
Таким образом, lazy-фикация представляется излишней,
можно просто сразу пробросить ссылки, и все дела.
Возможно излишняя но мне нравится lazy, не используешь не загружается лишнее
Кстати, почему только эти.
Мне вот за Text{En, De}coder особенно обидно было ещё в прошлом UCF.
Хм что-то не вижу где в прошлом UCF это было? Но ок добавлю
Добавлено 04-03-2024 19:28:26
А вот кнопку "Open settings" button я так и не смог отыскать
Значек шестеренка, в зависимости от локали может отличаться, например для en-US так
label кнопки:
Settings UserChromeFiles
tooltip:
Left-click: Open UserChromeFiles settings in window
Midle-click: Open about:config
Right-click: Open UserChromeFiles settings in the tab
И вообще она по умолчанию находится на дополнительной панели
Отредактировано Vitaliy V. (04-03-2024 19:28:26)
Отсутствует
Vitaliy V.
Мне кажется лишним код с разными переводами. Может оставить просто английский, кому надо, сами переведут в коде, вручную. Пытался выпилить не нужное, как обычно:
"ucf-open-about-config-button", - пользуюсь через ucf_hookClicks.js
"ucf-additional-vertical-spring", - special_widgets(из-за space, separator)
"ucf-additional-top-spring",
"ucf-additional-bottom-spring",
"ucf-restart-app", - через ucf_hookClicks.js + hotkey
"ucf-view-history-sidebar-button", - через ucf_hookClicks.js + hotkey
"ucf-view-bookmarks-sidebar-button", - тоже самое
"ucf-open-directories-button", - через ucf_hookClicks.js + hotkey
И их в переводе не выпилишь(плохо разбираюсь как), мне по сути нужно только вертикальная, изредка верхняя. А тут какие-то переводы еще добавились) Итак путаюсь в коде, наверняка выпиливая костыльно и не все. Многие пользуются, тем же Aris-t2, на соседнем форуме. Так он без переводов, как и многие другие альтернативы. Лишние переводы, как по мне, лишнее. На костыль похоже)
Это лишь мой каприз, может другим нужны переводы. Мне и одного вполне хватает, если код от этого будет меньше и выпиливать будет легче. Да, можно просто под коврик спрятать все эти потроха, но они и там в глаза бросаются. Вместо одного spring, висят аж 4) Можно не прятать, оставляя на местах. Но все равно, не то. Зачем их именовать по-разному, чтобы не путаться? В коде, их тоже так и хочется выпиливать, возможно это лишь мой причуды и не критично.
(В общем, пытался их убрать в "async formatMessages(){}", файл UcfPrefs.mjs, и у меня пропали пункты выбора, раскрыть-спрятать вертикальную панель и другие. Пришлось их вернуть, а так, вроде везде выпилил).
Отредактировано b0ttle (04-03-2024 20:09:34)
Отсутствует
не было цели чтобы локали изменялись без перезагрузки
OK, принято.
В XPCOMUtils.sys.mjs так и записано
Точно. Запись довольно старая, старше чем globalThis.
В чем проблемма геттера?
Проблем нет никаких.
Геттер это функция. Обратился к свойству — считай вызвал функцию.
А функция всегда возвращает одно и то же.
оставил может пригодится для использования в пользовательском коде
OK, принято.
Возможно излишняя но мне нравится lazy, не используешь не загружается лишнее
Наоборот.
В цикле всё равно идёт перебор свойств, где для каждого из них
низачем создаётся своя отдельная функция и назначается как геттер.
Когда случится обращение к этому свойству,
геттер-функция низачем проверит, есть ли такое свойство в SystemGlobal,
ведь оно есть и было, перезапишет как свойство сандбокса, и вернёт значение.
Создание множества этих функций, которые проверяют уже заранее известное,
и возвращающих нечто заведомо существующее — это и есть «лишнее».
Хм что-то не вижу где в прошлом UCF это было?
Да-да, не было. Именно поэтому мне и было странно чем они впали в немилость.
Вообще-то да, это проблема, как выбрать то, что следует пробросить.
В смысле как определить наиболее популярное.
Гобальные свойства проброшены не все, но их хотя бы немного,
а если брать и что-то вроде L10nRegistry, то это и вовсе не гобальное свойство,
но нечто DOM-idl'ское, а такого добра в SystemGlobal целый вагон.
Например, IOUtils и PathUtils кажутся вполне достойными кандидатами.
Отсутствует
Мне кажется лишним код с разными переводами. Может оставить просто английский, кому надо, сами переведут в коде
Предлагаете переводить юзерам в коде потому что вам сложно разобраться с кодом а им типа легко.
Не не вариант с локалью проще добавить новый язык просто создать в папке locales папку с названием идентификатора нужного языка и в ней файлы .ftl с переводом.
Мне и одного вполне хватает, если код от этого будет меньше и выпиливать будет легче. Да, можно просто под коврик спрятать все эти потроха, но они и там в глаза бросаются. Вместо одного spring, висят аж 4
Первое пробовали отключить в настройках ненужные панели? Вместе с панелями отключаются и соответствующие кнопки, интервалы
И в коде лучше не выпиливать если не ориентируетесь, можно добавить данный код в custom_script.js или в другой подключенный в scriptsbackground
и эти кнопоки, интервалы будут удалятся до того как попасть на панели или хранилище
(ids => ({ init() { CustomizableUI.addListener(this); Services.obs.addObserver(this, "browser-delayed-startup-finished"); }, observe() { Services.obs.removeObserver(this, "browser-delayed-startup-finished"); CustomizableUI.removeListener(this); }, onWidgetCreated(aWidgetId) { if (ids.has(aWidgetId)) CustomizableUI.destroyWidget(aWidgetId); }, }).init())(new Set([ "ucf-open-about-config-button", "ucf-additional-vertical-spring", "ucf-additional-top-spring", "ucf-additional-bottom-spring", "ucf-restart-app", "ucf-view-history-sidebar-button", "ucf-view-bookmarks-sidebar-button", "ucf-open-directories-button", ]));
Отредактировано Vitaliy V. (05-03-2024 01:27:01)
Отсутствует
Наоборот.
В цикле всё равно идёт перебор свойств, где для каждого из них
низачем создаётся своя отдельная функция и назначается как геттер.Когда случится обращение к этому свойству,
геттер-функция низачем проверит, есть ли такое свойство в SystemGlobal,
ведь оно есть и было, перезапишет как свойство сандбокса, и вернёт значение.
Да это понятно но следует добавить что это происходит только один раз при первом вызове
Создание множества этих функций, которые проверяют уже заранее известное,
и возвращающих нечто заведомо существующее — это и есть «лишнее».
Так а где гарантии что это сейчас заведомо существующее не станет потом просто существующим или вообще не существующим.
А лишнее для меня то что не требуется для работы основных функций UserChromeFiles
Отредактировано Vitaliy V. (05-03-2024 02:30:41)
Отсутствует
Vitaliy V. Спасибо. До меня потом дошло, что можно просто оставить все как есть. Если не пытаться выпилить сразу, то потом может и привыкнуть можно. Про настройки, что-то не подумал. Код попробую. Чисто мой закидоны)
Отсутствует
добавить что это происходит только один раз при первом вызове
Да, разумеется. Но могло бы не происходить вовсе.
а где гарантии что это сейчас заведомо существующее не станет потом просто существующим или вообще не существующим
Ну так можно вообще обо всём сказать.
Хорошо, пусть сочтётся как осторожность.
Кстати, Console.sys.mjs же собираются выпилить,
неплохо бы что-то предусмотреть на такой случай.
Ещё, при переключении тулбаров посредством контекстного меню,
BrowserUsageTelemetry мусорит в консоль записью "widgetId is undefined".
Когда был проект встроить в UCF дебаггер,
то я просто добавлял id'шники в BROWSER_UI_CONTAINER_IDS
А теперь, наверно, надо какую-то функцию переопределять.
Ну, или ничего не делать, в консоль всё равно никто не смотрит.
Отсутствует
Кстати, Console.sys.mjs же собираются выпилить
Да уж 6 лет выпиливали Console.jsm не выпилили, выпилили jsm теперь Console.sys.mjs выпиливают
Когда был проект встроить в UCF дебаггер
Что за проект? Нашел только настройки
extensions.user_chrome_files.debug
extensions.user_chrome_files.expert
Добавлено 05-03-2024 18:32:38
BrowserUsageTelemetry мусорит
Её вообще выпиливать нужно а не id'шники в BROWSER_UI_CONTAINER_IDS добавлять
Отредактировано Vitaliy V. (05-03-2024 18:35:57)
Отсутствует
Что за проект?
Поскольку никто не мог знать, что нарисуется UCF 2024 от самого́ Автора,
а желающих обезопасить педыдущий UCF от последствий завершения JSM-геноцида
как-то не наблюдалось, то чувствовалось, что отдуваться придётся мне.
Я уже упоминал, что, увы, для некоторых задач, необходим дебаггер.
Вот когда приступил пробовать править UCF, решил, что он будет встроен.
Собственно, ничего особо сделать не успел,
пока там подформатировал всякий xml-like стафф в более человеко-читаемый вид,
пока заменил все четырёх-пробелья на благородную tab'уляцию,
случилось то, что случилось, и проект, соответственно, был мгновенно остановлен.
И это, несомненно, к лучшему.
Так вот, в config.js предполагалось оставить только самый минимум,
определение nsIFile'а с путём %профиль%/chrome/user_chrome_files/init.js
проверка, что он существует, и является файлом,
и загрузка этого init.js в объект {file: этот_файл};
А сырой набросок init.js был такой, скину какой был.
Не годен ни на что, но лишь составить представление о чём речь.
Дебаггер, собственно, это некая цитата из ранее добавленного в CB,
ну и в антиподписячем подобный есть, но без наворотов.
(url => { (file = file.parent).append("user_chrome.manifest"); if (!file.exists() || !file.isFile()) return; Components.manager.QueryInterface(Ci.nsIComponentRegistrar).autoRegister(file); var sysp = Cu.getObjectPrincipal(this), SB = opts => Cu.Sandbox(sysp, opts); var sb = SB({sandboxName: "UserChromeFiles", wantGlobalProperties: ["ChromeUtils"]}); Services.scriptloader.loadSubScript(url, sb); var unload = ["unload", e => e.target.ownerGlobal.windowRoot.removeEventListener(...ins), {once: true}]; var ins = ["DOMDocElementInserted", e => { var win = e.target.ownerGlobal; if (win.windowRoot.ownerGlobal == win) { if (win.location == "about:blank") return; win.addEventListener(...unload); } win.isChromeWindow && sb.user_chrome.initWindow(win); }]; Services.obs.addObserver(win => win.windowRoot.addEventListener(...ins), "domwindowopened"); var re = Cu.reportError; var sandbox = SB({freshCompartment: true}); Cc["@mozilla.org/jsdebugger;1"].createInstance(Ci.IJSDebugger).addClass(sandbox); var dbg = sb.dbg = new sandbox.Debugger(); var g = Cu.getGlobalForObject(Cu); var gref = dbg.gref = dbg.makeGlobalObjectReference(g); var envRef = function(name) { var val = this.find(name).getVariable(name); return val.unsafeDereference?.() || val; } dbg.ref = (arg, func, glob) => { var go = glob === undefined ? g : glob || Cu.getGlobalForObject(func); var has = dbg.hasDebuggee(go); has || dbg.addDebuggee(go); try { var ref = go == g ? gref : dbg.makeGlobalObjectReference(go); var env = ref.makeDebuggeeValue(func).environment; var cn = arg.constructor.name; if (cn == "Object") for(var name in arg) try { env.find(name).setVariable(name, ref.makeDebuggeeValue(arg[name])); } catch(err) {re(err);} else return cn == "Array" ? arg.map(envRef, env) : envRef.call(env, arg); } catch(ex) {re(ex);} finally {has || dbg.removeDebuggee(go);} } // Meds. Prevent "widgetId is undefined" console spam // from BrowserUsageTelemetry.sys.mjs when toggle ucf-toolbars. if (sb.UcfPrefs.vertical_top_bottom_bar_enable) try { var exp = ChromeUtils.importESModule("resource:///modules/BrowserUsageTelemetry.sys.mjs"); var ids = dbg.ref("BROWSER_UI_CONTAINER_IDS", exp.BrowserUsageTelemetry.init); ids && ["top", "vertical", "bottom"].forEach(pos => ids[`ucf-additional-${pos}-bar`] = ""); } catch(ex) {re(ex);} })("chrome://user_chrome_files/content/user_chrome.js");
Пока нынешний Ку.import() ещё с нами можно использовать его.
Вообще, метод, конечно, волшебный. Возвращает некий прокси,
куда проброшен весь стафф — var, let, const, function, class, всё вообще.
Это arai подогнал какую-то .cpp-магию.
Но метод сгинет вместе с JSM.
И как тогда получить ссылку? Вроде никак. Только дебаггером.
Отсутствует
Сделал всё по инструкции ...никаких изменений. Видимо чего-то не понимаю. 125.0a1 (2024-03-03) (64-разрядный)
В 123 тоже не работает ?
Add, если не работает, тогда опишите что сделали, желательно по пунктам!
Add, ладно.... user_chrome_files. С остальным надеюсь сами разберётесь.
Отредактировано kokoss (06-03-2024 19:19:57)
Win7
Отсутствует
Я уже упоминал, что, увы, для некоторых задач, необходим дебаггер
Ну именно для BrowserUsageTelemetry я бы не стал добавлять его, но если нужно для некоего кода в custom_script.js что если добавить этот модуль
он делает часть работы ?
ChromeUtils.defineESModuleGetters(scope, {
...
addDebuggerToGlobal: "resource://gre/modules/jsdebugger.sys.mjs",
addSandboxedDebuggerToGlobal: "resource://gre/modules/jsdebugger.sys.mjs",
});
Отсутствует
именно для BrowserUsageTelemetry я бы не стал добавлять его, но если нужно для некоего кода
Не-не, конечно же, в первую очередь, для пользовательского кода.
Просто когда он уже есть, возникает соблазн
воспользоваться им и для усмирения BrowserUsageTelemetry.
Мягонькое такое воздействие, никакого насилия,
добавляем id'шники как пустые строки, и это дело умолкает.
Если будет принято решение заткнуть BrowserUsageTelemetry
как-то иначе, или не делать с этим ничего, тогда дебаггер мог бы быть lazy getter'ом.
Наверно лучше как свойство UcfPrefs. Он определён как в сандбоксе, так и в окнах браузера.
В других окнах UcfPrefs можно просто импортировать, если вдруг понадобится.
Вот, поискал, нашёл, например, такой код.
Здесь TransactionsHistory не вытащишь никак, когда исчезнет Cu.import()
А с дебаггером просто пишем UcfPrefs.dbg.ref("lazy", PlacesTransactions.undo).TransactionsHistory
что если добавить этот модуль
он делает часть работы ?
Да, указанные методы этого модуля делают часть работы.
Но только совсем небольшую, только самое начало.
Плюс, они делают нечто совсем, в данном случае ненужное, вызывают initPromiseDebugging();
Таким образом, добавление этого модуля не представляется полезным.
Отредактировано Dumby (06-03-2024 18:20:20)
Отсутствует
Dumby
https://github.com/VitaliyVstyle/Vitali … fs.mjs#L46
Проверил сработало на BROWSER_UI_CONTAINER_IDS и код по ссылке
Но чтобы не мусорила BrowserUsageTelemetry просто переопределил
функцию onViewToolbarCommand https://github.com/VitaliyVstyle/Vitali … ar.js#L143
Также убрал Lazy, побавил TextEncoder TextDecoder https://github.com/VitaliyVstyle/Vitali … me.js#L179
Отредактировано Vitaliy V. (07-03-2024 00:34:54)
Отсутствует
О, спасибо!
Тогда код «Восстановить удалённое», будет, наверно, таким
(async sep => { if (!sep) return; var key = "hasRemoveTransaction"; var raws = UcfPrefs.dbg.ref("lazy", PlacesTransactions.undo).TransactionsHistory.proxifiedToRaw; raws[key] ??= entry => { for(var transaction of entry) { if (raws.get(transaction) instanceof PlacesTransactions.Remove) return true; } } var menuitem = document.createXULElement("menuitem"); for(var args of Object.entries({ closemenu: "single", class: "menuitem-iconic", id: "placesCmd_undoRemove", label: "Восстановить удалённое", oncommand: "PlacesTransactions.undo().catch(Cu.reportError);", image: "", })) menuitem.setAttribute(...args); var desc = Object.getOwnPropertyDescriptor(XULElement.prototype, "hidden"); var {set} = desc; desc.set = () => { var entry = PlacesTransactions.topUndoEntry; set.call(menuitem, !entry || !raws[key](entry)); } Object.defineProperty(menuitem, "disabled", {}); Object.defineProperty(menuitem, "hidden", desc); sep.before(menuitem); })(document.getElementById("placesContext_deleteSeparator"));
Кстати, и в геттере UcfPrefs.dbg
строка var g = Cu.getGlobalForObject(Cu); — это тоже globalThis
Это глобальный объект всех модулей.
Такой единственный, такой один на весь процесс. Он.
Но чтобы не мусорила BrowserUsageTelemetry просто переопределил
функцию onViewToolbarCommand https://github.com/VitaliyVstyle/Vitali … ar.js#L143
Да, вижу, теперь в консоли тишина.

побавил TextEncoder TextDecoder https://github.com/VitaliyVstyle/Vitali … me.js#L179
Благодарю, надеюсь достойны.
И, я смотрю, console изменилась. Это тоже хорошо.
Также убрал Lazy
Ну здесь я не смог тебя убедить просто сразу скопировать
их с глобального объекта модулей, поэтому просто скажу
самому себе, что я был недостаточно убедителен.
Отредактировано Dumby (07-03-2024 10:38:53)
Отсутствует
сразу скопировать
их с глобального объекта модулей
Это типа оператором присваивания ?
scope.TextEncoder = UcfPrefs.global.TextEncoder
или же Object.assign() использовать
Можно ещё в виде прототипа все унаследовать
sandboxPrototype: UcfPrefs.global,
но тогда нужно будет опять загружать CustomizableUI и UcfPrefs
Отсутствует
Это типа оператором присваивания ?
Да-да, именно им.
Они всё равно перебираются в цикле, вот прямо там и присвоить.
Можно ещё в виде прототипа все унаследовать
sandboxPrototype: UcfPrefs.global
Ууу, мысль, несомненно, интересная.
Это был бы эпический сдвиг само́й парадигмы.
Но тогда, да, действительно, мы получим вообще всё и сразу.
тогда нужно будет опять загружать CustomizableUI и UcfPrefs
Не загружать, а сослаться. Они уже загружены.
Отсутствует