reactos/reactos/doc
Filip Navara 612346a8b7 DPC stands for Deferred Procedure Call.
svn path=/trunk/; revision=16611
2005-07-17 12:24:15 +00:00
..
apc Lots of changes to the kernel 1999-05-29 00:15:17 +00:00
DIRS Moved system applications 2000-12-05 02:40:51 +00:00
HACKING Changed debug output to use INT 2D 2000-01-17 21:02:50 +00:00
INDEX Add new documentation 1999-01-17 17:17:09 +00:00
INTERNALS DPC stands for Deferred Procedure Call. 2005-07-17 12:24:15 +00:00
irp cancel boilerplate.c fix nasty bug:-( 2005-03-07 00:04:21 +00:00
news1 Added .o -> .sys rule to simplify driver makefiles 2000-08-18 22:27:09 +00:00
news2 Added .o -> .sys rule to simplify driver makefiles 2000-08-18 22:27:09 +00:00
notes Documentation update. 2001-07-24 20:49:57 +00:00
README.WINE - imported uxtheme.dll from WINE-20050703 2005-07-03 18:32:22 +00:00
todo Documentation update. 2001-07-24 20:49:57 +00:00

# ReactOS WINE porting guide for 0.3
# Update this file when you port a dll/program from WINE.

The ReactOS Project shares quite a bit of code with the WINE project.
This document should provide a compleate reference for all of the
locations in the ReactOS source tree where code is shared between the
two projects. If you find something is missing from this documentation
please add it.

If you find that a function in ReactOS that is not implemented properly
and is based on WINE sources, check the latest Winehq CVS and see if
it has been fixed there. If so, please submit a patch to 
ros-dev@reactos.com. Otherwise please send a patch to both 
wine-patches@winehq.com and ros-dev@reactos.com

When porting a dll from WINE to ReactOS please take a look at how
comctl32 has been imported. We start by creating a makefile that has
a target defined like so:

TARGET_TYPE = winedll

This will cause the reactos build system to look for a file called
makefile.ros-template. This file contains all of the information needed
for the ReactOS build system to make use of the WINE Makefile.in. 
This will allow you to use the WINE tools and librarys with very little
work to import a new dll.

The following build tools are shared with Wine.
reactos/tools/unicode		# Synced to Wine-20050419
reactos/tools/wpp		# Synced to Wine-20050419
reactos/tools/bin2res		# Resource to binary converter
reactos/tools/winebuild		# Synced to Wine-20050419
reactos/tools/wmc		# Wine Message Compiler
reactos/tools/wrc		# Synced to Wine-20050419
reactos/tools/widl		# Synced to Wine-20050419 (merge back to winehq in progress)

The following libraries are shared with Wine.

reactos/lib/cabinet             # Synced to Wine-20050419
reactos/lib/comctl32            # Synced to Wine-20050419
reactos/lib/comdlg32		# Synced to Wine-20050419
reactos/lib/dinput		# Synced to Wine-20050310
reactos/lib/dinput8		# Synced to Wine-20050419
reactos/lib/icmp		# Synced to Wine-20050419
reactos/lib/iphlpapi		# Out of sync
reactos/lib/imagehlp		# Patches for BindImage need review and submission to winehq.
reactos/lib/msvcrt20		# Out of sync
reactos/lib/mpr                 # Synced to Wine-20050419
reactos/lib/msacm		# Out of sync
reactos/lib/msimg32		# Synced to Wine-20050419
reactos/lib/msi			# Synced to Wine-20050419
reactos/lib/msvideo		# Out of sync
reactos/lib/netapi32		# Out of sync
reactos/lib/odbc32		# In sync. Depends on port of Linux ODBC.
reactos/lib/ole32               # Synced to Wine-20050419
reactos/lib/oleaut32		# Synced to Wine-20050419
reactos/lib/oledlg              # Synced to Wine-20050419
reactos/lib/olepro32		# Synced to Wine-20050419
reactos/lib/riched20		# Synced to Wine-20050419
reactos/lib/richedit		# Synced to Wine-20050419
reactos/lib/rpcrt4		# Synced to Wine-20050419
reactos/lib/setupapi		# Synced to Wine-20050419
reactos/lib/shell32             # Synced to Wine-20050419
reactos/lib/shdocvw             # Synced to Wine-20050419
reactos/lib/shlwapi             # Synced to Wine-20050419
reactos/lib/twain		# Out of sync
reactos/lib/urlmon		# Synced to Wine-20050419
reactos/lib/uxtheme		# Synced to Wine-20050703
reactos/lib/version		# Out of sync
reactos/lib/wininet		# Out of sync
reactos/lib/winmm		# Synced to Wine-20050419
reactos/lib/winmm/midimap       # Synced to Wine-20050419
reactos/lib/winmm/wavemap       # Synced to Wine-20050419

ReactOS shares the following programs with Winehq.
reactos/subsys/system/regedit	# Out of sync
reactos/subsys/system/expand	# Out of sync
reactos/subsys/system/msiexec	# Synced to Wine-20050419

In addition the following libs, dlls and source files are mostly based on code ported
from Winehq CVS. If you are looking to update something in these files
check Wine current souces first as it may already be fixed.

reactos/lib/imm32		# 
reactos/lib/uuid		#

advapi32 -
  reactos/lib/advapi32/crypt/*.c	# ekohl says we're not sharing this

gdi32 -
  reactos/lib/gdi32/objects/linedda.c	# Out of sync

kernel32 -
  reactos/lib/kernel32/misc/errormsg.c	# Out of sync
  reactos/lib/kernel32/misc/profile.c	# Out of sync
  reactos/lib/kernel32/misc/lcformat.c	# Out of sync

msvcrt -
  reactos/lib/msvcrt/wine/*.c		# Out of sync

User32 -
  reactos/lib/user32/controls/button.c	# Out of sync
  reactos/lib/user32/controls/edit.c	# Out of sync
  reactos/lib/user32/controls/static.c	# Out of sync
  reactos/lib/user32/misc/wsprintf.c	# Out of sync
  reactos/lib/user32/windows/mdi.c	# Out of sync

- Cd to the parent directory of your top-level "reactos" directory
- Check out the Wine release: "cvs -d :pserver:cvs@cvs.winehq.com:2401/home/wine co wine -r Wine-20050211"
- Create "vendor" directory (as a sibling of your top-level "reactos" directory)
- Cd to the vendor dir and check out the current vendor drop:
  "svn co svn://svn.reactos.com/vendor/wine".
- For each component shared with Wine (e.g. cabinet):
  "del vendor\wine\dlls\cabinet\current\*"
  "copy wine\dlls\cabinet vendor\wine\dlls\cabinet\current"
  "del vendor\wine\dlls\cabinet\current\.cvsignore"
  Check svn status, svn add/delete files as needed
  Tag new Wine release "svn copy vendor\wine\dlls\cabinet\current vendor\wine\dlls\cabinet\Wine-20050211"
- Commit the vendor drop: svn commit vendor\wine -m "Wine-20050211 vendor drop"
- Determine the revision number of the last Wine tag by looking at http://svn.reactos.com/viewcvs/tags/
  and finding the last Wine-yyyymmdd-sync tag, e.g. Wine-20050111-sync had rev 13007
- For each component shared with Wine (e.g. cabinet):
- "cd reactos\lib\cabinet"
- Check for changes in the ReactOS tree: "svn diff -r 13007" (13007 is the revno of the previous sync).
  If any changes are found, see if they're present in the Wine code. If not, submit to WineHQ
  if apropriate.
- Merge in Wine changes:
  "svn merge svn://svn.reactos.com/vendor/wine/dlls/cabinet/Wine-20050111
   svn://svn.reactos.com/vendor/wine/dlls/cabinet/current"
- Fix any merge conflicts
- Build and test (building will sometimes require adjusting header files)
- Check which files were changed: "svn status"
- For each of the changed files, get the WineHQ CVS log. Copy author and CVS commit message into a
  commit log
- Commit changed files "svn commit" using generated commit log as commit message