mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 15:56:37 +00:00 
			
		
		
		
	some simplification
This commit is contained in:
		
							parent
							
								
									b37a2ac09c
								
							
						
					
					
						commit
						0dc3d10112
					
				
					 6 changed files with 38 additions and 41 deletions
				
			
		|  | @ -1,16 +1,11 @@ | ||||||
| 
 | 
 | ||||||
| #include "category.hpp" | #include "category.hpp" | ||||||
| 
 | 
 | ||||||
| CSMPrefs::Category::Category (State *parent, const std::string& key, const std::string& name) | CSMPrefs::Category::Category (State *parent, const std::string& key) | ||||||
| : mParent (parent), mKey (key), mName (name) | : mParent (parent), mKey (key) | ||||||
| {} | {} | ||||||
| 
 | 
 | ||||||
| const std::string& CSMPrefs::Category::getKey() const | const std::string& CSMPrefs::Category::getKey() const | ||||||
| { | { | ||||||
|     return mKey; |     return mKey; | ||||||
| } | } | ||||||
| 
 |  | ||||||
| const std::string& CSMPrefs::Category::getName() const |  | ||||||
| { |  | ||||||
|     return mName; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  | @ -11,15 +11,13 @@ namespace CSMPrefs | ||||||
|     { |     { | ||||||
|             State *mParent; |             State *mParent; | ||||||
|             std::string mKey; |             std::string mKey; | ||||||
|             std::string mName; |  | ||||||
| 
 | 
 | ||||||
|         public: |         public: | ||||||
| 
 | 
 | ||||||
|             Category (State *parent, const std::string& key, const std::string& name); |             Category (State *parent, const std::string& key); | ||||||
| 
 | 
 | ||||||
|             const std::string& getKey() const; |             const std::string& getKey() const; | ||||||
| 
 | 
 | ||||||
|             const std::string& getName() const; |  | ||||||
|     }; |     }; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -28,28 +28,28 @@ void CSMPrefs::State::load() | ||||||
| 
 | 
 | ||||||
| void CSMPrefs::State::declare() | void CSMPrefs::State::declare() | ||||||
| { | { | ||||||
|     declareCategory ("window", "Windows"); |     declareCategory ("Windows"); | ||||||
| 
 | 
 | ||||||
|     declareCategory ("records", "Records"); |     declareCategory ("Records"); | ||||||
| 
 | 
 | ||||||
|     declareCategory ("table-input", "ID Tables"); |     declareCategory ("ID Tables"); | ||||||
| 
 | 
 | ||||||
|     declareCategory ("dialogues", "ID Dialogues"); |     declareCategory ("ID Dialogues"); | ||||||
| 
 | 
 | ||||||
|     declareCategory ("report-input", "Reports"); |     declareCategory ("Reports"); | ||||||
| 
 | 
 | ||||||
|     declareCategory ("search", "Search & Replace"); |     declareCategory ("Search & Replace"); | ||||||
| 
 | 
 | ||||||
|     declareCategory ("script-editor", "Scripts"); |     declareCategory ("Scripts"); | ||||||
| 
 | 
 | ||||||
|     declareCategory ("general-input", "General Input"); |     declareCategory ("General Input"); | ||||||
| 
 | 
 | ||||||
|     declareCategory ("scene-input", "3D Scene Input"); |     declareCategory ("3D Scene Input"); | ||||||
| 
 | 
 | ||||||
|     declareCategory ("tooltips", "Tooltips"); |     declareCategory ("Tooltips"); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CSMPrefs::State::declareCategory (const std::string& key, const std::string& name) | void CSMPrefs::State::declareCategory (const std::string& key) | ||||||
| { | { | ||||||
|     std::map<std::string, Category>::iterator iter = mCategories.find (key); |     std::map<std::string, Category>::iterator iter = mCategories.find (key); | ||||||
| 
 | 
 | ||||||
|  | @ -60,7 +60,7 @@ void CSMPrefs::State::declareCategory (const std::string& key, const std::string | ||||||
|     else |     else | ||||||
|     { |     { | ||||||
|         mCurrentCategory = |         mCurrentCategory = | ||||||
|             mCategories.insert (std::make_pair (key, Category (this, key, name))).first; |             mCategories.insert (std::make_pair (key, Category (this, key))).first; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -88,17 +88,14 @@ void CSMPrefs::State::save() | ||||||
|     mSettings.saveUser (user.string()); |     mSettings.saveUser (user.string()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::vector<std::pair<std::string, std::string> > CSMPrefs::State::listCategories() const | CSMPrefs::State::Iterator CSMPrefs::State::begin() | ||||||
| { | { | ||||||
|     std::vector<std::pair<std::string, std::string> > list; |     return mCategories.begin(); | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
|     for (std::map<std::string, Category>::const_iterator iter (mCategories.begin()); | CSMPrefs::State::Iterator CSMPrefs::State::end() | ||||||
|         iter!=mCategories.end(); ++iter) | { | ||||||
|         list.push_back (std::make_pair (iter->second.getName(), iter->first)); |     return mCategories.end(); | ||||||
| 
 |  | ||||||
|     std::sort (list.begin(), list.end()); |  | ||||||
| 
 |  | ||||||
|     return list; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| CSMPrefs::State& CSMPrefs::State::get() | CSMPrefs::State& CSMPrefs::State::get() | ||||||
|  |  | ||||||
|  | @ -22,11 +22,18 @@ namespace CSMPrefs | ||||||
| 
 | 
 | ||||||
|             static State *sThis; |             static State *sThis; | ||||||
| 
 | 
 | ||||||
|  |         public: | ||||||
|  | 
 | ||||||
|  |             typedef std::map<std::string, Category> Collection; | ||||||
|  |             typedef Collection::iterator Iterator; | ||||||
|  | 
 | ||||||
|  |         private: | ||||||
|  | 
 | ||||||
|             const std::string mConfigFile; |             const std::string mConfigFile; | ||||||
|             const Files::ConfigurationManager& mConfigurationManager; |             const Files::ConfigurationManager& mConfigurationManager; | ||||||
|             Settings::Manager mSettings; |             Settings::Manager mSettings; | ||||||
|             std::map<std::string, Category> mCategories; |             Collection mCategories; | ||||||
|             std::map<std::string, Category>::iterator mCurrentCategory; |             Iterator mCurrentCategory; | ||||||
| 
 | 
 | ||||||
|             // not implemented
 |             // not implemented
 | ||||||
|             State (const State&); |             State (const State&); | ||||||
|  | @ -38,7 +45,7 @@ namespace CSMPrefs | ||||||
| 
 | 
 | ||||||
|             void declare(); |             void declare(); | ||||||
| 
 | 
 | ||||||
|             void declareCategory (const std::string& key, const std::string& name); |             void declareCategory (const std::string& key); | ||||||
| 
 | 
 | ||||||
|         public: |         public: | ||||||
| 
 | 
 | ||||||
|  | @ -48,8 +55,9 @@ namespace CSMPrefs | ||||||
| 
 | 
 | ||||||
|             void save(); |             void save(); | ||||||
| 
 | 
 | ||||||
|             /// \return collection of name, key pairs (sorted)
 |             Iterator begin(); | ||||||
|             std::vector<std::pair<std::string, std::string> > listCategories() const; | 
 | ||||||
|  |             Iterator end(); | ||||||
| 
 | 
 | ||||||
|             static State& get(); |             static State& get(); | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|  | @ -24,10 +24,10 @@ void CSVPrefs::Dialogue::buildCategorySelector (QSplitter *main) | ||||||
| 
 | 
 | ||||||
|     int maxWidth = 1; |     int maxWidth = 1; | ||||||
| 
 | 
 | ||||||
|     for (std::vector<std::pair<std::string, std::string> >::const_iterator iter (mCategories.begin()); |     for (CSMPrefs::State::Iterator iter = CSMPrefs::get().begin(); iter!=CSMPrefs::get().end(); | ||||||
|         iter!=mCategories.end(); ++iter) |         ++iter) | ||||||
|     { |     { | ||||||
|         QString label = QString::fromUtf8 (iter->first.c_str()); |         QString label = QString::fromUtf8 (iter->second.getKey().c_str()); | ||||||
|         maxWidth = std::max (maxWidth, metrics.width (label)); |         maxWidth = std::max (maxWidth, metrics.width (label)); | ||||||
| 
 | 
 | ||||||
|         mList->addItem (label); |         mList->addItem (label); | ||||||
|  | @ -46,7 +46,7 @@ void CSVPrefs::Dialogue::buildContentArea (QSplitter *main) | ||||||
|     main->addWidget (mContent); |     main->addWidget (mContent); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| CSVPrefs::Dialogue::Dialogue() : mCategories (CSMPrefs::get().listCategories()) | CSVPrefs::Dialogue::Dialogue() | ||||||
| { | { | ||||||
|     setWindowTitle ("User Settings"); |     setWindowTitle ("User Settings"); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -15,7 +15,6 @@ namespace CSVPrefs | ||||||
| 
 | 
 | ||||||
|             QListWidget *mList; |             QListWidget *mList; | ||||||
|             QStackedWidget *mContent; |             QStackedWidget *mContent; | ||||||
|             std::vector<std::pair<std::string, std::string> > mCategories; |  | ||||||
| 
 | 
 | ||||||
|         private: |         private: | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue