trivial docu patch
[p5sagit/p5-mst-13.2.git] / pod / perlapi.pod
index 516b2e7..d55b88a 100644 (file)
@@ -17,6 +17,85 @@ unadorned names, but this support may be disabled in a future release.
 
 The listing is alphabetical, case insensitive.
 
+
+=head1 "Gimme" Values
+
+=over 8
+
+=item GIMME
+
+A backward-compatible version of C<GIMME_V> which can only return
+C<G_SCALAR> or C<G_ARRAY>; in a void context, it returns C<G_SCALAR>.
+Deprecated.  Use C<GIMME_V> instead.
+
+       U32     GIMME
+
+=for hackers
+Found in file op.h
+
+=item GIMME_V
+
+The XSUB-writer's equivalent to Perl's C<wantarray>.  Returns C<G_VOID>,
+C<G_SCALAR> or C<G_ARRAY> for void, scalar or list context,
+respectively.
+
+       U32     GIMME_V
+
+=for hackers
+Found in file op.h
+
+=item G_ARRAY
+
+Used to indicate list context.  See C<GIMME_V>, C<GIMME> and
+L<perlcall>.
+
+=for hackers
+Found in file cop.h
+
+=item G_DISCARD
+
+Indicates that arguments returned from a callback should be discarded.  See
+L<perlcall>.
+
+=for hackers
+Found in file cop.h
+
+=item G_EVAL
+
+Used to force a Perl C<eval> wrapper around a callback.  See
+L<perlcall>.
+
+=for hackers
+Found in file cop.h
+
+=item G_NOARGS
+
+Indicates that no arguments are being sent to a callback.  See
+L<perlcall>.
+
+=for hackers
+Found in file cop.h
+
+=item G_SCALAR
+
+Used to indicate scalar context.  See C<GIMME_V>, C<GIMME>, and
+L<perlcall>.
+
+=for hackers
+Found in file cop.h
+
+=item G_VOID
+
+Used to indicate void context.  See C<GIMME_V> and L<perlcall>.
+
+=for hackers
+Found in file cop.h
+
+
+=back
+
+=head1 Array Manipulation Functions
+
 =over 8
 
 =item AvFILL
@@ -182,47 +261,53 @@ must then use C<av_store> to assign values to these new elements.
 =for hackers
 Found in file av.c
 
-=item ax
+=item get_av
 
-Variable which is setup by C<xsubpp> to indicate the stack base offset,
-used by the C<ST>, C<XSprePUSH> and C<XSRETURN> macros.  The C<dMARK> macro
-must be called prior to setup the C<MARK> variable.
+Returns the AV of the specified Perl array.  If C<create> is set and the
+Perl variable does not exist then it will be created.  If C<create> is not
+set and the variable does not exist then NULL is returned.
 
-       I32     ax
+NOTE: the perl_ form of this function is deprecated.
+
+       AV*     get_av(const char* name, I32 create)
 
 =for hackers
-Found in file XSUB.h
+Found in file perl.c
 
-=item bytes_from_utf8
+=item newAV
 
-Converts a string C<s> of length C<len> from UTF8 into byte encoding.
-Unlike <utf8_to_bytes> but like C<bytes_to_utf8>, returns a pointer to
-the newly-created string, and updates C<len> to contain the new
-length.  Returns the original string if no conversion occurs, C<len>
-is unchanged. Do nothing if C<is_utf8> points to 0. Sets C<is_utf8> to
-0 if C<s> is converted or contains all 7bit characters.
+Creates a new AV.  The reference count is set to 1.
 
-NOTE: this function is experimental and may change or be
-removed without notice.
+       AV*     newAV()
+
+=for hackers
+Found in file av.c
+
+=item Nullav
+
+Null AV pointer.
 
-       U8*     bytes_from_utf8(U8 *s, STRLEN *len, bool *is_utf8)
 
 =for hackers
-Found in file utf8.c
+Found in file av.h
 
-=item bytes_to_utf8
+=item sortsv
 
-Converts a string C<s> of length C<len> from ASCII into UTF8 encoding.
-Returns a pointer to the newly-created string, and sets C<len> to
-reflect the new length.
+Sort an array. Here is an example:
 
-NOTE: this function is experimental and may change or be
-removed without notice.
+    sortsv(AvARRAY(av), av_len(av)+1, Perl_sv_cmp_locale);
 
-       U8*     bytes_to_utf8(U8 *s, STRLEN *len)
+       void    sortsv(SV ** array, size_t num_elts, SVCOMPARE_t cmp)
 
 =for hackers
-Found in file utf8.c
+Found in file pp_sort.c
+
+
+=back
+
+=head1 Callback Functions
+
+=over 8
 
 =item call_argv
 
@@ -270,232 +355,181 @@ NOTE: the perl_ form of this function is deprecated.
 =for hackers
 Found in file perl.c
 
-=item CLASS
+=item ENTER
 
-Variable which is setup by C<xsubpp> to indicate the 
-class name for a C++ XS constructor.  This is always a C<char*>.  See C<THIS>.
+Opening bracket on a callback.  See C<LEAVE> and L<perlcall>.
 
-       char*   CLASS
+               ENTER;
 
 =for hackers
-Found in file XSUB.h
+Found in file scope.h
 
-=item Copy
+=item eval_pv
 
-The XSUB-writer's interface to the C C<memcpy> function.  The C<src> is the
-source, C<dest> is the destination, C<nitems> is the number of items, and C<type> is
-the type.  May fail on overlapping copies.  See also C<Move>.
+Tells Perl to C<eval> the given string and return an SV* result.
 
-       void    Copy(void* src, void* dest, int nitems, type)
+NOTE: the perl_ form of this function is deprecated.
 
-=for hackers
-Found in file handy.h
+       SV*     eval_pv(const char* p, I32 croak_on_error)
 
-=item croak
+=for hackers
+Found in file perl.c
 
-This is the XSUB-writer's interface to Perl's C<die> function.
-Normally use this function the same way you use the C C<printf>
-function.  See C<warn>.
+=item eval_sv
 
-If you want to throw an exception object, assign the object to
-C<$@> and then pass C<Nullch> to croak():
+Tells Perl to C<eval> the string in the SV.
 
-   errsv = get_sv("@", TRUE);
-   sv_setsv(errsv, exception_object);
-   croak(Nullch);
+NOTE: the perl_ form of this function is deprecated.
 
-       void    croak(const char* pat, ...)
+       I32     eval_sv(SV* sv, I32 flags)
 
 =for hackers
-Found in file util.c
+Found in file perl.c
 
-=item CvSTASH
+=item FREETMPS
 
-Returns the stash of the CV.
+Closing bracket for temporaries on a callback.  See C<SAVETMPS> and
+L<perlcall>.
 
-       HV*     CvSTASH(CV* cv)
+               FREETMPS;
 
 =for hackers
-Found in file cv.h
-
-=item cv_const_sv
+Found in file scope.h
 
-If C<cv> is a constant sub eligible for inlining. returns the constant
-value returned by the sub.  Otherwise, returns NULL.
+=item LEAVE
 
-Constant subs can be created with C<newCONSTSUB> or as described in
-L<perlsub/"Constant Functions">.
+Closing bracket on a callback.  See C<ENTER> and L<perlcall>.
 
-       SV*     cv_const_sv(CV* cv)
+               LEAVE;
 
 =for hackers
-Found in file op.c
+Found in file scope.h
 
-=item dAX
+=item SAVETMPS
 
-Sets up the C<ax> variable.
-This is usually handled automatically by C<xsubpp> by calling C<dXSARGS>.
+Opening bracket for temporaries on a callback.  See C<FREETMPS> and
+L<perlcall>.
 
-               dAX;
+               SAVETMPS;
 
 =for hackers
-Found in file XSUB.h
+Found in file scope.h
 
-=item dITEMS
 
-Sets up the C<items> variable.
-This is usually handled automatically by C<xsubpp> by calling C<dXSARGS>.
+=back
 
-               dITEMS;
+=head1 Character classes
 
-=for hackers
-Found in file XSUB.h
+=over 8
 
-=item dMARK
+=item isALNUM
 
-Declare a stack marker variable, C<mark>, for the XSUB.  See C<MARK> and
-C<dORIGMARK>.
+Returns a boolean indicating whether the C C<char> is an ASCII alphanumeric
+character (including underscore) or digit.
 
-               dMARK;
+       bool    isALNUM(char ch)
 
 =for hackers
-Found in file pp.h
+Found in file handy.h
 
-=item dORIGMARK
+=item isALPHA
 
-Saves the original stack mark for the XSUB.  See C<ORIGMARK>.
+Returns a boolean indicating whether the C C<char> is an ASCII alphabetic
+character.
 
-               dORIGMARK;
+       bool    isALPHA(char ch)
 
 =for hackers
-Found in file pp.h
+Found in file handy.h
 
-=item dSP
+=item isDIGIT
 
-Declares a local copy of perl's stack pointer for the XSUB, available via
-the C<SP> macro.  See C<SP>.
+Returns a boolean indicating whether the C C<char> is an ASCII
+digit.
 
-               dSP;
+       bool    isDIGIT(char ch)
 
 =for hackers
-Found in file pp.h
+Found in file handy.h
 
-=item dXSARGS
+=item isLOWER
 
-Sets up stack and mark pointers for an XSUB, calling dSP and dMARK.
-Sets up the C<ax> and C<items> variables by calling C<dAX> and C<dITEMS>.
-This is usually handled automatically by C<xsubpp>.
+Returns a boolean indicating whether the C C<char> is a lowercase
+character.
 
-               dXSARGS;
+       bool    isLOWER(char ch)
 
 =for hackers
-Found in file XSUB.h
+Found in file handy.h
 
-=item dXSI32
+=item isSPACE
 
-Sets up the C<ix> variable for an XSUB which has aliases.  This is usually
-handled automatically by C<xsubpp>.
+Returns a boolean indicating whether the C C<char> is whitespace.
 
-               dXSI32;
+       bool    isSPACE(char ch)
 
 =for hackers
-Found in file XSUB.h
+Found in file handy.h
 
-=item ENTER
-
-Opening bracket on a callback.  See C<LEAVE> and L<perlcall>.
-
-               ENTER;
-
-=for hackers
-Found in file scope.h
-
-=item eval_pv
-
-Tells Perl to C<eval> the given string and return an SV* result.
-
-NOTE: the perl_ form of this function is deprecated.
-
-       SV*     eval_pv(const char* p, I32 croak_on_error)
-
-=for hackers
-Found in file perl.c
-
-=item eval_sv
-
-Tells Perl to C<eval> the string in the SV.
+=item isUPPER
 
-NOTE: the perl_ form of this function is deprecated.
+Returns a boolean indicating whether the C C<char> is an uppercase
+character.
 
-       I32     eval_sv(SV* sv, I32 flags)
+       bool    isUPPER(char ch)
 
 =for hackers
-Found in file perl.c
+Found in file handy.h
 
-=item EXTEND
+=item toLOWER
 
-Used to extend the argument stack for an XSUB's return values. Once
-used, guarantees that there is room for at least C<nitems> to be pushed
-onto the stack.
+Converts the specified character to lowercase.
 
-       void    EXTEND(SP, int nitems)
+       char    toLOWER(char ch)
 
 =for hackers
-Found in file pp.h
+Found in file handy.h
 
-=item fbm_compile
+=item toUPPER
 
-Analyses the string in order to make fast searches on it using fbm_instr()
--- the Boyer-Moore algorithm.
+Converts the specified character to uppercase.
 
-       void    fbm_compile(SV* sv, U32 flags)
+       char    toUPPER(char ch)
 
 =for hackers
-Found in file util.c
+Found in file handy.h
 
-=item fbm_instr
 
-Returns the location of the SV in the string delimited by C<str> and
-C<strend>.  It returns C<Nullch> if the string can't be found.  The C<sv>
-does not have to be fbm_compiled, but the search will not be as fast
-then.
+=back
 
-       char*   fbm_instr(unsigned char* big, unsigned char* bigend, SV* littlesv, U32 flags)
+=head1 Cloning an interpreter
 
-=for hackers
-Found in file util.c
+=over 8
 
-=item FREETMPS
+=item perl_clone
 
-Closing bracket for temporaries on a callback.  See C<SAVETMPS> and
-L<perlcall>.
+Create and return a new interpreter by cloning the current one.
 
-               FREETMPS;
+       PerlInterpreter*        perl_clone(PerlInterpreter* interp, UV flags)
 
 =for hackers
-Found in file scope.h
-
-=item getcwd_sv
+Found in file sv.c
 
-Fill the sv with current working directory
 
