亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? algparam.h

?? 加密函數庫:包括多種加密解密算法,數字簽名,散列算法
?? H
字號:
#ifndef CRYPTOPP_ALGPARAM_H
#define CRYPTOPP_ALGPARAM_H

#include "cryptlib.h"
#include "smartptr.h"
#include "secblock.h"

NAMESPACE_BEGIN(CryptoPP)

//! used to pass byte array input as part of a NameValuePairs object
/*! the deepCopy option is used when the NameValuePairs object can't
	keep a copy of the data available */
class ConstByteArrayParameter
{
public:
	ConstByteArrayParameter(const char *data = NULL, bool deepCopy = false)
	{
		Assign((const byte *)data, data ? strlen(data) : 0, deepCopy);
	}
	ConstByteArrayParameter(const byte *data, unsigned int size, bool deepCopy = false)
	{
		Assign(data, size, deepCopy);
	}
	template <class T> ConstByteArrayParameter(const T &string, bool deepCopy = false)
	{
		CRYPTOPP_COMPILE_ASSERT(sizeof(string[0])==1);
		Assign((const byte *)string.data(), string.size(), deepCopy);
	}

	void Assign(const byte *data, unsigned int size, bool deepCopy)
	{
		if (deepCopy)
			m_block.Assign(data, size);
		else
		{
			m_data = data;
			m_size = size;
		}
		m_deepCopy = deepCopy;
	}

	const byte *begin() const {return m_deepCopy ? m_block.begin() : m_data;}
	const byte *end() const {return m_deepCopy ? m_block.end() : m_data + m_size;}
	unsigned int size() const {return m_deepCopy ? m_block.size() : m_size;}

private:
	bool m_deepCopy;
	const byte *m_data;
	unsigned int m_size;
	SecByteBlock m_block;
};

class ByteArrayParameter
{
public:
	ByteArrayParameter(byte *data = NULL, unsigned int size = 0)
		: m_data(data), m_size(size) {}
	ByteArrayParameter(SecByteBlock &block)
		: m_data(block.begin()), m_size(block.size()) {}

	byte *begin() const {return m_data;}
	byte *end() const {return m_data + m_size;}
	unsigned int size() const {return m_size;}

private:
	byte *m_data;
	unsigned int m_size;
};

class CombinedNameValuePairs : public NameValuePairs
{
public:
	CombinedNameValuePairs(const NameValuePairs &pairs1, const NameValuePairs &pairs2)
		: m_pairs1(pairs1), m_pairs2(pairs2) {}

	bool GetVoidValue(const char *name, const std::type_info &valueType, void *pValue) const
	{
		if (strcmp(name, "ValueNames") == 0)
			return m_pairs1.GetVoidValue(name, valueType, pValue) && m_pairs2.GetVoidValue(name, valueType, pValue);
		else
			return m_pairs1.GetVoidValue(name, valueType, pValue) || m_pairs2.GetVoidValue(name, valueType, pValue);
	}

	const NameValuePairs &m_pairs1, &m_pairs2;
};

template <class T, class BASE>
class GetValueHelperClass
{
public:
	GetValueHelperClass(const T *pObject, const char *name, const std::type_info &valueType, void *pValue, const NameValuePairs *searchFirst)
		: m_pObject(pObject), m_name(name), m_valueType(&valueType), m_pValue(pValue), m_found(false), m_getValueNames(false)
	{
		if (strcmp(m_name, "ValueNames") == 0)
		{
			m_found = m_getValueNames = true;
			NameValuePairs::ThrowIfTypeMismatch(m_name, typeid(std::string), *m_valueType);
			if (searchFirst)
				searchFirst->GetVoidValue(m_name, valueType, pValue);
			if (typeid(T) != typeid(BASE))
				pObject->BASE::GetVoidValue(m_name, valueType, pValue);
			((*reinterpret_cast<std::string *>(m_pValue) += "ThisPointer:") += typeid(T).name()) += ';';
		}

		if (!m_found && strncmp(m_name, "ThisPointer:", 12) == 0 && strcmp(m_name+12, typeid(T).name()) == 0)
		{
			NameValuePairs::ThrowIfTypeMismatch(m_name, typeid(T *), *m_valueType);
			*reinterpret_cast<const T **>(pValue) = pObject;
			m_found = true;
			return;
		}

		if (!m_found && searchFirst)
			m_found = searchFirst->GetVoidValue(m_name, valueType, pValue);
		
		if (!m_found && typeid(T) != typeid(BASE))
			m_found = pObject->BASE::GetVoidValue(m_name, valueType, pValue);
	}

	operator bool() const {return m_found;}

