mirror of
				https://github.com/pocoproject/poco.git
				synced 2025-10-25 18:22:59 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			168 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			168 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| //
 | |
| // TextBufferIterator.h
 | |
| //
 | |
| // $Id: //poco/1.4/Foundation/include/Poco/TextBufferIterator.h#1 $
 | |
| //
 | |
| // Library: Foundation
 | |
| // Package: Text
 | |
| // Module:  TextBufferIterator
 | |
| //
 | |
| // Definition of the TextBufferIterator class.
 | |
| //
 | |
| // Copyright (c) 2010, Applied Informatics Software Engineering GmbH.
 | |
| // and Contributors.
 | |
| //
 | |
| // Permission is hereby granted, free of charge, to any person or organization
 | |
| // obtaining a copy of the software and accompanying documentation covered by
 | |
| // this license (the "Software") to use, reproduce, display, distribute,
 | |
| // execute, and transmit the Software, and to prepare derivative works of the
 | |
| // Software, and to permit third-parties to whom the Software is furnished to
 | |
| // do so, all subject to the following:
 | |
| // 
 | |
| // The copyright notices in the Software and this entire statement, including
 | |
| // the above license grant, this restriction and the following disclaimer,
 | |
| // must be included in all copies of the Software, in whole or in part, and
 | |
| // all derivative works of the Software, unless such copies or derivative
 | |
| // works are solely in the form of machine-executable object code generated by
 | |
| // a source language processor.
 | |
| // 
 | |
| // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | |
| // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | |
| // FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
 | |
| // SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
 | |
| // FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
 | |
| // ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
 | |
| // DEALINGS IN THE SOFTWARE.
 | |
| //
 | |
| 
 | |
| 
 | |
| #ifndef Foundation_TextBufferIterator_INCLUDED
 | |
| #define Foundation_TextBufferIterator_INCLUDED
 | |
| 
 | |
| 
 | |
| #include "Poco/Foundation.h"
 | |
| #include <cstdlib>
 | |
| 
 | |
| 
 | |
| namespace Poco {
 | |
| 
 | |
| 
 | |
| class TextEncoding;
 | |
| 
 | |
| 
 | |
| class Foundation_API TextBufferIterator
 | |
| 	/// An unidirectional iterator for iterating over characters in a buffer.
 | |
| 	/// The TextBufferIterator uses a TextEncoding object to
 | |
| 	/// work with multi-byte character encodings like UTF-8.
 | |
| 	/// Characters are reported in Unicode.
 | |
| 	///
 | |
| 	/// Example: Count the number of UTF-8 characters in a buffer.
 | |
| 	///
 | |
| 	///     UTF8Encoding utf8Encoding;
 | |
| 	///     char buffer[] = "...";
 | |
| 	///     TextBufferIterator it(buffer, utf8Encoding);
 | |
| 	///     TextBufferIterator end(it.end());
 | |
| 	///     int n = 0;
 | |
| 	///     while (it != end) { ++n; ++it; }
 | |
| 	///
 | |
| 	/// NOTE: When an UTF-16 encoding is used, surrogate pairs will be
 | |
| 	/// reported as two separate characters, due to restrictions of
 | |
| 	/// the TextEncoding class.
 | |
| 	///
 | |
| 	/// For iterating over the characters in a std::string, see the
 | |
| 	/// TextIterator class.
 | |
| {
 | |
| public:
 | |
| 	TextBufferIterator();
 | |
| 		/// Creates an uninitialized TextBufferIterator.
 | |
| 		
 | |
| 	TextBufferIterator(const char* begin, const TextEncoding& encoding);
 | |
| 		/// Creates a TextBufferIterator for the given buffer, which must be 0-terminated.
 | |
| 		/// The encoding object must not be deleted as long as the iterator
 | |
| 		/// is in use.
 | |
| 
 | |
| 	TextBufferIterator(const char* begin, std::size_t size, const TextEncoding& encoding);
 | |
| 		/// Creates a TextBufferIterator for the given buffer with the given size.
 | |
| 		/// The encoding object must not be deleted as long as the iterator
 | |
| 		/// is in use.
 | |
| 
 | |
| 	TextBufferIterator(const char* begin, const char* end, const TextEncoding& encoding);
 | |
| 		/// Creates a TextBufferIterator for the given range.
 | |
| 		/// The encoding object must not be deleted as long as the iterator
 | |
| 		/// is in use.
 | |
| 
 | |
| 	TextBufferIterator(const char* end);
 | |
| 		/// Creates an end TextBufferIterator for the given buffer.
 | |
| 
 | |
| 	~TextBufferIterator();
 | |
| 		/// Destroys the TextBufferIterator.
 | |
| 	
 | |
| 	TextBufferIterator(const TextBufferIterator& it);
 | |
| 		/// Copy constructor.
 | |
| 	
 | |
| 	TextBufferIterator& operator = (const TextBufferIterator& it);
 | |
| 		/// Assignment operator.
 | |
| 		
 | |
| 	void swap(TextBufferIterator& it);
 | |
| 		/// Swaps the iterator with another one.
 | |
| 	
 | |
| 	int operator * () const;
 | |
| 		/// Returns the Unicode value of the current character.
 | |
| 		/// If there is no valid character at the current position,
 | |
| 		/// -1 is returned.
 | |
| 		
 | |
| 	TextBufferIterator& operator ++ (); 
 | |
| 		/// Prefix increment operator.
 | |
| 
 | |
| 	TextBufferIterator operator ++ (int);		
 | |
| 		/// Postfix increment operator.
 | |
| 
 | |
| 	bool operator == (const TextBufferIterator& it) const;
 | |
| 		/// Compares two iterators for equality.
 | |
| 		
 | |
| 	bool operator != (const TextBufferIterator& it) const;
 | |
| 		/// Compares two iterators for inequality.
 | |
| 
 | |
| 	TextBufferIterator end() const;
 | |
| 		/// Returns the end iterator for the range handled
 | |
| 		/// by the iterator.
 | |
| 		
 | |
| private:
 | |
| 	const TextEncoding* _pEncoding;
 | |
| 	const char* _it;
 | |
| 	const char* _end;
 | |
| };
 | |
| 
 | |
| 
 | |
| //
 | |
| // inlines
 | |
| //
 | |
| inline bool TextBufferIterator::operator == (const TextBufferIterator& it) const
 | |
| {
 | |
| 	return _it == it._it;
 | |
| }
 | |
| 
 | |
| 
 | |
| inline bool TextBufferIterator::operator != (const TextBufferIterator& it) const
 | |
| {
 | |
| 	return _it != it._it;
 | |
| }
 | |
| 
 | |
| 
 | |
| inline void swap(TextBufferIterator& it1, TextBufferIterator& it2)
 | |
| {
 | |
| 	it1.swap(it2);
 | |
| }
 | |
| 
 | |
| 
 | |
| inline TextBufferIterator TextBufferIterator::end() const
 | |
| {
 | |
| 	return TextBufferIterator(_end);
 | |
| }
 | |
| 
 | |
| 
 | |
| } // namespace Poco
 | |
| 
 | |
| 
 | |
| #endif // Foundation_TextBufferIterator_INCLUDED
 | 