-       int     getcwd_sv(SV* sv)
+=back
 
-=for hackers
-Found in file util.c
+=head1 CV Manipulation Functions
 
-=item get_av
+=over 8
 
-Returns the AV of the specified Perl array.  If C<create> is set and the
-Perl variable does not exist then it will be created.  If C<create> is not
-set and the variable does not exist then NULL is returned.
+=item CvSTASH
 
-NOTE: the perl_ form of this function is deprecated.
+Returns the stash of the CV.
 
-       AV*     get_av(const char* name, I32 create)
+       HV*     CvSTASH(CV* cv)
 
 =for hackers
-Found in file perl.c
+Found in file cv.h
 
 =item get_cv
 
@@ -511,162 +545,186 @@ NOTE: the perl_ form of this function is deprecated.
 =for hackers
 Found in file perl.c
 
-=item get_hv
-
-Returns the HV of the specified Perl hash.  If C<create> is set and the
-Perl variable does not exist then it will be created.  If C<create> is not
-set and the variable does not exist then NULL is returned.
+=item Nullcv
 
-NOTE: the perl_ form of this function is deprecated.
+Null CV pointer.
 
-       HV*     get_hv(const char* name, I32 create)
 
 =for hackers
-Found in file perl.c
+Found in file cv.h
 
-=item get_sv
 
-Returns the SV of the specified Perl scalar.  If C<create> is set and the
-Perl variable does not exist then it will be created.  If C<create> is not
-set and the variable does not exist then NULL is returned.
+=back
 
-NOTE: the perl_ form of this function is deprecated.
+=head1 Embedding Functions
 
-       SV*     get_sv(const char* name, I32 create)
+=over 8
+
+=item load_module
+
+Loads the module whose name is pointed to by the string part of name.
+Note that the actual module name, not its filename, should be given.
+Eg, "Foo::Bar" instead of "Foo/Bar.pm".  flags can be any of
+PERL_LOADMOD_DENY, PERL_LOADMOD_NOIMPORT, or PERL_LOADMOD_IMPORT_OPS
+(or 0 for no flags). ver, if specified, provides version semantics
+similar to C<use Foo::Bar VERSION>.  The optional trailing SV*
+arguments can be used to specify arguments to the module's import()
+method, similar to C<use Foo::Bar VERSION LIST>.
+
+       void    load_module(U32 flags, SV* name, SV* ver, ...)
 
 =for hackers
-Found in file perl.c
+Found in file op.c
 
-=item GIMME
+=item perl_alloc
 
-A backward-compatible version of C<GIMME_V> which can only return
-C<G_SCALAR> or C<G_ARRAY>; in a void context, it returns C<G_SCALAR>.
-Deprecated.  Use C<GIMME_V> instead.
+Allocates a new Perl interpreter.  See L<perlembed>.
 
-       U32     GIMME
+       PerlInterpreter*        perl_alloc()
 
 =for hackers
-Found in file op.h
+Found in file perl.c
 
-=item GIMME_V
+=item perl_construct
 
-The XSUB-writer's equivalent to Perl's C<wantarray>.  Returns C<G_VOID>,
-C<G_SCALAR> or C<G_ARRAY> for void, scalar or list context,
-respectively.
+Initializes a new Perl interpreter.  See L<perlembed>.
 
-       U32     GIMME_V
+       void    perl_construct(PerlInterpreter* interp)
 
 =for hackers
-Found in file op.h
+Found in file perl.c
 
-=item grok_bin
+=item perl_destruct
 
-converts a string representing a binary number to numeric form.
+Shuts down a Perl interpreter.  See L<perlembed>.
 
-On entry I<start> and I<*len> give the string to scan, I<*flags> gives
-conversion flags, and I<result> should be NULL or a pointer to an NV.
-The scan stops at the end of the string, or the first invalid character.
-On return I<*len> is set to the length scanned string, and I<*flags> gives
-output flags.
+       int     perl_destruct(PerlInterpreter* interp)
 
-If the value is <= UV_MAX it is returned as a UV, the output flags are clear,
-and nothing is written to I<*result>. If the value is > UV_MAX C<grok_bin>
-returns UV_MAX, sets C<PERL_SCAN_GREATER_THAN_UV_MAX> in the output flags,
-and writes the value to I<*result> (or the value is discarded if I<result>
-is NULL).
+=for hackers
+Found in file perl.c
 
-The hex number may optinally be prefixed with "0b" or "b" unless
-C<PERL_SCAN_DISALLOW_PREFIX> is set in I<*flags> on entry. If
-C<PERL_SCAN_ALLOW_UNDERSCORES> is set in I<*flags> then the binary
-number may use '_' characters to separate digits.
+=item perl_free
 
-       UV      grok_bin(char* start, STRLEN* len, I32* flags, NV *result)
+Releases a Perl interpreter.  See L<perlembed>.
+
+       void    perl_free(PerlInterpreter* interp)
 
 =for hackers
-Found in file numeric.c
+Found in file perl.c
 
-=item grok_hex
+=item perl_parse
 
-converts a string representing a hex number to numeric form.
+Tells a Perl interpreter to parse a Perl script.  See L<perlembed>.
 
-On entry I<start> and I<*len> give the string to scan, I<*flags> gives
-conversion flags, and I<result> should be NULL or a pointer to an NV.
-The scan stops at the end of the string, or the first non-hex-digit character.
-On return I<*len> is set to the length scanned string, and I<*flags> gives
-output flags.
+       int     perl_parse(PerlInterpreter* interp, XSINIT_t xsinit, int argc, char** argv, char** env)
 
-If the value is <= UV_MAX it is returned as a UV, the output flags are clear,
-and nothing is written to I<*result>. If the value is > UV_MAX C<grok_hex>
-returns UV_MAX, sets C<PERL_SCAN_GREATER_THAN_UV_MAX> in the output flags,
-and writes the value to I<*result> (or the value is discarded if I<result>
-is NULL).
+=for hackers
+Found in file perl.c
 
-The hex number may optinally be prefixed with "0x" or "x" unless
-C<PERL_SCAN_DISALLOW_PREFIX> is set in I<*flags> on entry. If
-C<PERL_SCAN_ALLOW_UNDERSCORES> is set in I<*flags> then the hex
-number may use '_' characters to separate digits.
+=item perl_run
 
-       UV      grok_hex(char* start, STRLEN* len, I32* flags, NV *result)
+Tells a Perl interpreter to run.  See L<perlembed>.
 
-=for hackers
-Found in file numeric.c
+       int     perl_run(PerlInterpreter* interp)
 
-=item grok_number
+=for hackers
+Found in file perl.c
 
-Recognise (or not) a number.  The type of the number is returned
-(0 if unrecognised), otherwise it is a bit-ORed combination of
-IS_NUMBER_IN_UV, IS_NUMBER_GREATER_THAN_UV_MAX, IS_NUMBER_NOT_INT,
-IS_NUMBER_NEG, IS_NUMBER_INFINITY, IS_NUMBER_NAN (defined in perl.h).
+=item require_pv
 
-If the value of the number can fit an in UV, it is returned in the *valuep
-IS_NUMBER_IN_UV will be set to indicate that *valuep is valid, IS_NUMBER_IN_UV
-will never be set unless *valuep is valid, but *valuep may have been assigned
-to during processing even though IS_NUMBER_IN_UV is not set on return.
-If valuep is NULL, IS_NUMBER_IN_UV will be set for the same cases as when
-valuep is non-NULL, but no actual assignment (or SEGV) will occur.
+Tells Perl to C<require> the file named by the string argument.  It is
+analogous to the Perl code C<eval "require '$file'">.  It's even
+implemented that way; consider using Perl_load_module instead.
 
-IS_NUMBER_NOT_INT will be set with IS_NUMBER_IN_UV if trailing decimals were
-seen (in which case *valuep gives the true value truncated to an integer), and
-IS_NUMBER_NEG if the number is negative (in which case *valuep holds the
-absolute value).  IS_NUMBER_IN_UV is not set if e notation was used or the
-number is larger than a UV.
+NOTE: the perl_ form of this function is deprecated.
 
-       int     grok_number(const char *pv, STRLEN len, UV *valuep)
+       void    require_pv(const char* pv)
 
 =for hackers
-Found in file numeric.c
+Found in file perl.c
 
-=item grok_numeric_radix
 
-Scan and skip for a numeric decimal separator (radix).
+=back
 
-       bool    grok_numeric_radix(const char **sp, const char *send)
+=head1 Global Variables
 
-=for hackers
-Found in file numeric.c
+=over 8
 
-=item grok_oct
+=item PL_modglobal
 
+C<PL_modglobal> is a general purpose, interpreter global HV for use by
+extensions that need to keep information on a per-interpreter basis.
+In a pinch, it can also be used as a symbol table for extensions
+to share data among each other.  It is a good idea to use keys
+prefixed by the package name of the extension that owns the data.
 
-       UV      grok_oct(char* start, STRLEN* len, I32* flags, NV *result)
+       HV*     PL_modglobal
 
 =for hackers
-Found in file numeric.c
+Found in file intrpvar.h
 
-=item GvSV
+=item PL_na
 
-Return the SV from the GV.
+A convenience variable which is typically used with C<SvPV> when one
+doesn't care about the length of the string.  It is usually more efficient
+to either declare a local variable and use that instead or to use the
+C<SvPV_nolen> macro.
 
-       SV*     GvSV(GV* gv)
+       STRLEN  PL_na
 
 =for hackers
-Found in file gv.h
-
-=item gv_fetchmeth
+Found in file thrdvar.h
 
-Returns the glob with the given C<name> and a defined subroutine or
-C<NULL>.  The glob lives in the given C<stash>, or in the stashes
-accessible via @ISA and UNIVERSAL::.
+=item PL_sv_no
+
+This is the C<false> SV.  See C<PL_sv_yes>.  Always refer to this as
+C<&PL_sv_no>.
+
+       SV      PL_sv_no
+
+=for hackers
+Found in file intrpvar.h
+
+=item PL_sv_undef
+
+This is the C<undef> SV.  Always refer to this as C<&PL_sv_undef>.
+
+       SV      PL_sv_undef
+
+=for hackers
+Found in file intrpvar.h
+
+=item PL_sv_yes
+
+This is the C<true> SV.  See C<PL_sv_no>.  Always refer to this as
+C<&PL_sv_yes>.
+
+       SV      PL_sv_yes
+
+=for hackers
+Found in file intrpvar.h
+
+
+=back
+
+=head1 GV Functions
+
+=over 8
+
+=item GvSV
+
+Return the SV from the GV.
+
+       SV*     GvSV(GV* gv)
+
+=for hackers
+Found in file gv.h
+
+=item gv_fetchmeth
+
+Returns the glob with the given C<name> and a defined subroutine or
+C<NULL>.  The glob lives in the given C<stash>, or in the stashes
+accessible via @ISA and UNIVERSAL::.
 
 The argument C<level> should be either 0 or -1.  If C<level==0>, as a
 side-effect creates a glob with the given C<name> in the given C<stash>
@@ -744,61 +802,55 @@ valid UTF-8 string.  See C<gv_stashpv>.
 =for hackers
 Found in file gv.c
 
-=item G_ARRAY
 
-Used to indicate list context.  See C<GIMME_V>, C<GIMME> and
-L<perlcall>.
+=back
 
-=for hackers
-Found in file cop.h
+=head1 Handy Values
 
-=item G_DISCARD
+=over 8
 
-Indicates that arguments returned from a callback should be discarded.  See
-L<perlcall>.
+=item HEf_SVKEY
 
-=for hackers
-Found in file cop.h
+This flag, used in the length slot of hash entries and magic structures,
+specifies the structure contains an C<SV*> pointer where a C<char*> pointer
+is to be expected. (For information only--not to be used).
 
-=item G_EVAL
 
-Used to force a Perl C<eval> wrapper around a callback.  See
-L<perlcall>.
+=for hackers
+Found in file hv.h
 
+=item Nullch 
+
+Null character pointer.
 =for hackers
-Found in file cop.h
+Found in file handy.h
 
-=item G_NOARGS
+=item Nullsv
 
-Indicates that no arguments are being sent to a callback.  See
-L<perlcall>.
+Null SV pointer.
 
 =for hackers
-Found in file cop.h
+Found in file handy.h
 
-=item G_SCALAR
 
-Used to indicate scalar context.  See C<GIMME_V>, C<GIMME>, and
-L<perlcall>.
+=back
 
-=for hackers
-Found in file cop.h
+=head1 Hash Manipulation Functions
 
-=item G_VOID
+=over 8
 
-Used to indicate void context.  See C<GIMME_V> and L<perlcall>.
+=item get_hv
 