	template <class R>
	GetValueHelperClass<T,BASE> & operator()(const char *name, const R & (T::*pm)() const)
	{
		if (m_getValueNames)
			(*reinterpret_cast<std::string *>(m_pValue) += name) += ";";
		if (!m_found && strcmp(name, m_name) == 0)
		{
			NameValuePairs::ThrowIfTypeMismatch(name, typeid(R), *m_valueType);
			*reinterpret_cast<R *>(m_pValue) = (m_pObject->*pm)();
			m_found = true;
		}
		return *this;
	}

	GetValueHelperClass<T,BASE> &Assignable()
	{
		if (m_getValueNames)
			((*reinterpret_cast<std::string *>(m_pValue) += "ThisObject:") += typeid(T).name()) += ';';
		if (!m_found && strncmp(m_name, "ThisObject:", 11) == 0 && strcmp(m_name+11, typeid(T).name()) == 0)
		{
			NameValuePairs::ThrowIfTypeMismatch(m_name, typeid(T), *m_valueType);
			*reinterpret_cast<T *>(m_pValue) = *m_pObject;
			m_found = true;
		}
		return *this;
	}

private:
	const T *m_pObject;
	const char *m_name;
	const std::type_info *m_valueType;
	void *m_pValue;
	bool m_found, m_getValueNames;
};

template <class BASE, class T>
GetValueHelperClass<T, BASE> GetValueHelper(const T *pObject, const char *name, const std::type_info &valueType, void *pValue, const NameValuePairs *searchFirst=NULL, BASE *dummy=NULL)
{
	return GetValueHelperClass<T, BASE>(pObject, name, valueType, pValue, searchFirst);
}

template <class T>
GetValueHelperClass<T, T> GetValueHelper(const T *pObject, const char *name, const std::type_info &valueType, void *pValue, const NameValuePairs *searchFirst=NULL)
{
	return GetValueHelperClass<T, T>(pObject, name, valueType, pValue, searchFirst);
}

// ********************************************************

template <class R>
R Hack_DefaultValueFromConstReferenceType(const R &)
{
	return R();
}

template <class R>
bool Hack_GetValueIntoConstReference(const NameValuePairs &source, const char *name, const R &value)
{
	return source.GetValue(name, const_cast<R &>(value));
}

template <class T, class BASE>
class AssignFromHelperClass
{
public:
	AssignFromHelperClass(T *pObject, const NameValuePairs &source)
		: m_pObject(pObject), m_source(source), m_done(false)
	{
		if (source.GetThisObject(*pObject))
			m_done = true;
		else if (typeid(BASE) != typeid(T))
			pObject->BASE::AssignFrom(source);
	}

	template <class R>
	AssignFromHelperClass & operator()(const char *name, void (T::*pm)(R))	// VC60 workaround: "const R &" here causes compiler error
	{
		if (!m_done)
		{
			R value = Hack_DefaultValueFromConstReferenceType(reinterpret_cast<R>(*(int *)NULL));
			if (!Hack_GetValueIntoConstReference(m_source, name, value))
				throw InvalidArgument(std::string(typeid(T).name()) + ": Missing required parameter '" + name + "'");
			(m_pObject->*pm)(value);
		}
		return *this;
	}

	template <class R, class S>
	AssignFromHelperClass & operator()(const char *name1, const char *name2, void (T::*pm)(R, S))	// VC60 workaround: "const R &" here causes compiler error
	{
		if (!m_done)
		{
			R value1 = Hack_DefaultValueFromConstReferenceType(reinterpret_cast<R>(*(int *)NULL));
			if (!Hack_GetValueIntoConstReference(m_source, name1, value1))
				throw InvalidArgument(std::string(typeid(T).name()) + ": Missing required parameter '" + name1 + "'");
			S value2 = Hack_DefaultValueFromConstReferenceType(reinterpret_cast<S>(*(int *)NULL));
			if (!Hack_GetValueIntoConstReference(m_source, name2, value2))
				throw InvalidArgument(std::string(typeid(T).name()) + ": Missing required parameter '" + name2 + "'");
			(m_pObject->*pm)(value1, value2);
		}
		return *this;
	}

private:
	T *m_pObject;
	const NameValuePairs &m_source;
	bool m_done;
};

template <class BASE, class T>
AssignFromHelperClass<T, BASE> AssignFromHelper(T *pObject, const NameValuePairs &source, BASE *dummy=NULL)
{
	return AssignFromHelperClass<T, BASE>(pObject, source);
}

template <class T>
AssignFromHelperClass<T, T> AssignFromHelper(T *pObject, const NameValuePairs &source)
{
	return AssignFromHelperClass<T, T>(pObject, source);
}

// ********************************************************

// This should allow the linker to discard Integer code if not needed.
extern bool (*AssignIntToInteger)(const std::type_info &valueType, void *pInteger, const void *pInt);

const std::type_info & IntegerTypeId();

template <class BASE, class T>
class AlgorithmParameters : public NameValuePairs
{
public:
	AlgorithmParameters(const BASE &base, const char *name, const T &value)
		: m_base(base), m_name(name), m_value(value)
#ifndef NDEBUG
		, m_used(false)
#endif
	{}

#ifndef NDEBUG
	AlgorithmParameters(const AlgorithmParameters &copy)
		: m_base(copy.m_base), m_name(copy.m_name), m_value(copy.m_value), m_used(false)
	{
		copy.m_used = true;
	}

	// TODO: revisit after implementing some tracing mechanism, this won't work because of exceptions
//	~AlgorithmParameters() {assert(m_used);}	// use assert here because we don't want to throw out of a destructor
#endif

	template <class R>
	AlgorithmParameters<AlgorithmParameters<BASE,T>, R> operator()(const char *name, const R &value) const
	{
		return AlgorithmParameters<AlgorithmParameters<BASE,T>, R>(*this, name, value);
	}

	bool GetVoidValue(const char *name, const std::type_info &valueType, void *pValue) const
	{
		if (strcmp(name, "ValueNames") == 0)
		{
			ThrowIfTypeMismatch(name, typeid(std::string), valueType);
			m_base.GetVoidValue(name, valueType, pValue);
			(*reinterpret_cast<std::string *>(pValue) += m_name) += ";";
			return true;
		}
		else if (strcmp(name, m_name) == 0)
		{
			// special case for retrieving an Integer parameter when an int was passed in
			if (!(AssignIntToInteger != NULL && typeid(T) == typeid(int) && AssignIntToInteger(valueType, pValue, &m_value)))
			{
				ThrowIfTypeMismatch(name, typeid(T), valueType);
				*reinterpret_cast<T *>(pValue) = m_value;
			}
#ifndef NDEBUG
			m_used = true;
#endif
			return true;
		}
		else
			return m_base.GetVoidValue(name, valueType, pValue);
	}

private:
	BASE m_base;
	const char *m_name;
	T m_value;
#ifndef NDEBUG
	mutable bool m_used;
#endif
};

template <class T>
AlgorithmParameters<NullNameValuePairs,T> MakeParameters(const char *name, const T &value)
{
	return AlgorithmParameters<NullNameValuePairs,T>(g_nullNameValuePairs, name, value);
}

#define CRYPTOPP_GET_FUNCTION_ENTRY(name)		(Name::name(), &ThisClass::Get##name)
#define CRYPTOPP_SET_FUNCTION_ENTRY(name)		(Name::name(), &ThisClass::Set##name)
#define CRYPTOPP_SET_FUNCTION_ENTRY2(name1, name2)	(Name::name1(), Name::name2(), &ThisClass::Set##name1##And##name2)

NAMESPACE_END

