git.stg.codes
/
stg.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Handle short string correctly in blowfish encription.
[stg.git]
/
include
/
stg
/
user_property.h
diff --git
a/include/stg/user_property.h
b/include/stg/user_property.h
index f53b416d31845d1164e099fca4c8355e641f14d7..20ca6fd8052fe33336a3c66b89292a6da0462239 100644
(file)
--- a/
include/stg/user_property.h
+++ b/
include/stg/user_property.h
@@
-12,12
+12,14
@@
$Author: faust $
#include <ctime>
#include <string>
#include <set>
#include <ctime>
#include <string>
#include <set>
+#include <map>
#include <sstream>
#include <iostream>
#include "stg/logger.h"
#include "stg/locker.h"
#include "stg/scriptexecuter.h"
#include <sstream>
#include <iostream>
#include "stg/logger.h"
#include "stg/locker.h"
#include "stg/scriptexecuter.h"
+#include "stg/common.h"
#include "store.h"
#include "admin.h"
#include "store.h"
#include "admin.h"
@@
-31,8
+33,10
@@
public:
virtual std::string ToString() const = 0;
};
//-----------------------------------------------------------------------------
virtual std::string ToString() const = 0;
};
//-----------------------------------------------------------------------------
+typedef std::map<std::string, USER_PROPERTY_BASE *> REGISTRY;
+//-----------------------------------------------------------------------------
template<typename varT>
template<typename varT>
-class USER_PROPERTY : USER_PROPERTY_BASE {
+class USER_PROPERTY :
public
USER_PROPERTY_BASE {
public:
USER_PROPERTY(varT & val);
virtual ~USER_PROPERTY();
public:
USER_PROPERTY(varT & val);
virtual ~USER_PROPERTY();
@@
-73,10
+77,11
@@
public:
bool isStat,
STG_LOGGER & logger,
const std::string & sd,
bool isStat,
STG_LOGGER & logger,
const std::string & sd,
-
std::map<std::string, USER_PROPERTY_BASE*>
& properties);
+
REGISTRY
& properties);
virtual ~USER_PROPERTY_LOGGED() {}
USER_PROPERTY_LOGGED<varT> * GetPointer() throw() { return this; }
virtual ~USER_PROPERTY_LOGGED() {}
USER_PROPERTY_LOGGED<varT> * GetPointer() throw() { return this; }
+ const USER_PROPERTY_LOGGED<varT> * GetPointer() const throw() { return this; }
const varT & Get() const { return USER_PROPERTY<varT>::ConstData(); }
const std::string & GetName() const { return name; }
bool Set(const varT & val,
const varT & Get() const { return USER_PROPERTY<varT>::ConstData(); }
const std::string & GetName() const { return name; }
bool Set(const varT & val,
@@
-123,7
+128,7
@@
private:
USER_STAT stat;
USER_CONF conf;
USER_STAT stat;
USER_CONF conf;
-
std::map<std::string, USER_PROPERTY_BASE *> &
properties;
+
REGISTRY
properties;
public:
USER_PROPERTIES(const std::string & sd);
public:
USER_PROPERTIES(const std::string & sd);
@@
-137,6
+142,7
@@
public:
void SetProperties(const USER_PROPERTIES & p) { stat = p.stat; conf = p.conf; }
std::string GetPropertyValue(const std::string & name) const;
void SetProperties(const USER_PROPERTIES & p) { stat = p.stat; conf = p.conf; }
std::string GetPropertyValue(const std::string & name) const;
+ bool Exists(const std::string & name) const;
USER_PROPERTY_LOGGED<double> cash;
USER_PROPERTY_LOGGED<DIR_TRAFF> up;
USER_PROPERTY_LOGGED<double> cash;
USER_PROPERTY_LOGGED<DIR_TRAFF> up;
@@
-209,7
+215,7
@@
template <typename varT>
inline
void USER_PROPERTY<varT>::Set(const varT & rvalue)
{
inline
void USER_PROPERTY<varT>::Set(const varT & rvalue)
{
-STG_LOCKER locker(&mutex
, __FILE__, __LINE__
);
+STG_LOCKER locker(&mutex);
typename std::set<PROPERTY_NOTIFIER_BASE<varT> *>::iterator ni;
typename std::set<PROPERTY_NOTIFIER_BASE<varT> *>::iterator ni;
@@
-239,7
+245,7
@@
template <typename varT>
inline
void USER_PROPERTY<varT>::AddBeforeNotifier(PROPERTY_NOTIFIER_BASE<varT> * n)
{
inline
void USER_PROPERTY<varT>::AddBeforeNotifier(PROPERTY_NOTIFIER_BASE<varT> * n)
{
-STG_LOCKER locker(&mutex
, __FILE__, __LINE__
);
+STG_LOCKER locker(&mutex);
beforeNotifiers.insert(n);
}
//-----------------------------------------------------------------------------
beforeNotifiers.insert(n);
}
//-----------------------------------------------------------------------------
@@
-247,7
+253,7
@@
template <typename varT>
inline
void USER_PROPERTY<varT>::DelBeforeNotifier(const PROPERTY_NOTIFIER_BASE<varT> * n)
{
inline
void USER_PROPERTY<varT>::DelBeforeNotifier(const PROPERTY_NOTIFIER_BASE<varT> * n)
{
-STG_LOCKER locker(&mutex
, __FILE__, __LINE__
);
+STG_LOCKER locker(&mutex);
beforeNotifiers.erase(const_cast<PROPERTY_NOTIFIER_BASE<varT> *>(n));
}
//-----------------------------------------------------------------------------
beforeNotifiers.erase(const_cast<PROPERTY_NOTIFIER_BASE<varT> *>(n));
}
//-----------------------------------------------------------------------------
@@
-255,7
+261,7
@@
template <typename varT>
inline
void USER_PROPERTY<varT>::AddAfterNotifier(PROPERTY_NOTIFIER_BASE<varT> * n)
{
inline
void USER_PROPERTY<varT>::AddAfterNotifier(PROPERTY_NOTIFIER_BASE<varT> * n)
{
-STG_LOCKER locker(&mutex
, __FILE__, __LINE__
);
+STG_LOCKER locker(&mutex);
afterNotifiers.insert(n);
}
//-----------------------------------------------------------------------------
afterNotifiers.insert(n);
}
//-----------------------------------------------------------------------------
@@
-263,7
+269,7
@@
template <typename varT>
inline
void USER_PROPERTY<varT>::DelAfterNotifier(const PROPERTY_NOTIFIER_BASE<varT> * n)
{
inline
void USER_PROPERTY<varT>::DelAfterNotifier(const PROPERTY_NOTIFIER_BASE<varT> * n)
{
-STG_LOCKER locker(&mutex
, __FILE__, __LINE__
);
+STG_LOCKER locker(&mutex);
afterNotifiers.erase(const_cast<PROPERTY_NOTIFIER_BASE<varT> *>(n));
}
//-----------------------------------------------------------------------------
afterNotifiers.erase(const_cast<PROPERTY_NOTIFIER_BASE<varT> *>(n));
}
//-----------------------------------------------------------------------------
@@
-277,7
+283,7
@@
USER_PROPERTY_LOGGED<varT>::USER_PROPERTY_LOGGED(varT & val,
bool isSt,
STG_LOGGER & logger,
const std::string & sd,
bool isSt,
STG_LOGGER & logger,
const std::string & sd,
-
std::map<std::string, USER_PROPERTY_BASE*>
& properties)
+
REGISTRY
& properties)
: USER_PROPERTY<varT>(val),
stgLogger(logger),
: USER_PROPERTY<varT>(val),
stgLogger(logger),
@@
-286,7
+292,7
@@
USER_PROPERTY_LOGGED<varT>::USER_PROPERTY_LOGGED(varT & val,
name(n),
scriptsDir(sd)
{
name(n),
scriptsDir(sd)
{
-properties.insert(std::make_pair(
name
, this));
+properties.insert(std::make_pair(
ToLower(name)
, this));
}
//-------------------------------------------------------------------------
template <typename varT>
}
//-------------------------------------------------------------------------
template <typename varT>
@@
-386,12
+392,19
@@
else
//-------------------------------------------------------------------------
//-------------------------------------------------------------------------
//-------------------------------------------------------------------------
//-------------------------------------------------------------------------
//-------------------------------------------------------------------------
//-------------------------------------------------------------------------
+inline
std::string USER_PROPERTIES::GetPropertyValue(const std::string & name) const
{
std::string USER_PROPERTIES::GetPropertyValue(const std::string & name) const
{
-
std::map<std::string, USER_PROPERTY_BASE*>::iterator it = properties.find(name
);
+
REGISTRY::const_iterator it = properties.find(ToLower(name)
);
if (it == properties.end())
return "";
if (it == properties.end())
return "";
-return it->second.ToString();
+return it->second->ToString();
+}
+//-----------------------------------------------------------------------------
+inline
+bool USER_PROPERTIES::Exists(const std::string & name) const
+{
+return properties.find(ToLower(name)) != properties.end();
}
//-------------------------------------------------------------------------
//-------------------------------------------------------------------------
}
//-------------------------------------------------------------------------
//-------------------------------------------------------------------------
@@
-407,7
+420,7
@@
template<typename varT>
inline
std::string USER_PROPERTY<varT>::ToString() const
{
inline
std::string USER_PROPERTY<varT>::ToString() const
{
-std::stringstream stream;
+std::
o
stringstream stream;
stream << value;
return stream.str();
}
stream << value;
return stream.str();
}