peter 2d6deeaade * regenerated %!s(int64=22) %!d(string=hai) anos
..
Makefile 2d6deeaade * regenerated %!s(int64=22) %!d(string=hai) anos
Makefile.fpc 293d6a1671 * Makefile fixes %!s(int64=24) %!d(string=hai) anos
README 3a56cae749 * moved %!s(int64=26) %!d(string=hai) anos
converu.pas 8835bfd0c6 * big update, it now converts much more files without serious errors %!s(int64=24) %!d(string=hai) anos
h2pas.pas be03148a1e + Patch from Jeff Pohlmeyer to process empty structs %!s(int64=22) %!d(string=hai) anos
h2pas.y be03148a1e + Patch from Jeff Pohlmeyer to process empty structs %!s(int64=22) %!d(string=hai) anos
h2paspp.pas 8835bfd0c6 * big update, it now converts much more files without serious errors %!s(int64=24) %!d(string=hai) anos
lexlib.pas 164e1c25e6 + -S, -T, -c modes added %!s(int64=25) %!d(string=hai) anos
options.pas 952e80a72f * old logs removed and tabs fixed %!s(int64=23) %!d(string=hai) anos
scan.l c38ebece5a * fix from Jeff Pohlmeyer <[email protected]> for problem with %!s(int64=22) %!d(string=hai) anos
scan.pas 952e80a72f * old logs removed and tabs fixed %!s(int64=23) %!d(string=hai) anos
testit.h f86c568373 * support for enum enumtype enumvar; fixed %!s(int64=23) %!d(string=hai) anos
yacclib.pas 952e80a72f * old logs removed and tabs fixed %!s(int64=23) %!d(string=hai) anos
yylex.cod 3a56cae749 * moved %!s(int64=26) %!d(string=hai) anos
yyparse.cod 3a56cae749 * moved %!s(int64=26) %!d(string=hai) anos

README

This is the h2pas program, a utility to convert C header files to pascal
units. It is part of the Free Pascal distribution.

COMPILING

To compile the program, a simple
'make'
should be sufficient; you need GNU make for this. When using TP, a simple
tpc h2pas.pas
should also be possible.

USAGE

h2pas [-p] [-t] [-o outputfilename] [-l libname] [-u unitname] filename

-t : Prepend 'T' to all type names in typedef definitions. This may help
when the C header use uppercase types and lowercase variables of the
same name.

-p : Use 'P' instead of ^ as a pointer symbol;
This will convert
^char to pchar
^longint to plongint
etc. It will also define a PSOMETYPE pointer for each SOMETYPE struct type
definition in the header file.
Thus
typedef struct somestruct {
...
}
Will be converted to
somestruct = record
...
end;
PSomestruct = ^Somestruct;
If the -t options is used, the -p option takes care of that too.

-l : In the implementation part, the external functions will be
written with 'external libname;' behind it.
If you omit this option, all functions will be declared as
cdecl; external;

-o : specify the outputname. By default, the inputname is used, with
extension '.pp'.

-u : Specify the unit name. By default, the outputname is used, without
extension.

-v : Replaces pointer types in parameter list by call by reference
parameters:
void p(int *i) => procedure p(var i : longint);

Enjoy !