#include "versionlib.h"
#include <map>
-class PreferenceDictionary : public PreferenceSystem {
- class PreferenceEntry {
- Property<const char *> m_cb;
- public:
- PreferenceEntry(const Property<const char *> &cb)
- : m_cb(cb)
- {
- }
-
- void importString(const char *string)
- {
- m_cb.set(string);
- }
-
- void exportString(const Callback<void(const char *)> &importer)
- {
- m_cb.get(importer);
- }
- };
-
- typedef std::map<CopiedString, PreferenceEntry> PreferenceEntries;
- PreferenceEntries m_preferences;
-
- typedef std::map<CopiedString, CopiedString> PreferenceCache;
- PreferenceCache m_cache;
+class PreferenceDictionary : public PreferenceSystem
+{
+class PreferenceEntry
+{
+Property<const char *> m_cb;
+public:
+PreferenceEntry( const Property<const char *>& cb )
+ : m_cb( cb ){
+}
+void importString( const char* string ){
+ m_cb.set( string );
+}
+void exportString( const Callback<void(const char *)> & importer ){
+ m_cb.get( importer );
+}
+};
+
+typedef std::map<CopiedString, PreferenceEntry> PreferenceEntries;
+PreferenceEntries m_preferences;
+
+typedef std::map<CopiedString, CopiedString> PreferenceCache;
+PreferenceCache m_cache;
public:
- typedef PreferenceEntries::iterator iterator;
-
- iterator begin()
- {
- return m_preferences.begin();
- }
-
- iterator end()
- {
- return m_preferences.end();
- }
-
- iterator find(const char *name)
- {
- return m_preferences.find(name);
- }
-
- void registerPreference(const char *name, const Property<const char *> &cb)
- {
- m_preferences.insert(PreferenceEntries::value_type(name, PreferenceEntry(cb)));
- PreferenceCache::iterator i = m_cache.find(name);
- if (i != m_cache.end()) {
- cb.set(i->second.c_str());
- m_cache.erase(i);
- }
- }
-
- void importPref(const char *name, const char *value)
- {
- PreferenceEntries::iterator i = m_preferences.find(name);
- if (i != m_preferences.end()) {
- (*i).second.importString(value);
- } else {
- m_cache.erase(name);
- m_cache.insert(PreferenceCache::value_type(name, value));
- }
- }
+typedef PreferenceEntries::iterator iterator;
+
+iterator begin(){
+ return m_preferences.begin();
+}
+iterator end(){
+ return m_preferences.end();
+}
+iterator find( const char* name ){
+ return m_preferences.find( name );
+}
+
+void registerPreference( const char* name, const Property<const char *>& cb ){
+ m_preferences.insert( PreferenceEntries::value_type( name, PreferenceEntry( cb ) ) );
+ PreferenceCache::iterator i = m_cache.find( name );
+ if ( i != m_cache.end() ) {
+ cb.set( i->second.c_str() );
+ m_cache.erase( i );
+ }
+}
+
+void importPref( const char* name, const char* value ){
+ PreferenceEntries::iterator i = m_preferences.find( name );
+ if ( i != m_preferences.end() ) {
+ ( *i ).second.importString( value );
+ }
+ else
+ {
+ m_cache.erase( name );
+ m_cache.insert( PreferenceCache::value_type( name, value ) );
+ }
+}
+};
+
+inline void XMLPreference_importString( XMLImporter& importer, const char* value ){
+ importer.write( value, string_length( value ) );
+}
+typedef ReferenceCaller<XMLImporter, void(const char*), XMLPreference_importString> XMLPreferenceImportStringCaller;
+
+class XMLPreferenceDictionaryExporter : public XMLExporter
+{
+class XMLQPrefElement : public XMLElement
+{
+const char* m_version;
+public:
+XMLQPrefElement( const char* version ) : m_version( version ){
+}
+const char* name() const {
+ return "qpref";
+}
+const char* attribute( const char* name ) const {
+ if ( string_equal( name, "version" ) ) {
+ return m_version;
+ }
+ return "";
+}
+void forEachAttribute( XMLAttrVisitor& visitor ) const {
+ visitor.visit( "version", m_version );
+}
};
-inline void XMLPreference_importString(XMLImporter &importer, const char *value)
+class XMLPreferenceElement : public XMLElement
{
- importer.write(value, string_length(value));
+const char* m_name;
+public:
+XMLPreferenceElement( const char* name )
+ : m_name( name ){
}
+const char* name() const {
+ return "epair";
+}
+const char* attribute( const char* name ) const {
+ if ( string_equal( name, "name" ) ) {
+ return m_name;
+ }
+ return "";
+}
+void forEachAttribute( XMLAttrVisitor& visitor ) const {
+ visitor.visit( "name", m_name );
+}
+};
-typedef ReferenceCaller<XMLImporter, void(const char *), XMLPreference_importString> XMLPreferenceImportStringCaller;
-
-class XMLPreferenceDictionaryExporter : public XMLExporter {
- class XMLQPrefElement : public XMLElement {
- const char *m_version;
- public:
- XMLQPrefElement(const char *version) : m_version(version)
- {
- }
-
- const char *name() const
- {
- return "qpref";
- }
-
- const char *attribute(const char *name) const
- {
- if (string_equal(name, "version")) {
- return m_version;
- }
- return "";
- }
-
- void forEachAttribute(XMLAttrVisitor &visitor) const
- {
- visitor.visit("version", m_version);
- }
- };
-
- class XMLPreferenceElement : public XMLElement {
- const char *m_name;
- public:
- XMLPreferenceElement(const char *name)
- : m_name(name)
- {
- }
-
- const char *name() const
- {
- return "epair";
- }
-
- const char *attribute(const char *name) const
- {
- if (string_equal(name, "name")) {
- return m_name;
- }
- return "";
- }
-
- void forEachAttribute(XMLAttrVisitor &visitor) const
- {
- visitor.visit("name", m_name);
- }
- };
-
- typedef PreferenceDictionary PreferenceEntries;
- PreferenceEntries &m_preferences;
- const char *m_version;
+typedef PreferenceDictionary PreferenceEntries;
+PreferenceEntries& m_preferences;
+const char* m_version;
public:
- XMLPreferenceDictionaryExporter(PreferenceDictionary &preferences, const char *version)
- : m_preferences(preferences), m_version(version)
- {
- }
+XMLPreferenceDictionaryExporter( PreferenceDictionary& preferences, const char* version )
+ : m_preferences( preferences ), m_version( version ){
+}
- void exportXML(XMLImporter &importer)
- {
- importer.write("\n", 1);
+void exportXML( XMLImporter& importer ){
+ importer.write( "\n", 1 );
- XMLQPrefElement qpref_element(m_version);
- importer.pushElement(qpref_element);
- importer.write("\n", 1);
+ XMLQPrefElement qpref_element( m_version );
+ importer.pushElement( qpref_element );
+ importer.write( "\n", 1 );
- for (PreferenceEntries::iterator i = m_preferences.begin(); i != m_preferences.end(); ++i) {
- XMLPreferenceElement epair_element((*i).first.c_str());
+ for ( PreferenceEntries::iterator i = m_preferences.begin(); i != m_preferences.end(); ++i )
+ {
+ XMLPreferenceElement epair_element( ( *i ).first.c_str() );
- importer.pushElement(epair_element);
+ importer.pushElement( epair_element );
- (*i).second.exportString(XMLPreferenceImportStringCaller(importer));
+ ( *i ).second.exportString( XMLPreferenceImportStringCaller( importer ) );
- importer.popElement(epair_element.name());
- importer.write("\n", 1);
- }
+ importer.popElement( epair_element.name() );
+ importer.write( "\n", 1 );
+ }
- importer.popElement(qpref_element.name());
- importer.write("\n", 1);
- }
+ importer.popElement( qpref_element.name() );
+ importer.write( "\n", 1 );
+}
};
-class XMLPreferenceDictionaryImporter : public XMLImporter {
- struct xml_state_t {
- enum ETag {
- tag_qpref,
- tag_qpref_ignore,
- tag_epair,
- tag_epair_ignore
- };
-
- xml_state_t(ETag tag)
- : m_tag(tag)
- {
- }
-
- ETag m_tag;
- CopiedString m_name;
- StringOutputStream m_ostream;
- };
-
- typedef std::vector<xml_state_t> xml_stack_t;
- xml_stack_t m_xml_stack;
-
- typedef PreferenceDictionary PreferenceEntries;
- PreferenceEntries &m_preferences;
- Version m_version;
+class XMLPreferenceDictionaryImporter : public XMLImporter
+{
+struct xml_state_t
+{
+ enum ETag
+ {
+ tag_qpref,
+ tag_qpref_ignore,
+ tag_epair,
+ tag_epair_ignore
+ };
+
+ xml_state_t( ETag tag )
+ : m_tag( tag ){
+ }
+
+ ETag m_tag;
+ CopiedString m_name;
+ StringOutputStream m_ostream;
+};
+
+typedef std::vector<xml_state_t> xml_stack_t;
+xml_stack_t m_xml_stack;
+
+typedef PreferenceDictionary PreferenceEntries;
+PreferenceEntries& m_preferences;
+Version m_version;
public:
- XMLPreferenceDictionaryImporter(PreferenceDictionary &preferences, const char *version)
- : m_preferences(preferences), m_version(version_parse(version))
- {
- }
-
- void pushElement(const XMLElement &element)
- {
- if (m_xml_stack.empty()) {
- if (string_equal(element.name(), "qpref")) {
- Version dataVersion(version_parse(element.attribute("version")));
- if (!version_compatible(m_version, dataVersion)) {
- globalOutputStream() << "qpref import: data version " << dataVersion
- << " is not compatible with code version " << m_version << "\n";
- m_xml_stack.push_back(xml_state_t::tag_qpref_ignore);
- } else {
- globalOutputStream() << "qpref import: data version " << dataVersion
- << " is compatible with code version " << m_version << "\n";
- m_xml_stack.push_back(xml_state_t::tag_qpref);
- }
- } else {
- // not valid
- }
- } else {
- switch (m_xml_stack.back().m_tag) {
- case xml_state_t::tag_qpref:
- if (string_equal(element.name(), "epair")) {
- m_xml_stack.push_back(xml_state_t::tag_epair);
- m_xml_stack.back().m_name = element.attribute("name");
- } else {
- // not valid
- }
- break;
- case xml_state_t::tag_qpref_ignore:
- if (string_equal(element.name(), "epair")) {
- m_xml_stack.push_back(xml_state_t::tag_epair_ignore);
- } else {
- // not valid
- }
- break;
- case xml_state_t::tag_epair:
- case xml_state_t::tag_epair_ignore:
- // not valid
- break;
- }
- }
-
- }
-
- void popElement(const char *name)
- {
- if (m_xml_stack.back().m_tag == xml_state_t::tag_epair) {
- m_preferences.importPref(m_xml_stack.back().m_name.c_str(), m_xml_stack.back().m_ostream.c_str());
- }
- m_xml_stack.pop_back();
- }
-
- std::size_t write(const char *buffer, std::size_t length)
- {
- return m_xml_stack.back().m_ostream.write(buffer, length);
- }
+XMLPreferenceDictionaryImporter( PreferenceDictionary& preferences, const char* version )
+ : m_preferences( preferences ), m_version( version_parse( version ) ){
+}
+
+void pushElement( const XMLElement& element ){
+ if ( m_xml_stack.empty() ) {
+ if ( string_equal( element.name(), "qpref" ) ) {
+ Version dataVersion( version_parse( element.attribute( "version" ) ) );
+ if ( !version_compatible( m_version, dataVersion ) ) {
+ globalOutputStream() << "qpref import: data version " << dataVersion << " is not compatible with code version " << m_version << "\n";
+ m_xml_stack.push_back( xml_state_t::tag_qpref_ignore );
+ }
+ else
+ {
+ globalOutputStream() << "qpref import: data version " << dataVersion << " is compatible with code version " << m_version << "\n";
+ m_xml_stack.push_back( xml_state_t::tag_qpref );
+ }
+ }
+ else
+ {
+ // not valid
+ }
+ }
+ else
+ {
+ switch ( m_xml_stack.back().m_tag )
+ {
+ case xml_state_t::tag_qpref:
+ if ( string_equal( element.name(), "epair" ) ) {
+ m_xml_stack.push_back( xml_state_t::tag_epair );
+ m_xml_stack.back().m_name = element.attribute( "name" );
+ }
+ else
+ {
+ // not valid
+ }
+ break;
+ case xml_state_t::tag_qpref_ignore:
+ if ( string_equal( element.name(), "epair" ) ) {
+ m_xml_stack.push_back( xml_state_t::tag_epair_ignore );
+ }
+ else
+ {
+ // not valid
+ }
+ break;
+ case xml_state_t::tag_epair:
+ case xml_state_t::tag_epair_ignore:
+ // not valid
+ break;
+ }
+ }
+
+}
+void popElement( const char* name ){
+ if ( m_xml_stack.back().m_tag == xml_state_t::tag_epair ) {
+ m_preferences.importPref( m_xml_stack.back().m_name.c_str(), m_xml_stack.back().m_ostream.c_str() );
+ }
+ m_xml_stack.pop_back();
+}
+std::size_t write( const char* buffer, std::size_t length ){
+ return m_xml_stack.back().m_ostream.write( buffer, length );
+}
};
#endif