-=for hackers
-Found in file cop.h
+Returns the HV of the specified Perl hash.  If C<create> is set and the
+Perl variable does not exist then it will be created.  If C<create> is not
+set and the variable does not exist then NULL is returned.
 
-=item HEf_SVKEY
+NOTE: the perl_ form of this function is deprecated.
 
-This flag, used in the length slot of hash entries and magic structures,
-specifies the structure contains a C<SV*> pointer where a C<char*> pointer
-is to be expected. (For information only--not to be used).
+       HV*     get_hv(const char* name, I32 create)
 
 =for hackers
-Found in file hv.h
+Found in file perl.c
 
 =item HeHASH
 
@@ -958,7 +1010,7 @@ Found in file hv.c
 Returns the SV which corresponds to the specified key in the hash.  The
 C<klen> is the length of the key.  If C<lval> is set then the fetch will be
 part of a store.  Check that the return value is non-null before
-dereferencing it to a C<SV*>.
+dereferencing it to an C<SV*>.
 
 See L<perlguts/"Understanding the Magic of Tied Hashes and Arrays"> for more
 information on how to use this function on tied hashes.
@@ -1108,151 +1160,29 @@ Undefines the hash.
 =for hackers
 Found in file hv.c
 
-=item isALNUM
-
-Returns a boolean indicating whether the C C<char> is an ASCII alphanumeric
-character (including underscore) or digit.
-
-       bool    isALNUM(char ch)
-
-=for hackers
-Found in file handy.h
-
-=item isALPHA
-
-Returns a boolean indicating whether the C C<char> is an ASCII alphabetic
-character.
-
-       bool    isALPHA(char ch)
-
-=for hackers
-Found in file handy.h
-
-=item isDIGIT
-
-Returns a boolean indicating whether the C C<char> is an ASCII
-digit.
-
-       bool    isDIGIT(char ch)
-
-=for hackers
-Found in file handy.h
-
-=item isLOWER
-
-Returns a boolean indicating whether the C C<char> is a lowercase
-character.
-
-       bool    isLOWER(char ch)
-
-=for hackers
-Found in file handy.h
-
-=item isSPACE
-
-Returns a boolean indicating whether the C C<char> is whitespace.
-
-       bool    isSPACE(char ch)
-
-=for hackers
-Found in file handy.h
-
-=item isUPPER
-
-Returns a boolean indicating whether the C C<char> is an uppercase
-character.
-
-       bool    isUPPER(char ch)
-
-=for hackers
-Found in file handy.h
-
-=item is_utf8_char
-
-Tests if some arbitrary number of bytes begins in a valid UTF-8
-character.  Note that an INVARIANT (i.e. ASCII) character is a valid UTF-8 character.
-The actual number of bytes in the UTF-8 character will be returned if
-it is valid, otherwise 0.
-
-       STRLEN  is_utf8_char(U8 *p)
-
-=for hackers
-Found in file utf8.c
-
-=item is_utf8_string
-
-Returns true if first C<len> bytes of the given string form a valid UTF8
-string, false otherwise.  Note that 'a valid UTF8 string' does not mean
-'a string that contains UTF8' because a valid ASCII string is a valid
-UTF8 string.
-
-       bool    is_utf8_string(U8 *s, STRLEN len)
-
-=for hackers
-Found in file utf8.c
-
-=item items
-
-Variable which is setup by C<xsubpp> to indicate the number of 
-items on the stack.  See L<perlxs/"Variable-length Parameter Lists">.
-
-       I32     items
-
-=for hackers
-Found in file XSUB.h
-
-=item ix
-
-Variable which is setup by C<xsubpp> to indicate which of an 
-XSUB's aliases was used to invoke it.  See L<perlxs/"The ALIAS: Keyword">.
-
-       I32     ix
-
-=for hackers
-Found in file XSUB.h
-
-=item LEAVE
+=item newHV
 
-Closing bracket on a callback.  See C<ENTER> and L<perlcall>.
+Creates a new HV.  The reference count is set to 1.
 
-               LEAVE;
+       HV*     newHV()
 
 =for hackers
-Found in file scope.h
+Found in file hv.c
 
-=item load_module
+=item Nullhv
 
-Loads the module whose name is pointed to by the string part of name.
-Note that the actual module name, not its filename, should be given.
-Eg, "Foo::Bar" instead of "Foo/Bar.pm".  flags can be any of
-PERL_LOADMOD_DENY, PERL_LOADMOD_NOIMPORT, or PERL_LOADMOD_IMPORT_OPS
-(or 0 for no flags). ver, if specified, provides version semantics
-similar to C<use Foo::Bar VERSION>.  The optional trailing SV*
-arguments can be used to specify arguments to the module's import()
-method, similar to C<use Foo::Bar VERSION LIST>.
+Null HV pointer.
 
-       void    load_module(U32 flags, SV* name, SV* ver, ...)
 
 =for hackers
-Found in file op.c
-
-=item looks_like_number
-
-Test if the content of an SV looks like a number (or is a number).
-C<Inf> and C<Infinity> are treated as numbers (so will not issue a
-non-numeric warning), even if your atof() doesn't grok them.
-
-       I32     looks_like_number(SV* sv)
+Found in file hv.h
 
-=for hackers
-Found in file sv.c
 
-=item MARK
+=back
 
-Stack marker variable for the XSUB.  See C<dMARK>.
+=head1 Magical Functions
 
-=for hackers
-Found in file pp.h
+=over 8
 
 =item mg_clear
 
@@ -1326,83 +1256,102 @@ Do magic after a value is assigned to the SV.  See C<sv_magic>.
 =for hackers
 Found in file mg.c
 
-=item Move
+=item SvGETMAGIC
 
-The XSUB-writer's interface to the C C<memmove> function.  The C<src> is the
-source, C<dest> is the destination, C<nitems> is the number of items, and C<type> is
-the type.  Can do overlapping moves.  See also C<Copy>.
+Invokes C<mg_get> on an SV if it has 'get' magic.  This macro evaluates its
+argument more than once.
 
-       void    Move(void* src, void* dest, int nitems, type)
+       void    SvGETMAGIC(SV* sv)
 
 =for hackers
-Found in file handy.h
+Found in file sv.h
 
-=item New
+=item SvSETMAGIC
 
-The XSUB-writer's interface to the C C<malloc> function.
+Invokes C<mg_set> on an SV if it has 'set' magic.  This macro evaluates its
+argument more than once.
 
-       void    New(int id, void* ptr, int nitems, type)
+       void    SvSETMAGIC(SV* sv)
 
 =for hackers
-Found in file handy.h
+Found in file sv.h
 
-=item newAV
+=item SvSetMagicSV
 
-Creates a new AV.  The reference count is set to 1.
+Like C<SvSetSV>, but does any set magic required afterwards.
 
-       AV*     newAV()
+       void    SvSetMagicSV(SV* dsb, SV* ssv)
 
 =for hackers
-Found in file av.c
+Found in file sv.h
 
-=item Newc
+=item SvSetSV
 
-The XSUB-writer's interface to the C C<malloc> function, with
-cast.
+Calls C<sv_setsv> if dsv is not the same as ssv.  May evaluate arguments
+more than once.
 
-       void    Newc(int id, void* ptr, int nitems, type, cast)
+       void    SvSetSV(SV* dsb, SV* ssv)
 
 =for hackers
-Found in file handy.h
+Found in file sv.h
 
-=item newCONSTSUB
+=item SvSetSV_nosteal
 
-Creates a constant sub equivalent to Perl C<sub FOO () { 123 }> which is
-eligible for inlining at compile-time.
+Calls a non-destructive version of C<sv_setsv> if dsv is not the same as
+ssv. May evaluate arguments more than once.
 
-       CV*     newCONSTSUB(HV* stash, char* name, SV* sv)
+       void    SvSetSV_nosteal(SV* dsv, SV* ssv)
 
 =for hackers
-Found in file op.c
+Found in file sv.h
 
-=item newHV
 
-Creates a new HV.  The reference count is set to 1.
+=back
 
-       HV*     newHV()
+=head1 Memory Management
+
+=over 8
+
+=item Copy
+
+The XSUB-writer's interface to the C C<memcpy> function.  The C<src> is the
+source, C<dest> is the destination, C<nitems> is the number of items, and C<type> is
+the type.  May fail on overlapping copies.  See also C<Move>.
+
+       void    Copy(void* src, void* dest, int nitems, type)
 
 =for hackers
-Found in file hv.c
+Found in file handy.h
 
-=item newRV_inc
+=item Move
 
-Creates an RV wrapper for an SV.  The reference count for the original SV is
-incremented.
+The XSUB-writer's interface to the C C<memmove> function.  The C<src> is the
+source, C<dest> is the destination, C<nitems> is the number of items, and C<type> is
+the type.  Can do overlapping moves.  See also C<Copy>.
 
-       SV*     newRV_inc(SV* sv)
+       void    Move(void* src, void* dest, int nitems, type)
 
 =for hackers
-Found in file sv.h
+Found in file handy.h
 
-=item newRV_noinc
+=item New
 
-Creates an RV wrapper for an SV.  The reference count for the original
-SV is B<not> incremented.
+The XSUB-writer's interface to the C C<malloc> function.
 
-       SV*     newRV_noinc(SV *sv)
+       void    New(int id, void* ptr, int nitems, type)
 
 =for hackers
-Found in file sv.c
+Found in file handy.h
+
+=item Newc
+
+The XSUB-writer's interface to the C C<malloc> function, with
+cast.
+
+       void    Newc(int id, void* ptr, int nitems, type, cast)
+
+=for hackers
+Found in file handy.h
 
 =item NEWSV
 
@@ -1412,305 +1361,523 @@ tailing NUL is also reserved.  (SvPOK is not set for the SV even if string
 space is allocated.)  The reference count for the new SV is set to 1.
 C<id> is an integer id between 0 and 1299 (used to identify leaks).
 
+
        SV*     NEWSV(int id, STRLEN len)
 
 =for hackers
 Found in file handy.h
 
-=item newSV
+=item Newz
 
-Create a new null SV, or if len > 0, create a new empty SVt_PV type SV
-with an initial PV allocation of len+1. Normally accessed via the C<NEWSV>
-macro.
+The XSUB-writer's interface to the C C<malloc> function.  The allocated
+memory is zeroed with C<memzero>.
 
-       SV*     newSV(STRLEN len)
+       void    Newz(int id, void* ptr, int nitems, type)
 
 =for hackers
-Found in file sv.c
+Found in file handy.h
 
-=item newSViv
+=item Renew
 
-Creates a new SV and copies an integer into it.  The reference count for the
-SV is set to 1.
+The XSUB-writer's interface to the C C<realloc> function.
 
-       SV*     newSViv(IV i)
+       void    Renew(void* ptr, int nitems, type)
 
 =for hackers
-Found in file sv.c
+Found in file handy.h
 
-=item newSVnv
+=item Renewc
 
-Creates a new SV and copies a floating point value into it.
-The reference count for the SV is set to 1.
+The XSUB-writer's interface to the C C<realloc> function, with
+cast.
 
-       SV*     newSVnv(NV n)
+       void    Renewc(void* ptr, int nitems, type, cast)
 
 =for hackers
-Found in file sv.c
+Found in file handy.h
 
-=item newSVpv
+=item Safefree
 
-Creates a new SV and copies a string into it.  The reference count for the
-SV is set to 1.  If C<len> is zero, Perl will compute the length using
-strlen().  For efficiency, consider using C<newSVpvn> instead.
+The XSUB-writer's interface to the C C<free> function.
 
-       SV*     newSVpv(const char* s, STRLEN len)
+       void    Safefree(void* ptr)
 
 =for hackers
-Found in file sv.c
+Found in file handy.h
 
-=item newSVpvf
+=item savepv
 
-Creates a new SV and initializes it with the string formatted like
-C<sprintf>.
+Copy a string to a safe spot.  This does not use an SV.
 
-       SV*     newSVpvf(const char* pat, ...)
+       char*   savepv(const char* sv)
 
 =for hackers
-Found in file sv.c
+Found in file util.c
 
-=item newSVpvn
+=item savepvn
 
-Creates a new SV and copies a string into it.  The reference count for the
-SV is set to 1.  Note that if C<len> is zero, Perl will create a zero length
-string.  You are responsible for ensuring that the source string is at least
-C<len> bytes long.
+Copy a string to a safe spot.  The C<len> indicates number of bytes to
+copy.  This does not use an SV.
 
-       SV*     newSVpvn(const char* s, STRLEN len)
+       char*   savepvn(const char* sv, I32 len)
 
 =for hackers
