Scroll to navigation

Remind::PDF(3pm) VERSION 05.02.02 Remind::PDF(3pm)

NAME

Remind::PDF - Render a month's worth of Remind data to PDF

CLASS METHODS

Remind::PDF->create_from_stream($in, $specials_accepted)

This method reads data from an open file handle $in. $specials_accepted is a hashref of SPECIAL reminder types to accept; the key is the name of the SPECIAL (all lower-case) and the value should be 1. Any SPECIAL reminders not in the hash are ignored.

This function returns a two-element array: "($obj, $err)". On success, $obj will be a "Remind::PDF" object and $err will be undef. On failure, $obj will be undef and $err will be an error message.

Remind::PDF->create_from_hash($hash, $specials_accepted)

This method takes data from a hash $hash, which must be one month's worth of data from "remind -ppp" output. $specials_accepted is a hashref of SPECIAL reminder types to accept; the key is the name of the SPECIAL (all lower-case) and the value should be 1. Any SPECIAL reminders not in the hash are ignored.

This function returns a two-element array: "($obj, $err)". On success, $obj will be a "Remind::PDF" object and $err will be undef. On failure, $obj will be undef and $err will be an error message.

INSTANCE METHODS

read_one_month($in, $first_line, $specials_accepted)

This function reads one month's worth of data from the file handle $in. $first_line is the line that was read from $in just before calling this function. $specials_accepted is a hashref as documented above.

The return value is the same "($obj, $err)" two-element array as "create_from_stream" returns.

read_one_month_p($in, $specials_accepted)

This function reads one month's worth of data from the file handle $in, assuming the original "remind -p" format. $specials_accepted is a hashref as documented above.

The return value is the same "($obj, $err)" two-element array as "create_from_stream" returns.

parse_oldstyle_line ($line)

This method parses an old-style "remind -p" line and returns a hashref containing some or all of the hash keys found in the newer "remind -pp" JSON output.

setup_daymap

Set up the array that maps ($row, $col) to day number (or -1 for rows/cols out of range.)

read_one_month_pp($in, $specials_accepted)

This function reads one month's worth of data from the file handle $in, assuming the "remind -pp" partial-JSON format. $specials_accepted is a hashref as documented above.

The return value is the same "($obj, $err)" two-element array as "create_from_stream" returns.

accept_special($hash, $specials_accepted)

Given a hashref $hash consisting of one entry parsed from the "remind -p" stream and a $specials_accepted hash, return 1 if we should include this entry in the calendar or 0 if not.

find_last_special($special, $entries)

Given an array of Reminder entries, find the last $special-type SPECIAL in the array. Return the entry if one was found or undef if not.

render($cr, $settings)

Render a calendar for one month. $cr is a Cairo drawing context, and $settings is a settings hash passed in by the caller. See the source code of "rem2pdf" for the contents of $settings

draw_row($cr, $settings, $so_far, $row, $start_day, $start_col)

Draw a single row in the calendar. $cr is a Cairo drawing context and $settings is the settings hash passed to "render". $so_far is the Y-coordinate of the top of the row; drawing starts at this coordinate. $start_day is the day of the month at which the row starts and $start col is the column number (0-6) at which to start drawing from $start_day

Returns the Y coordinate at which to start drawing the next calendar row.

col_box_coordinates($so_far, $col, $height, $settings)

Returns a four-element array "($x1, $y1, $x2, $y2)" representing the bounding box of the calendar box at column $col (0-6). $height is the height of the box and $settings is the settings hashref passed to "render".

draw_day($cr, $settings, $so_far, $day, $col, $height)

Renders a single day's worth of reminders. $cr is a Cairo drawing context and $settings is the settings hash passed to "render". $so_far is the Y-coordinate of the top of the box and $col is the column number.

$height is the height of the box. If $height is passed in as zero, then do not actually render anything... instead, compute how high the box should be. If $height is non-zero, then it is the height of the box.

Returns the height required for the calendar box.

draw_daynames($cr, $settings, $so_far)

Draw the weekday names heading. $cr is a Cairo drawing context and $settings is the settings hash passed to "render". $so_far is the Y-coordinate of the top of the row; drawing starts at this coordinate.

Returns the Y coordinate at which to start drawing the first calendar row.

draw_title($cr, $settings)

Draw the title ("Monthname Year") at the top of the calendar. $cr is a Cairo drawing context and $settings is the settings hash passed to "render".

Returns the Y coordinate at which to start drawing the row containing the weekday names.

draw_small_calendar($cr, $x, $y, $width, $height, $settings, $month, $days, $start_wkday)

Draw a small calendar on the Cairo context $cr. The top left-hand corner of the box is at "($x, $y)" and the size of the box is "($width, $height"). $settings is the settings hashref passed to "render". $month is the name of the month to draw and $days is the number of days in the month. Finally, $start_wkday is the weekday (0=Sunday, 6=Saturday) on which the month starts

NAME

Remind::PDF::Multi - A container for multiple months' worth of calendar data

DESCRIPTION

The "remind -ppp" output consists of a JSON array with each element representing one month's worth of reminders. "Remind::PDF::Multi" reads this output and returns an instance of itself containing an array of "Remind::PDF" objects, one object for each month.

CLASS METHODS

Remind::PDF::Multi->create_from_stream($in, $specials_accepted)

This method reads data from an open file handle $in. $specials_accepted is a hashref of SPECIAL reminder types to accept; the key is the name of the SPECIAL (all lower-case) and the value should be 1. Any SPECIAL reminders not in the hash are ignored.

This function returns a two-element array: "($obj, $err)". On success, $obj will be a "Remind::PDF::Multi" object and $err will be undef. On failure, $obj will be undef and $err will be an error message.

Remind::PDF::Multi->create_from_json($json, $specials_accepted)

This method takes data from a JSON string <$json>. $specials_accepted is a hashref of SPECIAL reminder types to accept; the key is the name of the SPECIAL (all lower-case) and the value should be 1. Any SPECIAL reminders not in the hash are ignored.

This function returns a two-element array: "($obj, $err)". On success, $obj will be a "Remind::PDF::Multi" object and $err will be undef. On failure, $obj will be undef and $err will be an error message.

INSTANCE METHODS

render($cr, $settings)

Iterate through all the "Remind::PDF" objects and call their "render" methods. This method renders as many months worth of calendar data as were read from the "remind -ppp" stream

NAME

Remind::PDF::Weekly - render a weekly calendar

2025-01-06 perl v5.40.0