Perl extension for generating rich text (rtf) files
RTF::Document is a module for generating Rich Text Format (\s-1RTF\s0) documents that can be used by most text converters and word processors.
For a listing of properties, consult the %DOCINFO and %PROPERTIES hashes in the source code.
Carp POSIX Convert::Units::Type 0.33
use RTF::Document;
# Document properties
$rtf = new RTF::Document( { doc_page_width => '8.5in', doc_page_height => '11in' } );
# Font definitions
$fAvantGarde = $rtf->add_font ("AvantGarde", { family=>swiss, default=>1 } ); $fCourier = $rtf->add_font ("Courier", { family=>monospace, pitch=>fixed, alternates=>["Courier New", "American Typewriter"] } );
# Color definitions
$cRed = $rtf->add_color ( { red=>255 } ); $cGreen = $rtf->add_color ( { green=>128 } ); $cCustm = $rtf->add_color ( { red=>0x66, blue=>0x33, green=>0x33 } );
$cBlack = $rtf->add_color ( { name=>'black' } ); $cWhite = $rtf->add_color ( { gray=>'100%' } );
$cNavy = $rtf->add_color ( { blue=>'100%', gray=>'50%' } );
# style definitions
$sNormal = $rtf->add_style( "Normal", { font=>$fAvantGarde, font_size=>'12pt', color_foreground=>$cBlack }, { type=>paragraph, default=>1 } );
$sGreen = $rtf->add_style( "Green", { color_foreground=>$cGreen }, { type=>character, additive=>1 } );
# Mix any combo of properties and text...
$rtf->add_text( $rtf->root(), "Default text\n\n",
{ bold=>1, underline=>continuous }, "Bold/Underlined Text\n\n",
{ font_size=>'20pt', font=>$fCourier, color_foreground=>$cRed }, "Bigger, Red and Monospaced.\n\n",
{ style_default=>paragraph }, { style_default=>character },
"This is ", [ { style=>$sGreen }, "green" ], " styled.\n\n"
);
open FILE, ">MyFile.rtf"; binmode FILE; print FILE $rtf->rtf(); close FILE;
For purposes of using this module, a Rich Text (\s-1RTF\s0) Document can be subdivided into groups. Groups can be considered containers for text and controls (controlling document and text properties).
For all intents and purposes, a group limits the scope of controls. So if we set the \*(L"bold\*(R" character property within a group, the text will be bold only within that group (until it is turned off within that group).
When generating a \s-1RTF\s0 document using this module, we are only concerned with the root group (also called the \*(L"Document Area\*(R"). (The \*(L"Header\*(R" groups are taken care of automatically by this module.)
The Document Area is subdivided into sections. Each section is subdivided into paragraphs.
Some of the methods are documented below. (Methods not documented here may be changed in future versions.)
\$1
$rtf = new RTF::Document( \%DocumentProperties );
Creates a new \s-1RTF\s0 document object. $gRoot = $rtf->root();
Returns the \*(L"root\*(R" group in the \s-1RTF\s0 document. $gMyGroup = $rtf->new_group();
Creates a new group (not inside of the \s-1RTF\s0 document). $gChildOfRoot = $rtf->add_group(); $gChildOfChild = $rtf->add_group( $gChild );
Adds a child group to the specfied group. If no group is specified, the \*(L"root\*(R" group is assumed.
$rtf->add_group( $rtf->root(), $gMyGroup );
Adds a group to the specified parent group (in this case, the root group). $rtf->add_raw( $group, '\par', "Some Text" );
Adds raw controls and text to the group. This method is intended for internal use only. $rtf->add_text( $group, "Some text ", { bold=>1 }, "more text" );
Adds text and controls to a group. Text is escaped.
This module should be considered in the \*(L"alpha\*(R" stage. Use at your own risk.
There are no default document or style properties produced by this module, with the exception of the character set. If you want to make sure that a specific font, color, or style is used, you must specify it. Otherwise you rely on the assumptions of whatever \s-1RTF\s0 reader someone is using.
This module does not insert newlines anywhere in the text, even though some \s-1RTF\s0 writers break lines before they exceed 225 characters. This may or may not be an issue with some reader software.
Unknown font or style properties will generally be ignored without warning.
This module supports some newer \s-1RTF\s0 controls (used in Word 95/Word 97) that may are not understood by older \s-1RTF\s0 readers.
Once a Font, Color or Style is added, it cannot be changed. No checking for redundant entries is done.
Generally, it is not possible to reference a not-yet-created Style with the next or basedon attributes. However, you can use the constances \*(L"last\*(R", \*(L"self\*(R" or \*(L"next\*(R" to reference the last style added, the current style being added, or the next style that will be added, respectively.
Specifying properties in a particular order within a group does not guarantee that they will be emitted in that order. If order matters, specify them separetly. For instance,
$rtf->add_text($rtf->root, { style_default=>character, bold=>1 } );
should be (if you want to ensure character styles are reset before setting bold text):
$rtf->add_text($rtf->root, { style_default=>character }, { bold=>1 } );
Also note that duplicate properties within the same group won't work. i.e., If you want to set \*(L"style_default\*(R" for both paragraphs and characters, you must do so in separate groups.
This isn't so much as a bug as the way Perl handles hashes. A rather large number of features and control words are not handled in this version. Among the major features:
Some support has been added. The backwards-compatability controls for numbered paragraphs used by older readers has not been added because it is not properly handled by newer readers.
Non-\*(L"\s-1ANSI\s0\*(R" character sets (i.e., Macintosh) and Unicode character sets are not supported (at least not intentionally). There is no support for Asian character sets in this version of the module. Unicode character escapes are not implemented. Language codes (defining a default language, or a language for a group of characters) are not implemented. Bi-directional and text-flow controls are not implemented.
Some minimal controls have been added.
Not implemented: List Tables are really a kind of style sheet for lists. Priority will be given to support generic bullets and paragraph numbering.
Minimal definition, untested.
Most special characters not not implemented, with the exception of tabs. Double newline characters are converted to a new paragraph control, and single newlines are converted to a new line control.
Microsoft Technical Support and Application Note, \*(L"Rich Text Format (\s-1RTF\s0) Specification and Sample Reader Program\*(R", Version 1.5.
Convert::Units::Type.
Robert Rothenberg <[email protected]>
Copyright (c) 1999-2000 Robert Rothenberg. All rights reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
Some bugs have been fixed by nmag only <[email protected]>, now the code is clean and under strict directives.