winedump pl

SYNOPSIS

        [ |   |   |   ] []

DESCRIPTION

        is a Wine tool which aims to help:
       A: Reimplementing a Win32 DLL for use within Wine, or
       B: Compiling a Win32 application with Winelib that uses x86 DLLs
       For both tasks in order to be able to link to the Win functions some
       glue code is needed.  This 'glue' comes in the form of a  file.
       The  file, along with some dummy code, is used to create a
       Wine .so corresponding to the Windows DLL.  The  program
       can then resolve calls made to DLL functions.
       Creating a  file is a labour intensive task during which it is
       easy to make a mistake. The idea of  is to automate this task
       and create the majority of the support code needed for your DLL. In
       addition you can have  create code to help you re-implement a
       DLL, by providing tracing of calls to the DLL, and (in some cases)
       automatically determining the parameters, calling conventions, and
       return values of the DLL's functions.
       Another use for this tool is to display (dump) information about a 32bit
       DLL or PE format image file. When used in this way  functions
       similarly to tools such as pedump provided by many Win32 compiler
       vendors.
       Finally  can be also used to demangle C++ symbols.

MODES

        can be used in several different modes.  The first argument to
       the program determines the mode winedump will run in.
            Help mode.  Basic usage help is printed.
          To dump the contents of a file.
          For generating .spec files and stub DLLs.
           Symbol mode.  Used to demangle C++ symbols.

OPTIONS

       Mode options depend on the mode given as the first argument.

       No options are used.
       The program prints the help info and than exits.

        Dumps the content of the file named . Various file
              formats are supported (PE, NE, LE, Minidumps, .lnk).
            Turns on symbol demangling.
            Dumps file header information.
              This option dumps only the standard PE header structures,
              along with the COFF sections available in the file.

              Dumps only the content of directory , for files
              which header points to directories.
              For PE files, currently the import, export, debug, resource,
              tls and clr directories are implemented.
              For NE files, currently the export and resource directories are
              implemented.
            Dumps everything.
              This command prints all available information (including all
              available directories - see  option) about the file. You may
              wish to pipe the output through more/less or into a file, since
              a lot of output will be produced.
            Dumps contents of debug section if any (for now, only stabs
              information is supported).

         Use dll for input file and generate implementation code.
         Look for prototypes in '' (implies ). In the case of
              Windows DLLs, this could be either the standard include
              directory from your compiler, or a SDK include directory.
              If you have a text document with prototypes (such as
              documentation) that can be used also, however you may need
              to delete some non-code lines to ensure that prototypes are
              parsed correctly.
              The '' argument can also be a file specification (e.g.
              "include/*"). If it contains wildcards you must quote it to
              prevent the shell from expanding it.
              If you have no prototypes, specify /dev/null for ''.
              Winedump may still be able to generate some working stub
              code for you.
            Generate skeleton code (requires ).
              This option tells winedump to create function stubs for each
              function in the DLL. As winedump reads each exported symbol
              from the source DLL, it first tries to demangle the name. If
              the name is a C++ symbol, the arguments, class and return
              value are all encoded into the symbol name. Winedump
              converts this information into a C function prototype. If
              this fails, the file(s) specified in the  argument are
              scanned for a function prototype. If one is found it is used
              for the next step of the process, code generation.
            TRACE arguments (implies ).
              This option produces the same code as , except that
              arguments are printed out when the function is called.
              Structs that are passed by value are printed as "struct",
              and functions that take variable argument lists print "...".
         Forward calls to '' (implies ).
              This is the most complicated level of code generation. The
              same code is generated as , however support is added for
              forwarding calls to another DLL. The DLL to forward to is
              given as ''.
            Generate documentation.
              By default, winedump generates a standard comment at the
              header of each function it generates. Passing this option
              makes winedump output a full header template for standard
              Wine documentation, listing the parameters and return value
              of the function.

              Set the output dll name (default: ).
              By default, if winedump is run on DLL 'foo', it creates
              files 'foo.spec', 'foo_main.c' etc, and prefixes any
              functions generated with 'FOO_'.  If '-o bar' is given,
              these will become 'bar.spec', 'bar_main.c' and 'BAR_'
              respectively.
              This option is mostly useful when generating a forwarding DLL.
            Assume __cdecl calls (default: __stdcall).
              If winebuild cannot determine the calling convention,
              __stdcall is used by default, unless this option has
              been given.
              Unless  is given, a warning will be printed for every
              function that winedump determines the calling convention
              for and which does not match the assumed calling convention.
         Start prototype search after symbol ''.
         End prototype search after symbol ''.
              By passing the  or  options you can have winedump try to
              generate code for only some functions in your DLL. This may
              be used to generate a single function, for example, if you
              wanted to add functionality to an existing DLL.

              Search only prototype names found in ''.
              If you want to only generate code for a subset of exported
              functions from your source DLL, you can use this option to
              provide a text file containing the names of the symbols to
              extract, one per line. Only the symbols present in this file
              will be used in your output DLL.
            Don't show progress (quiet).
              No output is printed unless a fatal error is encountered.
            Show lots of detail while working (verbose).
              There are 3 levels of output while winedump is running. The
              default level, when neither -q or -v are given, prints the
              number of exported functions found in the dll, followed by
              the name of each function as it is processed, and a status
              indication of whether it was processed OK.  With -v given, a
              lot of information is dumped while winedump works: this is
              intended to help debug any problems.

         Demangles C++ symbol '' and then exits.

FILES

              Perl script used to retrieve a function prototype.
       Files output in   for

              This is the .spec file.


              These are the source code files containing the minimum set
              of code to build a stub DLL. The C file contains one
              function, FOO_Init, which does nothing (but must be
              present).

              This is a template for 'configure' to produce a makefile. It
              is designed for a DLL that will be inserted into the Wine
              source tree.

BUGS

       C++ name demangling is currently under development. Since the algorithm
       used  is not documented, it must be decoded. Many simple prototypes are
       already working however.

AUTHORS

       Jon P. Griffiths <jon_p_griffiths at yahoo dot com>
       Michael Stefaniuc <mstefani at redhat dot com>

SEE ALSO

       's README file
       The Winelib User Guide
       The Wine Developers Guide
Wine 1.1.9                       October 2005

winedump pl (last edited 2008-11-22 05:43:03 by andromus)