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

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

?? algparam.h

?? 研讀AxCrypt對加解密的處理方法
?? 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(CPP_TYPENAME T::value_type) == 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 CRYPTOPP_DLL 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;

private:
	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.
CRYPTOPP_DLL extern bool (*AssignIntToInteger)(const std::type_info &valueType, void *pInteger, const void *pInt);

CRYPTOPP_DLL const std::type_info & IntegerTypeId();

class CRYPTOPP_DLL AlgorithmParametersBase : public NameValuePairs
{
public:
	class ParameterNotUsed : public Exception
	{
	public: 
		ParameterNotUsed(const char *name) : Exception(OTHER_ERROR, std::string("AlgorithmParametersBase: parameter \"") + name + "\" not used") {}
	};

	AlgorithmParametersBase(const char *name, bool throwIfNotUsed)
		: m_name(name), m_throwIfNotUsed(throwIfNotUsed), m_used(false) {}

	~AlgorithmParametersBase()
	{
#ifdef CRYPTOPP_UNCAUGHT_EXCEPTION_AVAILABLE
		if (!std::uncaught_exception())
#else
		try
#endif
		{
			if (m_throwIfNotUsed && !m_used)
				throw ParameterNotUsed(m_name);
		}
#ifndef CRYPTOPP_UNCAUGHT_EXCEPTION_AVAILABLE
		catch(...)
		{
		}
#endif
	}

	bool GetVoidValue(const char *name, const std::type_info &valueType, void *pValue) const;

protected:
	virtual void AssignValue(const char *name, const std::type_info &valueType, void *pValue) const =0;
	virtual const NameValuePairs & GetParent() const =0;

	const char *m_name;
	bool m_throwIfNotUsed;
	mutable bool m_used;
};

template <class T>
class AlgorithmParametersBase2 : public AlgorithmParametersBase
{
public:
	AlgorithmParametersBase2(const char *name, const T &value, bool throwIfNotUsed) : AlgorithmParametersBase(name, throwIfNotUsed), m_value(value) {}

	void AssignValue(const char *name, const std::type_info &valueType, void *pValue) const
	{
		// 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;
		}
	}

protected:
	T m_value;
};

template <class PARENT, class T>
class AlgorithmParameters : public AlgorithmParametersBase2<T>
{
public:
	AlgorithmParameters(const PARENT &parent, const char *name, const T &value, bool throwIfNotUsed)
		: AlgorithmParametersBase2<T>(name, value, throwIfNotUsed), m_parent(parent)
	{}

	AlgorithmParameters(const AlgorithmParameters &copy)
		: AlgorithmParametersBase2<T>(copy), m_parent(copy.m_parent)
	{
		copy.m_used = true;
	}

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

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

private:
	const NameValuePairs & GetParent() const {return m_parent;}
	PARENT m_parent;
};

//! Create an object that implements NameValuePairs for passing parameters
/*! \param throwIfNotUsed if true, the object will throw an exception if the value is not accessed
	\note throwIfNotUsed is ignored if using a compiler that does not support std::uncaught_exception(),
	such as MSVC 7.0 and earlier.
	\note A NameValuePairs object containing an arbitrary number of name value pairs may be constructed by
	repeatedly using operator() on the object returned by MakeParameters, for example:
	const NameValuePairs &parameters = MakeParameters(name1, value1)(name2, value2)(name3, value3);
*/
template <class T>
AlgorithmParameters<NullNameValuePairs,T> MakeParameters(const char *name, const T &value, bool throwIfNotUsed = true)
{
	return AlgorithmParameters<NullNameValuePairs,T>(g_nullNameValuePairs, name, value, throwIfNotUsed);
}

