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

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

?? algparam.h

?? hashish-1.1b加密算法庫c++
?? 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一区二区三区免费野_久草精品视频
91精品国产欧美一区二区18| 中文一区在线播放| 亚洲国产高清aⅴ视频| 亚洲国产一区二区视频| 国产一区二区三区免费| 欧美乱熟臀69xxxxxx| 日韩美女视频一区二区 | 国产精品911| 欧美性一二三区| 亚洲欧洲精品一区二区精品久久久| 麻豆极品一区二区三区| 欧美亚洲国产怡红院影院| 国产精品午夜春色av| 久久66热re国产| 欧美一级夜夜爽| 午夜精品123| 欧美视频中文字幕| 亚洲黄网站在线观看| 成人av影视在线观看| 久久综合九色综合97婷婷女人| 五月天中文字幕一区二区| 91传媒视频在线播放| 亚洲欧美在线另类| 成人av在线电影| 国产精品亲子乱子伦xxxx裸| 国产一区二区三区高清播放| 日韩欧美精品在线| 久久精品国产亚洲一区二区三区| 777亚洲妇女| 日韩成人免费电影| 91精品国产aⅴ一区二区| 一二三区精品视频| 欧美日本精品一区二区三区| 夜夜操天天操亚洲| 欧美网站大全在线观看| 亚洲国产欧美在线人成| 欧美日韩国产影片| 日韩黄色片在线观看| 91精品国产日韩91久久久久久| 亚洲成人综合网站| 欧美肥大bbwbbw高潮| 日本中文在线一区| 精品91自产拍在线观看一区| 国内久久精品视频| 中文字幕久久午夜不卡| 色欧美日韩亚洲| 婷婷成人综合网| 欧美tickling网站挠脚心| 国产精品99久久久久久久vr| 中文天堂在线一区| 在线免费观看一区| 日韩电影在线一区| 久久久精品国产免费观看同学| 国产成人午夜电影网| 亚洲精选视频免费看| 欧美三日本三级三级在线播放| 婷婷开心激情综合| 国产日韩欧美麻豆| 在线亚洲高清视频| 国产美女在线观看一区| 国产精品毛片无遮挡高清| 欧美在线色视频| 久久精品国产一区二区三区免费看 | 亚洲综合一二区| 欧美亚洲动漫精品| 亚洲成av人片在www色猫咪| 日韩精品一区二区三区中文不卡| 国产91丝袜在线18| 亚洲v日本v欧美v久久精品| 精品精品欲导航| 91免费在线播放| 国产一区二区三区黄视频 | 美女一区二区久久| 国产精品网站一区| 在线播放视频一区| eeuss鲁一区二区三区| 男人操女人的视频在线观看欧美| 中文幕一区二区三区久久蜜桃| 在线不卡一区二区| eeuss鲁一区二区三区| 黄色小说综合网站| 午夜视频久久久久久| 国产精品久久久久桃色tv| 欧美一区二区久久久| 一本到一区二区三区| 国产伦精品一区二区三区免费| 夜夜爽夜夜爽精品视频| 国产精品毛片久久久久久| 欧美一级黄色录像| 欧美影视一区二区三区| 99精品国产视频| 国产91精品一区二区麻豆网站| 亚洲成a人v欧美综合天堂| 最近日韩中文字幕| 国产亚洲成aⅴ人片在线观看| 欧美精品一卡二卡| 在线观看一区二区精品视频| 成人黄色a**站在线观看| 国产制服丝袜一区| 精东粉嫩av免费一区二区三区| 偷拍亚洲欧洲综合| 亚洲综合色自拍一区| 亚洲欧美韩国综合色| 国产免费观看久久| 日韩亚洲欧美在线| 91精品国产综合久久久久久 | 不卡的av网站| 高清国产午夜精品久久久久久| 久久精品国产99| 美国精品在线观看| 免费观看30秒视频久久| 蜜臀av性久久久久蜜臀aⅴ流畅 | 亚洲香蕉伊在人在线观| 一区二区三区中文免费| 亚洲欧美日韩中文播放| 亚洲精品成人精品456| 亚洲欧美日韩久久| 伊人一区二区三区| 洋洋成人永久网站入口| 午夜精品久久久久久久99水蜜桃| 亚洲国产精品一区二区www| 五月天一区二区| 久久精品二区亚洲w码| 国产一区二区三区免费看| 国产一区二区三区精品视频| 国产成人综合亚洲网站| 成人黄色网址在线观看| 91网址在线看| 欧美日韩在线综合| 日韩三级免费观看| 久久精品一区二区三区不卡| 欧美高清一级片在线观看| 亚洲人吸女人奶水| 亚洲国产另类精品专区| 老鸭窝一区二区久久精品| 国产专区综合网| 91免费在线看| 欧美一级日韩免费不卡| 国产午夜亚洲精品理论片色戒 | 91在线播放网址| 欧美性色黄大片| 精品国产伦一区二区三区观看方式 | 日本 国产 欧美色综合| 韩国精品一区二区| 99精品国产视频| 欧美日韩国产一二三| 精品久久一区二区| 亚洲欧美在线另类| 美女高潮久久久| 99久久免费精品高清特色大片| 日本电影欧美片| 精品国产乱码久久久久久老虎| 国产精品麻豆99久久久久久| 亚洲成在线观看| 福利电影一区二区三区| 欧美日韩一区 二区 三区 久久精品| 欧美刺激脚交jootjob| 中文字幕中文乱码欧美一区二区 | 91黄色免费观看| 2024国产精品视频| 亚洲午夜精品久久久久久久久| 国内精品写真在线观看| 色94色欧美sute亚洲13| 久久久夜色精品亚洲| 午夜亚洲福利老司机| 粉嫩一区二区三区性色av| 在线不卡免费av| 亚洲色图一区二区| 国产精品1区2区3区在线观看| 欧美人妖巨大在线| 日韩毛片视频在线看| 国产一区二区三区精品视频| 欧美日韩精品一区二区三区| 国产精品国产a级| 国产一区二区按摩在线观看| 欧美高清精品3d| 亚洲精品国产成人久久av盗摄 | 欧美理论片在线| 17c精品麻豆一区二区免费| 国内成人自拍视频| 欧美一区二区视频在线观看2020 | 国产精品美女久久久久久久| 精品一区二区三区在线播放| 精品视频一区 二区 三区| 中文字幕综合网| caoporn国产精品| 日本一区二区在线不卡| 国产一区二区美女| 久久久精品蜜桃| 国产精品自拍毛片| 久久午夜羞羞影院免费观看| 久久国产精品99久久人人澡| 91精品婷婷国产综合久久| 亚洲高清免费观看 | 丝袜亚洲精品中文字幕一区| 在线视频中文字幕一区二区| 亚洲激情综合网| 欧美色涩在线第一页| 亚洲制服丝袜av| 欧美三级乱人伦电影|