-Found in file sv.c
+Found in file util.c
 
-=item newSVpvn_share
+=item StructCopy
 
-Creates a new SV with its SvPVX pointing to a shared string in the string
-table. If the string does not already exist in the table, it is created
-first.  Turns on READONLY and FAKE.  The string's hash is stored in the UV
-slot of the SV; if the C<hash> parameter is non-zero, that value is used;
-otherwise the hash is computed.  The idea here is that as the string table
-is used for shared hash keys these strings will have SvPVX == HeKEY and
-hash lookup will avoid string compare.
+This is an architecture-independent macro to copy one structure to another.
 
-       SV*     newSVpvn_share(const char* s, I32 len, U32 hash)
+       void    StructCopy(type src, type dest, type)
 
 =for hackers
-Found in file sv.c
+Found in file handy.h
 
-=item newSVrv
+=item Zero
 
-Creates a new SV for the RV, C<rv>, to point to.  If C<rv> is not an RV then
-it will be upgraded to one.  If C<classname> is non-null then the new SV will
-be blessed in the specified package.  The new SV is returned and its
-reference count is 1.
+The XSUB-writer's interface to the C C<memzero> function.  The C<dest> is the
+destination, C<nitems> is the number of items, and C<type> is the type.
 
-       SV*     newSVrv(SV* rv, const char* classname)
+       void    Zero(void* dest, int nitems, type)
 
 =for hackers
-Found in file sv.c
+Found in file handy.h
 
-=item newSVsv
 
-Creates a new SV which is an exact duplicate of the original SV.
-(Uses C<sv_setsv>).
+=back
 
-       SV*     newSVsv(SV* old)
+=head1 Miscellaneous Functions
+
+=over 8
+
+=item fbm_compile
+
+Analyses the string in order to make fast searches on it using fbm_instr()
+-- the Boyer-Moore algorithm.
+
+       void    fbm_compile(SV* sv, U32 flags)
 
 =for hackers
-Found in file sv.c
+Found in file util.c
 
-=item newSVuv
+=item fbm_instr
 
-Creates a new SV and copies an unsigned integer into it.
-The reference count for the SV is set to 1.
+Returns the location of the SV in the string delimited by C<str> and
+C<strend>.  It returns C<Nullch> if the string can't be found.  The C<sv>
+does not have to be fbm_compiled, but the search will not be as fast
+then.
 
-       SV*     newSVuv(UV u)
+       char*   fbm_instr(unsigned char* big, unsigned char* bigend, SV* littlesv, U32 flags)
 
 =for hackers
-Found in file sv.c
+Found in file util.c
 
-=item newXS
+=item form
 
-Used by C<xsubpp> to hook up XSUBs as Perl subs.
+Takes a sprintf-style format pattern and conventional
+(non-SV) arguments and returns the formatted string.
+
+    (char *) Perl_form(pTHX_ const char* pat, ...)
+
+can be used any place a string (char *) is required:
+
+    char * s = Perl_form("%d.%d",major,minor);
+
+Uses a single private buffer so if you want to format several strings you
+must explicitly copy the earlier strings away (and free the copies when you
+are done).
+
+       char*   form(const char* pat, ...)
 
 =for hackers
-Found in file op.c
+Found in file util.c
 
-=item newXSproto
+=item getcwd_sv
 
-Used by C<xsubpp> to hook up XSUBs as Perl subs.  Adds Perl prototypes to
-the subs.
+Fill the sv with current working directory
+
+       int     getcwd_sv(SV* sv)
 
 =for hackers
-Found in file XSUB.h
+Found in file util.c
 
-=item Newz
+=item strEQ
 
-The XSUB-writer's interface to the C C<malloc> function.  The allocated
-memory is zeroed with C<memzero>.
+Test two strings to see if they are equal.  Returns true or false.
 
-       void    Newz(int id, void* ptr, int nitems, type)
+       bool    strEQ(char* s1, char* s2)
 
 =for hackers
 Found in file handy.h
 
-=item Nullav
+=item strGE
 
-Null AV pointer.
+Test two strings to see if the first, C<s1>, is greater than or equal to
+the second, C<s2>.  Returns true or false.
+
+       bool    strGE(char* s1, char* s2)
 
 =for hackers
-Found in file av.h
+Found in file handy.h
 
-=item Nullch
+=item strGT
 
-Null character pointer.
+Test two strings to see if the first, C<s1>, is greater than the second,
+C<s2>.  Returns true or false.
+
+       bool    strGT(char* s1, char* s2)
 
 =for hackers
 Found in file handy.h
 
-=item Nullcv
+=item strLE
 
-Null CV pointer.
+Test two strings to see if the first, C<s1>, is less than or equal to the
+second, C<s2>.  Returns true or false.
+
+       bool    strLE(char* s1, char* s2)
 
 =for hackers
-Found in file cv.h
+Found in file handy.h
 
-=item Nullhv
+=item strLT
 
-Null HV pointer.
+Test two strings to see if the first, C<s1>, is less than the second,
+C<s2>.  Returns true or false.
+
+       bool    strLT(char* s1, char* s2)
 
 =for hackers
-Found in file hv.h
+Found in file handy.h
 
-=item Nullsv
+=item strNE
 
-Null SV pointer.
+Test two strings to see if they are different.  Returns true or
+false.
+
+       bool    strNE(char* s1, char* s2)
 
 =for hackers
 Found in file handy.h
 
-=item ORIGMARK
+=item strnEQ
 
-The original stack mark for the XSUB.  See C<dORIGMARK>.
+Test two strings to see if they are equal.  The C<len> parameter indicates
+the number of bytes to compare.  Returns true or false. (A wrapper for
+C<strncmp>).
+
+       bool    strnEQ(char* s1, char* s2, STRLEN len)
 
 =for hackers
-Found in file pp.h
+Found in file handy.h
 
-=item perl_alloc
+=item strnNE
 
-Allocates a new Perl interpreter.  See L<perlembed>.
+Test two strings to see if they are different.  The C<len> parameter
+indicates the number of bytes to compare.  Returns true or false. (A
+wrapper for C<strncmp>).
 
-       PerlInterpreter*        perl_alloc()
+       bool    strnNE(char* s1, char* s2, STRLEN len)
 
 =for hackers
-Found in file perl.c
+Found in file handy.h
 
-=item perl_clone
 
-Create and return a new interpreter by cloning the current one.
+=back
 
-       PerlInterpreter*        perl_clone(PerlInterpreter* interp, UV flags)
+=head1 Numeric functions
+
+=over 8
+
+=item grok_bin
+
+converts a string representing a binary number to numeric form.
+
+On entry I<start> and I<*len> give the string to scan, I<*flags> gives
+conversion flags, and I<result> should be NULL or a pointer to an NV.
+The scan stops at the end of the string, or the first invalid character.
+On return I<*len> is set to the length scanned string, and I<*flags> gives
+output flags.
+
+If the value is <= UV_MAX it is returned as a UV, the output flags are clear,
+and nothing is written to I<*result>. If the value is > UV_MAX C<grok_bin>
+returns UV_MAX, sets C<PERL_SCAN_GREATER_THAN_UV_MAX> in the output flags,
+and writes the value to I<*result> (or the value is discarded if I<result>
+is NULL).
+
+The hex number may optionally be prefixed with "0b" or "b" unless
+C<PERL_SCAN_DISALLOW_PREFIX> is set in I<*flags> on entry. If
+C<PERL_SCAN_ALLOW_UNDERSCORES> is set in I<*flags> then the binary
+number may use '_' characters to separate digits.
+
+       UV      grok_bin(char* start, STRLEN* len, I32* flags, NV *result)
 
 =for hackers
-Found in file sv.c
+Found in file numeric.c
 
-=item perl_construct
+=item grok_hex
 
-Initializes a new Perl interpreter.  See L<perlembed>.
+converts a string representing a hex number to numeric form.
 
-       void    perl_construct(PerlInterpreter* interp)
+On entry I<start> and I<*len> give the string to scan, I<*flags> gives
+conversion flags, and I<result> should be NULL or a pointer to an NV.
+The scan stops at the end of the string, or the first non-hex-digit character.
+On return I<*len> is set to the length scanned string, and I<*flags> gives
+output flags.
+
+If the value is <= UV_MAX it is returned as a UV, the output flags are clear,
+and nothing is written to I<*result>. If the value is > UV_MAX C<grok_hex>
+returns UV_MAX, sets C<PERL_SCAN_GREATER_THAN_UV_MAX> in the output flags,
+and writes the value to I<*result> (or the value is discarded if I<result>
+is NULL).
+
+The hex number may optionally be prefixed with "0x" or "x" unless
+C<PERL_SCAN_DISALLOW_PREFIX> is set in I<*flags> on entry. If
+C<PERL_SCAN_ALLOW_UNDERSCORES> is set in I<*flags> then the hex
+number may use '_' characters to separate digits.
+
+       UV      grok_hex(char* start, STRLEN* len, I32* flags, NV *result)
+
+=for hackers
+Found in file numeric.c
+
+=item grok_number
+
+Recognise (or not) a number.  The type of the number is returned
+(0 if unrecognised), otherwise it is a bit-ORed combination of
+IS_NUMBER_IN_UV, IS_NUMBER_GREATER_THAN_UV_MAX, IS_NUMBER_NOT_INT,
+IS_NUMBER_NEG, IS_NUMBER_INFINITY, IS_NUMBER_NAN (defined in perl.h).
+
+If the value of the number can fit an in UV, it is returned in the *valuep
+IS_NUMBER_IN_UV will be set to indicate that *valuep is valid, IS_NUMBER_IN_UV
+will never be set unless *valuep is valid, but *valuep may have been assigned
+to during processing even though IS_NUMBER_IN_UV is not set on return.
+If valuep is NULL, IS_NUMBER_IN_UV will be set for the same cases as when
+valuep is non-NULL, but no actual assignment (or SEGV) will occur.
+
+IS_NUMBER_NOT_INT will be set with IS_NUMBER_IN_UV if trailing decimals were
+seen (in which case *valuep gives the true value truncated to an integer), and
+IS_NUMBER_NEG if the number is negative (in which case *valuep holds the
+absolute value).  IS_NUMBER_IN_UV is not set if e notation was used or the
+number is larger than a UV.
+
+       int     grok_number(const char *pv, STRLEN len, UV *valuep)
+
+=for hackers
+Found in file numeric.c
+
+=item grok_numeric_radix
+
+Scan and skip for a numeric decimal separator (radix).
+
+       bool    grok_numeric_radix(const char **sp, const char *send)
+
+=for hackers
+Found in file numeric.c
+
+=item grok_oct
+
+
+       UV      grok_oct(char* start, STRLEN* len, I32* flags, NV *result)
+
+=for hackers
+Found in file numeric.c
+
+=item scan_bin
+
+For backwards compatibility. Use C<grok_bin> instead.
+
+       NV      scan_bin(char* start, STRLEN len, STRLEN* retlen)
+
+=for hackers
+Found in file numeric.c
+
+=item scan_hex
+
+For backwards compatibility. Use C<grok_hex> instead.
+
+       NV      scan_hex(char* start, STRLEN len, STRLEN* retlen)
+
+=for hackers
+Found in file numeric.c
+
+=item scan_oct
+
+For backwards compatibility. Use C<grok_oct> instead.
+
+       NV      scan_oct(char* start, STRLEN len, STRLEN* retlen)
+
+=for hackers
+Found in file numeric.c
+
+
+=back
+
+=head1 Optree Manipulation Functions
+
+=over 8
+
+=item cv_const_sv
+
+If C<cv> is a constant sub eligible for inlining. returns the constant
+value returned by the sub.  Otherwise, returns NULL.
+
+Constant subs can be created with C<newCONSTSUB> or as described in
+L<perlsub/"Constant Functions">.
+
+       SV*     cv_const_sv(CV* cv)
+
+=for hackers
+Found in file op.c
+
+=item newCONSTSUB
+
+Creates a constant sub equivalent to Perl C<sub FOO () { 123 }> which is
+eligible for inlining at compile-time.
+
+       CV*     newCONSTSUB(HV* stash, char* name, SV* sv)
+
+=for hackers
+Found in file op.c
+
+=item newXS
+
+Used by C<xsubpp> to hook up XSUBs as Perl subs.
+
+=for hackers
+Found in file op.c
+
+
+=back
+
+=head1 Shared SV Functions
+
+=over 8
+
+=item sharedsv_find
+
+Tries to find if a given SV has a shared backend, either by
+looking at magic, or by checking if it is tied again threads::shared.
+
+       shared_sv*      sharedsv_find(SV* sv)
+
+=for hackers
+Found in file sharedsv.c
+
+=item sharedsv_init
+
+Saves a space for keeping SVs wider than an interpreter,
+currently only stores a pointer to the first interpreter.
+
+       void    sharedsv_init()
+
+=for hackers
+Found in file sharedsv.c
+
+=item sharedsv_lock
+
+Recursive locks on a sharedsv.
+Locks are dynamically scoped at the level of the first lock.
+       void    sharedsv_lock(shared_sv* ssv)
+
+=for hackers
+Found in file sharedsv.c
+
+=item sharedsv_new
+
+Allocates a new shared sv struct, you must yourself create the SV/AV/HV.
+       shared_sv*      sharedsv_new()
+
+=for hackers
+Found in file sharedsv.c
+
+=item sharedsv_thrcnt_dec
+
+Decrements the threadcount of a shared sv. When a threads frontend is freed
+this function should be called.
+
+       void    sharedsv_thrcnt_dec(shared_sv* ssv)
 
 =for hackers
-Found in file perl.c
-
-=item perl_destruct
+Found in file sharedsv.c
 
-Shuts down a Perl interpreter.  See L<perlembed>.
+=item sharedsv_thrcnt_inc
 
-       int     perl_destruct(PerlInterpreter* interp)
+Increments the threadcount of a sharedsv.
+       void    sharedsv_thrcnt_inc(shared_sv* ssv)
 
 =for hackers
-Found in file perl.c
+Found in file sharedsv.c
 
-=item perl_free
+=item sharedsv_unlock
 
-Releases a Perl interpreter.  See L<perlembed>.
+Recursively unlocks a shared sv.
 
-       void    perl_free(PerlInterpreter* interp)
+       void    sharedsv_unlock(shared_sv* ssv)
 
 =for hackers
-Found in file perl.c
+Found in file sharedsv.c
 
-=item perl_parse
 
-Tells a Perl interpreter to parse a Perl script.  See L<perlembed>.
+=back
 
-       int     perl_parse(PerlInterpreter* interp, XSINIT_t xsinit, int argc, char** argv, char** env)
+=head1 Stack Manipulation Macros
 
-=for hackers
-Found in file perl.c
+=over 8
 
-=item perl_run
+=item dMARK
 
-Tells a Perl interpreter to run.  See L<perlembed>.
+Declare a stack marker variable, C<mark>, for the XSUB.  See C<MARK> and
+C<dORIGMARK>.
 
-       int     perl_run(PerlInterpreter* interp)
+               dMARK;
 
 =for hackers
-Found in file perl.c
+Found in file pp.h
 
-=item PL_modglobal
+=item dORIGMARK
 
-C<PL_modglobal> is a general purpose, interpreter global HV for use by
-extensions that need to keep information on a per-interpreter basis.
-In a pinch, it can also be used as a symbol table for extensions
-to share data among each other.  It is a good idea to use keys
-prefixed by the package name of the extension that owns the data.
+Saves the original stack mark for the XSUB.  See C<ORIGMARK>.
 
-       HV*     PL_modglobal
+               dORIGMARK;
 
 =for hackers
-Found in file intrpvar.h
+Found in file pp.h
 
-=item PL_na
+=item dSP
 
-A convenience variable which is typically used with C<SvPV> when one
-doesn't care about the length of the string.  It is usually more efficient
-to either declare a local variable and use that instead or to use the
-C<SvPV_nolen> macro.
+Declares a local copy of perl's stack pointer for the XSUB, available via
+the C<SP> macro.  See C<SP>.
 
-       STRLEN  PL_na
+               dSP;
 
 =for hackers
-Found in file thrdvar.h
+Found in file pp.h
 
-=item PL_sv_no
+=item EXTEND
 
-This is the C<false> SV.  See C<PL_sv_yes>.  Always refer to this as
-C<&PL_sv_no>.
+Used to extend the argument stack for an XSUB's return values. Once
+used, guarantees that there is room for at least C<nitems> to be pushed
+onto the stack.
 
-       SV      PL_sv_no
+       void    EXTEND(SP, int nitems)
 
 =for hackers
-Found in file intrpvar.h
-
-=item PL_sv_undef
+Found in file pp.h
 
-This is the C<undef> SV.  Always refer to this as C<&PL_sv_undef>.
+=item MARK
 
-       SV      PL_sv_undef
+Stack marker variable for the XSUB.  See C<dMARK>.
 
 =for hackers
-Found in file intrpvar.h
-
-=item PL_sv_yes
+Found in file pp.h
 
-This is the C<true> SV.  See C<PL_sv_no>.  Always refer to this as
-C<&PL_sv_yes>.
+=item ORIGMARK
 
-       SV      PL_sv_yes
+The original stack mark for the XSUB.  See C<dORIGMARK>.
 
 =for hackers
-Found in file intrpvar.h
+Found in file pp.h
 
 =item POPi
 
@@ -1849,305 +2016,441 @@ See C<PUSHMARK> and L<perlcall> for other uses.
 =for hackers
 Found in file pp.h
 
-=item Renew
+=item SP
 
-The XSUB-writer's interface to the C C<realloc> function.
+Stack pointer.  This is usually handled by C<xsubpp>.  See C<dSP> and
+C<SPAGAIN>.
 
-       void    Renew(void* ptr, int nitems, type)
+=for hackers
+Found in file pp.h
+
+=item SPAGAIN
+
+Refetch the stack pointer.  Used after a callback.  See L<perlcall>.
+
+               SPAGAIN;
 
 =for hackers
-Found in file handy.h
+Found in file pp.h
 
-=item Renewc
+=item XPUSHi
 
-The XSUB-writer's interface to the C C<realloc> function, with
-cast.
+Push an integer onto the stack, extending the stack if necessary.  Handles
+'set' magic. See C<PUSHi>.
 
-       void    Renewc(void* ptr, int nitems, type, cast)
+       void    XPUSHi(IV iv)
 
 =for hackers
-Found in file handy.h
+Found in file pp.h
 
-=item require_pv
+=item XPUSHn
 
-Tells Perl to C<require> the file named by the string argument.  It is
-analogous to the Perl code C<eval "require '$file'">.  It's even
-implemented that way; consider using Perl_load_module instead.
+Push a double onto the stack, extending the stack if necessary.  Handles
+'set' magic.  See C<PUSHn>.
 
-NOTE: the perl_ form of this function is deprecated.
+       void    XPUSHn(NV nv)
 
-       void    require_pv(const char* pv)
+=for hackers
+Found in file pp.h
+
+=item XPUSHp
+
+Push a string onto the stack, extending the stack if necessary.  The C<len>
+indicates the length of the string.  Handles 'set' magic.  See
+C<PUSHp>.
+
+       void    XPUSHp(char* str, STRLEN len)
 
 =for hackers
-Found in file perl.c
+Found in file pp.h
 
-=item RETVAL
+=item XPUSHs
 
-Variable which is setup by C<xsubpp> to hold the return value for an 
-XSUB. This is always the proper type for the XSUB. See 
-L<perlxs/"The RETVAL Variable">.
+Push an SV onto the stack, extending the stack if necessary.  Does not
+handle 'set' magic.  See C<PUSHs>.
+
+       void    XPUSHs(SV* sv)
+
+=for hackers
+Found in file pp.h
+
+=item XPUSHu
+
+Push an unsigned integer onto the stack, extending the stack if necessary.
+See C<PUSHu>.
+
+       void    XPUSHu(UV uv)
+
+=for hackers
+Found in file pp.h
+
+=item XSRETURN
+
+Return from XSUB, indicating number of items on the stack.  This is usually
+handled by C<xsubpp>.
+
+       void    XSRETURN(int nitems)
+
+=for hackers
+Found in file XSUB.h
+
+=item XSRETURN_IV
+
+Return an integer from an XSUB immediately.  Uses C<XST_mIV>.
+
+       void    XSRETURN_IV(IV iv)
+
+=for hackers
+Found in file XSUB.h
+
+=item XSRETURN_NO
+
+Return C<&PL_sv_no> from an XSUB immediately.  Uses C<XST_mNO>.
+
+               XSRETURN_NO;
+
+=for hackers
+Found in file XSUB.h
+
+=item XSRETURN_NV
+
+Return a double from an XSUB immediately.  Uses C<XST_mNV>.
+
+       void    XSRETURN_NV(NV nv)
+
+=for hackers
+Found in file XSUB.h
+
+=item XSRETURN_PV
+
+Return a copy of a string from an XSUB immediately.  Uses C<XST_mPV>.
+
+       void    XSRETURN_PV(char* str)
+
+=for hackers
+Found in file XSUB.h
+
+=item XSRETURN_UNDEF
+
+Return C<&PL_sv_undef> from an XSUB immediately.  Uses C<XST_mUNDEF>.
+
+               XSRETURN_UNDEF;
+
+=for hackers
+Found in file XSUB.h
+
+=item XSRETURN_YES
+
+Return C<&PL_sv_yes> from an XSUB immediately.  Uses C<XST_mYES>.
+
+               XSRETURN_YES;
+
+=for hackers
+Found in file XSUB.h
+
+=item XST_mIV
+
+Place an integer into the specified position C<pos> on the stack.  The
+value is stored in a new mortal SV.
+
+       void    XST_mIV(int pos, IV iv)
+
+=for hackers
+Found in file XSUB.h
+
+=item XST_mNO
+
+Place C<&PL_sv_no> into the specified position C<pos> on the
+stack.
+
+       void    XST_mNO(int pos)
+
+=for hackers
+Found in file XSUB.h
+
+=item XST_mNV
+
+Place a double into the specified position C<pos> on the stack.  The value
+is stored in a new mortal SV.
+
+       void    XST_mNV(int pos, NV nv)
+
+=for hackers
+Found in file XSUB.h
+
+=item XST_mPV
+
+Place a copy of a string into the specified position C<pos> on the stack. 
+The value is stored in a new mortal SV.
 
-       (whatever)      RETVAL
+       void    XST_mPV(int pos, char* str)
 
 =for hackers
 Found in file XSUB.h
 
-=item Safefree
+=item XST_mUNDEF
 
-The XSUB-writer's interface to the C C<free> function.
+Place C<&PL_sv_undef> into the specified position C<pos> on the
+stack.
 
-       void    Safefree(void* ptr)
+       void    XST_mUNDEF(int pos)
 
 =for hackers
-Found in file handy.h
+Found in file XSUB.h
 
-=item savepv
+=item XST_mYES
 
-Copy a string to a safe spot.  This does not use an SV.
+Place C<&PL_sv_yes> into the specified position C<pos> on the
+stack.
 
-       char*   savepv(const char* sv)
+       void    XST_mYES(int pos)
 
 =for hackers
-Found in file util.c
-
-=item savepvn
+Found in file XSUB.h
 
-Copy a string to a safe spot.  The C<len> indicates number of bytes to
-copy.  This does not use an SV.
 
-       char*   savepvn(const char* sv, I32 len)
+=back
 
-=for hackers
-Found in file util.c
+=head1 SV Flags
 
-=item SAVETMPS
+=over 8
 
-Opening bracket for temporaries on a callback.  See C<FREETMPS> and
-L<perlcall>.
+=item svtype
 
-               SAVETMPS;
+An enum of flags for Perl types.  These are found in the file B<sv.h>
+in the C<svtype> enum.  Test these flags with the C<SvTYPE> macro.
 
 =for hackers
-Found in file scope.h
-
-=item scan_bin
+Found in file sv.h
 
-For backwards compatibility. Use C<grok_bin> instead.
+=item SVt_IV
 
-       NV      scan_bin(char* start, STRLEN len, STRLEN* retlen)
+Integer type flag for scalars.  See C<svtype>.
 
 =for hackers
-Found in file numeric.c
-
-=item scan_hex
+Found in file sv.h
 
-For backwards compatibility. Use C<grok_hex> instead.
+=item SVt_NV
 
-       NV      scan_hex(char* start, STRLEN len, STRLEN* retlen)
+Double type flag for scalars.  See C<svtype>.
 
 =for hackers
-Found in file numeric.c
-
-=item scan_oct
+Found in file sv.h
 
-For backwards compatibility. Use C<grok_oct> instead.
+=item SVt_PV
 
-       NV      scan_oct(char* start, STRLEN len, STRLEN* retlen)
+Pointer type flag for scalars.  See C<svtype>.
 
 =for hackers
-Found in file numeric.c
-
-=item sharedsv_find
+Found in file sv.h
 
-Tries to find if a given SV has a shared backend, either by
-looking at magic, or by checking if it is tied again threads::shared.
+=item SVt_PVAV
 
