Click here to Skip to main content
15,891,749 members
Articles / Desktop Programming / WPF

Writing Your Own RTF Converter

Rate me:
Please Sign up or sign in to vote.
4.95/5 (234 votes)
1 Aug 2013CPOL14 min read 2.5M   40.4K   632  
An article on how to write a custom RTF parser and converter.
// -- FILE ------------------------------------------------------------------
// name       : IRtfParser.cs
// project    : RTF Framelet
// created    : Leon Poyyayil - 2008.05.19
// language   : c#
// environment: .NET 2.0
// copyright  : (c) 2004-2013 by Jani Giannoudis, Switzerland
// --------------------------------------------------------------------------
using System;
using System.IO;

namespace Itenso.Rtf
{

	// ------------------------------------------------------------------------
	public interface IRtfParser
	{

		// ----------------------------------------------------------------------
		/// <summary>
		/// Determines whether to ignore all content after the root group ends.
		/// Set this to true when parsing content from streams which contain other
		/// data after the RTF or if the writer of the RTF is known to terminate the
		/// actual RTF content with a null byte (as some popular sources such as
		/// WordPad are known to behave).
		/// </summary>
		bool IgnoreContentAfterRootGroup { get; set; }

		// ----------------------------------------------------------------------
		/// <summary>
		/// Adds a listener that will get notified along the parsing process.
		/// </summary>
		/// <param name="listener">the listener to add</param>
		/// <exception cref="ArgumentNullException">in case of a null argument</exception>
		void AddParserListener( IRtfParserListener listener );

		// ----------------------------------------------------------------------
		/// <summary>
		/// Removes a listener from this instance.
		/// </summary>
		/// <param name="listener">the listener to remove</param>
		/// <exception cref="ArgumentNullException">in case of a null argument</exception>
		void RemoveParserListener( IRtfParserListener listener );

		// ----------------------------------------------------------------------
		/// <summary>
		/// Parses the given RTF text that is read from the given source.
		/// </summary>
		/// <param name="rtfTextSource">the source with RTF text to parse</param>
		/// <exception cref="RtfException">in case of invalid RTF syntax</exception>
		/// <exception cref="IOException">in case of an IO error</exception>
		/// <exception cref="ArgumentNullException">in case of a null argument</exception>
		void Parse( IRtfSource rtfTextSource );

	} // interface IRtfParser

} // namespace Itenso.Rtf
// -- EOF -------------------------------------------------------------------

By viewing downloads associated with this article you agree to the Terms of Service and the article's licence.

If a file you wish to view isn't highlighted, and is a text file (not binary), please let us know and we'll add colourisation support for it.

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)


Written By
Software Developer (Senior)
Switzerland Switzerland
👨 Senior .NET Software Engineer

🚀 My Open Source Projects
- Time Period Library 👉 GitHub
- Payroll Engine 👉 GitHub

Feedback and contributions are welcome.



Comments and Discussions