Commit 80c26e70 authored by JC Brand's avatar JC Brand

Add new option strict_plugin_dependencies

parent 45bc7f11
...@@ -717,6 +717,20 @@ Data in localStorage on the other hand is kept indefinitely. ...@@ -717,6 +717,20 @@ Data in localStorage on the other hand is kept indefinitely.
roster contact statuses will not become out of sync in a single session, roster contact statuses will not become out of sync in a single session,
only across more than one session. only across more than one session.
strict_plugin_dependencies
--------------------------
* Default: ``false``
When set to ``true`` and a plugin tries to override an object which doesn't
exist (for example because the plugin which provides that object is not
loaded), then an error will be raised.
Otherwise a message will simply be logged and the override instruction ignored.
This allows plugins to have "soft" dependencies which aren't declared as
as dependencies.
synchronize_availability synchronize_availability
-------------------- --------------------
......
...@@ -279,6 +279,7 @@ ...@@ -279,6 +279,7 @@
show_only_online_users: false, show_only_online_users: false,
sid: undefined, sid: undefined,
storage: 'session', storage: 'session',
strict_plugin_dependencies: false,
synchronize_availability: true, // Set to false to not sync with other clients or with resource name of the particular client that it should synchronize with synchronize_availability: true, // Set to false to not sync with other clients or with resource name of the particular client that it should synchronize with
use_vcards: true, use_vcards: true,
visible_toolbar_buttons: { visible_toolbar_buttons: {
...@@ -1875,8 +1876,17 @@ ...@@ -1875,8 +1876,17 @@
/* We automatically override all methods and Backbone views and /* We automatically override all methods and Backbone views and
* models that are in the "overrides" namespace. * models that are in the "overrides" namespace.
*/ */
var override = plugin.overrides[key]; var msg,
override = plugin.overrides[key];
if (typeof override === "object") { if (typeof override === "object") {
if (typeof converse[key] === 'undefined') {
msg = "Error: Plugin tried to override "+key+" but it's not found.";
if (converse.strict_plugin_dependencies) {
throw msg;
} else {
converse.log(msg);
}
}
this._extendObject(converse[key], override); this._extendObject(converse[key], override);
} else { } else {
this._overrideAttribute(key, plugin); this._overrideAttribute(key, plugin);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment