⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 filters.h

📁 lots Elliptic curve cryptography codes. Use Visual c++ to compile
💻 H
📖 第 1 页 / 共 3 页
字号:
#ifndef CRYPTOPP_FILTERS_H#define CRYPTOPP_FILTERS_H#include "simple.h"#include "secblock.h"#include "misc.h"#include "smartptr.h"#include "queue.h"#include "algparam.h"#include <deque>NAMESPACE_BEGIN(CryptoPP)/// provides an implementation of BufferedTransformation's attachment interfaceclass CRYPTOPP_DLL CRYPTOPP_NO_VTABLE Filter : public BufferedTransformation, public NotCopyable{public:	Filter(BufferedTransformation *attachment = NULL);	bool Attachable() {return true;}	BufferedTransformation *AttachedTransformation();	const BufferedTransformation *AttachedTransformation() const;	void Detach(BufferedTransformation *newAttachment = NULL);	size_t TransferTo2(BufferedTransformation &target, lword &transferBytes, const std::string &channel=DEFAULT_CHANNEL, bool blocking=true);	size_t CopyRangeTo2(BufferedTransformation &target, lword &begin, lword end=LWORD_MAX, const std::string &channel=DEFAULT_CHANNEL, bool blocking=true) const;	void Initialize(const NameValuePairs &parameters=g_nullNameValuePairs, int propagation=-1);	bool Flush(bool hardFlush, int propagation=-1, bool blocking=true);	bool MessageSeriesEnd(int propagation=-1, bool blocking=true);protected:	virtual BufferedTransformation * NewDefaultAttachment() const;	void Insert(Filter *nextFilter);	// insert filter after this one	virtual bool ShouldPropagateMessageEnd() const {return true;}	virtual bool ShouldPropagateMessageSeriesEnd() const {return true;}	void PropagateInitialize(const NameValuePairs &parameters, int propagation);	size_t Output(int outputSite, const byte *inString, size_t length, int messageEnd, bool blocking, const std::string &channel=DEFAULT_CHANNEL);	size_t OutputModifiable(int outputSite, byte *inString, size_t length, int messageEnd, bool blocking, const std::string &channel=DEFAULT_CHANNEL);	bool OutputMessageEnd(int outputSite, int propagation, bool blocking, const std::string &channel=DEFAULT_CHANNEL);	bool OutputFlush(int outputSite, bool hardFlush, int propagation, bool blocking, const std::string &channel=DEFAULT_CHANNEL);	bool OutputMessageSeriesEnd(int outputSite, int propagation, bool blocking, const std::string &channel=DEFAULT_CHANNEL);private:	member_ptr<BufferedTransformation> m_attachment;	protected:	size_t m_inputPosition;	int m_continueAt;};struct CRYPTOPP_DLL FilterPutSpaceHelper{	// desiredSize is how much to ask target, bufferSize is how much to allocate in m_tempSpace	byte *HelpCreatePutSpace(BufferedTransformation &target, const std::string &channel, size_t minSize, size_t desiredSize, size_t &bufferSize)	{		assert(desiredSize >= minSize && bufferSize >= minSize);		if (m_tempSpace.size() < minSize)		{			byte *result = target.ChannelCreatePutSpace(channel, desiredSize);			if (desiredSize >= minSize)			{				bufferSize = desiredSize;				return result;			}			m_tempSpace.New(bufferSize);		}		bufferSize = m_tempSpace.size();		return m_tempSpace.begin();	}	byte *HelpCreatePutSpace(BufferedTransformation &target, const std::string &channel, size_t minSize)		{return HelpCreatePutSpace(target, channel, minSize, minSize, minSize);}	byte *HelpCreatePutSpace(BufferedTransformation &target, const std::string &channel, size_t minSize, size_t bufferSize)		{return HelpCreatePutSpace(target, channel, minSize, minSize, bufferSize);}	SecByteBlock m_tempSpace;};//! measure how many byte and messages pass through, also serves as valveclass CRYPTOPP_DLL MeterFilter : public Bufferless<Filter>{public:	MeterFilter(BufferedTransformation *attachment=NULL, bool transparent=true)		: m_transparent(transparent) {Detach(attachment); ResetMeter();}	void SetTransparent(bool transparent) {m_transparent = transparent;}	void AddRangeToSkip(unsigned int message, lword position, lword size, bool sortNow = true);	void ResetMeter();	void IsolatedInitialize(const NameValuePairs &parameters) {ResetMeter();}	lword GetCurrentMessageBytes() const {return m_currentMessageBytes;}	lword GetTotalBytes() {return m_totalBytes;}	unsigned int GetCurrentSeriesMessages() {return m_currentSeriesMessages;}	unsigned int GetTotalMessages() {return m_totalMessages;}	unsigned int GetTotalMessageSeries() {return m_totalMessageSeries;}	byte * CreatePutSpace(size_t &size)		{return AttachedTransformation()->CreatePutSpace(size);}	size_t Put2(const byte *begin, size_t length, int messageEnd, bool blocking);	size_t PutModifiable2(byte *inString, size_t length, int messageEnd, bool blocking);	bool IsolatedMessageSeriesEnd(bool blocking);private:	size_t PutMaybeModifiable(byte *inString, size_t length, int messageEnd, bool blocking, bool modifiable);	bool ShouldPropagateMessageEnd() const {return m_transparent;}	bool ShouldPropagateMessageSeriesEnd() const {return m_transparent;}	struct MessageRange	{		inline bool operator<(const MessageRange &b) const	// BCB2006 workaround: this has to be a member function			{return message < b.message || (message == b.message && position < b.position);}		unsigned int message; lword position; lword size;	};	bool m_transparent;	lword m_currentMessageBytes, m_totalBytes;	unsigned int m_currentSeriesMessages, m_totalMessages, m_totalMessageSeries;	std::deque<MessageRange> m_rangesToSkip;	byte *m_begin;	size_t m_length;};//! _class CRYPTOPP_DLL TransparentFilter : public MeterFilter{public:	TransparentFilter(BufferedTransformation *attachment=NULL) : MeterFilter(attachment, true) {}};//! _class CRYPTOPP_DLL OpaqueFilter : public MeterFilter{public:	OpaqueFilter(BufferedTransformation *attachment=NULL) : MeterFilter(attachment, false) {}};/*! FilterWithBufferedInput divides up the input stream into	a first block, a number of middle blocks, and a last block.	First and last blocks are optional, and middle blocks may	be a stream instead (i.e. blockSize == 1).*/class CRYPTOPP_DLL FilterWithBufferedInput : public Filter{public:	FilterWithBufferedInput(BufferedTransformation *attachment);	//! firstSize and lastSize may be 0, blockSize must be at least 1	FilterWithBufferedInput(size_t firstSize, size_t blockSize, size_t lastSize, BufferedTransformation *attachment);	void IsolatedInitialize(const NameValuePairs &parameters);	size_t Put2(const byte *inString, size_t length, int messageEnd, bool blocking)	{		return PutMaybeModifiable(const_cast<byte *>(inString), length, messageEnd, blocking, false);	}	size_t PutModifiable2(byte *inString, size_t length, int messageEnd, bool blocking)	{		return PutMaybeModifiable(inString, length, messageEnd, blocking, true);	}	/*! calls ForceNextPut() if hardFlush is true */	bool IsolatedFlush(bool hardFlush, bool blocking);	/*! The input buffer may contain more than blockSize bytes if lastSize != 0.		ForceNextPut() forces a call to NextPut() if this is the case.	*/	void ForceNextPut();protected:	bool DidFirstPut() {return m_firstInputDone;}	virtual void InitializeDerivedAndReturnNewSizes(const NameValuePairs &parameters, size_t &firstSize, size_t &blockSize, size_t &lastSize)		{InitializeDerived(parameters);}	virtual void InitializeDerived(const NameValuePairs &parameters) {}	// FirstPut() is called if (firstSize != 0 and totalLength >= firstSize)	// or (firstSize == 0 and (totalLength > 0 or a MessageEnd() is received))	virtual void FirstPut(const byte *inString) =0;	// NextPut() is called if totalLength >= firstSize+blockSize+lastSize	virtual void NextPutSingle(const byte *inString) {assert(false);}	// Same as NextPut() except length can be a multiple of blockSize	// Either NextPut() or NextPutMultiple() must be overriden	virtual void NextPutMultiple(const byte *inString, size_t length);	// Same as NextPutMultiple(), but inString can be modified	virtual void NextPutModifiable(byte *inString, size_t length)		{NextPutMultiple(inString, length);}	// LastPut() is always called	// if totalLength < firstSize then length == totalLength	// else if totalLength <= firstSize+lastSize then length == totalLength-firstSize	// else lastSize <= length < lastSize+blockSize	virtual void LastPut(const byte *inString, size_t length) =0;	virtual void FlushDerived() {}protected:	size_t PutMaybeModifiable(byte *begin, size_t length, int messageEnd, bool blocking, bool modifiable);	void NextPutMaybeModifiable(byte *inString, size_t length, bool modifiable)	{		if (modifiable) NextPutModifiable(inString, length);		else NextPutMultiple(inString, length);	}	// This function should no longer be used, put this here to cause a compiler error	// if someone tries to override NextPut().	virtual int NextPut(const byte *inString, size_t length) {assert(false); return 0;}	class BlockQueue	{	public:		void ResetQueue(size_t blockSize, size_t maxBlocks);		byte *GetBlock();		byte *GetContigousBlocks(size_t &numberOfBytes);		size_t GetAll(byte *outString);		void Put(const byte *inString, size_t length);		size_t CurrentSize() const {return m_size;}		size_t MaxSize() const {return m_buffer.size();}	private:		SecByteBlock m_buffer;		size_t m_blockSize, m_maxBlocks, m_size;		byte *m_begin;	};	size_t m_firstSize, m_blockSize, m_lastSize;	bool m_firstInputDone;	BlockQueue m_queue;};//! _class CRYPTOPP_DLL FilterWithInputQueue : public Filter{public:	FilterWithInputQueue(BufferedTransformation *attachment=NULL) : Filter(attachment) {}	size_t Put2(const byte *inString, size_t length, int messageEnd, bool blocking)	{		if (!blocking)			throw BlockingInputOnly("FilterWithInputQueue");				m_inQueue.Put(inString, length);		if (messageEnd)		{			IsolatedMessageEnd(blocking);			Output(0, NULL, 0, messageEnd, blocking);		}		return 0;	}protected:	virtual bool IsolatedMessageEnd(bool blocking) =0;	void IsolatedInitialize(const NameValuePairs &parameters) {m_inQueue.Clear();}	ByteQueue m_inQueue;};struct BlockPaddingSchemeDef{	enum BlockPaddingScheme {NO_PADDING, ZEROS_PADDING, PKCS_PADDING, ONE_AND_ZEROS_PADDING, DEFAULT_PADDING};};//! Filter Wrapper for StreamTransformation, optionally handling padding/unpadding when neededclass CRYPTOPP_DLL StreamTransformationFilter : public FilterWithBufferedInput, public BlockPaddingSchemeDef, private FilterPutSpaceHelper{public:	/*! DEFAULT_PADDING means PKCS_PADDING if c.MandatoryBlockSize() > 1 && c.MinLastBlockSize() == 0 (e.g. ECB or CBC mode),		otherwise NO_PADDING (OFB, CFB, CTR, CBC-CTS modes).		See http://www.weidai.com/scan-mirror/csp.html for details of the padding schemes. */	StreamTransformationFilter(StreamTransformation &c, BufferedTransformation *attachment = NULL, BlockPaddingScheme padding = DEFAULT_PADDING, bool allowAuthenticatedSymmetricCipher = false);	std::string AlgorithmName() const {return m_cipher.AlgorithmName();}protected:

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -