UserDefault::setDelegate

UserDefault very slow, each call need read / write and parse xml file.
Delegate makes it possible to use other variants.
This commit is contained in:
Vladimir Perminov 2015-04-19 22:07:48 +03:00
parent 425b2b62e1
commit 87d0d4f677
4 changed files with 57 additions and 63 deletions

View File

@ -476,12 +476,11 @@ UserDefault* UserDefault::sharedUserDefault()
UserDefault* UserDefault::getInstance() UserDefault* UserDefault::getInstance()
{ {
#ifdef KEEP_COMPATABILITY
initXMLFilePath();
#endif
if (! _userDefault) if (! _userDefault)
{ {
#ifdef KEEP_COMPATABILITY
initXMLFilePath();
#endif
_userDefault = new (std::nothrow) UserDefault(); _userDefault = new (std::nothrow) UserDefault();
} }
@ -490,16 +489,7 @@ UserDefault* UserDefault::getInstance()
bool UserDefault::isXMLFileExist() bool UserDefault::isXMLFileExist()
{ {
FILE *fp = fopen(_filePath.c_str(), "r"); return FileUtils::getInstance()->isFileExist(_filePath);
bool bRet = false;
if (fp)
{
bRet = true;
fclose(fp);
}
return bRet;
} }
void UserDefault::initXMLFilePath() void UserDefault::initXMLFilePath()

View File

@ -476,12 +476,11 @@ void UserDefault::setDataForKey(const char* pKey, const Data& value) {
UserDefault* UserDefault::getInstance() UserDefault* UserDefault::getInstance()
{ {
#ifdef KEEP_COMPATABILITY
initXMLFilePath();
#endif
if (! _userDefault) if (! _userDefault)
{ {
#ifdef KEEP_COMPATABILITY
initXMLFilePath();
#endif
_userDefault = new (std::nothrow) UserDefault(); _userDefault = new (std::nothrow) UserDefault();
} }
@ -507,16 +506,7 @@ void UserDefault::purgeSharedUserDefault()
bool UserDefault::isXMLFileExist() bool UserDefault::isXMLFileExist()
{ {
FILE *fp = fopen(_filePath.c_str(), "r"); return FileUtils::getInstance()->isFileExist(_filePath);
bool bRet = false;
if (fp)
{
bRet = true;
fclose(fp);
}
return bRet;
} }
void UserDefault::initXMLFilePath() void UserDefault::initXMLFilePath()

View File

@ -406,17 +406,17 @@ void UserDefault::setDataForKey(const char* pKey, const Data& value) {
UserDefault* UserDefault::getInstance() UserDefault* UserDefault::getInstance()
{ {
initXMLFilePath(); if (!_userDefault)
// only create xml file one time
// the file exists after the program exit
if ((! isXMLFileExist()) && (! createXMLFile()))
{ {
return nullptr; initXMLFilePath();
}
// only create xml file one time
// the file exists after the program exit
if ((!isXMLFileExist()) && (!createXMLFile()))
{
return nullptr;
}
if (! _userDefault)
{
_userDefault = new (std::nothrow) UserDefault(); _userDefault = new (std::nothrow) UserDefault();
} }
@ -428,6 +428,15 @@ void UserDefault::destroyInstance()
CC_SAFE_DELETE(_userDefault); CC_SAFE_DELETE(_userDefault);
} }
void UserDefault::setDelegate(UserDefault *delegate)
{
if (_userDefault)
delete _userDefault;
_userDefault = delegate;
}
// FIXME:: deprecated // FIXME:: deprecated
UserDefault* UserDefault::sharedUserDefault() UserDefault* UserDefault::sharedUserDefault()
{ {
@ -442,16 +451,7 @@ void UserDefault::purgeSharedUserDefault()
bool UserDefault::isXMLFileExist() bool UserDefault::isXMLFileExist()
{ {
FILE *fp = fopen(_filePath.c_str(), "r"); return FileUtils::getInstance()->isFileExist(_filePath);
bool bRet = false;
if (fp)
{
bRet = true;
fclose(fp);
}
return bRet;
} }
void UserDefault::initXMLFilePath() void UserDefault::initXMLFilePath()

View File

@ -64,7 +64,7 @@ public:
* @param defaultValue The default value to return if the key doesn't exist. * @param defaultValue The default value to return if the key doesn't exist.
* @js NA * @js NA
*/ */
bool getBoolForKey(const char* key, bool defaultValue); virtual bool getBoolForKey(const char* key, bool defaultValue);
/** /**
* Get integer value by key, if the key doesn't exist, will return 0. * Get integer value by key, if the key doesn't exist, will return 0.
@ -82,7 +82,7 @@ public:
* @return Integer value of the key. * @return Integer value of the key.
* @js NA * @js NA
*/ */
int getIntegerForKey(const char* key, int defaultValue); virtual int getIntegerForKey(const char* key, int defaultValue);
/** /**
* Get float value by key, if the key doesn't exist, will return 0.0. * Get float value by key, if the key doesn't exist, will return 0.0.
@ -99,7 +99,7 @@ public:
* @return Float value of the key. * @return Float value of the key.
* @js NA * @js NA
*/ */
float getFloatForKey(const char* key, float defaultValue); virtual float getFloatForKey(const char* key, float defaultValue);
/** /**
* Get double value by key, if the key doesn't exist, will return 0.0. * Get double value by key, if the key doesn't exist, will return 0.0.
@ -116,7 +116,7 @@ public:
* @return Double value of the key. * @return Double value of the key.
* @js NA * @js NA
*/ */
double getDoubleForKey(const char* key, double defaultValue); virtual double getDoubleForKey(const char* key, double defaultValue);
/** /**
* Get string value by key, if the key doesn't exist, will return an empty string. * Get string value by key, if the key doesn't exist, will return an empty string.
@ -133,7 +133,7 @@ public:
* @return String value of the key. * @return String value of the key.
* @js NA * @js NA
*/ */
std::string getStringForKey(const char* key, const std::string & defaultValue); virtual std::string getStringForKey(const char* key, const std::string & defaultValue);
/** /**
* Get Data value by key, if the key doesn't exist, will return an empty Data. * Get Data value by key, if the key doesn't exist, will return an empty Data.
@ -150,7 +150,7 @@ public:
* @return Data value of the key. * @return Data value of the key.
* @js NA * @js NA
*/ */
Data getDataForKey(const char* key, const Data& defaultValue); virtual Data getDataForKey(const char* key, const Data& defaultValue);
// set value methods // set value methods
@ -160,47 +160,47 @@ public:
* @param value A bool value to set to the key. * @param value A bool value to set to the key.
* @js NA * @js NA
*/ */
void setBoolForKey(const char* key, bool value); virtual void setBoolForKey(const char* key, bool value);
/** /**
* Set integer value by key. * Set integer value by key.
* @param key The key to set. * @param key The key to set.
* @param value A integer value to set to the key. * @param value A integer value to set to the key.
* @js NA * @js NA
*/ */
void setIntegerForKey(const char* key, int value); virtual void setIntegerForKey(const char* key, int value);
/** /**
* Set float value by key. * Set float value by key.
* @param key The key to set. * @param key The key to set.
* @param value A float value to set to the key. * @param value A float value to set to the key.
* @js NA * @js NA
*/ */
void setFloatForKey(const char* key, float value); virtual void setFloatForKey(const char* key, float value);
/** /**
* Set double value by key. * Set double value by key.
* @param key The key to set. * @param key The key to set.
* @param value A double value to set to the key. * @param value A double value to set to the key.
* @js NA * @js NA
*/ */
void setDoubleForKey(const char* key, double value); virtual void setDoubleForKey(const char* key, double value);
/** /**
* Set string value by key. * Set string value by key.
* @param key The key to set. * @param key The key to set.
* @param value A string value to set to the key. * @param value A string value to set to the key.
* @js NA * @js NA
*/ */
void setStringForKey(const char* key, const std::string & value); virtual void setStringForKey(const char* key, const std::string & value);
/** /**
* Set Data value by key. * Set Data value by key.
* @param key The key to set. * @param key The key to set.
* @param value A Data value to set to the key. * @param value A Data value to set to the key.
* @js NA * @js NA
*/ */
void setDataForKey(const char* key, const Data& value); virtual void setDataForKey(const char* key, const Data& value);
/** /**
* You should invoke this function to save values set by setXXXForKey(). * You should invoke this function to save values set by setXXXForKey().
* @js NA * @js NA
*/ */
void flush(); virtual void flush();
/** Returns the singleton. /** Returns the singleton.
* @js NA * @js NA
@ -212,6 +212,18 @@ public:
*/ */
static void destroyInstance(); static void destroyInstance();
/**
* You can inherit from platform dependent implementation of UserDefault, such as UserDefaultAndroid,
* and use this function to set delegate, then UserDefault will invoke delegate's implementation.
* For example, your store native data base or other format store.
*
* If you don't want to system default implementation after setting delegate, you can just pass nullptr
* to this function.
*
* @warm It will delete previous delegate
*/
static void setDelegate(UserDefault *delegate);
/** @deprecated Use getInstace() instead. /** @deprecated Use getInstace() instead.
* @js NA * @js NA
* @lua NA * @lua NA
@ -231,10 +243,12 @@ public:
*/ */
static bool isXMLFileExist(); static bool isXMLFileExist();
private: protected:
UserDefault(); UserDefault();
~UserDefault(); ~UserDefault();
private:
static bool createXMLFile(); static bool createXMLFile();
static void initXMLFilePath(); static void initXMLFilePath();