Adopt EventEmitter class instead of injecting Signal methods

Introduce a new class, EventEmitter, which implements signal
handling for pure JavaScript classes. EventEmitter still
utilizes GJS' addSignalMethods internally.

EventEmitter allows static typechecking to understand the
structure of event-emitting JS classes and makes creating
child classes simpler.

The name 'EventEmitter' mirrors a common name for this pattern
in Node and in JS libraries.

Part-of: <https://gitlab.gnome.org/GNOME/gnome-shell/-/merge_requests/2043>
This commit is contained in:
Evan Welsh 2022-07-04 18:30:44 -04:00
parent 9e30afe678
commit a88e59c1a8
39 changed files with 204 additions and 169 deletions

View File

@ -43,12 +43,15 @@
* are not used elsewhere. These APIs may ultimately get dropped entirely and * are not used elsewhere. These APIs may ultimately get dropped entirely and
* replaced by something else. * replaced by something else.
*/ */
/* exported ConcurrentBatch, ConsecutiveBatch */
const { GObject } = imports.gi; const { GObject } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
var Task = class { var Task = class extends Signals.EventEmitter {
constructor(scope, handler) { constructor(scope, handler) {
super();
if (scope) if (scope)
this.scope = scope; this.scope = scope;
else else
@ -64,7 +67,6 @@ var Task = class {
return null; return null;
} }
}; };
Signals.addSignalMethods(Task.prototype);
var Hold = class extends Task { var Hold = class extends Task {
constructor() { constructor() {
@ -101,7 +103,6 @@ var Hold = class extends Task {
return this._acquisitions > 0; return this._acquisitions > 0;
} }
}; };
Signals.addSignalMethods(Hold.prototype);
var Batch = class extends Task { var Batch = class extends Task {
constructor(scope, tasks) { constructor(scope, tasks) {
@ -171,7 +172,6 @@ var Batch = class extends Task {
this.tasks = this.tasks.splice(0, this._currentTaskIndex + 1); this.tasks = this.tasks.splice(0, this._currentTaskIndex + 1);
} }
}; };
Signals.addSignalMethods(Batch.prototype);
var ConcurrentBatch = class extends Batch { var ConcurrentBatch = class extends Batch {
process() { process() {
@ -186,7 +186,6 @@ var ConcurrentBatch = class extends Batch {
this.nextTask(); this.nextTask();
} }
}; };
Signals.addSignalMethods(ConcurrentBatch.prototype);
var ConsecutiveBatch = class extends Batch { var ConsecutiveBatch = class extends Batch {
process() { process() {
@ -205,4 +204,3 @@ var ConsecutiveBatch = class extends Batch {
} }
} }
}; };
Signals.addSignalMethods(ConsecutiveBatch.prototype);

View File

@ -1,8 +1,12 @@
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
/* exported CredentialManager */ /* exported CredentialManager */
var CredentialManager = class CredentialManager { const Signals = imports.misc.signals;
var CredentialManager = class CredentialManager extends Signals.EventEmitter {
constructor(service) { constructor(service) {
super();
this._token = null; this._token = null;
this._service = service; this._service = service;
this._authenticatedSignalId = null; this._authenticatedSignalId = null;

View File

@ -2,7 +2,6 @@
/* exported getOVirtCredentialsManager */ /* exported getOVirtCredentialsManager */
const Gio = imports.gi.Gio; const Gio = imports.gi.Gio;
const Signals = imports.signals;
const Credential = imports.gdm.credentialManager; const Credential = imports.gdm.credentialManager;
var SERVICE_NAME = 'gdm-ovirtcred'; var SERVICE_NAME = 'gdm-ovirtcred';
@ -43,7 +42,6 @@ var OVirtCredentialsManager = class OVirtCredentialsManager extends Credential.C
}); });
} }
}; };
Signals.addSignalMethods(OVirtCredentialsManager.prototype);
function getOVirtCredentialsManager() { function getOVirtCredentialsManager() {
if (!_oVirtCredentialsManager) if (!_oVirtCredentialsManager)

View File

@ -1,7 +1,8 @@
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
/* exported Manager */
const Gio = imports.gi.Gio; const Gio = imports.gi.Gio;
const Signals = imports.signals; const Signals = imports.misc.signals;
const { loadInterfaceXML } = imports.misc.fileUtils; const { loadInterfaceXML } = imports.misc.fileUtils;
@ -14,8 +15,10 @@ const Service = Gio.DBusProxy.makeProxyWrapper(ServiceIface);
const RealmIface = loadInterfaceXML("org.freedesktop.realmd.Realm"); const RealmIface = loadInterfaceXML("org.freedesktop.realmd.Realm");
const Realm = Gio.DBusProxy.makeProxyWrapper(RealmIface); const Realm = Gio.DBusProxy.makeProxyWrapper(RealmIface);
var Manager = class { var Manager = class extends Signals.EventEmitter {
constructor() { constructor() {
super();
this._aggregateProvider = Provider(Gio.DBus.system, this._aggregateProvider = Provider(Gio.DBus.system,
'org.freedesktop.realmd', 'org.freedesktop.realmd',
'/org/freedesktop/realmd', '/org/freedesktop/realmd',
@ -105,4 +108,3 @@ var Manager = class {
this._updateLoginFormat(); this._updateLoginFormat();
} }
}; };
Signals.addSignalMethods(Manager.prototype);

View File

@ -1,9 +1,10 @@
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
/* exported BANNER_MESSAGE_KEY, BANNER_MESSAGE_TEXT_KEY, LOGO_KEY, /* exported BANNER_MESSAGE_KEY, BANNER_MESSAGE_TEXT_KEY, LOGO_KEY,
DISABLE_USER_LIST_KEY, fadeInActor, fadeOutActor, cloneAndFadeOutActor */ DISABLE_USER_LIST_KEY, fadeInActor, fadeOutActor, cloneAndFadeOutActor,
ShellUserVerifier */
const { Clutter, Gdm, Gio, GLib } = imports.gi; const { Clutter, Gdm, Gio, GLib } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const Batch = imports.gdm.batch; const Batch = imports.gdm.batch;
const OVirt = imports.gdm.oVirt; const OVirt = imports.gdm.oVirt;
@ -135,8 +136,9 @@ function cloneAndFadeOutActor(actor) {
return hold; return hold;
} }
var ShellUserVerifier = class { var ShellUserVerifier = class extends Signals.EventEmitter {
constructor(client, params) { constructor(client, params) {
super();
params = Params.parse(params, { reauthenticationOnly: false }); params = Params.parse(params, { reauthenticationOnly: false });
this._reauthOnly = params.reauthenticationOnly; this._reauthOnly = params.reauthenticationOnly;
@ -783,4 +785,3 @@ var ShellUserVerifier = class {
this._verificationFailed(serviceName, true); this._verificationFailed(serviceName, true);
} }
}; };
Signals.addSignalMethods(ShellUserVerifier.prototype);

View File

@ -2,7 +2,6 @@
/* exported getVmwareCredentialsManager */ /* exported getVmwareCredentialsManager */
const Gio = imports.gi.Gio; const Gio = imports.gi.Gio;
const Signals = imports.signals;
const Credential = imports.gdm.credentialManager; const Credential = imports.gdm.credentialManager;
const dbusPath = '/org/vmware/viewagent/Credentials'; const dbusPath = '/org/vmware/viewagent/Credentials';
@ -46,7 +45,6 @@ var VmwareCredentialsManager = class VmwareCredentialsManager extends Credential
}); });
} }
}; };
Signals.addSignalMethods(VmwareCredentialsManager.prototype);
function getVmwareCredentialsManager() { function getVmwareCredentialsManager() {
if (!_vmwareCredentialsManager) if (!_vmwareCredentialsManager)

View File

@ -29,6 +29,7 @@
<file>misc/permissionStore.js</file> <file>misc/permissionStore.js</file>
<file>misc/signalTracker.js</file> <file>misc/signalTracker.js</file>
<file>misc/smartcardManager.js</file> <file>misc/smartcardManager.js</file>
<file>misc/signals.js</file>
<file>misc/systemActions.js</file> <file>misc/systemActions.js</file>
<file>misc/util.js</file> <file>misc/util.js</file>
<file>misc/weather.js</file> <file>misc/weather.js</file>

View File

@ -1,13 +1,16 @@
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
/* exported HistoryManager */
const Signals = imports.signals; const Signals = imports.misc.signals;
const Clutter = imports.gi.Clutter; const Clutter = imports.gi.Clutter;
const Params = imports.misc.params; const Params = imports.misc.params;
var DEFAULT_LIMIT = 512; var DEFAULT_LIMIT = 512;
var HistoryManager = class { var HistoryManager = class extends Signals.EventEmitter {
constructor(params) { constructor(params) {
super();
params = Params.parse(params, { params = Params.parse(params, {
gsettingsKey: null, gsettingsKey: null,
limit: DEFAULT_LIMIT, limit: DEFAULT_LIMIT,
@ -109,4 +112,3 @@ var HistoryManager = class {
global.settings.set_strv(this._key, this._history); global.settings.set_strv(this._key, this._history);
} }
}; };
Signals.addSignalMethods(HistoryManager.prototype);

View File

@ -2,7 +2,7 @@
/* exported getIBusManager */ /* exported getIBusManager */
const { Gio, GLib, IBus, Meta, Shell } = imports.gi; const { Gio, GLib, IBus, Meta, Shell } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const IBusCandidatePopup = imports.ui.ibusCandidatePopup; const IBusCandidatePopup = imports.ui.ibusCandidatePopup;
@ -40,8 +40,10 @@ function getIBusManager() {
return _ibusManager; return _ibusManager;
} }
var IBusManager = class { var IBusManager = class extends Signals.EventEmitter {
constructor() { constructor() {
super();
IBus.init(); IBus.init();
// This is the longest we'll keep the keyboard frozen until an input // This is the longest we'll keep the keyboard frozen until an input
@ -325,4 +327,3 @@ var IBusManager = class {
}); });
} }
}; };
Signals.addSignalMethods(IBusManager.prototype);

View File

@ -2,7 +2,7 @@
/* exported canLock, getLoginManager, registerSessionWithGDM */ /* exported canLock, getLoginManager, registerSessionWithGDM */
const { GLib, Gio } = imports.gi; const { GLib, Gio } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const { loadInterfaceXML } = imports.misc.fileUtils; const { loadInterfaceXML } = imports.misc.fileUtils;
@ -87,8 +87,10 @@ function getLoginManager() {
return _loginManager; return _loginManager;
} }
var LoginManagerSystemd = class { var LoginManagerSystemd = class extends Signals.EventEmitter {
constructor() { constructor() {
super();
this._proxy = new SystemdLoginManager(Gio.DBus.system, this._proxy = new SystemdLoginManager(Gio.DBus.system,
'org.freedesktop.login1', 'org.freedesktop.login1',
'/org/freedesktop/login1'); '/org/freedesktop/login1');
@ -202,9 +204,8 @@ var LoginManagerSystemd = class {
this.emit('prepare-for-sleep', aboutToSuspend); this.emit('prepare-for-sleep', aboutToSuspend);
} }
}; };
Signals.addSignalMethods(LoginManagerSystemd.prototype);
var LoginManagerDummy = class { var LoginManagerDummy = class extends Signals.EventEmitter {
getCurrentSessionProxy(_callback) { getCurrentSessionProxy(_callback) {
// we could return a DummySession object that fakes whatever callers // we could return a DummySession object that fakes whatever callers
// expect (at the time of writing: connect() and connectSignal() // expect (at the time of writing: connect() and connectSignal()
@ -236,4 +237,3 @@ var LoginManagerDummy = class {
return null; return null;
} }
}; };
Signals.addSignalMethods(LoginManagerDummy.prototype);

View File

@ -1,8 +1,9 @@
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
/* exported ObjectManager */
const { Gio, GLib } = imports.gi; const { Gio, GLib } = imports.gi;
const Params = imports.misc.params; const Params = imports.misc.params;
const Signals = imports.signals; const Signals = imports.misc.signals;
// Specified in the D-Bus specification here: // Specified in the D-Bus specification here:
// http://dbus.freedesktop.org/doc/dbus-specification.html#standard-interfaces-objectmanager // http://dbus.freedesktop.org/doc/dbus-specification.html#standard-interfaces-objectmanager
@ -25,8 +26,10 @@ const ObjectManagerIface = `
const ObjectManagerInfo = Gio.DBusInterfaceInfo.new_for_xml(ObjectManagerIface); const ObjectManagerInfo = Gio.DBusInterfaceInfo.new_for_xml(ObjectManagerIface);
var ObjectManager = class { var ObjectManager = class extends Signals.EventEmitter {
constructor(params) { constructor(params) {
super();
params = Params.parse(params, { params = Params.parse(params, {
connection: null, connection: null,
name: null, name: null,
@ -288,4 +291,3 @@ var ObjectManager = class {
return proxies; return proxies;
} }
}; };
Signals.addSignalMethods(ObjectManager.prototype);

View File

@ -1,4 +1,4 @@
/* exported TransientSignalHolder, addObjectSignalMethods */ /* exported TransientSignalHolder, connectObject, disconnectObject */
const { GObject } = imports.gi; const { GObject } = imports.gi;
const destroyableTypes = []; const destroyableTypes = [];
@ -214,25 +214,6 @@ function disconnectObject(thisObj, obj) {
SignalManager.getDefault().getSignalTracker(thisObj).untrack(obj); SignalManager.getDefault().getSignalTracker(thisObj).untrack(obj);
} }
/**
* Add connectObject()/disconnectObject() methods
* to prototype. The prototype must have the connect()
* and disconnect() signal methods.
*
* @param {prototype} proto - a prototype
*/
function addObjectSignalMethods(proto) {
proto['connectObject'] = function (...args) {
connectObject(this, ...args);
};
proto['connect_object'] = proto['connectObject'];
proto['disconnectObject'] = function (obj) {
disconnectObject(this, obj);
};
proto['disconnect_object'] = proto['disconnectObject'];
}
/** /**
* Register a GObject type as having a 'destroy' signal * Register a GObject type as having a 'destroy' signal
* that should disconnect all handlers * that should disconnect all handlers

22
js/misc/signals.js Normal file
View File

@ -0,0 +1,22 @@
const Signals = imports.signals;
const SignalTracker = imports.misc.signalTracker;
var EventEmitter = class EventEmitter {
connectObject(...args) {
return SignalTracker.connectObject(this, ...args);
}
disconnectObject(...args) {
return SignalTracker.disconnectObject(this, ...args);
}
connect_object(...args) {
return this.connectObject(...args);
}
disconnect_object(...args) {
return this.disconnectObject(...args);
}
};
Signals.addSignalMethods(EventEmitter.prototype);

View File

@ -2,7 +2,7 @@
/* exported getSmartcardManager */ /* exported getSmartcardManager */
const Gio = imports.gi.Gio; const Gio = imports.gi.Gio;
const Signals = imports.signals; const Signals = imports.misc.signals;
const ObjectManager = imports.misc.objectManager; const ObjectManager = imports.misc.objectManager;
@ -25,8 +25,10 @@ function getSmartcardManager() {
return _smartcardManager; return _smartcardManager;
} }
var SmartcardManager = class { var SmartcardManager = class extends Signals.EventEmitter {
constructor() { constructor() {
super();
this._objectManager = new ObjectManager.ObjectManager({ this._objectManager = new ObjectManager.ObjectManager({
connection: Gio.DBus.session, connection: Gio.DBus.session,
name: 'org.gnome.SettingsDaemon.Smartcard', name: 'org.gnome.SettingsDaemon.Smartcard',
@ -114,4 +116,3 @@ var SmartcardManager = class {
return true; return true;
} }
}; };
Signals.addSignalMethods(SmartcardManager.prototype);

View File

@ -1,7 +1,8 @@
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
/* exported WeatherClient */
const { Geoclue, Gio, GLib, GWeather, Shell } = imports.gi; const { Geoclue, Gio, GLib, GWeather, Shell } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const PermissionStore = imports.misc.permissionStore; const PermissionStore = imports.misc.permissionStore;
@ -20,8 +21,10 @@ const WEATHER_APP_ID = 'org.gnome.Weather.desktop';
// Minimum time between updates to show loading indication // Minimum time between updates to show loading indication
var UPDATE_THRESHOLD = 10 * GLib.TIME_SPAN_MINUTE; var UPDATE_THRESHOLD = 10 * GLib.TIME_SPAN_MINUTE;
var WeatherClient = class { var WeatherClient = class extends Signals.EventEmitter {
constructor() { constructor() {
super();
this._loading = false; this._loading = false;
this._locationValid = false; this._locationValid = false;
this._lastUpdate = GLib.DateTime.new_from_unix_local(0); this._lastUpdate = GLib.DateTime.new_from_unix_local(0);
@ -319,4 +322,3 @@ var WeatherClient = class {
this._updateAutoLocation(); this._updateAutoLocation();
} }
}; };
Signals.addSignalMethods(WeatherClient.prototype);

View File

@ -3,7 +3,7 @@
const Shell = imports.gi.Shell; const Shell = imports.gi.Shell;
const ParentalControlsManager = imports.misc.parentalControlsManager; const ParentalControlsManager = imports.misc.parentalControlsManager;
const Signals = imports.signals; const Signals = imports.misc.signals;
const Main = imports.ui.main; const Main = imports.ui.main;
@ -64,8 +64,10 @@ const RENAMED_DESKTOP_IDS = {
'evince.desktop': 'org.gnome.Evince.desktop', 'evince.desktop': 'org.gnome.Evince.desktop',
}; };
class AppFavorites { class AppFavorites extends Signals.EventEmitter {
constructor() { constructor() {
super();
// Filter the apps through the users parental controls. // Filter the apps through the users parental controls.
this._parentalControlsManager = ParentalControlsManager.getDefault(); this._parentalControlsManager = ParentalControlsManager.getDefault();
this._parentalControlsManager.connect('app-filter-changed', () => { this._parentalControlsManager.connect('app-filter-changed', () => {
@ -201,7 +203,6 @@ class AppFavorites {
}); });
} }
} }
Signals.addSignalMethods(AppFavorites.prototype);
var appFavoritesInstance = null; var appFavoritesInstance = null;
function getAppFavorites() { function getAppFavorites() {

View File

@ -1,5 +1,5 @@
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
/* exported SystemBackground */ /* exported SystemBackground, BackgroundManager */
// READ THIS FIRST // READ THIS FIRST
// Background handling is a maze of objects, both objects in this file, and // Background handling is a maze of objects, both objects in this file, and
@ -95,7 +95,7 @@
// MetaBackgroundImage MetaBackgroundImage // MetaBackgroundImage MetaBackgroundImage
const { Clutter, GDesktopEnums, Gio, GLib, GObject, GnomeDesktop, Meta } = imports.gi; const { Clutter, GDesktopEnums, Gio, GLib, GObject, GnomeDesktop, Meta } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const LoginManager = imports.misc.loginManager; const LoginManager = imports.misc.loginManager;
const Main = imports.ui.main; const Main = imports.ui.main;
@ -137,8 +137,10 @@ function _fileEqual0(file1, file2) {
return file1.equal(file2); return file1.equal(file2);
} }
var BackgroundCache = class BackgroundCache { var BackgroundCache = class BackgroundCache extends Signals.EventEmitter {
constructor() { constructor() {
super();
this._fileMonitors = {}; this._fileMonitors = {};
this._backgroundSources = {}; this._backgroundSources = {};
this._animations = {}; this._animations = {};
@ -221,7 +223,6 @@ var BackgroundCache = class BackgroundCache {
} }
} }
}; };
Signals.addSignalMethods(BackgroundCache.prototype);
function getBackgroundCache() { function getBackgroundCache() {
if (!_backgroundCache) if (!_backgroundCache)
@ -682,8 +683,9 @@ class Animation extends GnomeDesktop.BGSlideShow {
} }
}); });
var BackgroundManager = class BackgroundManager { var BackgroundManager = class BackgroundManager extends Signals.EventEmitter {
constructor(params) { constructor(params) {
super();
params = Params.parse(params, { params = Params.parse(params, {
container: null, container: null,
layoutManager: Main.layoutManager, layoutManager: Main.layoutManager,
@ -838,4 +840,3 @@ var BackgroundManager = class BackgroundManager {
return backgroundActor; return backgroundActor;
} }
}; };
Signals.addSignalMethods(BackgroundManager.prototype);

View File

@ -2,7 +2,7 @@
/* exported Component */ /* exported Component */
const { Clutter, Gio, GLib, GObject, NM, Pango, Shell, St } = imports.gi; const { Clutter, Gio, GLib, GObject, NM, Pango, Shell, St } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const Dialog = imports.ui.dialog; const Dialog = imports.ui.dialog;
const Main = imports.ui.main; const Main = imports.ui.main;
@ -411,8 +411,10 @@ class NetworkSecretDialog extends ModalDialog.ModalDialog {
} }
}); });
var VPNRequestHandler = class { var VPNRequestHandler = class extends Signals.EventEmitter {
constructor(agent, requestId, authHelper, serviceType, connection, hints, flags) { constructor(agent, requestId, authHelper, serviceType, connection, hints, flags) {
super();
this._agent = agent; this._agent = agent;
this._requestId = requestId; this._requestId = requestId;
this._connection = connection; this._connection = connection;
@ -668,7 +670,6 @@ var VPNRequestHandler = class {
} }
} }
}; };
Signals.addSignalMethods(VPNRequestHandler.prototype);
var NetworkAgent = class { var NetworkAgent = class {
constructor() { constructor() {

View File

@ -2,7 +2,7 @@
/* exported addDragMonitor, removeDragMonitor, makeDraggable */ /* exported addDragMonitor, removeDragMonitor, makeDraggable */
const { Clutter, GLib, Meta, Shell, St } = imports.gi; const { Clutter, GLib, Meta, Shell, St } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const Main = imports.ui.main; const Main = imports.ui.main;
const Params = imports.misc.params; const Params = imports.misc.params;
@ -78,8 +78,10 @@ function removeDragMonitor(monitor) {
} }
} }
var _Draggable = class _Draggable { var _Draggable = class _Draggable extends Signals.EventEmitter {
constructor(actor, params) { constructor(actor, params) {
super();
params = Params.parse(params, { params = Params.parse(params, {
manualMode: false, manualMode: false,
timeoutThreshold: 0, timeoutThreshold: 0,
@ -801,7 +803,6 @@ var _Draggable = class _Draggable {
currentDraggable = null; currentDraggable = null;
} }
}; };
Signals.addSignalMethods(_Draggable.prototype);
/** /**
* makeDraggable: * makeDraggable:

View File

@ -45,7 +45,6 @@ try {
const { Clutter, Gio, GLib, GObject, Meta, Polkit, Shell, St } = imports.gi; const { Clutter, Gio, GLib, GObject, Meta, Polkit, Shell, St } = imports.gi;
const Gettext = imports.gettext; const Gettext = imports.gettext;
const Signals = imports.signals;
const System = imports.system; const System = imports.system;
const SignalTracker = imports.misc.signalTracker; const SignalTracker = imports.misc.signalTracker;
@ -358,12 +357,6 @@ function init() {
SignalTracker.disconnectObject(this, ...args); SignalTracker.disconnectObject(this, ...args);
}; };
const _addSignalMethods = Signals.addSignalMethods;
Signals.addSignalMethods = function (prototype) {
_addSignalMethods(prototype);
SignalTracker.addObjectSignalMethods(prototype);
};
SignalTracker.registerDestroyableType(Clutter.Actor); SignalTracker.registerDestroyableType(Clutter.Actor);
// Miscellaneous monkeypatching // Miscellaneous monkeypatching

View File

@ -1,8 +1,8 @@
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
/* exported init connect disconnect */ /* exported init connect disconnect ExtensionManager */
const { GLib, Gio, GObject, Shell, St } = imports.gi; const { GLib, Gio, GObject, Shell, St } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const ExtensionDownloader = imports.ui.extensionDownloader; const ExtensionDownloader = imports.ui.extensionDownloader;
const ExtensionUtils = imports.misc.extensionUtils; const ExtensionUtils = imports.misc.extensionUtils;
@ -19,8 +19,10 @@ const EXTENSION_DISABLE_VERSION_CHECK_KEY = 'disable-extension-version-validatio
const UPDATE_CHECK_TIMEOUT = 24 * 60 * 60; // 1 day in seconds const UPDATE_CHECK_TIMEOUT = 24 * 60 * 60; // 1 day in seconds
var ExtensionManager = class { var ExtensionManager = class extends Signals.EventEmitter {
constructor() { constructor() {
super();
this._initialized = false; this._initialized = false;
this._updateNotified = false; this._updateNotified = false;
@ -655,7 +657,6 @@ var ExtensionManager = class {
this._enableAllExtensions(); this._enableAllExtensions();
} }
}; };
Signals.addSignalMethods(ExtensionManager.prototype);
const ExtensionUpdateSource = GObject.registerClass( const ExtensionUpdateSource = GObject.registerClass(
class ExtensionUpdateSource extends MessageTray.Source { class ExtensionUpdateSource extends MessageTray.Source {

View File

@ -20,15 +20,18 @@
* Contributor: * Contributor:
* Magdalen Berns <m.berns@sms.ed.ac.uk> * Magdalen Berns <m.berns@sms.ed.ac.uk>
*/ */
/* exported FocusCaretTracker */
const Atspi = imports.gi.Atspi; const Atspi = imports.gi.Atspi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const CARETMOVED = 'object:text-caret-moved'; const CARETMOVED = 'object:text-caret-moved';
const STATECHANGED = 'object:state-changed'; const STATECHANGED = 'object:state-changed';
var FocusCaretTracker = class FocusCaretTracker { var FocusCaretTracker = class FocusCaretTracker extends Signals.EventEmitter {
constructor() { constructor() {
super();
this._atspiListener = Atspi.EventListener.new(this._onChanged.bind(this)); this._atspiListener = Atspi.EventListener.new(this._onChanged.bind(this));
this._atspiInited = false; this._atspiInited = false;
@ -86,4 +89,3 @@ var FocusCaretTracker = class FocusCaretTracker {
this._caretListenerRegistered = false; this._caretListenerRegistered = false;
} }
}; };
Signals.addSignalMethods(FocusCaretTracker.prototype);

View File

@ -2,7 +2,7 @@
/* exported KeyboardManager */ /* exported KeyboardManager */
const { Clutter, Gio, GLib, GObject, Graphene, Meta, Shell, St } = imports.gi; const { Clutter, Gio, GLib, GObject, Graphene, Meta, Shell, St } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const EdgeDragAction = imports.ui.edgeDragAction; const EdgeDragAction = imports.ui.edgeDragAction;
const InputSourceManager = imports.ui.status.keyboard; const InputSourceManager = imports.ui.status.keyboard;
@ -574,8 +574,10 @@ var KeyboardModel = class {
} }
}; };
var FocusTracker = class { var FocusTracker = class extends Signals.EventEmitter {
constructor() { constructor() {
super();
this._rect = null; this._rect = null;
global.display.connectObject( global.display.connectObject(
@ -670,7 +672,6 @@ var FocusTracker = class {
return rect; return rect;
} }
}; };
Signals.addSignalMethods(FocusTracker.prototype);
var EmojiPager = GObject.registerClass({ var EmojiPager = GObject.registerClass({
Properties: { Properties: {
@ -2055,8 +2056,10 @@ var Keyboard = GObject.registerClass({
} }
}); });
var KeyboardController = class { var KeyboardController = class extends Signals.EventEmitter {
constructor() { constructor() {
super();
let seat = Clutter.get_default_backend().get_default_seat(); let seat = Clutter.get_default_backend().get_default_seat();
this._virtualDevice = seat.create_virtual_device(Clutter.InputDeviceType.KEYBOARD_DEVICE); this._virtualDevice = seat.create_virtual_device(Clutter.InputDeviceType.KEYBOARD_DEVICE);
@ -2147,4 +2150,3 @@ var KeyboardController = class {
keyval, Clutter.KeyState.RELEASED); keyval, Clutter.KeyState.RELEASED);
} }
}; };
Signals.addSignalMethods(KeyboardController.prototype);

View File

@ -2,7 +2,7 @@
/* exported MonitorConstraint, LayoutManager */ /* exported MonitorConstraint, LayoutManager */
const { Clutter, Gio, GLib, GObject, Meta, Shell, St } = imports.gi; const { Clutter, Gio, GLib, GObject, Meta, Shell, St } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const Background = imports.ui.background; const Background = imports.ui.background;
const BackgroundMenu = imports.ui.backgroundMenu; const BackgroundMenu = imports.ui.backgroundMenu;
@ -1268,8 +1268,10 @@ class HotCorner extends Clutter.Actor {
} }
}); });
var PressureBarrier = class PressureBarrier { var PressureBarrier = class PressureBarrier extends Signals.EventEmitter {
constructor(threshold, timeout, actionMode) { constructor(threshold, timeout, actionMode) {
super();
this._threshold = threshold; this._threshold = threshold;
this._timeout = timeout; this._timeout = timeout;
this._actionMode = actionMode; this._actionMode = actionMode;
@ -1409,7 +1411,6 @@ var PressureBarrier = class PressureBarrier {
this._trigger(); this._trigger();
} }
}; };
Signals.addSignalMethods(PressureBarrier.prototype);
var ScreenTransition = GObject.registerClass( var ScreenTransition = GObject.registerClass(
class ScreenTransition extends Clutter.Actor { class ScreenTransition extends Clutter.Actor {

View File

@ -4,7 +4,7 @@
const { const {
Clutter, Cogl, Gio, GLib, GObject, Graphene, Meta, Pango, Shell, St, Clutter, Cogl, Gio, GLib, GObject, Graphene, Meta, Pango, Shell, St,
} = imports.gi; } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const System = imports.system; const System = imports.system;
const History = imports.misc.history; const History = imports.misc.history;
@ -56,8 +56,10 @@ function _getAutoCompleteGlobalKeywords() {
return keywords.concat(windowProperties).concat(headerProperties); return keywords.concat(windowProperties).concat(headerProperties);
} }
var AutoComplete = class AutoComplete { var AutoComplete = class AutoComplete extends Signals.EventEmitter {
constructor(entry) { constructor(entry) {
super();
this._entry = entry; this._entry = entry;
this._entry.connect('key-press-event', this._entryKeyPressEvent.bind(this)); this._entry.connect('key-press-event', this._entryKeyPressEvent.bind(this));
this._lastTabTime = global.get_current_time(); this._lastTabTime = global.get_current_time();
@ -121,7 +123,6 @@ var AutoComplete = class AutoComplete {
this._entry.clutter_text.insert_text(additionalCompletionText, cursorPos); this._entry.clutter_text.insert_text(additionalCompletionText, cursorPos);
} }
}; };
Signals.addSignalMethods(AutoComplete.prototype);
var Notebook = GObject.registerClass({ var Notebook = GObject.registerClass({

View File

@ -1,9 +1,10 @@
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
/* exported Magnifier */
const { const {
Atspi, Clutter, GDesktopEnums, Gio, GLib, GObject, Meta, Shell, St, Atspi, Clutter, GDesktopEnums, Gio, GLib, GObject, Meta, Shell, St,
} = imports.gi; } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const Background = imports.ui.background; const Background = imports.ui.background;
const FocusCaretTracker = imports.ui.focusCaretTracker; const FocusCaretTracker = imports.ui.focusCaretTracker;
@ -88,8 +89,10 @@ var MouseSpriteContent = GObject.registerClass({
} }
}); });
var Magnifier = class Magnifier { var Magnifier = class Magnifier extends Signals.EventEmitter {
constructor() { constructor() {
super();
// Magnifier is a manager of ZoomRegions. // Magnifier is a manager of ZoomRegions.
this._zoomRegions = []; this._zoomRegions = [];
@ -724,7 +727,6 @@ var Magnifier = class Magnifier {
} }
} }
}; };
Signals.addSignalMethods(Magnifier.prototype);
var ZoomRegion = class ZoomRegion { var ZoomRegion = class ZoomRegion {
constructor(magnifier, mouseSourceActor) { constructor(magnifier, mouseSourceActor) {

View File

@ -1,6 +1,6 @@
/* exported MediaSection */ /* exported MediaSection */
const { Gio, GObject, Shell, St } = imports.gi; const { Gio, GObject, Shell, St } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const Main = imports.ui.main; const Main = imports.ui.main;
const MessageList = imports.ui.messageList; const MessageList = imports.ui.messageList;
@ -86,14 +86,16 @@ class MediaMessage extends MessageList.Message {
} }
}); });
var MprisPlayer = class MprisPlayer { var MprisPlayer = class MprisPlayer extends Signals.EventEmitter {
constructor(busName) { constructor(busName) {
super();
this._mprisProxy = new MprisProxy(Gio.DBus.session, busName, this._mprisProxy = new MprisProxy(Gio.DBus.session, busName,
'/org/mpris/MediaPlayer2', '/org/mpris/MediaPlayer2',
this._onMprisProxyReady.bind(this)); this._onMprisProxyReady.bind(this));
this._playerProxy = new MprisPlayerProxy(Gio.DBus.session, busName, this._playerProxy = new MprisPlayerProxy(Gio.DBus.session, busName,
'/org/mpris/MediaPlayer2', '/org/mpris/MediaPlayer2',
this._onPlayerProxyReady.bind(this)); this._onPlayerProxyReady.bind(this));
this._visible = false; this._visible = false;
this._trackArtists = []; this._trackArtists = [];
@ -233,7 +235,6 @@ var MprisPlayer = class MprisPlayer {
} }
} }
}; };
Signals.addSignalMethods(MprisPlayer.prototype);
var MediaSection = GObject.registerClass( var MediaSection = GObject.registerClass(
class MediaSection extends MessageList.MessageListSection { class MediaSection extends MessageList.MessageListSection {

View File

@ -2,7 +2,7 @@
/* exported Overview, ANIMATION_TIME */ /* exported Overview, ANIMATION_TIME */
const { Clutter, Gio, GLib, GObject, Meta, Shell, St } = imports.gi; const { Clutter, Gio, GLib, GObject, Meta, Shell, St } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
// Time for initial animation going into Overview mode; // Time for initial animation going into Overview mode;
// this is defined here to make it available in imports. // this is defined here to make it available in imports.
@ -103,8 +103,10 @@ class OverviewActor extends St.BoxLayout {
} }
}); });
var Overview = class { var Overview = class extends Signals.EventEmitter {
constructor() { constructor() {
super();
this._initCalled = false; this._initCalled = false;
this._visible = false; this._visible = false;
@ -649,4 +651,3 @@ var Overview = class {
return this._overview.searchEntry; return this._overview.searchEntry;
} }
}; };
Signals.addSignalMethods(Overview.prototype);

View File

@ -5,7 +5,7 @@ const {
Atk, Clutter, GDesktopEnums, Gio, Atk, Clutter, GDesktopEnums, Gio,
GLib, GObject, Gtk, Meta, Pango, Rsvg, St, GLib, GObject, Gtk, Meta, Pango, Rsvg, St,
} = imports.gi; } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const Main = imports.ui.main; const Main = imports.ui.main;
const PopupMenu = imports.ui.popupMenu; const PopupMenu = imports.ui.popupMenu;
@ -957,8 +957,10 @@ var PadOsd = GObject.registerClass({
const PadOsdIface = loadInterfaceXML('org.gnome.Shell.Wacom.PadOsd'); const PadOsdIface = loadInterfaceXML('org.gnome.Shell.Wacom.PadOsd');
var PadOsdService = class { var PadOsdService = class extends Signals.EventEmitter {
constructor() { constructor() {
super();
this._dbusImpl = Gio.DBusExportedObject.wrapJSObject(PadOsdIface, this); this._dbusImpl = Gio.DBusExportedObject.wrapJSObject(PadOsdIface, this);
this._dbusImpl.export(Gio.DBus.session, '/org/gnome/Shell/Wacom'); this._dbusImpl.export(Gio.DBus.session, '/org/gnome/Shell/Wacom');
Gio.DBus.session.own_name('org.gnome.Shell.Wacom.PadOsd', Gio.BusNameOwnerFlags.REPLACE, null, null); Gio.DBus.session.own_name('org.gnome.Shell.Wacom.PadOsd', Gio.BusNameOwnerFlags.REPLACE, null, null);
@ -987,4 +989,3 @@ var PadOsdService = class {
invocation.return_value(null); invocation.return_value(null);
} }
}; };
Signals.addSignalMethods(PadOsdService.prototype);

View File

@ -4,7 +4,7 @@
PopupMenuSection, PopupSubMenuMenuItem, PopupMenuManager */ PopupMenuSection, PopupSubMenuMenuItem, PopupMenuManager */
const { Atk, Clutter, Gio, GObject, Graphene, Shell, St } = imports.gi; const { Atk, Clutter, Gio, GObject, Graphene, Shell, St } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const BoxPointer = imports.ui.boxpointer; const BoxPointer = imports.ui.boxpointer;
const Main = imports.ui.main; const Main = imports.ui.main;
@ -480,8 +480,10 @@ class PopupImageMenuItem extends PopupBaseMenuItem {
} }
}); });
var PopupMenuBase = class { var PopupMenuBase = class extends Signals.EventEmitter {
constructor(sourceActor, styleClass) { constructor(sourceActor, styleClass) {
super();
if (this.constructor === PopupMenuBase) if (this.constructor === PopupMenuBase)
throw new TypeError(`Cannot instantiate abstract class ${this.constructor.name}`); throw new TypeError(`Cannot instantiate abstract class ${this.constructor.name}`);
@ -805,7 +807,6 @@ var PopupMenuBase = class {
Main.sessionMode.disconnectObject(this); Main.sessionMode.disconnectObject(this);
} }
}; };
Signals.addSignalMethods(PopupMenuBase.prototype);
var PopupMenu = class extends PopupMenuBase { var PopupMenu = class extends PopupMenuBase {
constructor(sourceActor, arrowAlignment, arrowSide) { constructor(sourceActor, arrowAlignment, arrowSide) {
@ -951,8 +952,10 @@ var PopupMenu = class extends PopupMenuBase {
} }
}; };
var PopupDummyMenu = class { var PopupDummyMenu = class extends Signals.EventEmitter {
constructor(sourceActor) { constructor(sourceActor) {
super();
this.sourceActor = sourceActor; this.sourceActor = sourceActor;
this.actor = sourceActor; this.actor = sourceActor;
this.actor._delegate = this; this.actor._delegate = this;
@ -986,7 +989,6 @@ var PopupDummyMenu = class {
this.emit('destroy'); this.emit('destroy');
} }
}; };
Signals.addSignalMethods(PopupDummyMenu.prototype);
var PopupSubMenu = class extends PopupMenuBase { var PopupSubMenu = class extends PopupMenuBase {
constructor(sourceActor, sourceArrow) { constructor(sourceActor, sourceArrow) {

View File

@ -1,10 +1,11 @@
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
/* exported ScreenShield */
const { const {
AccountsService, Clutter, Gio, AccountsService, Clutter, Gio,
GLib, Graphene, Meta, Shell, St, GLib, Graphene, Meta, Shell, St,
} = imports.gi; } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const GnomeSession = imports.misc.gnomeSession; const GnomeSession = imports.misc.gnomeSession;
const OVirt = imports.gdm.oVirt; const OVirt = imports.gdm.oVirt;
@ -44,8 +45,10 @@ var CURTAIN_SLIDE_TIME = 300;
* This will ensure that the screen blanks at the right time when it fades out. * This will ensure that the screen blanks at the right time when it fades out.
* https://bugzilla.gnome.org/show_bug.cgi?id=668703 explains the dependency. * https://bugzilla.gnome.org/show_bug.cgi?id=668703 explains the dependency.
*/ */
var ScreenShield = class { var ScreenShield = class extends Signals.EventEmitter {
constructor() { constructor() {
super();
this.actor = Main.layoutManager.screenShieldGroup; this.actor = Main.layoutManager.screenShieldGroup;
this._lockScreenState = MessageTray.State.HIDDEN; this._lockScreenState = MessageTray.State.HIDDEN;
@ -676,4 +679,3 @@ var ScreenShield = class {
}); });
} }
}; };
Signals.addSignalMethods(ScreenShield.prototype);

View File

@ -2,7 +2,7 @@
/* exported SessionMode, listModes */ /* exported SessionMode, listModes */
const GLib = imports.gi.GLib; const GLib = imports.gi.GLib;
const Signals = imports.signals; const Signals = imports.misc.signals;
const FileUtils = imports.misc.fileUtils; const FileUtils = imports.misc.fileUtils;
const Params = imports.misc.params; const Params = imports.misc.params;
@ -145,8 +145,10 @@ function listModes() {
loop.run(); loop.run();
} }
var SessionMode = class { var SessionMode = class extends Signals.EventEmitter {
constructor() { constructor() {
super();
_loadModes(); _loadModes();
let isPrimary = _modes[global.session_mode] && let isPrimary = _modes[global.session_mode] &&
_modes[global.session_mode].isPrimary; _modes[global.session_mode].isPrimary;
@ -199,4 +201,3 @@ var SessionMode = class {
this.emit('updated'); this.emit('updated');
} }
}; };
Signals.addSignalMethods(SessionMode.prototype);

View File

@ -3,7 +3,7 @@
const { Clutter, Gio, GLib, GObject, IBus, Meta, Shell, St } = imports.gi; const { Clutter, Gio, GLib, GObject, IBus, Meta, Shell, St } = imports.gi;
const Gettext = imports.gettext; const Gettext = imports.gettext;
const Signals = imports.signals; const Signals = imports.misc.signals;
const IBusManager = imports.misc.ibusManager; const IBusManager = imports.misc.ibusManager;
const KeyboardManager = imports.misc.keyboardManager; const KeyboardManager = imports.misc.keyboardManager;
@ -32,8 +32,10 @@ class LayoutMenuItem extends PopupMenu.PopupBaseMenuItem {
} }
}); });
var InputSource = class { var InputSource = class extends Signals.EventEmitter {
constructor(type, id, displayName, shortName, index) { constructor(type, id, displayName, shortName, index) {
super();
this.type = type; this.type = type;
this.id = id; this.id = id;
this.displayName = displayName; this.displayName = displayName;
@ -69,7 +71,6 @@ var InputSource = class {
return engineDesc.layout; return engineDesc.layout;
} }
}; };
Signals.addSignalMethods(InputSource.prototype);
var InputSourcePopup = GObject.registerClass( var InputSourcePopup = GObject.registerClass(
class InputSourcePopup extends SwitcherPopup.SwitcherPopup { class InputSourcePopup extends SwitcherPopup.SwitcherPopup {
@ -135,8 +136,10 @@ class InputSourceSwitcher extends SwitcherPopup.SwitcherList {
} }
}); });
var InputSourceSettings = class { var InputSourceSettings = class extends Signals.EventEmitter {
constructor() { constructor() {
super();
if (this.constructor === InputSourceSettings) if (this.constructor === InputSourceSettings)
throw new TypeError(`Cannot instantiate abstract class ${this.constructor.name}`); throw new TypeError(`Cannot instantiate abstract class ${this.constructor.name}`);
} }
@ -173,7 +176,6 @@ var InputSourceSettings = class {
return false; return false;
} }
}; };
Signals.addSignalMethods(InputSourceSettings.prototype);
var InputSourceSystemSettings = class extends InputSourceSettings { var InputSourceSystemSettings = class extends InputSourceSettings {
constructor() { constructor() {
@ -300,8 +302,10 @@ var InputSourceSessionSettings = class extends InputSourceSettings {
} }
}; };
var InputSourceManager = class { var InputSourceManager = class extends Signals.EventEmitter {
constructor() { constructor() {
super();
// All valid input sources currently in the gsettings // All valid input sources currently in the gsettings
// KEY_INPUT_SOURCES list indexed by their index there // KEY_INPUT_SOURCES list indexed by their index there
this._inputSources = {}; this._inputSources = {};
@ -771,7 +775,6 @@ var InputSourceManager = class {
return this._keyboardManager; return this._keyboardManager;
} }
}; };
Signals.addSignalMethods(InputSourceManager.prototype);
let _inputSourceManager = null; let _inputSourceManager = null;

View File

@ -1,7 +1,7 @@
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
/* exported NMApplet */ /* exported NMApplet */
const { Clutter, Gio, GLib, GObject, Meta, NM, Polkit, St } = imports.gi; const { Clutter, Gio, GLib, GObject, Meta, NM, Polkit, St } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const Animation = imports.ui.animation; const Animation = imports.ui.animation;
const Main = imports.ui.main; const Main = imports.ui.main;
@ -107,8 +107,10 @@ function launchSettingsPanel(panel, ...args) {
} }
} }
var NMConnectionItem = class { var NMConnectionItem = class extends Signals.EventEmitter {
constructor(section, connection) { constructor(section, connection) {
super();
this._section = section; this._section = section;
this._connection = connection; this._connection = connection;
this._activeConnection = null; this._activeConnection = null;
@ -193,10 +195,11 @@ var NMConnectionItem = class {
this._sync(); this._sync();
} }
}; };
Signals.addSignalMethods(NMConnectionItem.prototype);
var NMConnectionSection = class NMConnectionSection { var NMConnectionSection = class NMConnectionSection extends Signals.EventEmitter {
constructor(client) { constructor(client) {
super();
if (this.constructor === NMConnectionSection) if (this.constructor === NMConnectionSection)
throw new TypeError(`Cannot instantiate abstract type ${this.constructor.name}`); throw new TypeError(`Cannot instantiate abstract type ${this.constructor.name}`);
@ -320,7 +323,6 @@ var NMConnectionSection = class NMConnectionSection {
this._sync(); this._sync();
} }
}; };
Signals.addSignalMethods(NMConnectionSection.prototype);
var NMConnectionDevice = class NMConnectionDevice extends NMConnectionSection { var NMConnectionDevice = class NMConnectionDevice extends NMConnectionSection {
constructor(client, device) { constructor(client, device) {
@ -1242,8 +1244,10 @@ class NMWirelessDialog extends ModalDialog.ModalDialog {
} }
}); });
var NMDeviceWireless = class { var NMDeviceWireless = class extends Signals.EventEmitter {
constructor(client, device) { constructor(client, device) {
super();
this._client = client; this._client = client;
this._device = device; this._device = device;
@ -1433,7 +1437,6 @@ var NMDeviceWireless = class {
return 'network-wireless-no-route-symbolic'; return 'network-wireless-no-route-symbolic';
} }
}; };
Signals.addSignalMethods(NMDeviceWireless.prototype);
var NMWireguardItem = class extends NMConnectionItem { var NMWireguardItem = class extends NMConnectionItem {
_buildUI() { _buildUI() {
@ -1657,7 +1660,6 @@ var NMVpnSection = class extends NMConnectionSection {
return ''; return '';
} }
}; };
Signals.addSignalMethods(NMVpnSection.prototype);
var DeviceCategory = class extends PopupMenu.PopupMenuSection { var DeviceCategory = class extends PopupMenu.PopupMenuSection {
constructor(category) { constructor(category) {

View File

@ -2,7 +2,7 @@
/* exported Indicator */ /* exported Indicator */
const { Gio, GObject } = imports.gi; const { Gio, GObject } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const Main = imports.ui.main; const Main = imports.ui.main;
const PanelMenu = imports.ui.panelMenu; const PanelMenu = imports.ui.panelMenu;
@ -16,18 +16,20 @@ const OBJECT_PATH = '/org/gnome/SettingsDaemon/Rfkill';
const RfkillManagerInterface = loadInterfaceXML('org.gnome.SettingsDaemon.Rfkill'); const RfkillManagerInterface = loadInterfaceXML('org.gnome.SettingsDaemon.Rfkill');
const RfkillManagerProxy = Gio.DBusProxy.makeProxyWrapper(RfkillManagerInterface); const RfkillManagerProxy = Gio.DBusProxy.makeProxyWrapper(RfkillManagerInterface);
var RfkillManager = class { var RfkillManager = class extends Signals.EventEmitter {
constructor() { constructor() {
super();
this._proxy = new RfkillManagerProxy(Gio.DBus.session, BUS_NAME, OBJECT_PATH, this._proxy = new RfkillManagerProxy(Gio.DBus.session, BUS_NAME, OBJECT_PATH,
(proxy, error) => { (proxy, error) => {
if (error) { if (error) {
log(error.message); log(error.message);
return; return;
} }
this._proxy.connect('g-properties-changed', this._proxy.connect('g-properties-changed',
this._changed.bind(this)); this._changed.bind(this));
this._changed(); this._changed();
}); });
} }
get airplaneMode() { get airplaneMode() {
@ -50,7 +52,6 @@ var RfkillManager = class {
this.emit('airplane-mode-changed'); this.emit('airplane-mode-changed');
} }
}; };
Signals.addSignalMethods(RfkillManager.prototype);
var _manager; var _manager;
function getRfkillManager() { function getRfkillManager() {

View File

@ -4,7 +4,7 @@
// the following is a modified version of bolt/contrib/js/client.js // the following is a modified version of bolt/contrib/js/client.js
const { Gio, GLib, GObject, Polkit, Shell } = imports.gi; const { Gio, GLib, GObject, Polkit, Shell } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const Main = imports.ui.main; const Main = imports.ui.main;
const MessageTray = imports.ui.messageTray; const MessageTray = imports.ui.messageTray;
@ -49,8 +49,10 @@ const BOLT_DBUS_CLIENT_IFACE = 'org.freedesktop.bolt1.Manager';
const BOLT_DBUS_NAME = 'org.freedesktop.bolt'; const BOLT_DBUS_NAME = 'org.freedesktop.bolt';
const BOLT_DBUS_PATH = '/org/freedesktop/bolt'; const BOLT_DBUS_PATH = '/org/freedesktop/bolt';
var Client = class { var Client = class extends Signals.EventEmitter {
constructor() { constructor() {
super();
this._proxy = null; this._proxy = null;
this.probing = false; this.probing = false;
this._getProxy(); this._getProxy();
@ -127,11 +129,12 @@ var Client = class {
return this._proxy.AuthMode; return this._proxy.AuthMode;
} }
}; };
Signals.addSignalMethods(Client.prototype);
/* helper class to automatically authorize new devices */ /* helper class to automatically authorize new devices */
var AuthRobot = class { var AuthRobot = class extends Signals.EventEmitter {
constructor(client) { constructor(client) {
super();
this._client = client; this._client = client;
this._devicesToEnroll = []; this._devicesToEnroll = [];
@ -217,7 +220,6 @@ var AuthRobot = class {
return GLib.SOURCE_REMOVE; return GLib.SOURCE_REMOVE;
} }
}; };
Signals.addSignalMethods(AuthRobot.prototype);
/* eof client.js */ /* eof client.js */

View File

@ -2,7 +2,7 @@
/* exported Indicator */ /* exported Indicator */
const { Clutter, Gio, GLib, GObject, Gvc, St } = imports.gi; const { Clutter, Gio, GLib, GObject, Gvc, St } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const Main = imports.ui.main; const Main = imports.ui.main;
const PanelMenu = imports.ui.panelMenu; const PanelMenu = imports.ui.panelMenu;
@ -29,8 +29,10 @@ function getMixerControl() {
return _mixerControl; return _mixerControl;
} }
var StreamSlider = class { var StreamSlider = class extends Signals.EventEmitter {
constructor(control) { constructor(control) {
super();
this._control = control; this._control = control;
this.item = new PopupMenu.PopupBaseMenuItem({ activate: false }); this.item = new PopupMenu.PopupBaseMenuItem({ activate: false });
@ -213,7 +215,6 @@ var StreamSlider = class {
return maxVolume / this._control.get_vol_max_norm(); return maxVolume / this._control.get_vol_max_norm();
} }
}; };
Signals.addSignalMethods(StreamSlider.prototype);
var OutputStreamSlider = class extends StreamSlider { var OutputStreamSlider = class extends StreamSlider {
constructor(control) { constructor(control) {

View File

@ -1,13 +1,16 @@
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
/* exported XdndHandler */
const { Clutter } = imports.gi; const { Clutter } = imports.gi;
const Signals = imports.signals; const Signals = imports.misc.signals;
const DND = imports.ui.dnd; const DND = imports.ui.dnd;
const Main = imports.ui.main; const Main = imports.ui.main;
var XdndHandler = class { var XdndHandler = class extends Signals.EventEmitter {
constructor() { constructor() {
super();
// Used to display a clone of the cursor window when the // Used to display a clone of the cursor window when the
// window group is hidden (like it happens in the overview) // window group is hidden (like it happens in the overview)
this._cursorWindowClone = null; this._cursorWindowClone = null;
@ -111,4 +114,3 @@ var XdndHandler = class {
} }
} }
}; };
Signals.addSignalMethods(XdndHandler.prototype);

View File

@ -5,7 +5,7 @@
const { GObject } = imports.gi; const { GObject } = imports.gi;
const JsUnit = imports.jsUnit; const JsUnit = imports.jsUnit;
const Signals = imports.signals; const Signals = imports.misc.signals;
const Environment = imports.ui.environment; const Environment = imports.ui.environment;
const { TransientSignalHolder, registerDestroyableType } = imports.misc.signalTracker; const { TransientSignalHolder, registerDestroyableType } = imports.misc.signalTracker;
@ -17,14 +17,11 @@ const Destroyable = GObject.registerClass({
}, class Destroyable extends GObject.Object {}); }, class Destroyable extends GObject.Object {});
registerDestroyableType(Destroyable); registerDestroyableType(Destroyable);
class PlainEmitter {}
Signals.addSignalMethods(PlainEmitter.prototype);
const GObjectEmitter = GObject.registerClass({ const GObjectEmitter = GObject.registerClass({
Signals: { 'signal': {} }, Signals: { 'signal': {} },
}, class GObjectEmitter extends Destroyable {}); }, class GObjectEmitter extends Destroyable {});
const emitter1 = new PlainEmitter(); const emitter1 = new Signals.EventEmitter();
const emitter2 = new GObjectEmitter(); const emitter2 = new GObjectEmitter();
const tracked1 = new Destroyable(); const tracked1 = new Destroyable();