#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一区二区三区免费野_久草精品视频
国产欧美一区二区三区沐欲| 蜜臀精品久久久久久蜜臀 | 日韩一区二区免费高清| 久久午夜羞羞影院免费观看| 一区二区三区高清在线| 国内精品国产成人国产三级粉色 | 亚洲一区在线播放| 成人午夜视频免费看| 在线不卡中文字幕播放| 亚洲欧美在线视频| 国产激情视频一区二区在线观看 | 亚洲青青青在线视频| 国产一区欧美二区| 91精品免费观看| 玉米视频成人免费看| 99久久精品国产网站| 欧美国产一区在线| 韩国av一区二区| 精品99999| 久久av老司机精品网站导航| 91精品久久久久久蜜臀| 午夜精品一区二区三区免费视频 | 久久国产剧场电影| 在线播放中文字幕一区| 亚洲福利视频一区二区| 91搞黄在线观看| 亚洲免费在线播放| 99国产精品99久久久久久| 国产精品天干天干在线综合| 国产乱码精品一区二区三区五月婷| 日韩美女一区二区三区四区| 美女视频一区二区| 日韩三级中文字幕| 韩国v欧美v日本v亚洲v| 国产亚洲制服色| 成人激情小说网站| 国产精品久久久久影视| 不卡一区在线观看| 一区二区三区中文字幕电影| 日本道在线观看一区二区| 一区二区三区四区激情| 日韩伦理电影网| 一本到不卡免费一区二区| 夜色激情一区二区| 91精品久久久久久久91蜜桃| 国产在线一区二区| 中文字幕一区二区三| 色综合久久六月婷婷中文字幕| 亚洲一区在线视频观看| 日韩无一区二区| 国产精品18久久久| 亚洲蜜臀av乱码久久精品蜜桃| 欧美亚洲综合网| 日本aⅴ亚洲精品中文乱码| 精品久久一区二区| 99久久国产免费看| 亚洲高清免费观看高清完整版在线观看 | 欧美精品v国产精品v日韩精品| 奇米综合一区二区三区精品视频| 久久久三级国产网站| 91浏览器入口在线观看| 日本成人在线网站| 中文字幕一区二区三区不卡在线| 欧美日韩久久一区| 福利视频网站一区二区三区| 亚洲精品国产精华液| 精品国产乱码久久久久久免费 | 欧美另类z0zxhd电影| 国产精品资源在线| 亚洲午夜精品网| 久久久久久久久免费| 欧美在线视频不卡| 国产精品一区二区在线观看不卡| 亚洲日本乱码在线观看| 精品国产污网站| 欧美私人免费视频| 国产精品白丝av| 视频一区视频二区中文| 国产精品第13页| 精品国产一区二区在线观看| 在线亚洲欧美专区二区| 国产成人午夜精品影院观看视频 | 一个色妞综合视频在线观看| 国产亚洲综合性久久久影院| 欧美丰满嫩嫩电影| 91福利区一区二区三区| 成人综合日日夜夜| 久久99精品久久只有精品| 亚洲精品成人天堂一二三| 国产亚洲一区字幕| 精品久久国产老人久久综合| 欧美日韩国产一级| 91视视频在线直接观看在线看网页在线看 | 亚洲自拍偷拍综合| 亚洲丝袜美腿综合| 久久精品国产网站| 午夜av一区二区三区| 亚洲欧美色一区| 中文一区二区在线观看| 久久久久久久久99精品| 日韩一卡二卡三卡四卡| 欧美久久一二区| 欧美四级电影网| 精品视频在线免费看| 色婷婷综合五月| 91免费小视频| 一道本成人在线| 99re热这里只有精品免费视频| 高清不卡在线观看av| 国产一区二区不卡老阿姨| 久久国产综合精品| 狠狠色丁香久久婷婷综合_中| 美女久久久精品| 黄色精品一二区| 国产真实精品久久二三区| 国模大尺度一区二区三区| 久久国产尿小便嘘嘘尿| 国产精品一区二区在线观看不卡 | 狠狠色丁香婷婷综合| 国内精品国产三级国产a久久| 国产在线精品一区二区三区不卡| 久久91精品国产91久久小草| 玖玖九九国产精品| 国产激情视频一区二区三区欧美 | 日韩三级视频在线看| 久久综合久久久久88| 国产日韩av一区二区| 国产精品电影院| 一区二区三区中文字幕| 日本午夜一本久久久综合| 韩国理伦片一区二区三区在线播放| 国产精品综合二区| av欧美精品.com| 欧美少妇bbb| 久久蜜桃av一区二区天堂| 中文字幕一区免费在线观看| 亚洲综合男人的天堂| 日韩av电影免费观看高清完整版在线观看| 婷婷久久综合九色综合伊人色| 久久精品国产秦先生| 波多野结衣中文字幕一区二区三区| 91在线无精精品入口| 欧美日韩国产高清一区二区 | 欧美刺激脚交jootjob| 国产精品视频麻豆| 亚洲一区二区三区视频在线播放| 亚洲成av人片一区二区三区| 激情图片小说一区| 99国产精品久久久久久久久久久| 在线综合+亚洲+欧美中文字幕| 精品国产乱码久久久久久图片| 综合久久国产九一剧情麻豆| 日韩二区在线观看| 成人免费不卡视频| 欧美日韩精品一区二区三区四区 | 一区二区三区中文字幕| 蜜臀精品久久久久久蜜臀| 97久久精品人人爽人人爽蜜臀| 亚洲影院免费观看| 国内精品视频一区二区三区八戒| 91蝌蚪porny九色| 久久亚洲综合色| 午夜精品成人在线| 99精品视频在线播放观看| 日韩欧美在线影院| 亚洲精品视频自拍| 国产成人在线电影| 欧美本精品男人aⅴ天堂| 亚洲最色的网站| av欧美精品.com| 久久久另类综合| 蜜桃av噜噜一区| 欧美午夜精品电影| 自拍av一区二区三区| 国产麻豆日韩欧美久久| 日韩写真欧美这视频| 亚洲一卡二卡三卡四卡无卡久久| 国产91精品一区二区| 久久综合九色欧美综合狠狠| 婷婷一区二区三区| 欧美三区在线观看| 亚洲综合在线电影| 色综合天天视频在线观看| 欧美激情在线一区二区| 久国产精品韩国三级视频| 91精品国产综合久久婷婷香蕉| 亚洲精品欧美二区三区中文字幕| 福利一区二区在线观看| 久久久99精品免费观看| 久久疯狂做爰流白浆xx| 91精品久久久久久久99蜜桃| 天天操天天综合网| 亚洲综合色噜噜狠狠| 91麻豆福利精品推荐| 亚洲柠檬福利资源导航| kk眼镜猥琐国模调教系列一区二区| 国产午夜精品美女毛片视频| 国产精品一二三区在线| 国产亚洲美州欧州综合国| 国产成人免费视频网站 |