-       shared_sv*      sharedsv_find(SV* sv)
+Type flag for arrays.  See C<svtype>.
 
 =for hackers
-Found in file sharedsv.c
-
-=item sharedsv_init
+Found in file sv.h
 
-Saves a space for keeping SVs wider than an interpreter,
-currently only stores a pointer to the first interpreter.
+=item SVt_PVCV
 
-       void    sharedsv_init()
+Type flag for code refs.  See C<svtype>.
 
 =for hackers
-Found in file sharedsv.c
+Found in file sv.h
 
-=item sharedsv_lock
+=item SVt_PVHV
 
-Recursive locks on a sharedsv.
-Locks are dynamicly scoped at the level of the first lock.
-       void    sharedsv_lock(shared_sv* ssv)
+Type flag for hashes.  See C<svtype>.
 
 =for hackers
-Found in file sharedsv.c
+Found in file sv.h
 
-=item sharedsv_new
+=item SVt_PVMG
 
-Allocates a new shared sv struct, you must yourself create the SV/AV/HV.
-       shared_sv*      sharedsv_new()
+Type flag for blessed scalars.  See C<svtype>.
 
 =for hackers
-Found in file sharedsv.c
+Found in file sv.h
 
-=item sharedsv_thrcnt_dec
 
-Decrements the threadcount of a shared sv. When a threads frontend is freed
-this function should be called.
+=back
 
-       void    sharedsv_thrcnt_dec(shared_sv* ssv)
+=head1 SV Manipulation Functions
 
-=for hackers
-Found in file sharedsv.c
+=over 8
 
-=item sharedsv_thrcnt_inc
+=item get_sv
 
-Increments the threadcount of a sharedsv.
-       void    sharedsv_thrcnt_inc(shared_sv* ssv)
+Returns the SV of the specified Perl scalar.  If C<create> is set and the
+Perl variable does not exist then it will be created.  If C<create> is not
+set and the variable does not exist then NULL is returned.
+
+NOTE: the perl_ form of this function is deprecated.
+
+       SV*     get_sv(const char* name, I32 create)
 
 =for hackers
-Found in file sharedsv.c
+Found in file perl.c
 
-=item sharedsv_unlock
+=item looks_like_number
 
-Recursively unlocks a shared sv.
+Test if the content of an SV looks like a number (or is a number).
+C<Inf> and C<Infinity> are treated as numbers (so will not issue a
+non-numeric warning), even if your atof() doesn't grok them.
 
-       void    sharedsv_unlock(shared_sv* ssv)
+       I32     looks_like_number(SV* sv)
 
 =for hackers
-Found in file sharedsv.c
-
-=item sortsv
+Found in file sv.c
 
-   
-Sort an array. Here is an example:
+=item newRV_inc
 
-    sortsv(AvARRAY(av), av_len(av)+1, Perl_sv_cmp_locale); 
+Creates an RV wrapper for an SV.  The reference count for the original SV is
+incremented.
 
-       void    sortsv(SV ** array, size_t num_elts, SVCOMPARE_t f)
+       SV*     newRV_inc(SV* sv)
 
 =for hackers
-Found in file pp_ctl.c
+Found in file sv.h
 
-=item SP
+=item newRV_noinc
 
-Stack pointer.  This is usually handled by C<xsubpp>.  See C<dSP> and
-C<SPAGAIN>.
+Creates an RV wrapper for an SV.  The reference count for the original
+SV is B<not> incremented.
+
+       SV*     newRV_noinc(SV *sv)
 
 =for hackers
-Found in file pp.h
+Found in file sv.c
 
-=item SPAGAIN
+=item newSV
 
-Refetch the stack pointer.  Used after a callback.  See L<perlcall>.
+Create a new null SV, or if len > 0, create a new empty SVt_PV type SV
+with an initial PV allocation of len+1. Normally accessed via the C<NEWSV>
+macro.
 
-               SPAGAIN;
+       SV*     newSV(STRLEN len)
 
 =for hackers
-Found in file pp.h
+Found in file sv.c
 
-=item ST
+=item newSViv
 
-Used to access elements on the XSUB's stack.
+Creates a new SV and copies an integer into it.  The reference count for the
+SV is set to 1.
 
-       SV*     ST(int ix)
+       SV*     newSViv(IV i)
 
 =for hackers
-Found in file XSUB.h
+Found in file sv.c
 
-=item strEQ
+=item newSVnv
 
-Test two strings to see if they are equal.  Returns true or false.
+Creates a new SV and copies a floating point value into it.
+The reference count for the SV is set to 1.
 
-       bool    strEQ(char* s1, char* s2)
+       SV*     newSVnv(NV n)
 
 =for hackers
-Found in file handy.h
+Found in file sv.c
 
-=item strGE
+=item newSVpv
 
-Test two strings to see if the first, C<s1>, is greater than or equal to
-the second, C<s2>.  Returns true or false.
+Creates a new SV and copies a string into it.  The reference count for the
+SV is set to 1.  If C<len> is zero, Perl will compute the length using
+strlen().  For efficiency, consider using C<newSVpvn> instead.
 
-       bool    strGE(char* s1, char* s2)
+       SV*     newSVpv(const char* s, STRLEN len)
 
 =for hackers
-Found in file handy.h
+Found in file sv.c
 
-=item strGT
+=item newSVpvf
 
-Test two strings to see if the first, C<s1>, is greater than the second,
-C<s2>.  Returns true or false.
+Creates a new SV and initializes it with the string formatted like
+C<sprintf>.
 
-       bool    strGT(char* s1, char* s2)
+       SV*     newSVpvf(const char* pat, ...)
 
 =for hackers
-Found in file handy.h
+Found in file sv.c
 
-=item strLE
+=item newSVpvn
 
-Test two strings to see if the first, C<s1>, is less than or equal to the
-second, C<s2>.  Returns true or false.
+Creates a new SV and copies a string into it.  The reference count for the
+SV is set to 1.  Note that if C<len> is zero, Perl will create a zero length
+string.  You are responsible for ensuring that the source string is at least
+C<len> bytes long.
 
-       bool    strLE(char* s1, char* s2)
+       SV*     newSVpvn(const char* s, STRLEN len)
 
 =for hackers
-Found in file handy.h
+Found in file sv.c
 
-=item strLT
+=item newSVpvn_share
 
-Test two strings to see if the first, C<s1>, is less than the second,
-C<s2>.  Returns true or false.
+Creates a new SV with its SvPVX pointing to a shared string in the string
+table. If the string does not already exist in the table, it is created
+first.  Turns on READONLY and FAKE.  The string's hash is stored in the UV
+slot of the SV; if the C<hash> parameter is non-zero, that value is used;
+otherwise the hash is computed.  The idea here is that as the string table
+is used for shared hash keys these strings will have SvPVX == HeKEY and
+hash lookup will avoid string compare.
 
-       bool    strLT(char* s1, char* s2)
+       SV*     newSVpvn_share(const char* s, I32 len, U32 hash)
 
 =for hackers
-Found in file handy.h
+Found in file sv.c
 
-=item strNE
+=item newSVrv
 
-Test two strings to see if they are different.  Returns true or
-false.
+Creates a new SV for the RV, C<rv>, to point to.  If C<rv> is not an RV then
+it will be upgraded to one.  If C<classname> is non-null then the new SV will
+be blessed in the specified package.  The new SV is returned and its
+reference count is 1.
 
-       bool    strNE(char* s1, char* s2)
+       SV*     newSVrv(SV* rv, const char* classname)
 
 =for hackers
-Found in file handy.h
+Found in file sv.c
 
-=item strnEQ
+=item newSVsv
 
-Test two strings to see if they are equal.  The C<len> parameter indicates
-the number of bytes to compare.  Returns true or false. (A wrapper for
-C<strncmp>).
+Creates a new SV which is an exact duplicate of the original SV.
+(Uses C<sv_setsv>).
 
-       bool    strnEQ(char* s1, char* s2, STRLEN len)
+       SV*     newSVsv(SV* old)
 
 =for hackers
-Found in file handy.h
+Found in file sv.c
 
-=item strnNE
+=item newSVuv
 
-Test two strings to see if they are different.  The C<len> parameter
-indicates the number of bytes to compare.  Returns true or false. (A
-wrapper for C<strncmp>).
+Creates a new SV and copies an unsigned integer into it.
+The reference count for the SV is set to 1.
 
-       bool    strnNE(char* s1, char* s2, STRLEN len)
+       SV*     newSVuv(UV u)
+
+=for hackers
+Found in file sv.c
+
+=item new_vstring
+
+Returns a pointer to the next character after the parsed
+vstring, as well as updating the passed in sv.
 
-=for hackers
-Found in file handy.h
+Function must be called like
 
-=item StructCopy
+        sv = NEWSV(92,5);
+       s = new_vstring(s,sv);
 
-This is an architecture-independent macro to copy one structure to another.
+The sv must already be large enough to store the vstring
+passed in.
 
-       void    StructCopy(type src, type dest, type)
+       char*   new_vstring(char *vstr, SV *sv)
 
 =for hackers
-Found in file handy.h
+Found in file util.c
 
 =item SvCUR
 
@@ -2177,16 +2480,6 @@ See C<SvCUR>.  Access the character as *(SvEND(sv)).
 =for hackers
 Found in file sv.h
 
-=item SvGETMAGIC
-
-Invokes C<mg_get> on an SV if it has 'get' magic.  This macro evaluates its
-argument more than once.
-
-       void    SvGETMAGIC(SV* sv)
-
-=for hackers
-Found in file sv.h
-
 =item SvGROW
 
 Expands the character buffer in the SV so that it has room for the
@@ -2220,7 +2513,7 @@ Found in file sv.h
 
 =item SvIOK_notUV
 
-Returns a boolean indicating whether the SV contains an signed integer.
+Returns a boolean indicating whether the SV contains a signed integer.
 
        void    SvIOK_notUV(SV* sv)
 
@@ -2285,7 +2578,7 @@ Found in file sv.h
 =item SvIVx
 
 Coerces the given SV to an integer and returns it. Guarantees to evaluate
-sv only once. Use the more efficent C<SvIV> otherwise.
+sv only once. Use the more efficient C<SvIV> otherwise.
 
        IV      SvIVx(SV* sv)
 
@@ -2410,7 +2703,7 @@ Found in file sv.h
 =item SvNVx
 
 Coerces the given SV to a double and returns it. Guarantees to evaluate
-sv only once. Use the more efficent C<SvNV> otherwise.
+sv only once. Use the more efficient C<SvNV> otherwise.
 
        NV      SvNVx(SV* sv)
 
@@ -2519,7 +2812,7 @@ Found in file sv.h
 =item SvPVbytex
 
 Like C<SvPV>, but converts sv to byte representation first if necessary.
-Guarantees to evalute sv only once; use the more efficient C<SvPVbyte>
+Guarantees to evaluate sv only once; use the more efficient C<SvPVbyte>
 otherwise.
 
 
@@ -2531,7 +2824,7 @@ Found in file sv.h
 =item SvPVbytex_force
 
 Like C<SvPV_force>, but converts sv to byte representation first if necessary.
-Guarantees to evalute sv only once; use the more efficient C<SvPVbyte_force>
+Guarantees to evaluate sv only once; use the more efficient C<SvPVbyte_force>
 otherwise.
 
        char*   SvPVbytex_force(SV* sv, STRLEN len)
@@ -2569,7 +2862,7 @@ Found in file sv.h
 =item SvPVutf8x
 
 Like C<SvPV>, but converts sv to utf8 first if necessary.
-Guarantees to evalute sv only once; use the more efficient C<SvPVutf8>
+Guarantees to evaluate sv only once; use the more efficient C<SvPVutf8>
 otherwise.
 
        char*   SvPVutf8x(SV* sv, STRLEN len)
@@ -2580,7 +2873,7 @@ Found in file sv.h
 =item SvPVutf8x_force
 
 Like C<SvPV_force>, but converts sv to utf8 first if necessary.
-Guarantees to evalute sv only once; use the more efficient C<SvPVutf8_force>
+Guarantees to evaluate sv only once; use the more efficient C<SvPVutf8_force>
 otherwise.
 
        char*   SvPVutf8x_force(SV* sv, STRLEN len)
@@ -2718,50 +3011,12 @@ Dereferences an RV to return the SV.
 =for hackers
 Found in file sv.h
 
-=item SvSETMAGIC
-
-Invokes C<mg_set> on an SV if it has 'set' magic.  This macro evaluates its
-argument more than once.
-
-       void    SvSETMAGIC(SV* sv)
-
-=for hackers
-Found in file sv.h
-
-=item SvSetMagicSV
-
-Like C<SvSetSV>, but does any set magic required afterwards.
-
-       void    SvSetMagicSV(SV* dsb, SV* ssv)
-
-=for hackers
-Found in file sv.h
-
 =item SvSetMagicSV_nosteal
 
 Like C<SvSetMagicSV>, but does any set magic required afterwards.
 
