public class Config extends Object
.config
, .gitconfig
, .gitmodules
file.Modifier and Type | Class and Description |
---|---|
static interface |
Config.ConfigEnum
Converts enumeration values into configuration options and vice-versa,
allowing to match a config option with an enum value.
|
static interface |
Config.SectionParser<T>
Parses a section of the configuration into an application model object.
|
Constructor and Description |
---|
Config()
Create a configuration with no default fallback.
|
Config(Config defaultConfig)
Create an empty configuration with a fallback for missing keys.
|
Modifier and Type | Method and Description |
---|---|
ListenerHandle |
addChangeListener(ConfigChangedListener listener)
Adds a listener to be notified about changes.
|
protected void |
clear()
Clear the configuration file
|
protected void |
fireConfigChangedEvent()
Notifies the listeners
|
void |
fromText(String text)
Clear this configuration and reset to the contents of the parsed string.
|
<T> T |
get(Config.SectionParser<T> parser)
Obtain a handle to a parsed set of configuration values.
|
boolean |
getBoolean(String section,
String name,
boolean defaultValue)
Get a boolean value from the git config
|
boolean |
getBoolean(String section,
String subsection,
String name,
boolean defaultValue)
Get a boolean value from the git config
|
<T extends Enum<?>> |
getEnum(String section,
String subsection,
String name,
T defaultValue)
Parse an enumeration from the configuration.
|
<T extends Enum<?>> |
getEnum(T[] all,
String section,
String subsection,
String name,
T defaultValue)
Parse an enumeration from the configuration.
|
int |
getInt(String section,
String name,
int defaultValue)
Obtain an integer value from the configuration.
|
int |
getInt(String section,
String subsection,
String name,
int defaultValue)
Obtain an integer value from the configuration.
|
long |
getLong(String section,
String name,
long defaultValue)
Obtain an integer value from the configuration.
|
long |
getLong(String section,
String subsection,
String name,
long defaultValue)
Obtain an integer value from the configuration.
|
Set<String> |
getNames(String section) |
Set<String> |
getNames(String section,
boolean recursive) |
Set<String> |
getNames(String section,
String subsection) |
Set<String> |
getNames(String section,
String subsection,
boolean recursive) |
Set<String> |
getSections() |
String |
getString(String section,
String subsection,
String name)
Get string value or null if not found.
|
String[] |
getStringList(String section,
String subsection,
String name)
Get a list of string values
|
Set<String> |
getSubsections(String section) |
protected boolean |
notifyUponTransientChanges()
Determine whether to issue change events for transient changes.
|
void |
setBoolean(String section,
String subsection,
String name,
boolean value)
Add or modify a configuration value.
|
<T extends Enum<?>> |
setEnum(String section,
String subsection,
String name,
T value)
Add or modify a configuration value.
|
void |
setInt(String section,
String subsection,
String name,
int value)
Add or modify a configuration value.
|
void |
setLong(String section,
String subsection,
String name,
long value)
Add or modify a configuration value.
|
void |
setString(String section,
String subsection,
String name,
String value)
Add or modify a configuration value.
|
void |
setStringList(String section,
String subsection,
String name,
List<String> values)
Set a configuration value.
|
String |
toText() |
void |
uncache(Config.SectionParser<?> parser)
Remove a cached configuration object.
|
void |
unset(String section,
String subsection,
String name)
Remove a configuration value.
|
void |
unsetSection(String section,
String subsection)
Remove all configuration values under a single section.
|
public Config()
public Config(Config defaultConfig)
defaultConfig
- the base configuration to be consulted when a key is missing
from this configuration instance.public int getInt(String section, String name, int defaultValue)
section
- section the key is grouped within.name
- name of the key to get.defaultValue
- default value to return if no value was present.public int getInt(String section, String subsection, String name, int defaultValue)
section
- section the key is grouped within.subsection
- subsection name, such a remote or branch name.name
- name of the key to get.defaultValue
- default value to return if no value was present.public long getLong(String section, String name, long defaultValue)
section
- section the key is grouped within.name
- name of the key to get.defaultValue
- default value to return if no value was present.public long getLong(String section, String subsection, String name, long defaultValue)
section
- section the key is grouped within.subsection
- subsection name, such a remote or branch name.name
- name of the key to get.defaultValue
- default value to return if no value was present.public boolean getBoolean(String section, String name, boolean defaultValue)
section
- section the key is grouped within.name
- name of the key to get.defaultValue
- default value to return if no value was present.public boolean getBoolean(String section, String subsection, String name, boolean defaultValue)
section
- section the key is grouped within.subsection
- subsection name, such a remote or branch name.name
- name of the key to get.defaultValue
- default value to return if no value was present.public <T extends Enum<?>> T getEnum(String section, String subsection, String name, T defaultValue)
T
- type of the enumeration object.section
- section the key is grouped within.subsection
- subsection name, such a remote or branch name.name
- name of the key to get.defaultValue
- default value to return if no value was present.defaultValue
.public <T extends Enum<?>> T getEnum(T[] all, String section, String subsection, String name, T defaultValue)
T
- type of the enumeration object.all
- all possible values in the enumeration which should be
recognized. Typically EnumType.values()
.section
- section the key is grouped within.subsection
- subsection name, such a remote or branch name.name
- name of the key to get.defaultValue
- default value to return if no value was present.defaultValue
.public String getString(String section, String subsection, String name)
section
- the sectionsubsection
- the subsection for the valuename
- the key namenull
if not foundpublic String[] getStringList(String section, String subsection, String name)
If this instance was created with a base, the base's values are returned first (if any).
section
- the sectionsubsection
- the subsection for the valuename
- the key namepublic Set<String> getSubsections(String section)
section
- section to search for.public Set<String> getSections()
Config
. The set's iterator
returns sections in the order they are declared by the
configuration starting from this instance and progressing through
the base.public Set<String> getNames(String section)
section
- the sectionpublic Set<String> getNames(String section, String subsection)
section
- the sectionsubsection
- the subsectionpublic Set<String> getNames(String section, boolean recursive)
section
- the sectionrecursive
- if true
recursively adds the names defined in all base
configurationspublic Set<String> getNames(String section, String subsection, boolean recursive)
section
- the sectionsubsection
- the subsectionrecursive
- if true
recursively adds the names defined in all base
configurationspublic <T> T get(Config.SectionParser<T> parser)
T
- type of configuration model to return.parser
- parser which can create the model if it is not already
available in this configuration file. The parser is also used
as the key into a cache and must obey the hashCode and equals
contract in order to reuse a parsed model.public void uncache(Config.SectionParser<?> parser)
If the associated configuration object has not yet been cached, this method has no effect.
parser
- parser used to obtain the configuration object.get(SectionParser)
public ListenerHandle addChangeListener(ConfigChangedListener listener)
Clients are supposed to remove the listeners after they are done with
them using the ListenerHandle.remove()
method
listener
- the listenerprotected boolean notifyUponTransientChanges()
If true
is returned (which is the default behavior),
fireConfigChangedEvent()
will be called upon each change.
Subclasses that override this to return false
are
responsible for issuing fireConfigChangedEvent()
calls
themselves.
protected void fireConfigChangedEvent()
public void setInt(String section, String subsection, String name, int value)
[section "subsection"] name = value
section
- section name, e.g "branch"subsection
- optional subsection value, e.g. a branch namename
- parameter name, e.g. "filemode"value
- parameter valuepublic void setLong(String section, String subsection, String name, long value)
[section "subsection"] name = value
section
- section name, e.g "branch"subsection
- optional subsection value, e.g. a branch namename
- parameter name, e.g. "filemode"value
- parameter valuepublic void setBoolean(String section, String subsection, String name, boolean value)
[section "subsection"] name = value
section
- section name, e.g "branch"subsection
- optional subsection value, e.g. a branch namename
- parameter name, e.g. "filemode"value
- parameter valuepublic <T extends Enum<?>> void setEnum(String section, String subsection, String name, T value)
[section "subsection"] name = value
T
- type of the enumeration object.section
- section name, e.g "branch"subsection
- optional subsection value, e.g. a branch namename
- parameter name, e.g. "filemode"value
- parameter valuepublic void setString(String section, String subsection, String name, String value)
[section "subsection"] name = value
section
- section name, e.g "branch"subsection
- optional subsection value, e.g. a branch namename
- parameter name, e.g. "filemode"value
- parameter value, e.g. "true"public void unset(String section, String subsection, String name)
section
- section name, e.g "branch"subsection
- optional subsection value, e.g. a branch namename
- parameter name, e.g. "filemode"public void unsetSection(String section, String subsection)
section
- section name, e.g "branch"subsection
- optional subsection value, e.g. a branch namepublic void setStringList(String section, String subsection, String name, List<String> values)
[section "subsection"] name = value
section
- section name, e.g "branch"subsection
- optional subsection value, e.g. a branch namename
- parameter name, e.g. "filemode"values
- list of zero or more values for this key.public String toText()
public void fromText(String text) throws ConfigInvalidException
text
- Git style text file listing configuration properties.ConfigInvalidException
- the text supplied is not formatted correctly. No changes were
made to this
.protected void clear()
Copyright © 2016 Eclipse JGit Project. All rights reserved.