Computer Science


H2PH(1)        User Contributed Perl Documentation        H2PH(1)

NNAAMMEE
       h2ph - convert .h C header files to .ph Perl header files

SSYYNNOOPPSSIISS
       hh22pphh [[--dd ddeessttiinnaattiioonn ddiirreeccttoorryy]] [[--rr || --aa]] [[--ll]]
       [[hheeaaddeerrffiilleess]]

DDEESSCCRRIIPPTTIIOONN
       h2ph converts any C header files specified to the
       corresponding Perl header file format.  It is most easily
       run while in /usr/include:

               cd /usr/include; h2ph * sys/*

       or

               cd /usr/include; h2ph -r -l .

       The output files are placed in the hierarchy rooted at
       Perl's architecture dependent library directory.  You can
       specify a different hierarchy with a --dd switch.

       If run with no arguments, filters standard input to
       standard output.

OOPPTTIIOONNSS
       -d destination_dir
           Put the resulting ..pphh files beneath ddeessttiinnaattiioonn_<i>_ddiirr,
           instead of beneath the default Perl library location
           ($Config{'installarchlib'}).

       -r  Run recursively; if any of hheeaaddeerrffiilleess are
           directories, then run h2ph on all files in those
           directories (and their subdirectories, etc.).  --rr and
           --aa are mutually exclusive.

       -a  Run automagically; convert hheeaaddeerrffiilleess, as well as any
           ..hh files which they include.  This option will search
           for ..hh files in all directories which your C compiler
           ordinarily uses.  --aa and --rr are mutually exclusive.

       -l  Symbolic links will be replicated in the destination
           directory.  If --ll is not specified, then links are
           skipped over.

       -h  Put ``hints'' in the .ph files which will help in
           locating problems with h2ph.  In those cases when you
           rreeqquuiirree a ..pphh file containing syntax errors, instead
           of the cryptic

                   [ some error condition ] at (eval mmm) line nnn

           you will see the slightly more helpful

                   [ some error condition ] at filename.ph line nnn

           However, the ..pphh files almost double in size when
           built using --hh.

       -D  Include the code from the ..hh file as a comment in the
           ..pphh file.  This is primarily used for debugging h2ph.

       -Q  ``Quiet'' mode; don't print out the names of the files
           being converted.

EENNVVIIRROONNMMEENNTT
       No environment variables are used.

FFIILLEESS
        /usr/include/*.h
        /usr/include/sys/*.h

       etc.

AAUUTTHHOORR
       Larry Wall

SSEEEE AALLSSOO
       perl(1)

DDIIAAGGNNOOSSTTIICCSS
       The usual warnings if it can't read or write the files
       involved.

BBUUGGSS
       Doesn't construct the %sizeof array for you.

       It doesn't handle all C constructs, but it does attempt to
       isolate definitions inside evals so that you can get at
       the definitions that it can translate.

       It's only intended as a rough tool.  You may need to
       dicker with the files produced.

       Doesn't run with use strict

       You have to run this program by hand; it's not run as part
       of the Perl installation.

       Doesn't handle complicated expressions built piecemeal, a
       la:

           enum {
               FIRST_VALUE,
               SECOND_VALUE,
           #ifdef ABC
               THIRD_VALUE
           #endif
           };

       Doesn't necessarily locate all of your C compiler's
       internally-defined symbols.

5/May/1999             perl 5.005, patch 03                     1

Back to the index


Apply now!


Handbook

Postgraduate study options

Computer Science Blog



Please give us your feedback or ask us a question

This message is...


My feedback or question is...


My email address is...

(Only if you need a reply)

A to Z Directory | Site map | Accessibility | Copyright | Privacy | Disclaimer | Feedback on this page