-       void    SvSetMagicSV_nosteal(SV* dsv, SV* ssv)
-
-=for hackers
-Found in file sv.h
-
-=item SvSetSV
-
-Calls C<sv_setsv> if dsv is not the same as ssv.  May evaluate arguments
-more than once.
-
-       void    SvSetSV(SV* dsb, SV* ssv)
-
-=for hackers
-Found in file sv.h
-
-=item SvSetSV_nosteal
 
-Calls a non-destructive version of C<sv_setsv> if dsv is not the same as
-ssv. May evaluate arguments more than once.
-
-       void    SvSetSV_nosteal(SV* dsv, SV* ssv)
+       void    SvSetMagicSV_nosteal(SV* dsv, SV* ssv)
 
 =for hackers
 Found in file sv.h
@@ -2827,14 +3082,6 @@ false, defined or undefined.  Does not handle 'get' magic.
 =for hackers
 Found in file sv.h
 
-=item svtype
-
-An enum of flags for Perl types.  These are found in the file B<sv.h>
-in the C<svtype> enum.  Test these flags with the C<SvTYPE> macro.
-
-=for hackers
-Found in file sv.h
-
 =item SvTYPE
 
 Returns the type of the SV.  See C<svtype>.
@@ -2844,55 +3091,6 @@ Returns the type of the SV.  See C<svtype>.
 =for hackers
 Found in file sv.h
 
-=item SVt_IV
-
-Integer type flag for scalars.  See C<svtype>.
-
-=for hackers
-Found in file sv.h
-
-=item SVt_NV
-
-Double type flag for scalars.  See C<svtype>.
-
-=for hackers
-Found in file sv.h
-
-=item SVt_PV
-
-Pointer type flag for scalars.  See C<svtype>.
-
-=for hackers
-Found in file sv.h
-
-=item SVt_PVAV
-
-Type flag for arrays.  See C<svtype>.
-
-=for hackers
-Found in file sv.h
-
-=item SVt_PVCV
-
-Type flag for code refs.  See C<svtype>.
-
-=for hackers
-Found in file sv.h
-
-=item SVt_PVHV
-
-Type flag for hashes.  See C<svtype>.
-
-=for hackers
-Found in file sv.h
-
-=item SVt_PVMG
-
-Type flag for blessed scalars.  See C<svtype>.
-
-=for hackers
-Found in file sv.h
-
 =item SvUOK
 
 Returns a boolean indicating whether the SV contains an unsigned integer.
@@ -2953,7 +3151,7 @@ Found in file sv.h
 =item SvUVx
 
 Coerces the given SV to an unsigned integer and returns it. Guarantees to
-evaluate sv only once. Use the more efficent C<SvUV> otherwise.
+evaluate sv only once. Use the more efficient C<SvUV> otherwise.
 
        UV      SvUVx(SV* sv)
 
@@ -3662,24 +3860,6 @@ instead.
 =for hackers
 Found in file sv.c
 
-=item sv_recode_to_utf8
-
-The encoding is assumed to be an Encode object, on entry the PV
-of the sv is assumed to be octets in that encoding, and the sv
-will be converted into Unicode (and UTF-8).
-
-If the sv already is UTF-8 (or if it is not POK), or if the encoding
-is not an object, nothing is done to the sv.
-
-If the encoding is not Encode object, bad things happen.
-
-The PV of the sv is returned.
-
-       void    sv_recode_to_utf8(SV* sv, SV *encoding)
-
-=for hackers
-Found in file sv.c
-
 =item sv_reftype
 
 Returns a string describing what the SV is a reference to.
@@ -4168,66 +4348,269 @@ Found in file sv.c
 A private implementation of the C<SvUVx> macro for compilers which can't
 cope with complex macro expressions. Always use the macro instead.
 
-       UV      sv_uv(SV* sv)
+       UV      sv_uv(SV* sv)
+
+=for hackers
+Found in file sv.c
+
+=item sv_vcatpvfn
+
+Processes its arguments like C<vsprintf> and appends the formatted output
+to an SV.  Uses an array of SVs if the C style variable argument list is
+missing (NULL).  When running with taint checks enabled, indicates via
+C<maybe_tainted> if results are untrustworthy (often due to the use of
+locales).
+
+Usually used via one of its frontends C<sv_catpvf> and C<sv_catpvf_mg>.
+
+       void    sv_vcatpvfn(SV* sv, const char* pat, STRLEN patlen, va_list* args, SV** svargs, I32 svmax, bool *maybe_tainted)
+
+=for hackers
+Found in file sv.c
+
+=item sv_vsetpvfn
+
+Works like C<vcatpvfn> but copies the text into the SV instead of
+appending it.
+
+Usually used via one of its frontends C<sv_setpvf> and C<sv_setpvf_mg>.
+
+       void    sv_vsetpvfn(SV* sv, const char* pat, STRLEN patlen, va_list* args, SV** svargs, I32 svmax, bool *maybe_tainted)
+
+=for hackers
+Found in file sv.c
+
+
+=back
+
+=head1 Unicode Support
+
+=over 8
+
+=item bytes_from_utf8
+
+Converts a string C<s> of length C<len> from UTF8 into byte encoding.
+Unlike <utf8_to_bytes> but like C<bytes_to_utf8>, returns a pointer to
+the newly-created string, and updates C<len> to contain the new
+length.  Returns the original string if no conversion occurs, C<len>
+is unchanged. Do nothing if C<is_utf8> points to 0. Sets C<is_utf8> to
+0 if C<s> is converted or contains all 7bit characters.
+
+NOTE: this function is experimental and may change or be
+removed without notice.
+
+       U8*     bytes_from_utf8(U8 *s, STRLEN *len, bool *is_utf8)
+
+=for hackers
+Found in file utf8.c
+
+=item bytes_to_utf8
+
+Converts a string C<s> of length C<len> from ASCII into UTF8 encoding.
+Returns a pointer to the newly-created string, and sets C<len> to
+reflect the new length.
+
+NOTE: this function is experimental and may change or be
+removed without notice.
+
+       U8*     bytes_to_utf8(U8 *s, STRLEN *len)
+
+=for hackers
+Found in file utf8.c
+
+=item ibcmp_utf8
+
+Return true if the strings s1 and s2 differ case-insensitively, false
+if not (if they are equal case-insensitively).  If u1 is true, the
+string s1 is assumed to be in UTF-8-encoded Unicode.  If u2 is true,
+the string s2 is assumed to be in UTF-8-encoded Unicode.  If u1 or u2
+are false, the respective string is assumed to be in native 8-bit
+encoding.
+
+If the pe1 and pe2 are non-NULL, the scanning pointers will be copied
+in there (they will point at the beginning of the I<next> character).
+If the pointers behind pe1 or pe2 are non-NULL, they are the end
+pointers beyond which scanning will not continue under any
+circustances.  If the byte lengths l1 and l2 are non-zero, s1+l1 and
+s2+l2 will be used as goal end pointers that will also stop the scan,
+and which qualify towards defining a successful match: all the scans
+that define an explicit length must reach their goal pointers for
+a match to succeed).
+
+For case-insensitiveness, the "casefolding" of Unicode is used
+instead of upper/lowercasing both the characters, see
+http://www.unicode.org/unicode/reports/tr21/ (Case Mappings).
+
+       I32     ibcmp_utf8(const char* a, char **pe1, UV l1, bool u1, const char* b, char **pe2, UV l2, bool u2)
+
+=for hackers
+Found in file utf8.c
+
+=item is_utf8_char
+
+Tests if some arbitrary number of bytes begins in a valid UTF-8
+character.  Note that an INVARIANT (i.e. ASCII) character is a valid UTF-8 character.
+The actual number of bytes in the UTF-8 character will be returned if
+it is valid, otherwise 0.
+
+       STRLEN  is_utf8_char(U8 *p)
+
+=for hackers
+Found in file utf8.c
+
+=item is_utf8_string
+
+Returns true if first C<len> bytes of the given string form a valid UTF8
+string, false otherwise.  Note that 'a valid UTF8 string' does not mean
+'a string that contains UTF8' because a valid ASCII string is a valid
+UTF8 string.
+
+       bool    is_utf8_string(U8 *s, STRLEN len)
+
+=for hackers
+Found in file utf8.c
+
+=item pv_uni_display
+
+Build to the scalar dsv a displayable version of the string spv,
+length len, the displayable version being at most pvlim bytes long
+(if longer, the rest is truncated and "..." will be appended).
+
+The flags argument can have UNI_DISPLAY_ISPRINT set to display
+isprint()able characters as themselves, UNI_DISPLAY_BACKSLASH
+to display the \\[nrfta\\] as the backslashed versions (like '\n')
+(UNI_DISPLAY_BACKSLASH is preferred over UNI_DISPLAY_ISPRINT for \\).
+UNI_DISPLAY_QQ (and its alias UNI_DISPLAY_REGEX) have both
+UNI_DISPLAY_BACKSLASH and UNI_DISPLAY_ISPRINT turned on.
+
+The pointer to the PV of the dsv is returned.
+
+       char*   pv_uni_display(SV *dsv, U8 *spv, STRLEN len, STRLEN pvlim, UV flags)
+
+=for hackers
+Found in file utf8.c
+
+=item sv_recode_to_utf8
+
+The encoding is assumed to be an Encode object, on entry the PV
+of the sv is assumed to be octets in that encoding, and the sv
+will be converted into Unicode (and UTF-8).
+
+If the sv already is UTF-8 (or if it is not POK), or if the encoding
+is not a reference, nothing is done to the sv.  If the encoding is not
+an C<Encode::XS> Encoding object, bad things will happen.
+(See F<lib/encoding.pm> and L<Encode>).
+
+The PV of the sv is returned.
+
+       char*   sv_recode_to_utf8(SV* sv, SV *encoding)
+
+=for hackers
+Found in file sv.c
+
+=item sv_uni_display
+
+Build to the scalar dsv a displayable version of the scalar sv,
+the displayable version being at most pvlim bytes long
+(if longer, the rest is truncated and "..." will be appended).
+
+The flags argument is as in pv_uni_display().
+
+The pointer to the PV of the dsv is returned.
+
+       char*   sv_uni_display(SV *dsv, SV *ssv, STRLEN pvlim, UV flags)
 
 =for hackers
-Found in file sv.c
+Found in file utf8.c
 
-=item sv_vcatpvfn
+=item to_utf8_case
 
-Processes its arguments like C<vsprintf> and appends the formatted output
-to an SV.  Uses an array of SVs if the C style variable argument list is
-missing (NULL).  When running with taint checks enabled, indicates via
-C<maybe_tainted> if results are untrustworthy (often due to the use of
-locales).
+The "p" contains the pointer to the UTF-8 string encoding
+the character that is being converted.
 
-Usually used via one of its frontends C<sv_catpvf> and C<sv_catpvf_mg>.
+The "ustrp" is a pointer to the character buffer to put the
+conversion result to.  The "lenp" is a pointer to the length
+of the result.
 
-       void    sv_vcatpvfn(SV* sv, const char* pat, STRLEN patlen, va_list* args, SV** svargs, I32 svmax, bool *maybe_tainted)
+The "swash" is a pointer to the swash to use.
+
+The "normal" is a string like "ToLower" which means the swash
+$utf8::ToLower, which is stored in lib/unicore/To/Lower.pl,
+and loaded by SWASHGET, using lib/utf8_heavy.pl.
+
+The "special" is a string like "utf8::ToSpecLower", which means
+the hash %utf8::ToSpecLower, which is stored in the same file,
+lib/unicore/To/Lower.pl, and also loaded by SWASHGET.  The access
+to the hash is by Perl_to_utf8_case().
+
+       UV      to_utf8_case(U8 *p, U8* ustrp, STRLEN *lenp, SV **swash, char *normal, char *special)
 
 =for hackers
-Found in file sv.c
+Found in file utf8.c
 
-=item sv_vsetpvfn
+=item to_utf8_fold
 
-Works like C<vcatpvfn> but copies the text into the SV instead of
-appending it.
+Convert the UTF-8 encoded character at p to its foldcase version and
+store that in UTF-8 in ustrp and its length in bytes in lenp.  Note
+that the ustrp needs to be at least UTF8_MAXLEN_FOLD+1 bytes since the
+foldcase version may be longer than the original character (up to
+three characters).
 
-Usually used via one of its frontends C<sv_setpvf> and C<sv_setpvf_mg>.
+The first character of the foldcased version is returned
+(but note, as explained above, that there may be more.)
 
-       void    sv_vsetpvfn(SV* sv, const char* pat, STRLEN patlen, va_list* args, SV** svargs, I32 svmax, bool *maybe_tainted)
+       UV      to_utf8_fold(U8 *p, U8* ustrp, STRLEN *lenp)
 
 =for hackers
-Found in file sv.c
+Found in file utf8.c
 
-=item THIS
+=item to_utf8_lower
 
-Variable which is setup by C<xsubpp> to designate the object in a C++ 
-XSUB.  This is always the proper type for the C++ object.  See C<CLASS> and 
-L<perlxs/"Using XS With C++">.
+Convert the UTF-8 encoded character at p to its lowercase version and
+store that in UTF-8 in ustrp and its length in bytes in lenp.  Note
+that the ustrp needs to be at least UTF8_MAXLEN_UCLC+1 bytes since the
+lowercase version may be longer than the original character (up to two
+characters).
 
-       (whatever)      THIS
+The first character of the lowercased version is returned
+(but note, as explained above, that there may be more.)
+
+       UV      to_utf8_lower(U8 *p, U8* ustrp, STRLEN *lenp)
 
 =for hackers
-Found in file XSUB.h
+Found in file utf8.c
 
-=item toLOWER
+=item to_utf8_title
 
-Converts the specified character to lowercase.
+Convert the UTF-8 encoded character at p to its titlecase version and
+store that in UTF-8 in ustrp and its length in bytes in lenp.  Note
+that the ustrp needs to be at least UTF8_MAXLEN_UCLC+1 bytes since the
+titlecase version may be longer than the original character (up to two
+characters).
 
-       char    toLOWER(char ch)
+The first character of the titlecased version is returned
+(but note, as explained above, that there may be more.)
+
+       UV      to_utf8_title(U8 *p, U8* ustrp, STRLEN *lenp)
 
 =for hackers
-Found in file handy.h
+Found in file utf8.c
 
-=item toUPPER
+=item to_utf8_upper
 
-Converts the specified character to uppercase.
+Convert the UTF-8 encoded character at p to its uppercase version and
+store that in UTF-8 in ustrp and its length in bytes in lenp.  Note
+that the ustrp needs to be at least UTF8_MAXLEN_UCLC+1 bytes since the
+uppercase version may be longer than the original character (up to two
+characters).
 
-       char    toUPPER(char ch)
+The first character of the uppercased version is returned
+(but note, as explained above, that there may be more.)
+
+       UV      to_utf8_upper(U8 *p, U8* ustrp, STRLEN *lenp)
 
 =for hackers
-Found in file handy.h
+Found in file utf8.c
 
 =item utf8n_to_uvchr
 
@@ -4369,223 +4752,174 @@ is the recommended wide native character-aware way of saying
 =for hackers
 Found in file utf8.c
 
-=item uvuni_to_utf8
+=item uvuni_to_utf8_flags
 
 Adds the UTF8 representation of the Unicode codepoint C<uv> to the end
 of the string C<d>; C<d> should be have at least C<UTF8_MAXLEN+1> free
 bytes available. The return value is the pointer to the byte after the
 end of the new character. In other words,
 
-    d = uvuni_to_utf8(d, uv);
-
-is the recommended Unicode-aware way of saying
-
-    *(d++) = uv;
-
-       U8*     uvuni_to_utf8(U8 *d, UV uv)
-
-=for hackers
-Found in file utf8.c
-
-=item warn
-
-This is the XSUB-writer's interface to Perl's C<warn> function.  Use this
-function the same way you use the C C<printf> function.  See
-C<croak>.
-
-       void    warn(const char* pat, ...)
-
-=for hackers
-Found in file util.c
-
-=item XPUSHi
-
-Push an integer onto the stack, extending the stack if necessary.  Handles
-'set' magic. See C<PUSHi>.
-
-       void    XPUSHi(IV iv)
-
-=for hackers
-Found in file pp.h
+    d = uvuni_to_utf8_flags(d, uv, flags);
 
-=item XPUSHn
+or, in most cases,
 
-Push a double onto the stack, extending the stack if necessary.  Handles
-'set' magic.  See C<PUSHn>.
+    d = uvuni_to_utf8(d, uv);
 
-       void    XPUSHn(NV nv)
+(which is equivalent to)
 
-=for hackers
-Found in file pp.h
+    d = uvuni_to_utf8_flags(d, uv, 0);
 
-=item XPUSHp
+is the recommended Unicode-aware way of saying
 
-Push a string onto the stack, extending the stack if necessary.  The C<len>
-indicates the length of the string.  Handles 'set' magic.  See
-C<PUSHp>.
+    *(d++) = uv;
 
-       void    XPUSHp(char* str, STRLEN len)
+       U8*     uvuni_to_utf8_flags(U8 *d, UV uv, UV flags)
 
 =for hackers
-Found in file pp.h
-
-=item XPUSHs
-
-Push an SV onto the stack, extending the stack if necessary.  Does not
-handle 'set' magic.  See C<PUSHs>.
-
-       void    XPUSHs(SV* sv)
+Found in file utf8.c
 
-=for hackers
-Found in file pp.h
 
-=item XPUSHu
+=back
 
-Push an unsigned integer onto the stack, extending the stack if necessary.
-See C<PUSHu>.
+=head1 Variables created by C<xsubpp> and C<xsubpp> internal functions
 
-       void    XPUSHu(UV uv)
+=over 8
 
-=for hackers
-Found in file pp.h
+=item ax
 
-=item XS
+Variable which is setup by C<xsubpp> to indicate the stack base offset,
+used by the C<ST>, C<XSprePUSH> and C<XSRETURN> macros.  The C<dMARK> macro
+must be called prior to setup the C<MARK> variable.
 
-Macro to declare an XSUB and its C parameter list.  This is handled by
-C<xsubpp>.
+       I32     ax
 
 =for hackers
 Found in file XSUB.h
 
-=item XSRETURN
+=item CLASS
 
-Return from XSUB, indicating number of items on the stack.  This is usually
-handled by C<xsubpp>.
+Variable which is setup by C<xsubpp> to indicate the 
+class name for a C++ XS constructor.  This is always a C<char*>.  See C<THIS>.
 
-       void    XSRETURN(int nitems)
+       char*   CLASS
 
 =for hackers
 Found in file XSUB.h
 
-=item XSRETURN_EMPTY
+=item dAX
 
-Return an empty list from an XSUB immediately.
+Sets up the C<ax> variable.
+This is usually handled automatically by C<xsubpp> by calling C<dXSARGS>.
 
-               XSRETURN_EMPTY;
+               dAX;
 
 =for hackers
 Found in file XSUB.h
 
-=item XSRETURN_IV
+=item dITEMS
 
-Return an integer from an XSUB immediately.  Uses C<XST_mIV>.
+Sets up the C<items> variable.
+This is usually handled automatically by C<xsubpp> by calling C<dXSARGS>.
 
-       void    XSRETURN_IV(IV iv)
+               dITEMS;
 
 =for hackers
 Found in file XSUB.h
 
-=item XSRETURN_NO
+=item dXSARGS
 
-Return C<&PL_sv_no> from an XSUB immediately.  Uses C<XST_mNO>.
+Sets up stack and mark pointers for an XSUB, calling dSP and dMARK.
+Sets up the C<ax> and C<items> variables by calling C<dAX> and C<dITEMS>.
+This is usually handled automatically by C<xsubpp>.
 
-               XSRETURN_NO;
+               dXSARGS;
 
 =for hackers
 Found in file XSUB.h
 
-=item XSRETURN_NV
+=item dXSI32
 
-Return an double from an XSUB immediately.  Uses C<XST_mNV>.
+Sets up the C<ix> variable for an XSUB which has aliases.  This is usually
+handled automatically by C<xsubpp>.
 
-       void    XSRETURN_NV(NV nv)
+               dXSI32;
 
 =for hackers
 Found in file XSUB.h
 
-=item XSRETURN_PV
+=item items
 
-Return a copy of a string from an XSUB immediately.  Uses C<XST_mPV>.
+Variable which is setup by C<xsubpp> to indicate the number of 
+items on the stack.  See L<perlxs/"Variable-length Parameter Lists">.
 
-       void    XSRETURN_PV(char* str)
+       I32     items
 
 =for hackers
 Found in file XSUB.h
 
-=item XSRETURN_UNDEF
+=item ix
 
-Return C<&PL_sv_undef> from an XSUB immediately.  Uses C<XST_mUNDEF>.
+Variable which is setup by C<xsubpp> to indicate which of an 
+XSUB's aliases was used to invoke it.  See L<perlxs/"The ALIAS: Keyword">.
 
-               XSRETURN_UNDEF;
+       I32     ix
 
 =for hackers
 Found in file XSUB.h
 
-=item XSRETURN_YES
-
-Return C<&PL_sv_yes> from an XSUB immediately.  Uses C<XST_mYES>.
+=item newXSproto
 
-               XSRETURN_YES;
+Used by C<xsubpp> to hook up XSUBs as Perl subs.  Adds Perl prototypes to
+the subs.
 
 =for hackers
 Found in file XSUB.h
 
-=item XST_mIV
+=item RETVAL
 
-Place an integer into the specified position C<pos> on the stack.  The
-value is stored in a new mortal SV.
+Variable which is setup by C<xsubpp> to hold the return value for an 
+XSUB. This is always the proper type for the XSUB. See 
+L<perlxs/"The RETVAL Variable">.
 
-       void    XST_mIV(int pos, IV iv)
+       (whatever)      RETVAL
 
 =for hackers
 Found in file XSUB.h
 
-=item XST_mNO
+=item ST
 
-Place C<&PL_sv_no> into the specified position C<pos> on the
-stack.
+Used to access elements on the XSUB's stack.
 
-       void    XST_mNO(int pos)
+       SV*     ST(int ix)
 
 =for hackers
 Found in file XSUB.h
 
-=item XST_mNV
+=item THIS
 
-Place a double into the specified position C<pos> on the stack.  The value
-is stored in a new mortal SV.
+Variable which is setup by C<xsubpp> to designate the object in a C++ 
+XSUB.  This is always the proper type for the C++ object.  See C<CLASS> and 
+L<perlxs/"Using XS With C++">.
 
-       void    XST_mNV(int pos, NV nv)
+       (whatever)      THIS
 
 =for hackers
 Found in file XSUB.h
 
-=item XST_mPV
-
-Place a copy of a string into the specified position C<pos> on the stack. 
-The value is stored in a new mortal SV.
+=item XS
 
-       void    XST_mPV(int pos, char* str)
+Macro to declare an XSUB and its C parameter list.  This is handled by
+C<xsubpp>.
 
 =for hackers
 Found in file XSUB.h
 
-=item XST_mUNDEF
-
-Place C<&PL_sv_undef> into the specified position C<pos> on the
-stack.
-
-       void    XST_mUNDEF(int pos)
-
-=for hackers
-Found in file XSUB.h
+=item XSRETURN_EMPTY
 
-=item XST_mYES
+Return an empty list from an XSUB immediately.
 
-Place C<&PL_sv_yes> into the specified position C<pos> on the
-stack.
 
-       void    XST_mYES(int pos)
+               XSRETURN_EMPTY;
 
 =for hackers
 Found in file XSUB.h
@@ -4609,15 +4943,42 @@ C<xsubpp>.  See L<perlxs/"The VERSIONCHECK: Keyword">.
 =for hackers
 Found in file XSUB.h
 
-=item Zero
 
-The XSUB-writer's interface to the C C<memzero> function.  The C<dest> is the
-destination, C<nitems> is the number of items, and C<type> is the type.
+=back
 
-       void    Zero(void* dest, int nitems, type)
+=head1 Warning and Dieing
+
+=over 8
+
+=item croak
+
+This is the XSUB-writer's interface to Perl's C<die> function.
+Normally use this function the same way you use the C C<printf>
+function.  See C<warn>.
+
+If you want to throw an exception object, assign the object to
+C<$@> and then pass C<Nullch> to croak():
+
+   errsv = get_sv("@", TRUE);
+   sv_setsv(errsv, exception_object);
+   croak(Nullch);
+
+       void    croak(const char* pat, ...)
 
 =for hackers
-Found in file handy.h
+Found in file util.c
+
+=item warn
+
+This is the XSUB-writer's interface to Perl's C<warn> function.  Use this
+function the same way you use the C C<printf> function.  See
+C<croak>.
+
+       void    warn(const char* pat, ...)
+
+=for hackers
+Found in file util.c
+
 
 =back