Update the doc to include all user32.dll's source code files which are shared one...
[reactos.git] / reactos / media / doc / README.WINE
1 # ReactOS WINE porting guide for 0.3
2 # Update this file when you port a dll/program from WINE.
3
4 The ReactOS Project shares quite a bit of code with the WINE project.
5 This document should provide a compleate reference for all of the
6 locations in the ReactOS source tree where code is shared between the
7 two projects. If you find something is missing from this documentation
8 please add it.
9
10 If you find that a function in ReactOS that is not implemented properly
11 and is based on WINE sources, check the latest Winehq CVS and see if
12 it has been fixed there. If so, please submit a patch to
13 ros-dev@reactos.com. Otherwise please send a patch to both
14 wine-patches@winehq.com and ros-dev@reactos.com
15
16 When porting a dll from WINE to ReactOS please take a look at how
17 comctl32 has been imported. We start by creating a makefile that has
18 a target defined like so:
19
20 TARGET_TYPE = winedll
21
22 This will cause the reactos build system to look for a file called
23 makefile.ros-template. This file contains all of the information needed
24 for the ReactOS build system to make use of the WINE Makefile.in.
25 This will allow you to use the WINE tools and librarys with very little
26 work to import a new dll.
27
28 The following build tools are shared with Wine.
29
30 reactos/tools/unicode # Synced to Wine-0_9_5
31 reactos/tools/wpp # Synced to Wine-0_9_5
32 reactos/tools/bin2res # Resource to binary converter
33 reactos/tools/winebuild # Synced to Wine-0_9_5
34 reactos/tools/wmc # Synced to Wine-0_9_5
35 reactos/tools/wrc # Synced to Wine-0_9_5
36 reactos/tools/widl # Forked at Wine-20050930
37
38 The following libraries are shared with Wine.
39
40 reactos/dll/win32/avifil32 # Synced to Wine-0_9_5
41 reactos/dll/win32/cabinet # Synced to Wine-0_9_10
42 reactos/dll/win32/comctl32 # Synced to Wine-20060328
43 reactos/dll/win32/comdlg32 # Synced to Wine-0_9_5
44 reactos/dll/win32/crypt32 # Synced to Wine-0_9_10
45 reactos/dll/win32/dbghelp #
46 reactos/dll/win32/icmp # Synced to Wine-0_9_10
47 reactos/dll/win32/imm32 # Synced to Wine-0_9_10
48 reactos/dll/win32/iphlpapi # Out of sync
49 reactos/dll/win32/imagehlp # Patches for BindImage need review and submission to winehq.
50 reactos/dll/win32/mapi32 # Synced to Wine-0_9_10
51 reactos/dll/win32/msvcrt20 # Out of sync
52 reactos/dll/win32/mpr # Synced to Wine-0_9_5
53 reactos/dll/win32/msacm # Out of sync
54 reactos/dll/win32/msimg32 # Synced to Wine-0_9_12
55 reactos/dll/win32/msi # Synced to Wine-0_9_5
56 reactos/dll/win32/msvideo # Out of sync
57 reactos/dll/win32/netapi32 # Synced to Wine-0_9_5
58 reactos/dll/win32/objsel # Synced to Wine-0_9_12
59 reactos/dll/win32/odbc32 # Out of sync. Depends on port of Linux ODBC.
60 reactos/dll/win32/ole32 # Synced to Wine-0_9_5
61 reactos/dll/win32/oleacc # Synced to Wine-0_9_10
62 reactos/dll/win32/oleaut32 # Synced to Wine-0_9_10
63 reactos/dll/win32/oledlg # Synced to Wine-0_9_5
64 reactos/dll/win32/olepro32 # Synced to Wine-0_9_10
65 reactos/dll/win32/powrprof # Synced to Wine-0_9_14
66 reactos/dll/win32/riched20 # Synced to Wine-0_9_5
67 reactos/dll/win32/richedit # Synced to Wine-0_9_10
68 reactos/dll/win32/rpcrt4 # Synced to Wine-0_9_10
69 reactos/dll/win32/setupapi # Forked at Wine-20050524
70 reactos/dll/win32/shell32 # Synced to Wine-0_9_5
71 reactos/dll/win32/shdocvw # Synced to Wine-0_9_5
72 reactos/dll/win32/shfolder # Synced to Wine-0_9_5
73 reactos/dll/win32/shlwapi # Synced to Wine-0_9_5
74 reactos/dll/win32/twain # Out of sync
75 reactos/dll/win32/urlmon # Synced to Wine-0_9_10
76 reactos/dll/win32/uxtheme # Synced to Wine-0_9_10
77 reactos/dll/win32/version # Synced at 20060509
78 reactos/dll/win32/wininet # Synced to Wine-0_9_10
79 reactos/dll/win32/wintrust # Synced to Wine-0_9_10
80 reactos/dll/win32/winmm # Forked at Wine-20050628
81 reactos/dll/win32/winmm/midimap # Forked at Wine-20050628
82 reactos/dll/win32/winmm/wavemap # Forked at Wine-20050628
83 reactos/dll/directx/dinput # Synced to Wine-0_9_5
84 reactos/dll/directx/dinput8 # Synced to Wine-0_9_5
85 reactos/dll/directx/dplay # Synced to Wine-0_9_5
86 reactos/dll/directx/dplayx # Synced to Wine-0_9_5
87 reactos/dll/directx/dxdiagn # Synced to Wine-0_9_5
88
89 ReactOS shares the following programs with Winehq.
90
91 reactos/base/applications/games/winemine # Out of sync
92 reactos/base/applications/regedit # Out of sync
93 reactos/base/system/expand # Out of sync
94 reactos/base/system/msiexec # Synced to Wine-0_9_3
95
96 In addition the following libs, dlls and source files are mostly based on code ported
97 from Winehq CVS. If you are looking to update something in these files
98 check Wine current souces first as it may already be fixed.
99
100 reactos/lib/uuid #
101
102 advapi32 -
103 reactos/dll/win32/advapi32/crypt/*.c # ekohl says we're not sharing this
104
105 gdi32 -
106 reactos/dll/win32/gdi32/objects/linedda.c # Out of sync
107
108 kernel32 -
109 reactos/dll/win32/kernel32/misc/errormsg.c # Out of sync
110 reactos/dll/win32/kernel32/misc/profile.c # Out of sync
111 reactos/dll/win32/kernel32/misc/lcformat.c # Out of sync
112
113 msvcrt -
114 reactos/dll/win32/msvcrt/wine/*.c # Out of sync
115
116 User32 -
117 reactos/dll/win32/user32/controls/button.c # Synced at 20060621
118 reactos/dll/win32/user32/controls/combo.c # Last sync date unknown
119 reactos/dll/win32/user32/controls/edit.c # Out of sync
120 reactos/dll/win32/user32/controls/icontitle.c # Last sync date unknown
121 reactos/dll/win32/user32/controls/listbox.c # Out of sync
122 reactos/dll/win32/user32/controls/scrollbar.c # Forked (?)
123 reactos/dll/win32/user32/controls/static.c # Out of sync
124
125 reactos/dll/win32/user32/misc/dde.c # Last sync date unknown (dde_misc.c)
126 reactos/dll/win32/user32/misc/ddeclient.c # Last sync date unknown
127 reactos/dll/win32/user32/misc/ddeserver.c # Last sync date unknown
128 reactos/dll/win32/user32/misc/exticon.c # Last sync date unknown
129 reactos/dll/win32/user32/misc/resources.c # Forked?
130 reactos/dll/win32/user32/misc/winhelp.c # Last sync date unknown
131 reactos/dll/win32/user32/misc/wsprintf.c # Out of sync
132
133 reactos/dll/win32/user32/windows/draw.c # Forked at Wine-20020904 (uitools.c)
134 reactos/dll/win32/user32/windows/mdi.c # Out of sync
135 reactos/dll/win32/user32/windows/menu.c # Last sync date unknown
136 reactos/dll/win32/user32/windows/messagebox.c # Forked
137 reactos/dll/win32/user32/windows/rect.c # Forked (uitools.c)
138 reactos/dll/win32/user32/windows/text.c # Forked (lstr.c)
139 reactos/dll/win32/user32/windows/winpos.c # Forked
140
141 Update process for shared DLLs
142
143 - Cd to the parent directory of your top-level "reactos" directory
144 - Check out the Wine release: "cvs -d :pserver:cvs@cvs.winehq.com:2401/home/wine co wine -r Wine-20050211"
145 - Create "vendor" directory (as a sibling of your top-level "reactos" directory)
146 - Cd to the vendor dir and check out the current vendor drop:
147 "svn co svn://svn.reactos.org/reactos/vendor/wine".
148 - For each component shared with Wine (e.g. cabinet):
149 "del vendor\wine\dlls\cabinet\current\*"
150 "copy wine\dlls\cabinet vendor\wine\dlls\cabinet\current"
151 "del vendor\wine\dlls\cabinet\current\.cvsignore"
152 Check svn status, svn add/delete files as needed
153 Tag new Wine release "svn copy vendor\wine\dlls\cabinet\current vendor\wine\dlls\cabinet\Wine-20050211"
154 - Commit the vendor drop: svn commit vendor\wine -m "Wine-20050211 vendor drop"
155 - Determine the revision number of the last Wine tag by looking at http://svn.reactos.ru/svn/reactos/tags/
156 and finding the last Wine-yyyymmdd-sync tag, e.g. Wine-20050111-sync had rev 13007
157 - For each component shared with Wine (e.g. cabinet):
158 - "cd reactos\lib\cabinet"
159 - Check for changes in the ReactOS tree: "svn diff -r 13007" (13007 is the revno of the previous sync).
160 If any changes are found, see if they're present in the Wine code. If not, submit to WineHQ
161 if apropriate.
162 - Merge in Wine changes:
163 "svn merge svn://svn.reactos.org/vendor/wine/dlls/cabinet/Wine-20050111
164 svn://svn.reactos.org/vendor/wine/dlls/cabinet/current"
165 - Fix any merge conflicts
166 - Build and test (building will sometimes require adjusting header files)
167 - Check which files were changed: "svn status"
168 - For each of the changed files, get the WineHQ CVS log. Copy author and CVS commit message into a
169 commit log
170 - Commit changed files "svn commit" using generated commit log as commit message