#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
爽好多水快深点欧美视频| 成人av在线影院| 99久久综合国产精品| 欧美日韩在线观看一区二区| wwwwxxxxx欧美| 亚洲一区二区三区视频在线播放| 国产在线精品不卡| 91精品国产色综合久久ai换脸 | 成人激情综合网站| 5566中文字幕一区二区电影| 中文字幕日韩一区| 丰满亚洲少妇av| 久久精品男人的天堂| 美女视频黄 久久| 884aa四虎影成人精品一区| 国产精品久久久久婷婷| 精品一二三四区| 欧美一区二区观看视频| 午夜精品久久久| 在线视频国产一区| 亚洲欧美在线高清| 成人av在线影院| 国产精品乱人伦中文| 国产91丝袜在线播放0| 精品播放一区二区| 欧美a级一区二区| 欧美精品粉嫩高潮一区二区| 亚洲精品国产第一综合99久久 | 国产精品资源在线观看| 欧美大尺度电影在线| 午夜精品福利一区二区三区av| 欧洲av一区二区嗯嗯嗯啊| 一区二区久久久久久| 欧美天天综合网| 日韩综合一区二区| 欧美一区二区三区在线观看视频| 午夜激情一区二区| 欧美一区二区三区的| 看片的网站亚洲| 久久久久久久久久久黄色| 国产成人一区二区精品非洲| 亚洲国产精品成人综合| www.视频一区| 一区二区三国产精华液| 7777精品久久久大香线蕉| 久久精品国产亚洲一区二区三区| 精品国产乱码久久久久久免费| 激情综合五月天| 国产精品色在线| 在线亚洲一区观看| 久久国产欧美日韩精品| 国产亚洲欧美日韩日本| 91视频在线观看| 亚洲国产精品久久久久婷婷884| 欧美精品18+| 国产福利一区二区三区视频| 一区二区三区在线高清| 日韩一区二区在线播放| 国产成人aaaa| 亚洲第一福利视频在线| 日韩精品综合一本久道在线视频| 高清在线不卡av| 亚洲亚洲精品在线观看| 精品国产第一区二区三区观看体验| 粉嫩在线一区二区三区视频| 一区二区三区不卡视频在线观看 | 亚洲美女视频一区| 日韩美女视频在线| 91在线免费播放| 久久精品免费观看| 夜夜精品视频一区二区 | 日韩一级欧美一级| 成人丝袜18视频在线观看| 亚洲一区二区三区四区不卡| 久久综合色8888| 欧美日韩一区二区在线观看视频 | 日本亚洲欧美天堂免费| 国产精品第五页| 欧美精品一区二区三区蜜桃视频| 成人中文字幕合集| 老鸭窝一区二区久久精品| 亚洲精品国产视频| 亚洲国产高清aⅴ视频| 6080yy午夜一二三区久久| 99久久伊人精品| 久久国内精品自在自线400部| 亚洲啪啪综合av一区二区三区| 精品国产伦理网| 欧美一区二区三区视频免费 | 成人免费高清在线观看| 看电视剧不卡顿的网站| 性做久久久久久| 亚洲精品高清视频在线观看| 欧美国产成人精品| 久久久亚洲精品一区二区三区 | 捆绑紧缚一区二区三区视频| 一区二区视频在线看| 亚洲国产精品ⅴa在线观看| 日韩精品一区二区三区视频在线观看| 一本一道久久a久久精品| 国产**成人网毛片九色| 国产制服丝袜一区| 久久国产精品露脸对白| 全部av―极品视觉盛宴亚洲| 亚洲综合视频网| 亚洲欧美激情插| 亚洲色图在线视频| 亚洲日本va午夜在线影院| 国产人妖乱国产精品人妖| 久久久久久久久久看片| xfplay精品久久| 337p日本欧洲亚洲大胆色噜噜| 日韩一级视频免费观看在线| 日韩午夜激情av| 欧美大片一区二区| 久久综合九色欧美综合狠狠| 精品少妇一区二区三区视频免付费 | 欧美国产一区在线| 中文字幕成人网| 国产精品国产三级国产a| 国产欧美日韩综合精品一区二区| 久久久精品黄色| 18欧美乱大交hd1984| 一区二区三区四区亚洲| 亚洲午夜视频在线| 日日夜夜一区二区| 日本vs亚洲vs韩国一区三区二区| 日韩在线观看一区二区| 久久精品国产免费| 韩国三级电影一区二区| 懂色av一区二区夜夜嗨| 成人激情av网| 91黄色免费看| 91精品国产综合久久福利软件| 日韩欧美国产麻豆| 国产欧美精品一区二区三区四区| 国产精品你懂的| 五月婷婷综合在线| 国内精品免费**视频| av在线综合网| 欧美日韩成人综合在线一区二区| 欧美不卡激情三级在线观看| 中文字幕精品一区| 性做久久久久久免费观看| 久久福利视频一区二区| 91在线视频免费观看| 欧美一区二区在线免费播放| 中文幕一区二区三区久久蜜桃| 玉足女爽爽91| 韩国v欧美v日本v亚洲v| 在线亚洲欧美专区二区| 日韩一区二区三区av| 国产精品二三区| 日本免费在线视频不卡一不卡二| 国产成人精品一区二区三区四区| 91国产福利在线| 久久美女艺术照精彩视频福利播放| 亚洲品质自拍视频| 韩国毛片一区二区三区| 欧美亚洲国产一区在线观看网站| xnxx国产精品| 婷婷开心激情综合| 91麻豆视频网站| 日本一区二区三区四区在线视频| 亚洲第一av色| a级精品国产片在线观看| 日韩一区二区三区在线| 一区二区三区免费看视频| 国产麻豆精品95视频| 91精品国产综合久久久久久| 国产精品麻豆网站| 国产裸体歌舞团一区二区| 欧美精品色综合| 亚洲精品国产一区二区精华液| 国产精品888| 欧美mv和日韩mv的网站| 亚洲第一电影网| 欧美性猛交一区二区三区精品| 中文字幕欧美日韩一区| 国产精品乡下勾搭老头1| 91精品午夜视频| 视频精品一区二区| 日本精品裸体写真集在线观看| 中文字幕制服丝袜成人av| 国产一区二区免费看| 日韩视频免费观看高清完整版在线观看 | 欧美在线一二三| 最近中文字幕一区二区三区| 国产经典欧美精品| 精品国产sm最大网站免费看| 麻豆精品精品国产自在97香蕉| 91.麻豆视频| 丝袜a∨在线一区二区三区不卡| 在线观看欧美黄色| 亚洲一区二区影院| 欧美中文字幕亚洲一区二区va在线| 亚洲女子a中天字幕| 91香蕉视频污| 亚洲乱码中文字幕| 一本色道久久综合亚洲aⅴ蜜桃|