A path is a set of figures defined by curves. A path can be used with
the 
draw-path method of a 
dc<%> object to draw
the path’s curves as lines, fill the region bounded by the path’s
curves, or both. A path can also be used with the 
set-path method of a 
region% object to generate a region
bounded by the path’s curves.
A path consists of zero or more closed sub-paths, and
 possibly one open sub-path. Some dc-path% methods
 extend the open sub-path, some dc-path% methods close the
 open sub-path, and some dc-path% methods add closed
 sub-paths. This approach to drawing formulation is inherited from
 PostScript [Adobe99].
When a path is drawn as a line, a closed sub-path is drawn as a closed
 figure, analogous to a polygon. An open sub-path is drawn with
 disjoint start and end points, analogous lines drawn with
 draw-lines in dc<%>.
When a path is filled or used as a region, the open sub-path (if any)
 is treated as if it were closed. The content of a path is determined
 either through the 'even-odd rule or the 'winding
 rule, as selected at the time when the path is filled or used to
 generate a region.
A path is not connected to any particular dc<%> object, so
 setting a dc<%> origin or scale does not affect path
 operations. Instead, a dc<%>’s origin and scale apply at the
 time that the path is drawn or used to set a region.
Creates a new path that contains no sub-paths (and no 
open
sub-path).
Extends or starts the path’s 
open sub-path with a curve that
 corresponds to a section of an ellipse. If 
width and 
height
 are non-negative, the ellipse is the one
 bounded by a rectangle whose top-left corner is 
(
x,
y)
 and whose dimensions are 
width by
 
height; if 
width is negative, then
 the rectangle’s right edge is 
x, and the ellipse
 width is 
(abs width), while a negative 
height
 similarly makes 
y is the bottom edge of the ellipse and
 the height 
(abs height).
 
Support for negative width and height
helps avoid round-off problems for aligned drawing in an eventual
destination, since arc reduces its input to a sequence of curves.
In contrast, draw-arc in dc<%> can automatically correct for round off,
since the drawing mode is known immediately.
 The ellipse section starts a the angle
 
start-radians (
0 is three o’clock and half-π is
 twelve o’clock) and continues to the angle 
end-radians; if
 
counter-clockwise? is true, then the arc runs
 counter-clockwise from 
start-radians to
 
end-radians, otherwise it runs clockwise.
If the path has no open sub-path, a new one is started with the
 arc’s starting point. Otherwise, the arc extends the existing
 sub-path, and the existing path is connected with a line to the arc’s
 starting point.
Closes the 
open sub-path, if any, and adds a 
closed
sub-path that represents an ellipse bounded by a rectangle whose
 top-left corner is 
(
x, y)
 and whose
 dimensions are 
width by 
height. (This convenience
 method is implemented in terms of 
close and
 
arc.)
Returns a rectangle that encloses the path’s points.  The return
 values are the left, top, width, and height of the rectangle.
For curves within the path, the bounding box enclosed the two control
 points as well as the start and end points. Thus, the bounding box
 does not always tightly bound the path.
Extends the path’s 
open sub-path with a sequences of lines to
 the given points. A pair is treated as a point where the 
car
 of the pair is the x-value and the 
cdr is the y-value.
 If the path has no 
open sub-path,
 an 
exn:fail:contract exception is raised.  (This convenience method is implemented in terms of
 
line-to.)
Closes the 
open sub-path, if any, and adds a closed path that
 represents a rectangle whose top-left corner is 
(
x,
y)
 and whose dimensions are 
width by
 
height. (This convenience method is implemented in terms of
 
close, 
move-to, and
 
line-to.)
Removes all sub-paths of the path.
Reverses the order of all points in all sub-paths. If the path has an
 
open sub-path, the starting point becomes the ending point,
 and extensions to the 
open sub-path build on this new ending
 point. Reversing a 
closed sub-path affects how it combines
 with other sub-paths when determining the content of a path in
 
'winding mode.
Adjusts all points within the path (including all sub-paths), rotating
 them radians counter-clockwise around (0, 0). Future
 additions to the path are not rotated by this call.
Closes the 
open sub-path, if any, and adds a 
closed
sub-path that represents a round-cornered rectangle whose top-left
 corner is 
(
x y)
 and whose dimensions are
 
width by 
height. (This convenience method is
 implemented in terms of 
close, 
move-to, 
arc, and 
line-to.)
If radius is positive, the value is used as the radius of the
 rounded corner. If radius is negative, the absolute value is
 used as the proportion of the smallest dimension of the
 rectangle.
If radius is less than -0.5 or more than half of
 width or height, an exn:fail:contract exception is raised.
Adjusts all points within the path
 (including all sub-paths), multiplying each x-coordinate by
 
x and each y-coordinate by 
y. Scaling by a negative
 number flips the path over the corresponding axis. Future additions
 to the path are not scaled by this call.
Closes the 
open sub-path, if any, and adds a 
closed
sub-path to outline 
str using 
font. The
 top left of the text is positioned at 
x and 
y. The
 
combine? argument enables kerning and character combinations
 as for 
draw-text in 
dc<%>.
Adjusts all points within the path (including all sub-paths) by
applying the transformation represented by m.
See get-initial-matrix for information on the matrix as
 represented by a vector m.
Adjusts all points within the path (including all sub-paths), shifting
 then x to the right and y down.  Future additions
 to the path are not translated by this call.