mirror of
https://github.com/reactos/wine.git
synced 2024-11-30 07:00:30 +00:00
2282 lines
79 KiB
Plaintext
2282 lines
79 KiB
Plaintext
\input texinfo @c -*-texinfo-*-
|
|
@c %**start of header
|
|
@setfilename wine.info
|
|
@settitle Wine Reference Manual
|
|
@iftex
|
|
@afourpaper
|
|
@end iftex
|
|
@c %**end of header
|
|
|
|
@ifinfo
|
|
@format
|
|
START-INFO-DIR-ENTRY
|
|
* wine: (wine.info). Windows on Unix.
|
|
END-INFO-DIR-ENTRY
|
|
@end format
|
|
@end ifinfo
|
|
|
|
@iftex
|
|
@c @finalout
|
|
@end iftex
|
|
|
|
@ifinfo
|
|
This file documents Wine, a system providing Microsoft Windows compatibility
|
|
to Unix.
|
|
|
|
@c
|
|
Copyright @copyright{} 1997,1998 The Wine authors. @*
|
|
@xref{Authors, The Wine Authors, The Wine Authors},
|
|
for a list of the copyright holders.
|
|
|
|
Permission is granted to make and distribute verbatim
|
|
copies of this manual provided the copyright notice and
|
|
this permission notice are preserved on all copies.
|
|
|
|
@ignore
|
|
Permission is granted to process this file through TeX
|
|
and print the results, provided the printed document
|
|
carries a copying permission notice identical to this
|
|
one except for the removal of this paragraph (this
|
|
paragraph not being relevant to the printed manual).
|
|
|
|
@end ignore
|
|
Permission is granted to copy and distribute modified
|
|
versions of this manual under the conditions stated in
|
|
the section entitled ``License, Warranty, and Authors of Wine''.
|
|
|
|
@sp 4
|
|
FIXME: X11 and POSIX trademarks. @*
|
|
UNIX is a registered trademark of the Open Group.
|
|
Microsoft, Windows, MS-Windows, Windows-NT, Windows 95, and MS-DOS are
|
|
registered trademarks of Microsoft Corporation.
|
|
NT is a trademark of Northern Telecom Limited.
|
|
C++Builder is a trademark of Borland International, Inc.
|
|
Postscript is a registered trademark of Adobe Systems Inc.
|
|
Other trademarks are the property of their respective owners, which may
|
|
be registered in certain jurisdictions.
|
|
@end ifinfo
|
|
|
|
@c begin chapters on right pages
|
|
@setchapternewpage odd
|
|
|
|
@titlepage
|
|
|
|
@title{The Wine Reference Manual}
|
|
@subtitle{Edition 0.0.5, February 1998}
|
|
|
|
@author{The Wine Team}
|
|
@c The following two commands start the copyright page.
|
|
@page
|
|
@vskip 0pt plus 1filll
|
|
|
|
Copyright @copyright{} 1997, 1998 The Wine authors. @*
|
|
@xref{Authors, The Wine Authors, The Wine Authors},
|
|
for a list of the copyright holders.
|
|
|
|
Permission is granted to make and distribute verbatim
|
|
copies of this manual provided the copyright notice and
|
|
this permission notice are preserved on all copies.
|
|
|
|
Permission is granted to copy and distribute modified
|
|
versions of this manual under the conditions stated in
|
|
the section entitled ``License, Warranty, and Authors of Wine''.
|
|
|
|
@sp 4
|
|
FIXME: UNIX and POSIX trademarks. @*
|
|
X11 @*
|
|
Microsoft, Windows, MS-Windows, Windows-NT, Windows 95, and MS-DOS are
|
|
registered trademarks of Microsoft Corporation.
|
|
NT is a trademark of Northern Telecom Limited.
|
|
C++Builder is a trademark of Borland International, Inc.
|
|
Postscript is a registered trademark of Adobe Systems Inc.
|
|
Other trademarks are the property of their respective owners, which may
|
|
be registered in certain jurisdictions.
|
|
@end titlepage
|
|
|
|
|
|
|
|
@c
|
|
@c SETTINGS, DEFINES, MACROS
|
|
@c
|
|
|
|
@c Edit this macro manually in the above parts of the document
|
|
@macro winemanualversion
|
|
0.0.4
|
|
@end macro
|
|
|
|
@c Edit this macro manually in the above parts of the document
|
|
@macro winemanualdate
|
|
February 1998
|
|
@end macro
|
|
|
|
@c Edit this macro manually into the TeX titlepage
|
|
@macro winemanualtitle
|
|
The Wine Reference Manual
|
|
@end macro
|
|
|
|
@c
|
|
@macro winelib
|
|
Winelib
|
|
@end macro
|
|
@c
|
|
@c MICROSOFT
|
|
@c
|
|
|
|
@c FIXME: automatic trademark reference
|
|
@macro mswindows
|
|
MS-Windows
|
|
@end macro
|
|
|
|
@c FIXME: automatic trademark reference
|
|
@c spell it always the same
|
|
@macro WIN32
|
|
WIN32
|
|
@end macro
|
|
@macro WIN16
|
|
WIN16
|
|
@end macro
|
|
|
|
@c FIXME: automatic trademark reference
|
|
@macro WINNT
|
|
Windows NT
|
|
@end macro
|
|
|
|
@c FIXME: automatic trademark reference
|
|
@macro WINNT40
|
|
Windows NT 4.0
|
|
@end macro
|
|
|
|
@c FIXME: automatic trademark reference
|
|
@macro WIN95
|
|
Windows 95
|
|
@end macro
|
|
|
|
|
|
@c
|
|
@c THE OTHERS
|
|
@c
|
|
@c FIXME: automatic trademark reference
|
|
@macro unix
|
|
UNIX
|
|
@end macro
|
|
|
|
@c FIXME: automatic trademark reference
|
|
@macro posix
|
|
POSIX
|
|
@end macro
|
|
|
|
@macro unicode
|
|
Unicode
|
|
@end macro
|
|
|
|
@macro ascii
|
|
ASCII
|
|
@end macro
|
|
|
|
@c
|
|
@c THIS MANUAL
|
|
@c
|
|
|
|
@c flag out differences to MS-Windows
|
|
@macro windiff
|
|
@emph{Differences to @mswindows{}:} @*
|
|
@end macro
|
|
|
|
@macro windiffnone
|
|
@windiff{}
|
|
No differences known.
|
|
@end macro
|
|
|
|
@c tell whether function is present in Windows 95 and/or NT
|
|
@macro winconf
|
|
@emph{Conformance to @mswindows{}:} @*
|
|
@end macro
|
|
|
|
@macro winconfall
|
|
@winconf{}
|
|
Present in @WIN95{} and @WINNT{}.
|
|
@end macro
|
|
|
|
@c give information about completion
|
|
@macro completion
|
|
@emph{Completion status:} @*
|
|
@end macro
|
|
|
|
@macro completionnone
|
|
@completion{}
|
|
Not yet implemented.
|
|
@end macro
|
|
|
|
@c
|
|
@c MACROS FOR FUNCTIONS, TYPES, CONSTANTS, VARIABLES
|
|
@c
|
|
|
|
@c Constants in the WIN32 API
|
|
@macro defvr_cw32 {restofline}
|
|
@defvr Constant \restofline\
|
|
@end macro
|
|
@macro defvrx_cw32 {restofline}
|
|
@defvrx Constant \restofline\
|
|
@end macro
|
|
|
|
@c Functions in the WIN32 API
|
|
@macro deftypefn_w32 {restofline}
|
|
@deftypefn {WIN32 function} \restofline\
|
|
@end macro
|
|
@macro deftypefnx_w32 {restofline}
|
|
@deftypefnx {WIN32 function} \restofline\
|
|
@end macro
|
|
|
|
@c Types in the WIN32 API
|
|
@macro deftp_w32 {restofline}
|
|
@deftp {Data type} \restofline\
|
|
@end macro
|
|
@macro deftpx_w32 {restofline}
|
|
@deftpx {Data type} \restofline\
|
|
@end macro
|
|
|
|
@c Macros internal to Wine
|
|
@macro deffn_winemacro {restofline}
|
|
@deffn {Wine internal macro} \restofline\
|
|
@end macro
|
|
@macro deffnx_winemacro {restofline}
|
|
@deffn {Wine internal macro} \restofline\
|
|
@end macro
|
|
|
|
@c Constants internal to Wine
|
|
@macro defvr_cwine {restofline}
|
|
@defvr {Wine internal constant} \restofline\
|
|
@end macro
|
|
@macro defvrx_cwine {restofline}
|
|
@defvrx {Wine internal constant} \restofline\
|
|
@end macro
|
|
|
|
|
|
@c
|
|
@c TOP NODE
|
|
@c
|
|
@ifinfo
|
|
@node Top, Copying, (dir), (dir)
|
|
@top Wine
|
|
|
|
This is edition @winemanualversion{}, last updated @winemanualdate{},
|
|
of @winemanualtitle{}.
|
|
|
|
Wine provides both source and binary compatibility with Microsoft Windows.
|
|
The Wine API is designed to be as compatible as possible with various
|
|
implementations of the Windows APIs. The Wine library allows porting
|
|
Windows source to Unix, and a program loader allows unaltered Windows binaries
|
|
to be run on Unix.
|
|
|
|
Wine is free software. Wine is still under development.
|
|
@end ifinfo
|
|
|
|
@menu
|
|
* Copying:: License, Warranty, and Authors of Wine.
|
|
* Introduction:: A short overview.
|
|
* Wine Design:: The design of Wine.
|
|
* Reference Manual:: The Wine reference manual.
|
|
* Installation:: Installing and configuring Wine.
|
|
* The Wine Project:: How to contribute to Wine.
|
|
* Concept Index:: Index of concepts and names.
|
|
* Type Index:: Index of types and type qualifiers.
|
|
* Function Index:: Index of functions and function-like
|
|
macros.
|
|
* Variable Index:: Index of variables, constants, and
|
|
variable-like macros.
|
|
* File Index:: Index of programs and files.
|
|
@end menu
|
|
|
|
@node Copying, Introduction, Top, Top
|
|
|
|
@unnumbered License, Warranty, and Authors of Wine
|
|
@cindex copying conditions for Wine
|
|
@cindex conditions for copying Wine
|
|
@cindex Wine copying conditions
|
|
|
|
The Wine license, warranty, and list of authors together form the
|
|
copyright for Wine. Read these sections carefully.
|
|
|
|
@menu
|
|
* License:: The Wine license.
|
|
* Warranty:: Wine comes with no warranty.
|
|
* Authors:: The persons that contributed to Wine.
|
|
@end menu
|
|
|
|
@node License, Warranty, , Copying
|
|
@cindex Wine license
|
|
@cindex license of Wine
|
|
|
|
@unnumberedsec The Wine License
|
|
Wine is distributed under the following copyright.
|
|
|
|
@quotation
|
|
@include LICENSE
|
|
@end quotation
|
|
|
|
@node Warranty, Authors, License, Copying
|
|
@cindex Wine warranty
|
|
@cindex warranty of Wine
|
|
|
|
@unnumberedsec The Wine Warranty
|
|
|
|
@quotation
|
|
@include WARRANTY
|
|
@end quotation
|
|
|
|
@node Authors, , Warranty, Copying
|
|
@cindex Wine authors
|
|
@cindex authors of Wine
|
|
@cindex copyright holders of Wine
|
|
@cindex Wine copyright holders
|
|
|
|
@unnumberedsec The Wine Authors
|
|
|
|
@quotation
|
|
@include AUTHORS
|
|
@end quotation
|
|
|
|
These persons also hold the copyright on Wine.
|
|
|
|
The overall coordination is done by @*
|
|
Alexandre Julliard @*
|
|
@email{julliard@@winehq.com}
|
|
|
|
|
|
|
|
@node Introduction, Wine Design, Copying, Top
|
|
@chapter Introduction
|
|
|
|
@strong{What is Wine?}
|
|
|
|
Wine is a Windows-compatibility layer for Unix and X11.
|
|
The Wine system consists of several thing:
|
|
@enumerate
|
|
@item
|
|
An API, sometimes referred to as the Wine API,
|
|
designed to be as compatible as possible with the
|
|
@mswindows{} API
|
|
@item
|
|
A library, called @winelib{}, which implements this API
|
|
@item
|
|
A binary compatibility layer
|
|
acts as a program loader for native Windows binaries.
|
|
It works for both 16 and 32 bit Intel binaries, and
|
|
provides all the appropriate translation between 16 and 32 bit code
|
|
(thunking). Real mode interrupts are also supported, and their
|
|
functionality is implemented in @winelib{}.
|
|
|
|
@end enumerate
|
|
|
|
@strong{System Requirements}
|
|
|
|
|
|
Wine provides binary support for Intel code on Intel hardware only.
|
|
Neither hardware emulation
|
|
nor non-Intel binaries are supported.
|
|
@winelib{} should be possible to port to just about any Unix system.
|
|
|
|
Currently, you must have one of:
|
|
@itemize @bullet
|
|
@item
|
|
Linux version 0.99.13 or above
|
|
@item
|
|
NetBSD-current
|
|
@item
|
|
FreeBSD-current or FreeBSD 1.1
|
|
@item
|
|
OpenBSD/i386 2.1 or later
|
|
@item
|
|
Solaris x86 2.5 or later
|
|
@end itemize
|
|
You need X11, and you must have @file{libXpm} installed on your system.
|
|
|
|
@strong{Availability}
|
|
|
|
Wine is free software; the license is BSD-style. Basically, you can do
|
|
anything with it, except claim that you wrote it.
|
|
@xref{Copying}, for more information.
|
|
|
|
@strong{Further information}
|
|
|
|
You should consult the files @file{README}, @file{ANNOUNCE},
|
|
@file{RELEASE-NOTES}, @file{BUGS}, @file{LICENSE}, and @file{WARRANTY},
|
|
in the root directory of the Wine distribution.
|
|
|
|
The Wine USENET newsgroup @url{news:comp.emulators.ms-windows.wine}
|
|
is useful for both Wine developers and Wine users. The Wine home page
|
|
is @url{http://www.winehq.com/}.
|
|
|
|
@node Wine Design, Reference Manual, Introduction, Top
|
|
@chapter Wine Design
|
|
|
|
@subsection The Wine Graphics Driver Model
|
|
|
|
Wine, like Windows, abstracts drawing code so that applications may access
|
|
a wide variety of devices, from different kinds of graphics cards,
|
|
X displays and printers, using a single unified graphics model.
|
|
This model is referred to as GDI: _G_raphics _D_river _I_nterface.
|
|
This section discusses the Wine implementation of GDI.
|
|
There are 61 functions in the Wine graphics model, including Arc, BitBlt,
|
|
Chord, etc. For a complete list and prototypes, see the definition
|
|
of DC_FUNCTIONS in [include/gdi.h].
|
|
|
|
Wine, as of 2Q1998, has three native drivers: these provide support
|
|
for rendering to X displays, metafiles, and Win16 native printer drivers.
|
|
As far as Wine is concerned, a driver
|
|
simply consists of a name and a table of function pointers
|
|
(see [graphics/driver.c]). These functions
|
|
are the driver's implementation of the various Wine graphics
|
|
operations (the GDI). Wine maintains a linked list of all drivers which
|
|
register themselves with Wine, as well as a ``generic''
|
|
driver. Currently, the X11 driver registers itself as DISPLAY, the
|
|
win16 driver registers itself as the generic driver, and the metafile
|
|
driver doesn't register itself at all.
|
|
|
|
@subsubsection How a driver function gets invoked
|
|
|
|
All drawing by Wine applications
|
|
is done in terms of a Device Context (DC).
|
|
Before an application can draw, it must create a DC, and all drawing calls
|
|
must pass a handle to the DC they wish to draw to.
|
|
[include/gdi.h] defines several structures relating to DCs, including
|
|
DC, WIN_DC_INFO, and DeviceCaps. The DeviceCaps structure is at the lowest
|
|
level: it holds
|
|
information relating to specifics of the graphics display
|
|
hardware and associated
|
|
driver.
|
|
WIN_DC_INFO holds information about several device independent
|
|
modes the DC can be in, plus a pointer to DeviceCaps.
|
|
Finally,
|
|
the DC structure is the toplevel structure usually passed around.
|
|
It holds viewport information, a pointer to WIN_DC_INFO, and a
|
|
pointer to the function table to be used while rendering that DC.
|
|
This function table is filled at the time of creating the DC.
|
|
|
|
@c Modes
|
|
|
|
@c Some discussion of the various modalities available to a DC would be nice.
|
|
|
|
@c Coordinate Systems
|
|
|
|
@c Some discussion of the maze of coordinate systems would also be nice.
|
|
|
|
@c Device Coordinates
|
|
|
|
@c Logical Coordinates
|
|
|
|
@c World transforms
|
|
|
|
|
|
@subsubsection The X11 driver
|
|
|
|
As a part of the Wine loading process,
|
|
X11DRV_Init in [graphics/x11drv/init.c] is called.
|
|
This initializes various aspects of the X11 driver and
|
|
registers it as DISPLAY. This function first
|
|
calls initialization procedures for various parts of the X11 driver.
|
|
It then
|
|
creates and
|
|
fills a static DeviceCaps
|
|
structure to be used for every X11 DC.
|
|
Finally, it fills the table of GDI functions to be used for X11
|
|
rendering and registers itself as ``DISPLAY''.
|
|
|
|
@subsubsection The Metafile Driver
|
|
|
|
The metafile driver is unusual, in that it is not a driver for any
|
|
kind of display device, but rather a mechanism which allows using
|
|
the Wine graphics model as a file format for saving graphics.
|
|
The advantage of this is that it allows using identical formats for
|
|
saving pictures as is actually used to display them; it is analogous
|
|
to Display PostScript.
|
|
|
|
The metafile driver is invoked explicitly by the application. The
|
|
application calls CreateMetaFile() to create a special DC for recording
|
|
graphics drawing operations in a metafile. Any drawing operations
|
|
performed in this DC are not drawn physically anywhere, they are
|
|
instead stored in the metafile. The DC is explicitly destroyed by a
|
|
call to CloseMetaFile(), which also finishes writing the metafile.
|
|
Metafiles may be written either to a file or to memory. Later, the
|
|
metafile can be rendered (in a physical DC) by PlayMetaFile().
|
|
|
|
The way that this works is that device contexts contain a pointer
|
|
to the function lookup table for drawing operations appropriate for
|
|
that device.
|
|
|
|
Not all functions in the Wine graphics model are relevant to metafiles, but
|
|
some relevant but rarely used functions are unimplemented.
|
|
|
|
@subsubsection The WIN16 Driver
|
|
|
|
WIN16DRV_Init is called by MAIN_EmulatorInit, and registers the
|
|
WIN16DRV function table WIN16DRV_Funcs [graphics/win16drv/init.c]
|
|
for the generic driver. The WIN16 driver is designed to load
|
|
specified native Windows printer drivers. I don't understand
|
|
how the whole scheme works,
|
|
start studying what happens when a printer DC is
|
|
created via WIN16DRV_CreateDC.
|
|
|
|
If a DC is created explicitly, via the
|
|
CreateDC() call, the driver name is specified explicitly and Wine
|
|
finds the appropriate driver by leafing through its table of registered
|
|
drivers. Metafile DCs can only be created by the CreateMetaFile function.
|
|
|
|
Alternatively, most of the time, the DISPLAY driver is invoked
|
|
implicitly.
|
|
The application creates a window with
|
|
CreateWindow(). If the CS_CLASSDC or CS_OWNDC flag is passed, a new DC
|
|
is created and saved for the window in a structure called DCE, which holds
|
|
a DC, a clipping region, and flags. Whenever the application wants to
|
|
paint in that window, it calls GetDC(hwnd), which returns the DC in the
|
|
DCE saved in the window.
|
|
|
|
If neither of those flags are used, the window gets a DCE assigned to it
|
|
from a pool of DCEs created during Wine initialization and temporarily
|
|
assigned during the GetDC() call.
|
|
All DCEs, whether part of the Wine DC pool or created by request of a window,
|
|
use the ``DISPLAY'' driver.
|
|
|
|
|
|
@node Reference Manual, Installation, Wine Design, Top
|
|
|
|
@menu
|
|
* @WIN32{} Reference Manual:: The @WIN32{} function calls and data types.
|
|
* Resources and INI files:: How to determine the appearance and
|
|
behaviour of Wine programs.
|
|
* Metafiles--Icons--Bitmaps:: FIXME missing.
|
|
* Debugging:: Debugging Wine.
|
|
* Programs:: Programs written to run in/with Wine.
|
|
* Tools:: Programs to support Wine.
|
|
@end menu
|
|
|
|
@node @WIN32{} Reference Manual, Resources and INI files, , Reference Manual
|
|
@chapter The @WIN32{} Reference Manual
|
|
|
|
@menu
|
|
* Kernel Objects:: How the Wine kernel keeps information.
|
|
* Processes and Threads:: Job control and management in Wine.
|
|
* Users and Groups:: Security in Wine.
|
|
* Date and Time:: Functions for getting the date and time
|
|
and for conversion between formats.
|
|
* System Information:: Getting information about the hardware
|
|
and software the system runs on.
|
|
* Memory Management:: How your programs get memory from
|
|
Wine.
|
|
* I/O Facilities:: Input/Output in Wine.
|
|
* Communication:: How processes can communicate.
|
|
* Windows and Graphics:: GUI functions of @WIN32{}.
|
|
* Errors and Exceptions:: How your program can report errors.
|
|
(messaging)
|
|
* Resources:: Functions for dealing with resources.
|
|
* The Registry:: FIXME missing.
|
|
* Dynamic Link Libraries:: Functions for dealing with DLL's.
|
|
@end menu
|
|
|
|
@node Kernel Objects, Processes and Threads, , @WIN32{} Reference Manual
|
|
@section Kernel Objects
|
|
|
|
|
|
@node Processes and Threads, Users and Groups, Kernel Objects, @WIN32{} Reference Manual
|
|
@section Processes and Threads
|
|
|
|
@node Users and Groups, Date and Time, Processes and Threads, @WIN32{} Reference Manual
|
|
@section Users and Groups
|
|
|
|
@node Date and Time, System Information, Users and Groups, @WIN32{} Reference Manual
|
|
@section Date and Time
|
|
|
|
This section describes functions for manipulating dates and times. This
|
|
includes the current time, the creation or manipulation times of files
|
|
and other objects, and conversion between different time
|
|
representations.
|
|
|
|
@menu
|
|
* File Times:: Creation and manipulation times of files.
|
|
@end menu
|
|
|
|
@node File Times, , , Date and Time
|
|
@subsection File Times
|
|
|
|
@menu
|
|
* Type FILETIME:: The data structure used for specifying
|
|
file times.
|
|
* Compare File Times:: Compare two file times.
|
|
@end menu
|
|
|
|
@c
|
|
@c *** struct FILETIME ***
|
|
@c
|
|
@node Type FILETIME, Compare File Times, , File Times
|
|
@subsubsection Type FILETIME
|
|
|
|
@noindent
|
|
File times in Wine are specified by the data type @code{FILETIME},
|
|
defined in @file{windows.h}.
|
|
@deftp_w32 FILETIME
|
|
@deftpx_w32 LPFILETIME
|
|
This is the data type for specifying file times. The file times are
|
|
stored with 64 bit precision. The actual data type is a structure with
|
|
two 32-bit values which are interpreted as the low and high parts of a
|
|
64-bit value. This value gives a time measured in a granularity of 100
|
|
nanoseconds, so 1.5 seconds are specified by a value of 15,000,000. In
|
|
Wine, this 64-bit value is signed, with the sign taken from the high
|
|
part. The lower part is used as unsigned.
|
|
|
|
The definition of @code{FILETIME} reads:
|
|
@example
|
|
typedef struct
|
|
@{
|
|
INT32 dwLowDateTime;
|
|
INT32 dwHighDateTime;
|
|
@} FILETIME, *LPFILETIME;
|
|
@end example
|
|
|
|
@cindex epoch in file time
|
|
The @code{FILETIME} structure may be used to hold absolute or relative
|
|
times. Absolute times are given as the number of 100 nanoseconds
|
|
intervals elapsed since 1 January 1601, 00:00:00 UTC (Coordinated
|
|
Universal Time, which is GMT, Greenwich Mean Time). This might be
|
|
called the @dfn{epoch} for file times. With a signed 64-bit value, this
|
|
representation covers absolute times of 29247 years around the epoch.
|
|
To convert this type to local time, use the function
|
|
@code{FileTimeToLocalFileTime}.
|
|
|
|
@windiff{}
|
|
In @mswindows{}, the elements of the structure are apparently of type
|
|
@code{DWORD}. Whether the full 64 bit value is interpreted as signed or
|
|
unsigned I do not know.
|
|
@end deftp
|
|
|
|
@c
|
|
@c *** CompareFileTime ***
|
|
@c
|
|
@node Compare File Times, , Type FILETIME, File Times
|
|
|
|
@noindent
|
|
The Wine function @code{CompareFileTime} compares two file times, and
|
|
returns whether the first time is less than, equal to, or greater than
|
|
the second file time. It is defined in @file{windows.h}.
|
|
@deftypefn_w32 LONG CompareFileTime (@w{CONST FILETIME* @var{time_1},} @w{CONST FILETIME* @var{time_2})}
|
|
This function returns @code{1}, if @var{time_1} is greater than
|
|
@var{time_2}, @code{-1} if it is less, and @code{0} if both times are
|
|
equal.
|
|
|
|
@winconfall{}
|
|
|
|
@windiffnone{}
|
|
|
|
@completionnone{}
|
|
@end deftypefn
|
|
|
|
@node System Information, Memory Management, Date and Time, @WIN32{} Reference Manual
|
|
@section System Information
|
|
|
|
@node Memory Management, I/O Facilities, System Information, @WIN32{} Reference Manual
|
|
@section Memory Management
|
|
|
|
@node I/O Facilities, Communication, Memory Management, @WIN32{} Reference Manual
|
|
@section I/O Facilities
|
|
|
|
This section describes all input/output of a process, except for two
|
|
topics: communication with other processes, and communication with the
|
|
windowing system.
|
|
|
|
@menu
|
|
* I/O on Files:: Accessing the contents of files.
|
|
* File System Interface:: Functions for manipulating files as a whole.
|
|
@end menu
|
|
|
|
@node I/O on Files, File System Interface, , I/O Facilities
|
|
@subsection I/O on Files
|
|
|
|
@node File System Interface, , I/O on Files, I/O Facilities
|
|
@subsection File System Interface
|
|
|
|
These functions are concerned with operating on files themselves, rather
|
|
than on their contents.
|
|
|
|
@menu
|
|
* Type BY_HANDLE_FILE_INFORMATION:: The data structure used to
|
|
specify file information.
|
|
* File attributes:: The file attributes flags in
|
|
a file information structure.
|
|
* Getting file information:: These functions let you obtain
|
|
information about a file.
|
|
@end menu
|
|
|
|
@node Type BY_HANDLE_FILE_INFORMATION, File attributes, , File System Interface
|
|
@subsubsection The file information structure
|
|
|
|
The file information structure of Wine is used to obtain information
|
|
about files. It is declared in the header @file{winedows.h}.
|
|
@deftp_w32 BY_HANDLE_FILE_INFORMATION
|
|
This is the data type for specifying information about files as objects
|
|
of the file system. It contains the following members:
|
|
@table @code
|
|
@item int dwFileAttributes
|
|
@cindex file attributes in file information
|
|
@cindex attributes of file in file information
|
|
@xref{File attributes}, for details.
|
|
@item FILETIME ftCreationTime
|
|
@cindex creation time in file information
|
|
@cindex time of file creation in file information
|
|
The time when the file was created.
|
|
@xref{Type FILETIME}, for details.
|
|
@item FILETIME ftLastAccessTime
|
|
@cindex access time in file information
|
|
@cindex time of file access in file information
|
|
The time when the file was last accessed.
|
|
@xref{Type FILETIME}, for details.
|
|
@item FILETIME ftLastWriteTime
|
|
@cindex write time in file information
|
|
@cindex time of last file write in file information
|
|
The time when the file was last written to.
|
|
@xref{Type FILETIME}, for details.
|
|
@item int dwVolumeSerialNumber
|
|
@cindex serial number of volume in file information
|
|
@cindex volume number (serial) in file information
|
|
The serial number of the volume containing the file. In Wine,
|
|
currently 0.
|
|
@item int nFileSizeHigh
|
|
@cindex file size in file information
|
|
@cindex size of file in file information
|
|
A 32 bit value which contains the high part of the 64 bit file size.
|
|
@item int nFileSizeLow
|
|
A 32 bit value which contains the low part of the 64 bit file size.
|
|
@item int nNumberOfLinks
|
|
@cindex hard links number in file information
|
|
@cindex links (number of hard) in file information
|
|
This is the number of hard links to the file. In a file system which
|
|
does not support hard links, this is 1.
|
|
@item int nFileIndexHigh
|
|
@cindex inode number in file information
|
|
@cindex file index in file information
|
|
@cindex index of file in file information
|
|
A 32 bit value which contains the high part of the 64 bit file
|
|
index. The file index is a unique number for a file on a volume.
|
|
This identifier cannot change while the file is opened by a process.
|
|
Together with the volume number, the file index is a unique
|
|
identifier for the file. This can be used by an application to check
|
|
whether two handles refer to the same file. Wine currently uses the
|
|
inode number for the file index.
|
|
@item int nFileIndexLow
|
|
A 32 bit value which contains the low part of the 64 bit file index.
|
|
@end table
|
|
|
|
The definition of @code{BY_HANDLE_FILE_INFORMATION} reads:
|
|
@example
|
|
typedef struct
|
|
@{
|
|
int dwFileAttributes;
|
|
FILETIME ftCreationTime;
|
|
FILETIME ftLastAccessTime;
|
|
FILETIME ftLastWriteTime;
|
|
int dwVolumeSerialNumber;
|
|
int nFileSizeHigh;
|
|
int nFileSizeLow;
|
|
int nNumberOfLinks;
|
|
int nFileIndexHigh;
|
|
int nFileIndexLow;
|
|
@} BY_HANDLE_FILE_INFORMATION ;
|
|
@end example
|
|
|
|
The @code{BY_HANDLE_FILE_INFORMATION} structure can be obtained by the
|
|
@code{GetFileInformationByHandle} function (@pxref{Getting file information}, for
|
|
details).
|
|
|
|
@windiff{}
|
|
In @mswindows{}, the @code{int} elements of the structure are apparently
|
|
of type @code{DWORD}.
|
|
@end deftp
|
|
|
|
@node File attributes, Getting file information, Type BY_HANDLE_FILE_INFORMATION, File System Interface
|
|
@subsubsection The file attributes in a file information structure
|
|
|
|
The file attributes in a file information structure and in other structures
|
|
are a logical @emph{or} of one or more of the following constants:
|
|
|
|
@defvr_cw32 FILE_ATTRIBUTE_READONLY
|
|
The file is a read-only file. (Wine value: 0x0001).
|
|
@end defvr
|
|
@defvr_cw32 FILE_ATTRIBUTE_HIDDEN
|
|
The file is a hidden file. Files in Wine do not have this attribute. (Wine value:
|
|
0x0002).
|
|
@end defvr
|
|
@defvr_cw32 FILE_ATTRIBUTE_SYSTEM
|
|
The file belongs to the operating system. Files in Wine do not have this
|
|
attribute. (Wine value: 0x0004).
|
|
@end defvr
|
|
@defvr_cw32 FILE_ATTRIBUTE_LABEL
|
|
This is not present in the @mswindows{} API. (Wine value: 0x0008).
|
|
@end defvr
|
|
@defvr_cw32 FILE_ATTRIBUTE_DIRECTORY
|
|
The file is a directory. (Wine value: 0x0010).
|
|
@end defvr
|
|
@defvr_cw32 FILE_ATTRIBUTE_ARCHIVE
|
|
The file is an archive file. Currently, all non-directory files are
|
|
reported by Wine to have this attribute. This attribute is normally set
|
|
by @mswindows{} to indicate that a file is to be archived; when the file
|
|
is archived, the flag is cleared. (Wine value: 0x0020).
|
|
@end defvr
|
|
@defvr_cw32 FILE_ATTRIBUTE_NORMAL
|
|
The file does not have any other attributes set. This value must be used
|
|
alone. In Wine, normal files are reported as archive files. (Wine value:
|
|
0x0080).
|
|
@end defvr
|
|
@defvr_cw32 FILE_ATTRIBUTE_TEMPORARY
|
|
The file is used as a temporary storage. Files in Wine do not have this
|
|
attribute. (Wine value: 0x0100).
|
|
@end defvr
|
|
@defvr_cw32 FILE_ATTRIBUTE_ATOMIC_WRITE
|
|
This is reserved for future use. Files in Wine do not have this
|
|
attribute. (Wine value: 0x0200).
|
|
@end defvr
|
|
@defvr_cw32 FILE_ATTRIBUTE_XACTION_WRITE
|
|
This is reserved for future use. Files in Wine do not have this
|
|
attribute. (Wine value: 0x0400).
|
|
@end defvr
|
|
@defvr_cw32 FILE_ATTRIBUTE_COMPRESSED
|
|
The file is compressed. Files in Wine do not have this attribute. (Wine
|
|
value: 0x0800).
|
|
@end defvr
|
|
|
|
@node Getting file information, , File attributes, File System Interface
|
|
@subsubsection Getting file information
|
|
|
|
The functions in this section describe how to get information about
|
|
files.
|
|
|
|
@c
|
|
@c *** GetFileInformationByHandle
|
|
@c
|
|
@noindent
|
|
The Wine function @code{GetFileInformationByHandle} returns a file
|
|
information structure. It is defined in @file{windows.h}.
|
|
|
|
@deftypefn_w32 BOOL GetFileInformationByHandle (@w{HFILE32 @var{file},} @w{BY_HANDLE_FILE_INFORMATION *@var{info})}
|
|
This function obtains for the specified @var{file} the file information,
|
|
and stores it in @var{info}. The file information contains the file
|
|
attributes, the file times, the volume serial number, the file size, the
|
|
number of links, and a unique file identifier. The function returns
|
|
@code{TRUE} on success, @code{FALSE} on failure.
|
|
|
|
@winconfall{}
|
|
|
|
@windiff{}
|
|
The Wine function can of course only give back information that is
|
|
accessible in the @unix{} file system. File times are produced in a
|
|
granularity of full seconds. Most file attributes are not present in the
|
|
@unix{} file system. @xref{File attributes}, for details. The volume
|
|
serial number is set to 0.
|
|
@end deftypefn
|
|
|
|
|
|
@c
|
|
@c *** GetFileTime ***
|
|
@c
|
|
@noindent
|
|
The Wine function @code{GetFileTime} returns the creation time and
|
|
the times of last the read and modification access to a file. It is
|
|
defined in @file{windows.h}.
|
|
|
|
@deftypefn_w32 BOOL GetFileTime (@w{HANDLE @var{file},} @w{LPFILETIME @var{ctime},} @w{LPFILETIME @var{atime},} @w{LPFILETIME @var{mtime})}
|
|
This function obtains for the specified @var{file} the creation time
|
|
@var{ctime}, the time of the last access to the file @var{atime}, and
|
|
the time of the last modification (write) to the file, @var{mtime}.
|
|
The file time arguments of this function are pointers to @code{FILETIME}
|
|
variables, which are filled with a value that indicates an absolute time
|
|
in UTC. @xref{Type FILETIME}, for details. If you do not need some of
|
|
the times, you can pass a @code{NULL} pointer.
|
|
The function returns @code{TRUE} on
|
|
success, @code{FALSE} on failure.
|
|
|
|
@winconfall{}
|
|
|
|
@windiff{}
|
|
The file times are produced in a granularity of full seconds, due to the
|
|
underlying @unix{} file system.
|
|
@end deftypefn
|
|
|
|
@c
|
|
@c *** GetFileAttributes ***
|
|
@c
|
|
@noindent
|
|
The Wine function @code{GetFileAttributes} returns the file attributes
|
|
for a file. It is defined in @file{windows.h}.
|
|
|
|
@deftypefn_w32 DWORD GetFileAttributes (@w{LPCTSTR @var{name})}
|
|
This function looks up the file with name @var{name}, and returns the
|
|
attributes of the file. @xref{File attributes}, for details on the file
|
|
attributes. If the function is not successful, it returns a word with
|
|
all bits set (@samp{0xffffffff}).
|
|
|
|
@winconfall{}
|
|
|
|
@windiff{}
|
|
Most file attributes are not present in the
|
|
@unix{} file system. @xref{File attributes}, for details.
|
|
@end deftypefn
|
|
|
|
|
|
|
|
|
|
@node Communication, Windows and Graphics, I/O Facilities, @WIN32{} Reference Manual
|
|
@section Communication
|
|
|
|
@node Windows and Graphics, Errors and Exceptions, Communication, @WIN32{} Reference Manual
|
|
@section Windows and Graphics
|
|
|
|
@node Errors and Exceptions, Resources, Windows and Graphics, @WIN32{} Reference Manual
|
|
@section Errors and Exceptions
|
|
|
|
@node Resources, The Registry, Errors and Exceptions, @WIN32{} Reference Manual
|
|
@section Resources
|
|
|
|
@node The Registry, Dynamic Link Libraries, Resources, @WIN32{} Reference Manual
|
|
@section The Registry
|
|
|
|
@node Dynamic Link Libraries, , The Registry, @WIN32{} Reference Manual
|
|
@section Dynamic Link Libraries (DLL's)
|
|
|
|
This section deals with API functions for handling DLL's (dynamic link
|
|
libraries). It does not describe DLL's themselves; nor does it give
|
|
information on how Wine handles DLL's. @xref{The build program}, for
|
|
information on how DLL's are integrated into Wine.
|
|
|
|
|
|
|
|
|
|
@node Resources and INI files, Metafiles--Icons--Bitmaps, @WIN32{} Reference Manual, Reference Manual
|
|
@chapter Resources and @file{INI} Files
|
|
|
|
@node Metafiles--Icons--Bitmaps, Debugging, Resources and INI files, Reference Manual
|
|
@chapter Metafiles --- Icons --- Bitmaps
|
|
|
|
@node Debugging, Programs, Metafiles--Icons--Bitmaps, Reference Manual
|
|
@chapter Debugging
|
|
|
|
@node Programs, Tools, Debugging, Reference Manual
|
|
@chapter Programs
|
|
|
|
@node Tools, , Programs, Reference Manual
|
|
@chapter Tools
|
|
|
|
This chapter describes some of the tools that are used by Wine. These
|
|
are not user-level programs which the user of Wine will
|
|
run. @xref{Programs}, for such programs.
|
|
|
|
Tools are internal programs that are used to help compile or configure
|
|
Wine.
|
|
|
|
@menu
|
|
* The build program:: A program used to build the DLL entry
|
|
points from specifications in @file{if1632/}.
|
|
@end menu
|
|
|
|
|
|
@node The build program, , , Tools
|
|
@section The @file{build} program
|
|
|
|
@cindex modules of Wine
|
|
@cindex Wine modules
|
|
@cindex DLL's built-in in Wine
|
|
@cindex Wine DLL's built-in
|
|
@cindex built-in DLL's in Wine
|
|
Wine contains several modules that implement various DLL's which are
|
|
required to run @mswindows{} programs.
|
|
|
|
The @file{build} program, located in the @file{tools/} directory, is
|
|
used to create the bindings for the DLL entry points of the API functions.
|
|
This program reads a @file{.spec}-file in the @file{if1632} directory
|
|
and creates the assembly code that translates the function arguments
|
|
correctly.
|
|
|
|
|
|
@menu
|
|
* The spec files:: The format of the @file{.spec}-files.
|
|
@end menu
|
|
|
|
FIXME: where in Wine are the DLL's affixed?
|
|
|
|
FIXME: write a description
|
|
|
|
@xref{Implementing an API function}, for notes on using this program.
|
|
|
|
@node The spec files, , , The build program
|
|
@subsection The @file{.spec}-files
|
|
@cindex DLL spec files
|
|
@cindex spec files of DLL's
|
|
@cindex entry points in DLL's
|
|
|
|
This subsection describes the format of the @file{.spec}-files.
|
|
|
|
A @file{.spec}-file contains the information about the functions,
|
|
variables, and constants that are contained in a DLL (dynamic link
|
|
library).
|
|
|
|
To be able to interpret the contents of a @file{.spec}-file, you must
|
|
know about the concept of ordinals.
|
|
@menu
|
|
* The general format:: General format conventions.
|
|
* Ordinals:: Ordinals are indexes of entry
|
|
points into DLL's.
|
|
* Spec file header:: The header information.
|
|
* Variable entry points:: Entries for DLL variables.
|
|
* Function entry points:: Entries for DLL functions.
|
|
* Special entries:: Entries for stubs, dummy
|
|
functions, Wine symbols, and
|
|
constant values.
|
|
@end menu
|
|
|
|
@node The general format, Ordinals, , The spec files
|
|
@subsubsection The general format
|
|
@cindex format of spec files
|
|
@cindex spec files format
|
|
|
|
The @file{.spec}-file contains a header and a sequence of declarations.
|
|
Each declaration describes an ordinal.
|
|
|
|
The header gives general information about the DLL and its properties.
|
|
|
|
Ordinal declarations are optional. That means that there is a default
|
|
behaviour assigned to ordinals which are not mentioned in the
|
|
@file{.spec}-file. The default handler function of an ordinal will print
|
|
an error message when called.
|
|
|
|
Comments are indicated by hash marks (@samp{#}); everything between a
|
|
hash mark and the end of the line is ignored.
|
|
|
|
Empty lines are allowed.
|
|
@* FIXME: is that so?
|
|
|
|
@node Ordinals, Spec file header, The general format, The spec files
|
|
@subsubsection Ordinals
|
|
@cindex ordinals in DLL's
|
|
@cindex DLL ordinals
|
|
|
|
All references to DLL objects like functions or variables are indexed by
|
|
unique nonnegative numbers. These numbers are called
|
|
@dfn{ordinals}. Apparently, a program can refer to a DLL function or
|
|
variable by specifying its name or its ordinal. Although reference by
|
|
name is the common usage, some program parts (notably DLL's themselves)
|
|
sometimes refer to DLL entries by ordinal. Therefore, the ordinals
|
|
cannot be chosen arbitrarily.
|
|
|
|
Regular programs that are compiled and linked against @mswindows{} DLL's
|
|
will import DLL functions by name. This is therefore the default
|
|
behaviour. Most DLL functions will be imported by name in all cases.
|
|
Apparently, the @WIN32{} DLL's even show some difference in the mapping
|
|
of functions and ordinals on @WINNT{} and @WIN95{}. For most DLL
|
|
functions, the ordinal number will not matter.
|
|
|
|
There are some exceptions to that. Notable the KERNEL32 ordinals below
|
|
100 are (presently) unnamed and undocumented functions which can only be
|
|
imported by ordinal. These functions are called by some @mswindows{}
|
|
programs. Also the @file{shell32.dll} functions are reported to be
|
|
imported by ordinal in some other DLL's.
|
|
|
|
@xref{Getting information on the API}, for sources of further information.
|
|
|
|
@node Spec file header, Variable entry points, Ordinals, The spec files
|
|
@subsubsection The header of a @file{.spec}-file
|
|
|
|
The @file{.spec}-file starts with two mandatory definitions. The first
|
|
line gives the name of the DLL which the @file{.spec}-file describes,
|
|
@example
|
|
name @var{NAME}
|
|
@end example
|
|
where @var{NAME} is the name of the DLL. The next line defines the type
|
|
of the DLL,
|
|
@example
|
|
type @var{TYPE}
|
|
@end example
|
|
with @var{TYPE} being either @samp{win16} or @samp{win32}.
|
|
|
|
An optional statement of the form
|
|
@example
|
|
base @var{ORDINAL}
|
|
@end example
|
|
can be used to define the offset of the first ordinal. @var{ORDINAL}
|
|
must be an integer number. If no base is specified, the offset is zero.
|
|
@* FIXME: is this the offset of the first or an offset that is added to all
|
|
ordinals?
|
|
what is the offset? Is it added to the ordinals, or is it an address, or
|
|
xxx?
|
|
|
|
An optional statement like
|
|
@example
|
|
heap @var{SIZE}
|
|
@end example
|
|
can be used to define the size of the module local heap. This is only
|
|
used for @WIN16{} DLL's. The local heap is the place where the segments
|
|
of 16 bit programs can locally allocate memory, without interfering with
|
|
one another. The default size of the local heap, if not specified, is 0.
|
|
|
|
@* FIXME: to my impression, a local heap in DLL's would only be required
|
|
if DLL functions used it. As all DLL functions in Wine are truly 32 bit
|
|
functions that are mapped from 16 bit on being called and back to 16 bit
|
|
on returning, a local heap should never be necessary.
|
|
If I receive a confirmation of that here, I will state so. Otherwise I
|
|
am missing some information on local heaps.
|
|
But why is a heap defined in user.spec and gdi.spec?
|
|
|
|
@node Variable entry points, Function entry points, Spec file header, The spec files
|
|
@subsubsection Variable entry points of @file{.spec}-files
|
|
|
|
You can declare an ordinal that holds data. Data items may be of 8, 16,
|
|
or 32 bit in size.
|
|
|
|
@example
|
|
@var{ORDINAL} @var{VARTYPE} @var{EXPORTNAME} (@var{DATA} @var{[DATA @dots{}]})
|
|
@end example
|
|
|
|
@var{ORDINAL} is the ordinal number corresponding to the
|
|
variable. @var{VARTYPE} must be @samp{byte}, @samp{word}, or
|
|
@samp{long}, for 8, 16, or 32 bits respectively. @var{EXPORTNAME} will
|
|
be the name available for dynamic linking. @var{DATA} can be a decimal
|
|
number or a hex number preceded by @samp{0x}. Each @var{DATA} item defines
|
|
a unit of storage.
|
|
|
|
The following example defines the variable @samp{VariableA} at ordinal
|
|
2, containing 4 bytes:
|
|
@example
|
|
2 byte VariableA(-1 0xff 0 0)
|
|
@end example
|
|
|
|
|
|
@node Function entry points, Special entries, Variable entry points, The spec files
|
|
@subsubsection Function entry points of @file{.spec}-files
|
|
|
|
@example
|
|
@var{ORDINAL} @var{FUNCTYPE} @var{EXPORTNAME} (@var{[ARGTYPE} @dots{} @var{]}) @var{HANDLERNAME}
|
|
@end example
|
|
|
|
@var{ORDINAL} is the ordinal number corresponding to the
|
|
function. @var{FUNCTYPE} must be chosen from this table:
|
|
@table @samp
|
|
@item pascal16
|
|
A @WIN16{} function that returns a 16 bit value.
|
|
@item pascal
|
|
A @WIN16{} function that returns a 32 bit value.
|
|
@item register
|
|
A function using CPU registers to pass arguments.
|
|
@item stdcall
|
|
A normal @WIN32{} function. @xref{Investigating the undocumented API},
|
|
for an explanation of the stdcall calling convention.
|
|
@item cdecl
|
|
A @WIN32{} function using the C calling conventions. (This is presently
|
|
only used for the built-in functions of the C runtime system).
|
|
@end table
|
|
|
|
@var{EXPORTNAME} specifies the name (prototype) available for dynamic
|
|
linking.
|
|
|
|
@var{ARGTYPE} must be chosen from this table:
|
|
@table @samp
|
|
@item byte
|
|
An 8 bit argument. Can be used in @WIN16{} functions only.
|
|
@item word
|
|
A 16 bit argument. Can be used in @WIN16{} functions only.
|
|
@item long
|
|
A 32 bit argument. Can be used in @WIN16{} or @WIN32{} functions.
|
|
@item ptr
|
|
A linear pointer, unsegmented. Can be used in @WIN16{} or @WIN32{}
|
|
functions.
|
|
@item str
|
|
A linear pointer, unsegmented, pointing to a null-terminated string.
|
|
Can be used in @WIN16{} or @WIN32{} functions.
|
|
@item s_byte
|
|
A signed 8 bit argument. Can be used in @WIN16{} functions only.
|
|
@item s_word
|
|
A signed 16 bit argument. Can be used in @WIN16{} functions only.
|
|
@item s_long
|
|
A signed 32 bit argument. Can be used in @WIN16{} or @WIN32{}
|
|
functions.
|
|
@item segptr
|
|
A segmented pointer. Can be used in @WIN16{} functions only.
|
|
@item segstr
|
|
A segmented pointer to a null-terminated string. Can be used in
|
|
@WIN16{} functions only.
|
|
@end table
|
|
|
|
@var{HANDLERNAME} is the name of the actual Wine function that will
|
|
process the request in 32-bit mode.
|
|
|
|
|
|
@sp 2
|
|
Here are some examples. The first example defines an entry point for the
|
|
@code{CreateWindow()} call (the ordinal 100 is just an example):
|
|
@example
|
|
100 pascal CreateWindow(ptr ptr long s_word s_word s_word s_word
|
|
word word word ptr) WIN_CreateWindow
|
|
@end example
|
|
|
|
The second example defines an entry point for the @code{GetFocus()} call
|
|
(again, the ordinal 100 is an example):
|
|
@example
|
|
100 pascal GetFocus() WIN_GetFocus()
|
|
@end example
|
|
|
|
To declare a function that uses a variable number of arguments, specify
|
|
the function as taking no arguments. In this special case, in @WIN32{}
|
|
the called function will be passed a pointer to the first arg; in
|
|
@WIN16{}, the args are available as @code{CURRENT_STACK16->args}.
|
|
@* FIXME: create a reference here
|
|
See the @code{wsprintf}* functions in @file{user.spec} and
|
|
@file{user32.spec} for an example.
|
|
|
|
Sometimes it is not known how many arguments an undocumented DLL
|
|
function takes. @xref{Getting information on the API}, for some hints on
|
|
how to proceed in such a case.
|
|
|
|
@node Special entries, , Function entry points, The spec files
|
|
@subsubsection Special entries of @file{.spec}-files
|
|
|
|
The @file{.spec}-files offer the possibility to use some special
|
|
entries. These entries are used for stubs (which allow linking for
|
|
non-existing functions), dummy functions that do not perform any
|
|
operations, Wine symbols that must be referenced directly, and constant
|
|
values.
|
|
|
|
|
|
@strong{Stub ordinals}
|
|
|
|
This pseudo function type defines a stub function. It makes the name and
|
|
ordinal available for dynamic linking, but will terminate execution with
|
|
an error message if the function is ever called.
|
|
|
|
@example
|
|
@var{ORDINAL} stub @var{EXPORTNAME}
|
|
@end example
|
|
|
|
@var{ORDINAL} is the ordinal number corresponding to the
|
|
function. @var{EXPORTNAME} specifies the name (prototype) available for dynamic
|
|
linking.
|
|
|
|
@strong{Return ordinals}
|
|
|
|
This pseudo function type defines a function entry point whose handler
|
|
should do nothing but return a value.
|
|
@example
|
|
@var{ORDINAL} return @var{EXPORTNAME} @var{ARGLENGTH} @var{RETVALUE}
|
|
@end example
|
|
|
|
@var{ORDINAL} is replaced by the ordinal number corresponding to the
|
|
function. @var{ARGLENGTH} is the number of bytes that need to be removed
|
|
from the stack before returning to the caller. @xref{Investigating the
|
|
undocumented API}, for an explanation of the stdcall calling convention.
|
|
@var{RETVALUE} is the return value which will be passed back to the
|
|
caller.
|
|
|
|
@strong{Extern ordinals}
|
|
|
|
@example
|
|
@var{ORDINAL} extern @var{EXPORTNAME} @var{SYMBOLNAME}
|
|
@end example
|
|
This type defines an entry that simply maps to a Wine symbol
|
|
(variable or function); @var{EXPORTNAME} will point to the symbol
|
|
@var{SYMBOLNAME} that must be defined in C code. This type only works with
|
|
@WIN32{}.
|
|
|
|
|
|
@strong{Equate ordinals}
|
|
|
|
@example
|
|
@var{ORDINAL} equate @var{EXPORTNAME} @var{DATA}
|
|
@end example
|
|
|
|
This type defines an ordinal as an absolute value.
|
|
@var{ORDINAL} is replaced by the ordinal number corresponding to the
|
|
entry. @var{EXPORTNAME} will be the name available for dynamic linking.
|
|
@var{DATA} can be a decimal number or a hex number preceeded by @samp{0x}.
|
|
|
|
|
|
@node Installation, The Wine Project, Reference Manual, Top
|
|
@chapter Wine installation and configuration
|
|
FIXME: write installation guide
|
|
|
|
@menu
|
|
* Applying patches:: How to update Wine to a newer version.
|
|
@end menu
|
|
|
|
@node Applying patches, , , Installation
|
|
@section Applying patches
|
|
@xref{Creating patches}, for instructions on creating patches.
|
|
|
|
@kbd{cd} to the top source directory for Wine, and run
|
|
@code{patch -p1 < @var{patchfile}}.
|
|
What needs to be done next depends to some extent on what the
|
|
patch touches. For small patches which only alter C source, it can be
|
|
enough to rerun @code{make}. In general, the sequence @code{configure},
|
|
@code{make depend}, @code{make} is sufficient, unless the patch alters
|
|
@code{[config.in]}, in which case you must regenerate @code{configure}
|
|
via @code{make configure} (which just runs @code{autoconf}).
|
|
|
|
|
|
@node The Wine Project, , Installation, Top
|
|
@chapter The Wine project
|
|
@cindex Wine project contributions
|
|
@cindex project contributions to Wine
|
|
|
|
If you are new to Wine and want to support this project, here are
|
|
some suggestions.
|
|
|
|
@menu
|
|
* Getting information on the API:: Official and unofficial sources
|
|
of information on the @WIN32{} API.
|
|
* Investigating the undocumented API:: You can find out some API
|
|
information on your own.
|
|
* Implementing an API type:: How to implement a data type
|
|
of the API (a checklist).
|
|
* Implementing an API function:: How to implement one function
|
|
of the API (a checklist).
|
|
* API function and type naming:: How to name API functions in Wine.
|
|
* Creating patches:: How to create patches for Wine.
|
|
* Adding Documentation:: Templates for the documentation.
|
|
* File names:: How Wine treats @mswindows{} and
|
|
@unix{} file names.
|
|
* Wide character strings:: How Wine treats wide character
|
|
strings.
|
|
@end menu
|
|
|
|
@xref{Debugging}, for advice on how to debug Wine.
|
|
@xref{Applying patches}, for instructions on applying patches.
|
|
|
|
|
|
@node Getting information on the API, Investigating the undocumented API, , The Wine Project
|
|
@section Official and unofficial documentation on the @mswindows{} API
|
|
@cindex documentation of API functions
|
|
@cindex undocumented API functions
|
|
|
|
|
|
@strong{Official documentation}
|
|
|
|
For documentation on @WIN32{} API functions, you might try one of these
|
|
sources:
|
|
|
|
@itemize @bullet
|
|
|
|
@item
|
|
There is a free online version of the MSDN library (including
|
|
documentation for the @WIN32{} API) on
|
|
@url{http://www.microsoft.com/msdn/}.
|
|
|
|
@item
|
|
The @WINNT{} DDK gives information about some kernel (``executive'')
|
|
routines. Some of the function documentation might also apply to user
|
|
accessible DLL's.
|
|
@end itemize
|
|
|
|
@strong{Unofficial documentation}
|
|
|
|
Not all of the @WIN32{} API is well documented. Some functions are
|
|
obscured, and undocumented. @xref{Ordinals}, for information about
|
|
undocumented functions imported by ordinal. Getting to know what these
|
|
functions do can be tiresome and tedious. Here is a quote from a
|
|
news posting concerning two books that might help:
|
|
@c From: vischne@ibm.net-nospam (root)
|
|
@c Subject: Re: Functions
|
|
@c Newsgroups: comp.emulators.ms-windows.wine
|
|
@c Date: 24 Jul 97 16:45:11 GMT
|
|
@c Organization: The Light
|
|
@c NNTP-Posting-Host: 129.37.246.203
|
|
@c Message-ID: <33d78697.0@news3.ibm.net>
|
|
|
|
@quotation
|
|
Well actually, there are at least _two_ books that address these problems.
|
|
One is by Matt Pietrek, ``Windows 95 System Programming Secrets'', which
|
|
gives some auxiliary programs for helping ferret out the information, and
|
|
the other is by Shulman, ``Undocumented Windows 95''.
|
|
@end quotation
|
|
|
|
@xref{Ordinals}, for some notes on undocumented kernel functions.
|
|
|
|
@itemize @bullet
|
|
|
|
@item
|
|
@cindex book on undocumented API features by Pietrik
|
|
``Windows 95 System Programming Secrets'' @*
|
|
by Matt Pietrek @*
|
|
Book & Disk Edition @*
|
|
Paperback, 778 pages @*
|
|
Published by IDG Books Worldwide @*
|
|
Publication date: November 1, 1995 @*
|
|
Dimensions (in inches): 9.25 x 7.42 x 2.06 @*
|
|
ISBN: 1568843186 @*
|
|
|
|
@item
|
|
@cindex book on undocumented API features by Schulman
|
|
``Undocumented Windows; A Programmers Guide
|
|
to Reserved Microsoft Windows API Functions'' @*
|
|
by Andrew Schulman @*
|
|
Paperback, 715 pages @*
|
|
Published by Addison-Wesley Pub Co @*
|
|
Publication date: February 1, 1994 @*
|
|
Dimensions (in inches): 9.11 x 7.37 x 1.53 @*
|
|
ISBN: 0201608340 @*
|
|
|
|
@item
|
|
More books on these topics (including Schulman and Pietrik): @*
|
|
@url{http://www.sonic.net/~undoc/bookstore.html}
|
|
|
|
@item
|
|
More details about calling undocumented functions can be found at
|
|
@url{http://ftp.uni-mannheim.de/info/OReilly/windows/win95.update/dirty.html}.
|
|
|
|
@item
|
|
In 1993 Dr. Dobbs Journal published a column called ``Undocumented
|
|
Corner''.
|
|
@item
|
|
You might want to check out BYTE from December 1983 as well.
|
|
@* FIXME: is that to be taken seriously?
|
|
@item
|
|
And you might try to find out something on your own. @xref{Investigating
|
|
the undocumented API}, for details.
|
|
@end itemize
|
|
|
|
But, all in all, @url{news:comp.emulators.ms-windows.wine} says
|
|
@c From: dacut@henry.ece.cmu.edu (David A. Cuthbert)
|
|
@c Subject: Re: Getting Internet Explorer to work
|
|
@c Newsgroups: comp.emulators.ms-windows.wine
|
|
@c Date: 24 Jul 1997 03:10:30 GMT
|
|
@c Organization: Electrical & Computer Engineering, Carnegie Mellon University
|
|
@c Reply-To: henry.ece.cmu.edu!dacut
|
|
@c Message-ID: <5r6h36$86c@fs7.ece.cmu.edu>
|
|
@c NNTP-Posting-Host: henry.ece.cmu.edu
|
|
|
|
@quotation
|
|
Unfortunately, short of getting something like NuMega's SoftIce, I
|
|
don't think there's a ``good'' reference on the mystery <100 ordinals in
|
|
KERNEL32.DLL.
|
|
@end quotation
|
|
|
|
|
|
@node Investigating the undocumented API, Implementing an API type, Getting information on the API, The Wine Project
|
|
@section Investigating the undocumented API
|
|
@cindex undocumented API investigation
|
|
@cindex parameters of undocumented API functions
|
|
@cindex stdcall calling convention
|
|
@cindex C calling convention
|
|
@cindex API function parameters investigation
|
|
@cindex stack handling under stdcall calling
|
|
|
|
Besides reading the documentation in @ref{Getting information on the API},
|
|
you can find out some properties of API functions on your own.
|
|
|
|
Sometimes it is not known how many arguments an undocumented DLL
|
|
function takes. Here is a text from a news posting that gives some
|
|
hints on how you might proceed in this case.
|
|
|
|
@c The following text is closely quoted from:
|
|
@c From: dacut@henry.ece.cmu.edu (David A. Cuthbert)
|
|
@c Subject: Win32 stub functions (Claus Fischer, please read)
|
|
@c Newsgroups: comp.emulators.ms-windows.wine
|
|
@c Date: 7 Aug 1997 22:33:09 GMT
|
|
@c Organization: Electrical & Computer Engineering, Carnegie Mellon University
|
|
@c Reply-To: henry.ece.cmu.edu!dacut
|
|
@c Message-ID: <5sdif5$qt3@fs7.ece.cmu.edu>
|
|
|
|
The problem with implementing stubs for @WIN32{} functions is that it is
|
|
not sufficient to return a default value (usually 0) and leave the
|
|
stack the way we found it. For most @WIN32{} functions -- those that use
|
|
the @dfn{stdcall} calling convention -- the arguments sent to the function
|
|
are removed from the stack.
|
|
|
|
Some background: On the i386 class of machines, stack entries are
|
|
usually dword (4 bytes) in size, little-endian. The stack grows
|
|
downward in memory. The stack pointer, maintained in the @samp{esp}
|
|
register, points to the last valid entry; thus, the operation of
|
|
pushing a value onto the stack involves decrementing @samp{esp} and then
|
|
moving the value into the memory pointed to by esp (i.e., @code{push p}
|
|
in assembly resembles @code{*(--esp) = p;} in C). Removing (popping)
|
|
values off the stack is the reverse (i.e., @code{pop p} corresponds to
|
|
@code{p = *(esp++);}).
|
|
|
|
In the @dfn{stdcall} calling convention, arguments are pushed onto the
|
|
stack right-to-left. For example, the C call
|
|
|
|
@example
|
|
myfunction(40, 20, 70, 30);
|
|
@end example
|
|
|
|
is expressed in Intel assembly as:
|
|
|
|
@example
|
|
push 30
|
|
push 70
|
|
push 20
|
|
push 40
|
|
call myfunction
|
|
@end example
|
|
|
|
In addition, the called function is responsible for removing the
|
|
arguments off the stack. Thus, before the call to myfunction, the
|
|
stack would look like:
|
|
|
|
@example
|
|
[local variable or temporary]
|
|
[local variable or temporary]
|
|
30
|
|
70
|
|
20
|
|
esp -> 40
|
|
@end example
|
|
|
|
After the call returns, it should look like:
|
|
|
|
@example
|
|
[local variable or temporary]
|
|
esp -> [local variable or temporary]
|
|
@end example
|
|
|
|
To restore the stack to this state, the called function must know how
|
|
many arguments to remove (which is the number of arguments it takes).
|
|
This is a problem if the function is undocumented.
|
|
|
|
One way to attempt to document the number of arguments each function
|
|
takes is to create a wrapper around that function that detects the
|
|
stack offset. @file{WinRelay} (see below) was written to create such
|
|
wrappers. Essentially, each wrapper assumes that the function will take
|
|
a large number of arguments (by default, 64 in @file{WinRelay}). The
|
|
wrapper copies each of these arguments into its stack, calls the actual
|
|
function, and then calculates the number of arguments by checking esp
|
|
before and after the call.
|
|
|
|
@cindex bsod (blue screen of death)
|
|
@cindex blue screen of death
|
|
The main problem with this scheme is that the function must actually
|
|
be called from another program. Many of these functions are seldom
|
|
used. An attempt was made to aggressively query each function in a
|
|
given library (@file{ntdll.dll}) by passing 64 arguments, all 0, to each
|
|
function. Unfortunately, @WINNT40{} quickly goes to a blue screen
|
|
of death (@dfn{bsod}), even if the program is run from a
|
|
non-administrator account.
|
|
|
|
Another method that has been much more successful is to attempt to
|
|
figure out how many arguments each function is removing from the
|
|
stack. This instruction, @code{ret hhll} (where @samp{hhll} is the
|
|
number of bytes to remove, i.e. the number of arguments times 4), contains
|
|
the bytes @samp{0xc2 ll hh} in memory. It is a reasonable assumption
|
|
that few, if any, functions take more than 16 arguments; therefore,
|
|
@samp{hh} is 0x0 and @samp{ll} is less than 0x40. This utility,
|
|
@file{MakeSpec} (see below), simply queries the address of a function
|
|
and looks for the first occurrence of the bytes @samp{0xc2 ll 0x0},
|
|
where @math{@samp{ll} <= 0x40}.
|
|
|
|
Of course, this is not without errors. @code{ret 00ll} is not the only
|
|
instruction that can have the byte sequence @samp{0xc2 ll 0x0}; for
|
|
example, @code{push 0x000040c2} has the byte sequence
|
|
@samp{0x68 0xc2 0x40 0x0 0x0}, which matches the above. Properly, the
|
|
utility should look for this sequence only on an instruction boundary;
|
|
unfortunately, finding instruction boundaries on an i386 requires
|
|
implementing a full disassemble -- quite a daunting task. Besides,
|
|
the probability of having such a byte sequence that is not the actual
|
|
return instruction is fairly low.
|
|
|
|
Much more troublesome is the non-linear flow of a function. For
|
|
example, consider the following two functions:
|
|
|
|
@example
|
|
somefunction1:
|
|
jmp somefunction1_impl
|
|
|
|
somefunction2:
|
|
ret 0004
|
|
|
|
somefunction1_impl:
|
|
ret 0008
|
|
@end example
|
|
|
|
@file{MakeSpec} would incorrectly list both @code{somefunction1} and
|
|
@code{somefunction2} as taking only a single argument, whereas
|
|
@code{somefunction1} really takes two arguments.
|
|
|
|
With these limitations in mind, it is possible to implement more stubs
|
|
in Wine and, eventually, the functions themselves.
|
|
|
|
@c end of quote
|
|
|
|
The program @file{WinRelay} can be downloaded from
|
|
@url{http://www.ece.cmu.edu/afs/ece/usr/dacut/www/src},
|
|
and @file{MakeSpec} will be available from the same location. You can
|
|
compile them with Borland's C++Builder; you should not optimize when
|
|
compiling (@file{WinRelay} needs the stack frames).
|
|
|
|
|
|
@node Implementing an API type, Implementing an API function, Investigating the undocumented API, The Wine Project
|
|
@section Implementing an API type
|
|
|
|
Here is a checklist that should help you writing your first API type. It
|
|
will of course not tell you which elements to put into the type
|
|
(assuming it is a structure), but it should help you along the way of
|
|
integrating this type into Wine.
|
|
@xref{Implementing an API function}, for comparison.
|
|
|
|
@enumerate
|
|
@item
|
|
Find out how the type should be named in Wine and in the DLL's.
|
|
@xref{API function and type naming}, for details.
|
|
|
|
@item
|
|
Find out where the type should go. Please try to keep the header files
|
|
structure as similar to @mswindows{} as possible.
|
|
|
|
@item
|
|
Prepare for the later patch (by saving the original files before you
|
|
work on them). @xref{Creating patches}, for details.
|
|
|
|
@item
|
|
Put the type declaration into the header file.
|
|
|
|
@item
|
|
Make sure the declaration is syntactically correct, i.e. it does not
|
|
keep Wine from compiling.
|
|
|
|
@item
|
|
Make sure the declared type is layout-compatible with
|
|
@mswindows{}-compiled types. Especially keep an eye on the packing of
|
|
the structure.
|
|
@* FIXME: a reference to packed structures here.
|
|
|
|
@item
|
|
Build Wine and test the type, if possible. If you cannot test the
|
|
type by implementing a proper API function, write a small test program
|
|
to test it on its own. Or rather stop here.
|
|
|
|
@item
|
|
Write the documentation of the type in the @file{wine.texinfo}
|
|
file. @xref{Adding Documentation}, for details.
|
|
With types, be especially careful and document all the details. Also
|
|
document all constants or flags that are used in the type.
|
|
|
|
@item
|
|
Create an entry in the @file{ChangeLog} file.
|
|
|
|
@item
|
|
Collect some of these changes, and create a patch. @xref{Creating
|
|
patches}, for details.
|
|
|
|
@item
|
|
Mail the patch to Alexandre Julliard, @email{julliard@@winehq.com}.
|
|
|
|
@item
|
|
Wait for the patch to appear in the official distribution.
|
|
@end enumerate
|
|
|
|
|
|
@node Implementing an API function, API function and type naming, Implementing an API type, The Wine Project
|
|
@section Implementing an API function
|
|
|
|
Here is a checklist that should help you writing your first API
|
|
function. It will of course not tell you what to do in the function,
|
|
but it should help you along the way of integrating this function into
|
|
Wine.
|
|
|
|
@enumerate
|
|
@item
|
|
Make sure all data types that appear in function arguments are properly
|
|
declared in Wine. Otherwise, start with the data types.
|
|
|
|
@item
|
|
Find out how the function should be named in Wine and in the DLL's.
|
|
@xref{API function and type naming}, for details.
|
|
|
|
@item
|
|
Find out what the function should do. This may be tricky for
|
|
undocumented functions. @xref{Getting information on the API}, for some
|
|
hints.
|
|
|
|
@item
|
|
Find out where the function should go:
|
|
@enumerate
|
|
@item
|
|
Which header file for the prototype.
|
|
@item
|
|
Which C source file.
|
|
@item
|
|
Which DLL(s), and which ordinal the function will take there. Perhaps
|
|
the function name is already present in one of the @file{.spec}-files in
|
|
the @file{if1632} directory.
|
|
@end enumerate
|
|
|
|
@item
|
|
Prepare for the later patch (by saving the original files before you
|
|
work on them). @xref{Creating patches}, for details.
|
|
|
|
@item
|
|
Put the prototype into the header file, and the code into the C file.
|
|
|
|
@item
|
|
Make sure the code compiles.
|
|
|
|
@item
|
|
Create or change the information for the DLL entry points in the
|
|
@file{.spec}-file in the @file{if1632} directory.
|
|
@xref{The build program}, for details of the DLL spec files.
|
|
|
|
@item
|
|
Build Wine and test the function, if possible. If you cannot test the
|
|
function in Wine, write a small test program to test it on its own.
|
|
|
|
@item
|
|
Write the documentation of the function in the @file{wine.texinfo}
|
|
file. @xref{Adding Documentation}, for details.
|
|
|
|
@item
|
|
Create an entry in the @file{ChangeLog} file.
|
|
|
|
@item
|
|
Collect some of these changes, and create a patch. @xref{Creating
|
|
patches}, for details.
|
|
|
|
@item
|
|
Mail the patch to Alexandre Julliard, @email{julliard@@winehq.com}.
|
|
|
|
@item
|
|
Wait for the patch to appear in the official distribution.
|
|
@end enumerate
|
|
|
|
|
|
@node API function and type naming, Creating patches, Implementing an API function, The Wine Project
|
|
@section API function and data type naming conventions
|
|
@cindex API function names
|
|
@cindex API type names
|
|
@cindex names of API functions and types
|
|
@cindex naming scheme for API functions and types
|
|
@cindex suffixes for API functions and types
|
|
@cindex endings of API function and type names
|
|
|
|
This section describes Wine's naming scheme for API functions and data
|
|
types.
|
|
|
|
The purpose of these naming conventions is to ensure that
|
|
@itemize @bullet
|
|
@item
|
|
both the @WIN16{} and @WIN32{} API are supported within the same source
|
|
code,
|
|
@item
|
|
both wide character functions (with @unicode{} strings) and 8 bit
|
|
character functions (with @ascii{} or extended @ascii{} encoding) are
|
|
supported, and
|
|
@item
|
|
the source code can be shared between the emulator and the library
|
|
version of Wine.
|
|
@end itemize
|
|
|
|
A function or data type whose name in the @mswindows{} API is @var{xxx}
|
|
will in the Wine code have the following name(s):
|
|
@table @code
|
|
@item @var{xxx}16
|
|
This is the version for the 16 bit API. You might call it the ``16 bit
|
|
version'' except that the function itself of course runs in true 32 bit
|
|
mode (being part of Wine). So, the correct meaning of the suffix is that
|
|
this function is part of the 16 bit API.
|
|
@item @var{xxx}32
|
|
This is the version for the 32 bit API. Use this suffix only if the
|
|
function does not use character strings in its parameters or return
|
|
values. Otherwise use the next two.
|
|
@item @var{xxx}32A
|
|
This is the version for the 32 bit API which uses @ascii{} strings (or
|
|
rather, strings with 8 bit character encodings, i.e. the standard C
|
|
@code{char} type). This version always goes together with another
|
|
version, using the next suffix.
|
|
@item @var{xxx}32W
|
|
This is the version for the 32 bit API which uses @unicode{} strings,
|
|
i.e. strings with wide characters. It goes together with the @ascii{}
|
|
version.
|
|
@end table
|
|
|
|
So, where the @mswindows{} API offers one name, Wine actually has two or
|
|
three different functions implemented (which will hopefully share a
|
|
large part of the code).
|
|
|
|
Wine allows to use its API functions in two ways. The emulator part of
|
|
Wine provides DLL's for the @mswindows{} programs it can run. The
|
|
library part of Wine provides a @unix{} programmer with the facility to
|
|
use the Wine API's in a standard @unix{} program.
|
|
|
|
@menu
|
|
* Access from the emulator:: How to access API functions and types
|
|
from applications that are run in the
|
|
Wine emulator.
|
|
* Access in the library:: How to access API functions and types
|
|
from applications that are linked with
|
|
the Wine library.
|
|
* Access from inside Wine:: How to access API functions and types
|
|
from inside the Wine code.
|
|
@end menu
|
|
|
|
@node Access from the emulator, Access in the library, , API function and type naming
|
|
@subsection Accessing API functions and types from the emulator
|
|
@cindex access to DLL API functions and types
|
|
@cindex Wine emulator access to API functions and types
|
|
@cindex emulator access to Wine API functions and types
|
|
|
|
The emulator part of Wine provides the hooks for dynamically linking the
|
|
API functions to the @mswindows{} executables (@file{.EXE}-files). The
|
|
Wine emulator contains all versions (16 or 32 bit, @ascii{} or
|
|
@unicode{}) of the API functions in one executable. The emulator
|
|
performs a mapping from the @mswindows{} name of the function,
|
|
by which the executable calls it, to one of the Wine internal names that
|
|
have been used in coding it.
|
|
|
|
This mapping is done by the built-in DLL handling code of Wine. A
|
|
programmer of Wine has to declare the function in one of the virtual
|
|
DLL's that are provided by Wine. The declarations are done in the
|
|
@file{.spec}-files in the @file{if1632/} directory. @xref{The build
|
|
program}, for details.
|
|
|
|
The @mswindows{} application simply calls the API function by its
|
|
standard @mswindows{} name. Wine will apply the correct mapping
|
|
according to Wine's selected appearance (as a 16 bit or 32 bit emulator,
|
|
which is a parameter on invocation of Wine).
|
|
|
|
|
|
@node Access in the library, Access from inside Wine, Access from the emulator, API function and type naming
|
|
@subsection Accessing API functions and types in the library
|
|
@cindex Wine library API function and type access
|
|
@cindex access to Wine library API functions and types
|
|
|
|
If Wine is built as a library, and linked to a user-level main program,
|
|
the user will also use the standard @mswindows{} names for the API
|
|
functions.
|
|
|
|
Some macros are defined in @file{include/wintypes.h} which perform the
|
|
necessary name mappings.
|
|
|
|
These macros are (see the examples below):
|
|
@deffn_winemacro WINELIB_NAME (@var{xxx})
|
|
This macro replaces @var{xxx} by one of @var{xxx}16 or
|
|
@var{xxx}32, depending on the definition of the symbols
|
|
@code{WINELIB16} and @code{WINELIB32}. @var{xxx} should
|
|
be the name of an API function that uses no string arguments.
|
|
Use this macro with a @code{#define} to establish the API name @var{xxx}.
|
|
@end deffn
|
|
@deffn_winemacro WINELIB_NAME_AW (@var{xxx})
|
|
This macro replaces @var{xxx} by one of @var{xxx}16, @var{xxx}32A, or
|
|
@var{xxx}32W, depending on the definition of the symbols
|
|
@code{WINELIB16}, @code{WINELIB32}, and @code{UNICODE}. @var{xxx} should
|
|
be the name of an API function that uses string arguments.
|
|
Use this macro with a @code{#define} to establish the API name @var{xxx}.
|
|
@end deffn
|
|
@deffn_winemacro DECL_WINELIB_TYPE (@var{xxx})
|
|
This macro declares @var{xxx} to be an equivalent to @var{xxx}16 or
|
|
@var{xxx}32, depending on the definition of the symbols
|
|
@code{WINELIB16} and @code{WINELIB32}. @var{xxx} should
|
|
be the name of an API data type that contains no string arguments.
|
|
@end deffn
|
|
@deffn_winemacro DECL_WINELIB_TYPE_AW (@var{xxx})
|
|
This macro declares the type @var{xxx} to be an equivalent to
|
|
@var{xxx}16, @var{xxx}32A, or @var{xxx}32W, depending on the definition
|
|
of the symbols @code{WINELIB16}, @code{WINELIB32}, and
|
|
@code{UNICODE}. @var{xxx} should be the name of an API data type that
|
|
contains string arguments.
|
|
@end deffn
|
|
|
|
If Wine is compiled as an emulator, these macros have no effect, for the
|
|
mapping is then done by the DLL code. This means that within Wine the
|
|
name @var{xxx} itself will not be defined.
|
|
|
|
Note: If the definition of @var{xxx} is exactly the same in @WIN16{} and
|
|
@WIN32{}, you can simply use the same name as @mswindows{}.
|
|
|
|
Here are some examples:
|
|
@example
|
|
/* A simple type without strings */
|
|
typedef short INT16;
|
|
typedef int INT32;
|
|
DECL_WINELIB_TYPE(INT);
|
|
|
|
/* A type with strings */
|
|
typedef struct @{ /* Win32 ASCII data structure */ @} WNDCLASS32A;
|
|
typedef struct @{ /* Win32 Unicode data structure */ @} WNDCLASS32W;
|
|
typedef struct @{ /* Win16 data structure */ @} WNDCLASS16;
|
|
DECL_WINELIB_TYPE_AW(WNDCLASS);
|
|
|
|
/* A function with strings */
|
|
ATOM RegisterClass16( WNDCLASS16 * );
|
|
ATOM RegisterClass32A( WNDCLASS32A * );
|
|
ATOM RegisterClass32W( WNDCLASS32W * );
|
|
#define RegisterClass WINELIB_NAME_AW(RegisterClass)
|
|
@end example
|
|
|
|
The Winelib user can then say (in the application program):
|
|
@example
|
|
INT i;
|
|
WNDCLASS wc = @{ @dots{} @};
|
|
RegisterClass( &wc );
|
|
@end example
|
|
and this will use the correct declaration depending on the definitions
|
|
@code{WINELIB16}, @code{WINELIB32}, and @code{UNICODE}.
|
|
|
|
Here are the primary defines that are used when Wine is compiled as a
|
|
library:
|
|
@defvr_cwine WINELIB16
|
|
If this @code{#define} is set, the Wine library is to be compiled in its
|
|
16 bit form. That means, the 16 bit variants of all functions will be
|
|
used and the appearance of the application linked with the Wine library
|
|
will be that of a 16 bit application. Of course, both the application
|
|
and the Wine library function really run in 32 bit mode. The switch only
|
|
selects the function with the name ending in @code{@dots{}16}, which
|
|
will perhaps have a behaviour different from its 32 bit counterpart.
|
|
@end defvr
|
|
@defvr_cwine WINELIB32
|
|
If this @code{#define} is set, the Wine library is to be compiled in its
|
|
32 bit form. That means, the 32 bit variants of all functions will be
|
|
used and the appearance of the application linked with the Wine library
|
|
will be that of a 32 bit application.
|
|
@end defvr
|
|
@defvr_cwine UNICODE
|
|
This @code{define} is used to select one of two possible 32 bit
|
|
variants. Functions and data types of the 32 bit API come in two
|
|
flavours: one handling @ascii{} strings (or rather strings with
|
|
characters encoded in 8 bit), the other @unicode{} strings. This define
|
|
selects the correct variant. As a user of the Wine library, you are
|
|
responsible to use the correct character type in your part of the
|
|
application which accesses the Wine API functions and data types.
|
|
@end defvr
|
|
|
|
These switches are automatically set when Wine is compiled as a library.
|
|
|
|
|
|
@node Access from inside Wine, , Access in the library, API function and type naming
|
|
@subsection Accessing API functions from within Wine
|
|
@cindex explicit names of API functions and types
|
|
|
|
Within Wine and during the compilation of Wine, you cannot rely on the
|
|
@mswindows{} names of the API functions and data types. If Wine is
|
|
compiled as a library, they will be defined; if Wine is compiled as an
|
|
emulator, they won't.
|
|
|
|
You therefore have to access all functions and data types by their full
|
|
names, with the proper suffix explicitly appended. In Wine, the 16 bit
|
|
and 32 bit versions of the functions are distinct entities, which might
|
|
(theoretically) show a completely different behaviour. They may even
|
|
call each other (and they will quite frequently).
|
|
|
|
Therefore Wine is a conglomerate that contains all two or
|
|
three flavours of each function at once, and exports to the
|
|
application whichever of these is appropriate. Remember that inside
|
|
Wine, there is no memory segmentation, so all functions are 32 bit.
|
|
The 16-to-32 bit mapping is done on exporting the DLL functions.
|
|
|
|
|
|
@node Creating patches, Adding Documentation, API function and type naming, The Wine Project
|
|
@section Creating patches
|
|
@xref{Applying patches}, for instructions on applying patches.
|
|
|
|
Patches are created with the program @code{diff}. You need a copy
|
|
of clean source tree to diff against. The @samp{-u} option, to create
|
|
unified diffs, is popular but not obligatory.
|
|
For changes to a single file,
|
|
@code{diff -u wine990101/windows/win.c mywine/windows/win.c > win_patch}
|
|
is sufficient.
|
|
To generate a complete diff between your tree and the distribution,
|
|
use @code{diff -uR wine990101 mywine}.
|
|
|
|
This assumes that the original distribution and your personal tree
|
|
have the same parent directory, from which you make the diff.
|
|
This ensures a consistent format for the diffs, which in turn
|
|
is necessary so that they can be applied consistently as described in
|
|
@xref{Applying patches}.
|
|
|
|
@node Adding Documentation, File names, Creating patches, The Wine Project
|
|
@section Adding Documentation
|
|
|
|
@ifinfo
|
|
Here are some templates which should help you collaborate on this
|
|
documentation. Read the text below before examining them.
|
|
@end ifinfo
|
|
|
|
@menu
|
|
* Type Template:: How to document data types in Wine's
|
|
include files.
|
|
* Function Template:: How to document an (API) function of
|
|
Wine.
|
|
@end menu
|
|
|
|
|
|
These are my tips for adding documentation.
|
|
|
|
Do not simply copy documentation from @mswindows{} related
|
|
material. Except from risking copyright violations, which you would not
|
|
want to do, there is another aspect to that:
|
|
As Wine is a product to run on @unix{} and @unix{}-like workstations,
|
|
it seems a good idea to me to organize this documentation primarily for
|
|
the well-trained @unix{} reader. Please keep that in mind when you add
|
|
some documentation.
|
|
|
|
Finally, read the info pages for @code{texinfo}.
|
|
|
|
The rest of this section provides some templates which can serve as a
|
|
start in writing documentation.
|
|
|
|
@subsection Template introduction
|
|
@iftex
|
|
On the following pages you will find some @code{texinfo} templates, which
|
|
should help you collaborate on this documentation.
|
|
@end iftex
|
|
|
|
These templates give hints on how to document data types, functions,
|
|
variables, constants etc. in Wine.
|
|
As documentation evolves, you will find common features of data types
|
|
that should be described in a unified fashion. In such a case, please
|
|
add a corresponding style guide-line here, in this very place, to help
|
|
keeping documentation of data types unified.
|
|
|
|
|
|
Start out the type or function with a new node. Write a comment before
|
|
the node, listing all data types (and functions) described in the node,
|
|
like this:
|
|
@example
|
|
@@c
|
|
@@c *** struct FILETIME ***
|
|
@@c
|
|
@@node Type FILETIME, NextNodeName, PreviousNodeName, ParentNodeName
|
|
@end example
|
|
|
|
The node command describes the node name and the names of the next node,
|
|
the previous node, and the parent node. The parent node should contain
|
|
a menu entry for this node. The previous node is the node that appears
|
|
before this node in the parent node menu. The next node is the node
|
|
succeeding this one in the parent node menu. If there is no previous or
|
|
next node, omit the name (putting just a single space between the two
|
|
commata).
|
|
|
|
The node name must be a unique sequence of words. Case is important, so
|
|
@emph{Type} and @emph{type} are distinct. The node name must not contain
|
|
special characters like @samp{@@, @{, @}} or the comma. If you need to
|
|
give a node the same name as a function, data type, etc., use the words
|
|
@samp{Type}, @samp{Function}, etc. before the identifier.
|
|
|
|
Always put the names of the node and its links on the same line, even if
|
|
it gets rather long.
|
|
|
|
If there are two or more data types or functions described in the node,
|
|
adapt the comment like this:
|
|
@example
|
|
@@c
|
|
@@c *** int X ***
|
|
@@c *** long Y() ***
|
|
@@c
|
|
@@node Ints and Longs, NextNodeName, PreviousNodeName, ParentNodeName
|
|
@end example
|
|
|
|
After the node name, put a sectioning command, such as @samp{@@chapter},
|
|
@samp{@@section}, @samp{@@subsection}, or @samp{@@subsubsection}.
|
|
Without that command, cross references to the node will fail.
|
|
@example
|
|
@@subsubsection Type FILETIME
|
|
@end example
|
|
|
|
Start the description of the type(s) or function(s) with a single
|
|
non-indented paragraph that gives a one-line description of the type(s)
|
|
or function(s) and states the include files that are required.
|
|
@example
|
|
@@noindent
|
|
File times in Wine are specified by the data type @@code@{FILETIME@},
|
|
defined in @@file@{windows.h@}.
|
|
@end example
|
|
If several types or functions are closely connected, use one paragraph
|
|
as a common description. If more paragraphs are required for a proper
|
|
description, indent all but the first of them.
|
|
|
|
Then start the definition of the data type or function. Use the proper
|
|
macro, which you will find defined in the beginning of the texinfo file.
|
|
If appropriate, add your own macros.
|
|
Again, put everything that belongs to the header into a single line.
|
|
Use continuation lines for additional headers.
|
|
@example
|
|
@@deftp_w32 FILETIME
|
|
@@deftpx_w32 LPFILETIME
|
|
@end example
|
|
|
|
In the definition, give a verbal explanation of the data type or
|
|
function. The explanation should be rather complete, exact, and
|
|
comprehensible, than well-structured. This is the point where you can
|
|
tell everything you want. Do not be afraid of wasting space.
|
|
Do not describe the @mswindows{} situation but only say what Wine
|
|
does. That is important. (Sometimes they might even do the same.)
|
|
@example
|
|
This is the data type for specifying file times. The file times are
|
|
stored with 64 bit precision. The actual data type is a structure with
|
|
two 32 bit values which are interpreted as the low and high parts of a
|
|
64-bit value. This value gives a time measured in a granularity of 100
|
|
nanoseconds, so 1.5 seconds are specified by a value of 15,000,000. In
|
|
Wine, this 64-bit value is signed, with the sign taken from the high
|
|
part. The lower part is used as unsigned.
|
|
@end example
|
|
|
|
For data types, it is recommended to quote the definition from the
|
|
header file. For a function, you might give a short example of its
|
|
usage. You may also put one example in the end of a node that explains
|
|
several of the functions in the node. Remember that cut-and-paste from a
|
|
well prepared example will help the readers write their code.
|
|
@example
|
|
The definition of @@code@{FILETIME@} reads:
|
|
@@example
|
|
typedef struct
|
|
@@@{
|
|
INT32 dwLowDateTime;
|
|
INT32 dwHighDateTime;
|
|
@@@} FILETIME, *LPFILETIME;
|
|
@@end example
|
|
@end example
|
|
|
|
You could also use the @code{cindex} command which creates an entry in
|
|
the concept index. The @code{texinfo} manual recommends to keep concept
|
|
entries distinct, so that a single concept index entry puts to one
|
|
well-defined place in the document. Use lower case letters for index
|
|
entries, unless they are proper names or quotes from actual code.
|
|
@example
|
|
@@cindex epoch in file time
|
|
The @@code@{FILETIME@} structure may be used to hold absolute or relative
|
|
times. Absolute times are given as the number of 100 nanoseconds
|
|
intervals elapsed since 1 January 1601, 00:00:00 UTC (Coordinated
|
|
Universal Time, which is GMT, Greenwich Mean Time). This might be
|
|
called the @@dfn@{epoch@} for file times. With a signed 64-bit value, this
|
|
representation covers absolute times of 29247 years around the epoch.
|
|
@end example
|
|
|
|
After the verbal documentation, you can add some special fields
|
|
describing bugs, implementation dependencies etc. Two of these are
|
|
recommended to attach to all descriptions. One describes the
|
|
conformance of the data type or function to @mswindows{} products,
|
|
i.e. whether the item is also present in @WINNT{} and @WIN95{}. The
|
|
other one describes known differences of the Wine item to its
|
|
@mswindows{} counterpart. Both will greatly help in porting software
|
|
from @mswindows{} to Wine and vice versa.
|
|
@example
|
|
@@winconfall@{@}
|
|
|
|
@@windiff@{@}
|
|
In @@mswindows@{@}, the elements of the structure are apparently of type
|
|
@@code@{DWORD@}. Whether the full 64 bit value is interpreted as signed or
|
|
unsigned I do not know.
|
|
@end example
|
|
|
|
If you find that more of these property attributes are necessary, feel
|
|
free to create your own ones. But keep in mind that they should be
|
|
applicable more or less to all described items. Very special properties
|
|
will better be put into the verbal text.
|
|
|
|
Finally end the definition of the data type or function:
|
|
@example
|
|
@@end deftp
|
|
@end example
|
|
|
|
Do not forget to enter the node in the menu of its top node, and do
|
|
properly link the node to its successor and predecessor.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@node Type Template, Function Template, , Adding Documentation
|
|
@subsection Data type template
|
|
|
|
Category: Data type
|
|
|
|
@node Function Template, , Type Template, Adding Documentation
|
|
@subsection API function template
|
|
|
|
Functions should be given category names, to indicate which API they
|
|
belong to. Please add items to the list of categories possible.
|
|
|
|
Category: WIN32 function
|
|
|
|
@example
|
|
@@c
|
|
@@c ***GetFileTime() ***
|
|
@@c
|
|
@@node Get File Times, , Compare File Times, File Times
|
|
@@noindent
|
|
The Wine function @@code@{GetFileTime@} returns the creation time and
|
|
the times of last the read and modification access to a file. It is
|
|
defined in @@file@{windows.h@}.
|
|
|
|
@@deftypefn_w32 BOOL GetFileTime (@@w@{HANDLE @@var@{file@},@} @@w@{LPFILETIME @@var@{ctime@},@} @@w@{LPFILETIME @@var@{atime@},@} @@w@{LPFILETIME @@var@{mtime@})@}
|
|
This function obtains for the specified @@var@{file@} the creation time
|
|
@@var@{ctime@}, the time of the last access to the file @@var@{atime@}, and
|
|
the time of the last modification (write) to the file, @@var@{mtime@}.
|
|
The @@var@{file@} handle must have been obtained by opening the file with
|
|
@@code@{GENERIC_READ@} access. The file time arguments of this function are
|
|
pointers to @@code@{FILETIME@} variables, which are filled with a value that
|
|
indicates an absolute time in UTC. To convert these values to local
|
|
times, use the function @@code@{FileTimeToLocalFileTime@}. If you do not
|
|
need some of the times, you can pass a @@code@{NULL@} pointer.
|
|
The function returns @@code@{TRUE@} on success, @@code@{FALSE@} on failure.
|
|
|
|
@@winconfall@{@}
|
|
|
|
@@windiffnone@{@}
|
|
@@end deftypefn
|
|
@end example
|
|
|
|
|
|
@node File names, Wide character strings, Adding Documentation, The Wine Project
|
|
@section @mswindows{} and @unix{} file names in Wine
|
|
@cindex file names in Wine
|
|
@cindex Windows file names
|
|
@cindex DOS file names in Wine
|
|
@cindex UNIX file names in Wine
|
|
@cindex POSIX file names in Wine
|
|
|
|
FIXME:
|
|
|
|
@node Wide character strings, , File names, The Wine Project
|
|
@section Wide character strings in API functions
|
|
@cindex unicode strings in API functions
|
|
@cindex wide character strings in API functions
|
|
@cindex strings in API functions
|
|
@cindex ascii strings in API functions
|
|
@cindex 16 bit characters in API functions
|
|
@cindex wchar_t in API functions
|
|
|
|
Presently, all wide character strings in API functions of Wine are
|
|
internally converted to 8 bit representation. Thus, the @WIN32{} API
|
|
with @unicode{} strings is not fully functional for the application
|
|
programmer at present.
|
|
|
|
Even so, application programmers might consider developing their
|
|
applications in wide character format with Wine, as future versions
|
|
might bring a change. This might come when a @unix{} filesystem can
|
|
handle @unicode{} file names.
|
|
|
|
Furthermore, the @unicode{} API is required to let Wine run @mswindows{}
|
|
applications which have been compiled for wide character strings.
|
|
|
|
In Wine, wide characters are strictly 16 bit; the @code{wchar_t} type of
|
|
standard C can therefore not be used.
|
|
|
|
@node Concept Index, , , Top
|
|
@comment node-name, next, previous, up
|
|
@unnumbered Concept Index
|
|
@printindex cp
|
|
|
|
@node Type Index, , , Top
|
|
@comment node-name, next, previous, up
|
|
@unnumbered Type Index
|
|
@printindex tp
|
|
|
|
@node Function Index, , , Top
|
|
@comment node-name, next, previous, up
|
|
@unnumbered Function Index
|
|
@printindex fn
|
|
|
|
@node Variable Index, , , Top
|
|
@comment node-name, next, previous, up
|
|
@unnumbered Variable, Constants, and Variable-like Macros Index
|
|
@printindex vr
|
|
|
|
@node File Index, , , Top
|
|
@comment node-name, next, previous, up
|
|
@unnumbered File and Program Index
|
|
@printindex pg
|
|
|
|
|
|
@contents
|
|
@bye
|