mirror of
https://github.com/eclipse-cdt/cdt
synced 2025-08-05 07:15:39 +02:00
[245918] Allow customization of DStore Preferences
This commit is contained in:
parent
135bdf1c79
commit
8d8b8b2a36
1 changed files with 61 additions and 25 deletions
|
@ -18,15 +18,19 @@
|
||||||
* David McKnight (IBM) - [227406] [dstore] DStoreFileService must listen to buffer size preference changes
|
* David McKnight (IBM) - [227406] [dstore] DStoreFileService must listen to buffer size preference changes
|
||||||
* David McKnight (IBM) - [228334][api][breaking][dstore] Default DataStore connection timeout is too short
|
* David McKnight (IBM) - [228334][api][breaking][dstore] Default DataStore connection timeout is too short
|
||||||
* David McKnight (IBM) - [233160] [dstore] SSL/non-SSL alert are not appropriate
|
* David McKnight (IBM) - [233160] [dstore] SSL/non-SSL alert are not appropriate
|
||||||
|
* Martin Oberhuber (Wind River) - [245918] Allow customization of DStore Preferences
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
|
|
||||||
package org.eclipse.rse.internal.connectorservice.dstore;
|
package org.eclipse.rse.internal.connectorservice.dstore;
|
||||||
|
|
||||||
import org.eclipse.jface.preference.IPreferenceStore;
|
import org.eclipse.core.runtime.Platform;
|
||||||
|
import org.eclipse.core.runtime.preferences.DefaultScope;
|
||||||
|
import org.eclipse.core.runtime.preferences.IEclipsePreferences;
|
||||||
import org.eclipse.rse.connectorservice.dstore.IUniversalDStoreConstants;
|
import org.eclipse.rse.connectorservice.dstore.IUniversalDStoreConstants;
|
||||||
import org.eclipse.rse.ui.ISystemPreferencesConstants;
|
import org.eclipse.rse.ui.ISystemPreferencesConstants;
|
||||||
import org.eclipse.rse.ui.RSEUIPlugin;
|
import org.eclipse.rse.ui.RSEUIPlugin;
|
||||||
import org.eclipse.rse.ui.SystemBasePlugin;
|
import org.eclipse.rse.ui.SystemBasePlugin;
|
||||||
|
import org.eclipse.ui.preferences.ScopedPreferenceStore;
|
||||||
import org.osgi.framework.BundleContext;
|
import org.osgi.framework.BundleContext;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -56,31 +60,63 @@ public class Activator extends SystemBasePlugin {
|
||||||
initializeDefaultPreferences();
|
initializeDefaultPreferences();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A Preference Store that gives direct access to Default Preferences.
|
||||||
|
*/
|
||||||
|
private static class DefaultPreferenceStore extends ScopedPreferenceStore {
|
||||||
|
private IEclipsePreferences[] defaultNodes;
|
||||||
|
public DefaultPreferenceStore(String qualifier) {
|
||||||
|
super(new DefaultScope(), qualifier);
|
||||||
|
defaultNodes = new IEclipsePreferences[] {
|
||||||
|
new DefaultScope().getNode(qualifier) };
|
||||||
|
}
|
||||||
|
public boolean hasDefault(String key) {
|
||||||
|
return Platform.getPreferencesService().get(key, null, defaultNodes) != null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void initializeDefaultPreferences() {
|
public void initializeDefaultPreferences() {
|
||||||
IPreferenceStore store = RSEUIPlugin.getDefault().getPreferenceStore();
|
|
||||||
|
// [245918] Since our Preferences are stored in RSEUIPlugin, we cannot
|
||||||
|
// use the core.runtime.preferences extension in order to do
|
||||||
|
// initialization in the correct order (allow overriding by
|
||||||
|
// plugin_customization.ini). We therefore explicitly check each
|
||||||
|
// Preference slot, and only set a there isn't one set already. Note
|
||||||
|
// that requires explicit access to the DefaultScope().
|
||||||
|
// TODO move Preferences to our own PreferenceStore to simplify this
|
||||||
|
DefaultPreferenceStore store = new DefaultPreferenceStore(RSEUIPlugin.getDefault().getBundle().getSymbolicName());
|
||||||
|
//IPreferenceStore store = RSEUIPlugin.getDefault().getPreferenceStore();
|
||||||
//Preferences store = RSECorePlugin.getDefault().getPluginPreferences();
|
//Preferences store = RSECorePlugin.getDefault().getPluginPreferences();
|
||||||
|
|
||||||
store.setDefault(IUniversalDStoreConstants.RESID_PREF_SOCKET_TIMEOUT, IDStoreDefaultPreferenceConstants.DEFAULT_PREF_SOCKET_TIMEOUT);
|
if (!store.hasDefault(IUniversalDStoreConstants.RESID_PREF_SOCKET_TIMEOUT))
|
||||||
|
store.setDefault(IUniversalDStoreConstants.RESID_PREF_SOCKET_TIMEOUT, IDStoreDefaultPreferenceConstants.DEFAULT_PREF_SOCKET_TIMEOUT);
|
||||||
|
|
||||||
// do keepalive
|
// do keepalive
|
||||||
store.setDefault(IUniversalDStoreConstants.RESID_PREF_DO_KEEPALIVE, IDStoreDefaultPreferenceConstants.DEFAULT_PREF_DO_KEEPALIVE);
|
if (!store.hasDefault(IUniversalDStoreConstants.RESID_PREF_DO_KEEPALIVE))
|
||||||
|
store.setDefault(IUniversalDStoreConstants.RESID_PREF_DO_KEEPALIVE, IDStoreDefaultPreferenceConstants.DEFAULT_PREF_DO_KEEPALIVE);
|
||||||
|
|
||||||
// socket read timeout
|
// socket read timeout
|
||||||
store.setDefault(IUniversalDStoreConstants.RESID_PREF_SOCKET_READ_TIMEOUT, IDStoreDefaultPreferenceConstants.DEFAULT_PREF_SOCKET_READ_TIMEOUT);
|
if (!store.hasDefault(IUniversalDStoreConstants.RESID_PREF_SOCKET_READ_TIMEOUT))
|
||||||
|
store.setDefault(IUniversalDStoreConstants.RESID_PREF_SOCKET_READ_TIMEOUT, IDStoreDefaultPreferenceConstants.DEFAULT_PREF_SOCKET_READ_TIMEOUT);
|
||||||
|
|
||||||
// keepalive response timeout
|
// keepalive response timeout
|
||||||
store.setDefault(IUniversalDStoreConstants.RESID_PREF_KEEPALIVE_RESPONSE_TIMEOUT, IDStoreDefaultPreferenceConstants.DEFAULT_PREF_KEEPALIVE_RESPONSE_TIMEOUT);
|
if (!store.hasDefault(IUniversalDStoreConstants.RESID_PREF_KEEPALIVE_RESPONSE_TIMEOUT))
|
||||||
|
store.setDefault(IUniversalDStoreConstants.RESID_PREF_KEEPALIVE_RESPONSE_TIMEOUT,
|
||||||
|
IDStoreDefaultPreferenceConstants.DEFAULT_PREF_KEEPALIVE_RESPONSE_TIMEOUT);
|
||||||
|
|
||||||
// show mismatched server warning
|
// show mismatched server warning
|
||||||
store.setDefault(IUniversalDStoreConstants.ALERT_MISMATCHED_SERVER, IDStoreDefaultPreferenceConstants.DEFAULT_ALERT_MISMATCHED_SERVER);
|
if (!store.hasDefault(IUniversalDStoreConstants.ALERT_MISMATCHED_SERVER))
|
||||||
|
store.setDefault(IUniversalDStoreConstants.ALERT_MISMATCHED_SERVER, IDStoreDefaultPreferenceConstants.DEFAULT_ALERT_MISMATCHED_SERVER);
|
||||||
|
|
||||||
// cache remote classes
|
// cache remote classes
|
||||||
store.setDefault(IUniversalDStoreConstants.RESID_PREF_CACHE_REMOTE_CLASSES, IDStoreDefaultPreferenceConstants.DEFAULT_PREF_CACHE_REMOTE_CLASSES);
|
if (!store.hasDefault(IUniversalDStoreConstants.RESID_PREF_CACHE_REMOTE_CLASSES))
|
||||||
|
store.setDefault(IUniversalDStoreConstants.RESID_PREF_CACHE_REMOTE_CLASSES, IDStoreDefaultPreferenceConstants.DEFAULT_PREF_CACHE_REMOTE_CLASSES);
|
||||||
|
|
||||||
// alert defaults
|
// alert defaults
|
||||||
store.setDefault(ISystemPreferencesConstants.ALERT_SSL, ISystemPreferencesConstants.DEFAULT_ALERT_SSL);
|
if (!store.hasDefault(ISystemPreferencesConstants.ALERT_SSL))
|
||||||
store.setDefault(ISystemPreferencesConstants.ALERT_NONSSL, ISystemPreferencesConstants.DEFAULT_ALERT_NON_SSL);
|
store.setDefault(ISystemPreferencesConstants.ALERT_SSL, ISystemPreferencesConstants.DEFAULT_ALERT_SSL);
|
||||||
|
if (!store.hasDefault(ISystemPreferencesConstants.ALERT_NONSSL))
|
||||||
|
store.setDefault(ISystemPreferencesConstants.ALERT_NONSSL, ISystemPreferencesConstants.DEFAULT_ALERT_NON_SSL);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Add table
Reference in a new issue