usp10: Fix MarkToBase offset for RTL text.
[wine] / dlls / gdi32 / gdi_private.h
1 /*
2  * GDI definitions
3  *
4  * Copyright 1993 Alexandre Julliard
5  *
6  * This library is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or (at your option) any later version.
10  *
11  * This library is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with this library; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
19  */
20
21 #ifndef __WINE_GDI_PRIVATE_H
22 #define __WINE_GDI_PRIVATE_H
23
24 #include <limits.h>
25 #include <math.h>
26 #include <stdlib.h>
27 #include <stdarg.h>
28 #include "windef.h"
29 #include "winbase.h"
30 #include "wingdi.h"
31 #include "wine/gdi_driver.h"
32
33 /* Metafile defines */
34 #define META_EOF 0x0000
35 /* values of mtType in METAHEADER.  Note however that the disk image of a disk
36    based metafile has mtType == 1 */
37 #define METAFILE_MEMORY 1
38 #define METAFILE_DISK   2
39 #define MFHEADERSIZE (sizeof(METAHEADER))
40 #define MFVERSION 0x300
41
42 typedef struct {
43     EMR   emr;
44     INT   nBreakExtra;
45     INT   nBreakCount;
46 } EMRSETTEXTJUSTIFICATION, *PEMRSETTEXTJUSTIFICATION;
47
48 /* extra stock object: default 1x1 bitmap for memory DCs */
49 #define DEFAULT_BITMAP (STOCK_LAST+1)
50
51 struct gdi_obj_funcs
52 {
53     HGDIOBJ (*pSelectObject)( HGDIOBJ handle, HDC hdc );
54     INT     (*pGetObjectA)( HGDIOBJ handle, INT count, LPVOID buffer );
55     INT     (*pGetObjectW)( HGDIOBJ handle, INT count, LPVOID buffer );
56     BOOL    (*pUnrealizeObject)( HGDIOBJ handle );
57     BOOL    (*pDeleteObject)( HGDIOBJ handle );
58 };
59
60 typedef struct tagDC
61 {
62     HDC          hSelf;            /* Handle to this DC */
63     struct gdi_physdev nulldrv;    /* physdev for the null driver */
64     PHYSDEV      physDev;          /* current top of the physdev stack */
65     DWORD        thread;           /* thread owning the DC */
66     LONG         refcount;         /* thread refcount */
67     LONG         dirty;            /* dirty flag */
68     INT          saveLevel;
69     struct tagDC *saved_dc;
70     DWORD_PTR    dwHookData;
71     DCHOOKPROC   hookProc;         /* DC hook */
72     HMODULE      module;           /* module handle of the graphics driver */
73     BOOL         bounds_enabled:1; /* bounds tracking is enabled */
74     BOOL         path_open:1;      /* path is currently open (only for saved DCs) */
75
76     INT          wndOrgX;          /* Window origin */
77     INT          wndOrgY;
78     INT          wndExtX;          /* Window extent */
79     INT          wndExtY;
80     INT          vportOrgX;        /* Viewport origin */
81     INT          vportOrgY;
82     INT          vportExtX;        /* Viewport extent */
83     INT          vportExtY;
84     SIZE         virtual_res;      /* Initially HORZRES,VERTRES. Changed by SetVirtualResolution */
85     SIZE         virtual_size;     /* Initially HORZSIZE,VERTSIZE. Changed by SetVirtualResolution */
86     RECT         vis_rect;         /* visible rectangle in screen coords */
87     RECT         device_rect;      /* rectangle for the whole device */
88     int          pixel_format;     /* pixel format (for memory DCs) */
89     UINT         aa_flags;         /* anti-aliasing flags to pass to GetGlyphOutline for current font */
90     FLOAT        miterLimit;
91
92     int           flags;
93     DWORD         layout;
94     HRGN          hClipRgn;      /* Clip region */
95     HRGN          hMetaRgn;      /* Meta region */
96     HRGN          hVisRgn;       /* Visible region */
97     HRGN          region;        /* Total DC region (intersection of clip and visible) */
98     HPEN          hPen;
99     HBRUSH        hBrush;
100     HFONT         hFont;
101     HBITMAP       hBitmap;
102     HPALETTE      hPalette;
103
104     struct gdi_path *path;
105
106     UINT          font_code_page;
107     WORD          ROPmode;
108     WORD          polyFillMode;
109     WORD          stretchBltMode;
110     WORD          relAbsMode;
111     WORD          backgroundMode;
112     COLORREF      backgroundColor;
113     COLORREF      textColor;
114     COLORREF      dcBrushColor;
115     COLORREF      dcPenColor;
116     short         brushOrgX;
117     short         brushOrgY;
118
119     DWORD         mapperFlags;       /* Font mapper flags */
120     WORD          textAlign;         /* Text alignment from SetTextAlign() */
121     INT           charExtra;         /* Spacing from SetTextCharacterExtra() */
122     INT           breakExtra;        /* breakTotalExtra / breakCount */
123     INT           breakRem;          /* breakTotalExtra % breakCount */
124     INT           MapMode;
125     INT           GraphicsMode;      /* Graphics mode */
126     ABORTPROC     pAbortProc;        /* AbortProc for Printing */
127     INT           CursPosX;          /* Current position */
128     INT           CursPosY;
129     INT           ArcDirection;
130     XFORM         xformWorld2Wnd;    /* World-to-window transformation */
131     XFORM         xformWorld2Vport;  /* World-to-viewport transformation */
132     XFORM         xformVport2World;  /* Inverse of the above transformation */
133     BOOL          vport2WorldValid;  /* Is xformVport2World valid? */
134     RECT          bounds;            /* Current bounding rect */
135 } DC;
136
137 /* Certain functions will do no further processing if the driver returns this.
138    Used by mfdrv for example. */
139 #define GDI_NO_MORE_WORK 2
140
141 /* Rounds a floating point number to integer. The world-to-viewport
142  * transformation process is done in floating point internally. This function
143  * is then used to round these coordinates to integer values.
144  */
145 static inline INT GDI_ROUND(double val)
146 {
147    return (int)floor(val + 0.5);
148 }
149
150 #define GET_DC_PHYSDEV(dc,func) \
151     get_physdev_entry_point( (dc)->physDev, FIELD_OFFSET(struct gdi_dc_funcs,func))
152
153 static inline PHYSDEV pop_dc_driver( DC *dc, const struct gdi_dc_funcs *funcs )
154 {
155     PHYSDEV dev, *pdev = &dc->physDev;
156     while (*pdev && (*pdev)->funcs != funcs) pdev = &(*pdev)->next;
157     if (!*pdev) return NULL;
158     dev = *pdev;
159     *pdev = dev->next;
160     return dev;
161 }
162
163 static inline PHYSDEV find_dc_driver( DC *dc, const struct gdi_dc_funcs *funcs )
164 {
165     PHYSDEV dev;
166
167     for (dev = dc->physDev; dev; dev = dev->next) if (dev->funcs == funcs) return dev;
168     return NULL;
169 }
170
171 /* bitmap object */
172
173 typedef struct tagBITMAPOBJ
174 {
175     DIBSECTION          dib;
176     SIZE                size;   /* For SetBitmapDimension() */
177     RGBQUAD            *color_table;  /* DIB color table if <= 8bpp (always 1 << bpp in size) */
178 } BITMAPOBJ;
179
180 static inline BOOL is_bitmapobj_dib( const BITMAPOBJ *bmp )
181 {
182     return bmp->dib.dsBmih.biSize != 0;
183 }
184
185 /* bidi.c */
186
187 /* Wine_GCPW Flags */
188 /* Directionality -
189  * LOOSE means taking the directionality of the first strong character, if there is found one.
190  * FORCE means the paragraph direction is forced. (RLE/LRE)
191  */
192 #define WINE_GCPW_FORCE_LTR 0
193 #define WINE_GCPW_FORCE_RTL 1
194 #define WINE_GCPW_LOOSE_LTR 2
195 #define WINE_GCPW_LOOSE_RTL 3
196 #define WINE_GCPW_DIR_MASK 3
197 #define WINE_GCPW_LOOSE_MASK 2
198
199 extern BOOL BIDI_Reorder( HDC hDC, LPCWSTR lpString, INT uCount, DWORD dwFlags, DWORD dwWineGCP_Flags,
200                           LPWSTR lpOutString, INT uCountOut, UINT *lpOrder, WORD **lpGlyphs, INT* cGlyphs ) DECLSPEC_HIDDEN;
201
202 /* bitblt.c */
203 extern DWORD convert_bits( const BITMAPINFO *src_info, struct bitblt_coords *src,
204                            BITMAPINFO *dst_info, struct gdi_image_bits *bits ) DECLSPEC_HIDDEN;
205 extern BOOL intersect_vis_rectangles( struct bitblt_coords *dst, struct bitblt_coords *src ) DECLSPEC_HIDDEN;
206 extern DWORD stretch_bits( const BITMAPINFO *src_info, struct bitblt_coords *src,
207                            BITMAPINFO *dst_info, struct bitblt_coords *dst,
208                            struct gdi_image_bits *bits, int mode ) DECLSPEC_HIDDEN;
209
210 /* brush.c */
211 extern BOOL store_brush_pattern( LOGBRUSH *brush, struct brush_pattern *pattern ) DECLSPEC_HIDDEN;
212 extern void free_brush_pattern( struct brush_pattern *pattern ) DECLSPEC_HIDDEN;
213 extern BOOL get_brush_bitmap_info( HBRUSH handle, BITMAPINFO *info, void **bits, UINT *usage ) DECLSPEC_HIDDEN;
214
215 /* clipping.c */
216 extern BOOL clip_device_rect( DC *dc, RECT *dst, const RECT *src ) DECLSPEC_HIDDEN;
217 extern BOOL clip_visrect( DC *dc, RECT *dst, const RECT *src ) DECLSPEC_HIDDEN;
218 extern void update_dc_clipping( DC * dc ) DECLSPEC_HIDDEN;
219
220 /* Return the total DC region (if any) */
221 static inline HRGN get_dc_region( DC *dc )
222 {
223     if (dc->region) return dc->region;
224     if (dc->hVisRgn) return dc->hVisRgn;
225     if (dc->hClipRgn) return dc->hClipRgn;
226     return dc->hMetaRgn;
227 }
228
229 /* dc.c */
230 extern DC *alloc_dc_ptr( WORD magic ) DECLSPEC_HIDDEN;
231 extern void free_dc_ptr( DC *dc ) DECLSPEC_HIDDEN;
232 extern DC *get_dc_ptr( HDC hdc ) DECLSPEC_HIDDEN;
233 extern void release_dc_ptr( DC *dc ) DECLSPEC_HIDDEN;
234 extern void update_dc( DC *dc ) DECLSPEC_HIDDEN;
235 extern void DC_InitDC( DC * dc ) DECLSPEC_HIDDEN;
236 extern void DC_UpdateXforms( DC * dc ) DECLSPEC_HIDDEN;
237
238 /* dib.c */
239 extern int bitmap_info_size( const BITMAPINFO * info, WORD coloruse ) DECLSPEC_HIDDEN;
240 extern BOOL fill_color_table_from_pal_colors( BITMAPINFO *info, HDC hdc ) DECLSPEC_HIDDEN;
241 extern const RGBQUAD *get_default_color_table( int bpp ) DECLSPEC_HIDDEN;
242 extern void fill_default_color_table( BITMAPINFO *info ) DECLSPEC_HIDDEN;
243 extern void get_ddb_bitmapinfo( BITMAPOBJ *bmp, BITMAPINFO *info ) DECLSPEC_HIDDEN;
244 extern BITMAPINFO *copy_packed_dib( const BITMAPINFO *src_info, UINT usage ) DECLSPEC_HIDDEN;
245 extern DWORD convert_bitmapinfo( const BITMAPINFO *src_info, void *src_bits, struct bitblt_coords *src,
246                                  const BITMAPINFO *dst_info, void *dst_bits ) DECLSPEC_HIDDEN;
247
248 extern DWORD stretch_bitmapinfo( const BITMAPINFO *src_info, void *src_bits, struct bitblt_coords *src,
249                                  const BITMAPINFO *dst_info, void *dst_bits, struct bitblt_coords *dst,
250                                  INT mode ) DECLSPEC_HIDDEN;
251 extern DWORD blend_bitmapinfo( const BITMAPINFO *src_info, void *src_bits, struct bitblt_coords *src,
252                                const BITMAPINFO *dst_info, void *dst_bits, struct bitblt_coords *dst,
253                                BLENDFUNCTION blend ) DECLSPEC_HIDDEN;
254 extern DWORD gradient_bitmapinfo( const BITMAPINFO *info, void *bits, TRIVERTEX *vert_array, ULONG nvert,
255                                   void *grad_array, ULONG ngrad, ULONG mode, const POINT *dev_pts, HRGN rgn ) DECLSPEC_HIDDEN;
256 extern COLORREF get_pixel_bitmapinfo( const BITMAPINFO *info, void *bits, struct bitblt_coords *src ) DECLSPEC_HIDDEN;
257 extern BOOL render_aa_text_bitmapinfo( HDC hdc, BITMAPINFO *info, struct gdi_image_bits *bits,
258                                        struct bitblt_coords *src, INT x, INT y, UINT flags,
259                                        UINT aa_flags, LPCWSTR str, UINT count, const INT *dx ) DECLSPEC_HIDDEN;
260 extern DWORD get_image_from_bitmap( BITMAPOBJ *bmp, BITMAPINFO *info,
261                                     struct gdi_image_bits *bits, struct bitblt_coords *src ) DECLSPEC_HIDDEN;
262 extern DWORD put_image_into_bitmap( BITMAPOBJ *bmp, HRGN clip, BITMAPINFO *info,
263                                     const struct gdi_image_bits *bits, struct bitblt_coords *src,
264                                     struct bitblt_coords *dst ) DECLSPEC_HIDDEN;
265 extern void dibdrv_set_window_surface( DC *dc, struct window_surface *surface ) DECLSPEC_HIDDEN;
266
267 /* driver.c */
268 extern const struct gdi_dc_funcs null_driver DECLSPEC_HIDDEN;
269 extern const struct gdi_dc_funcs dib_driver DECLSPEC_HIDDEN;
270 extern const struct gdi_dc_funcs path_driver DECLSPEC_HIDDEN;
271 extern const struct gdi_dc_funcs *font_driver DECLSPEC_HIDDEN;
272 extern const struct gdi_dc_funcs *DRIVER_load_driver( LPCWSTR name, HMODULE *module ) DECLSPEC_HIDDEN;
273 extern BOOL DRIVER_GetDriverName( LPCWSTR device, LPWSTR driver, DWORD size ) DECLSPEC_HIDDEN;
274
275 /* enhmetafile.c */
276 extern HENHMETAFILE EMF_Create_HENHMETAFILE(ENHMETAHEADER *emh, BOOL on_disk ) DECLSPEC_HIDDEN;
277
278 /* freetype.c */
279
280 /* Undocumented structure filled in by GdiRealizationInfo */
281 typedef struct
282 {
283     DWORD flags;       /* 1 for bitmap fonts, 3 for scalable fonts */
284     DWORD cache_num;   /* keeps incrementing - num of fonts that have been created allowing for caching?? */
285     DWORD unknown2;    /* fixed for a given font - looks like it could be the order of the face in the font list or the order
286                           in which the face was first rendered. */
287 } realization_info_t;
288
289
290 extern INT WineEngAddFontResourceEx(LPCWSTR, DWORD, PVOID) DECLSPEC_HIDDEN;
291 extern HANDLE WineEngAddFontMemResourceEx(PVOID, DWORD, PVOID, LPDWORD) DECLSPEC_HIDDEN;
292 extern BOOL WineEngCreateScalableFontResource(DWORD, LPCWSTR, LPCWSTR, LPCWSTR) DECLSPEC_HIDDEN;
293 extern BOOL WineEngInit(void) DECLSPEC_HIDDEN;
294 extern BOOL WineEngRemoveFontResourceEx(LPCWSTR, DWORD, PVOID) DECLSPEC_HIDDEN;
295
296 /* gdiobj.c */
297 extern HGDIOBJ alloc_gdi_handle( void *obj, WORD type, const struct gdi_obj_funcs *funcs ) DECLSPEC_HIDDEN;
298 extern void *free_gdi_handle( HGDIOBJ handle ) DECLSPEC_HIDDEN;
299 extern HGDIOBJ get_full_gdi_handle( HGDIOBJ handle ) DECLSPEC_HIDDEN;
300 extern void *GDI_GetObjPtr( HGDIOBJ, WORD ) DECLSPEC_HIDDEN;
301 extern void GDI_ReleaseObj( HGDIOBJ ) DECLSPEC_HIDDEN;
302 extern void GDI_CheckNotLock(void) DECLSPEC_HIDDEN;
303 extern UINT GDI_get_ref_count( HGDIOBJ handle ) DECLSPEC_HIDDEN;
304 extern HGDIOBJ GDI_inc_ref_count( HGDIOBJ handle ) DECLSPEC_HIDDEN;
305 extern BOOL GDI_dec_ref_count( HGDIOBJ handle ) DECLSPEC_HIDDEN;
306 extern void GDI_hdc_using_object(HGDIOBJ obj, HDC hdc) DECLSPEC_HIDDEN;
307 extern void GDI_hdc_not_using_object(HGDIOBJ obj, HDC hdc) DECLSPEC_HIDDEN;
308
309 /* metafile.c */
310 extern HMETAFILE MF_Create_HMETAFILE(METAHEADER *mh) DECLSPEC_HIDDEN;
311 extern METAHEADER *MF_CreateMetaHeaderDisk(METAHEADER *mr, LPCVOID filename, BOOL unicode ) DECLSPEC_HIDDEN;
312
313 /* path.c */
314
315 extern void free_gdi_path( struct gdi_path *path ) DECLSPEC_HIDDEN;
316 extern BOOL PATH_SavePath( DC *dst, DC *src ) DECLSPEC_HIDDEN;
317 extern BOOL PATH_RestorePath( DC *dst, DC *src ) DECLSPEC_HIDDEN;
318
319 /* painting.c */
320 extern POINT *GDI_Bezier( const POINT *Points, INT count, INT *nPtsOut ) DECLSPEC_HIDDEN;
321
322 /* palette.c */
323 extern HPALETTE WINAPI GDISelectPalette( HDC hdc, HPALETTE hpal, WORD wBkg) DECLSPEC_HIDDEN;
324 extern UINT WINAPI GDIRealizePalette( HDC hdc ) DECLSPEC_HIDDEN;
325 extern HPALETTE PALETTE_Init(void) DECLSPEC_HIDDEN;
326
327 /* region.c */
328 extern BOOL add_rect_to_region( HRGN rgn, const RECT *rect ) DECLSPEC_HIDDEN;
329 extern INT mirror_region( HRGN dst, HRGN src, INT width ) DECLSPEC_HIDDEN;
330 extern BOOL REGION_FrameRgn( HRGN dest, HRGN src, INT x, INT y ) DECLSPEC_HIDDEN;
331
332 typedef struct
333 {
334     INT size;
335     INT numRects;
336     RECT *rects;
337     RECT extents;
338 } WINEREGION;
339
340 /* return the region data without making a copy */
341 static inline const WINEREGION *get_wine_region(HRGN rgn)
342 {
343     return GDI_GetObjPtr( rgn, OBJ_REGION );
344 }
345 static inline void release_wine_region(HRGN rgn)
346 {
347     GDI_ReleaseObj(rgn);
348 }
349
350 /* null driver entry points */
351 extern BOOL nulldrv_AbortPath( PHYSDEV dev ) DECLSPEC_HIDDEN;
352 extern BOOL nulldrv_AlphaBlend( PHYSDEV dst_dev, struct bitblt_coords *dst,
353                                 PHYSDEV src_dev, struct bitblt_coords *src, BLENDFUNCTION func) DECLSPEC_HIDDEN;
354 extern BOOL nulldrv_AngleArc( PHYSDEV dev, INT x, INT y, DWORD radius, FLOAT start, FLOAT sweep ) DECLSPEC_HIDDEN;
355 extern BOOL nulldrv_ArcTo( PHYSDEV dev, INT left, INT top, INT right, INT bottom, INT xstart, INT ystart, INT xend, INT yend ) DECLSPEC_HIDDEN;
356 extern BOOL nulldrv_BeginPath( PHYSDEV dev ) DECLSPEC_HIDDEN;
357 extern DWORD nulldrv_BlendImage( PHYSDEV dev, BITMAPINFO *info, const struct gdi_image_bits *bits,
358                                  struct bitblt_coords *src, struct bitblt_coords *dst, BLENDFUNCTION func ) DECLSPEC_HIDDEN;
359 extern BOOL nulldrv_CloseFigure( PHYSDEV dev ) DECLSPEC_HIDDEN;
360 extern BOOL nulldrv_EndPath( PHYSDEV dev ) DECLSPEC_HIDDEN;
361 extern INT  nulldrv_ExcludeClipRect( PHYSDEV dev, INT left, INT top, INT right, INT bottom ) DECLSPEC_HIDDEN;
362 extern INT  nulldrv_ExtSelectClipRgn( PHYSDEV dev, HRGN rgn, INT mode ) DECLSPEC_HIDDEN;
363 extern BOOL nulldrv_ExtTextOut( PHYSDEV dev, INT x, INT y, UINT flags, const RECT *rect,
364                                 LPCWSTR str, UINT count, const INT *dx ) DECLSPEC_HIDDEN;
365 extern BOOL nulldrv_FillPath( PHYSDEV dev ) DECLSPEC_HIDDEN;
366 extern BOOL nulldrv_FillRgn( PHYSDEV dev, HRGN rgn, HBRUSH brush ) DECLSPEC_HIDDEN;
367 extern BOOL nulldrv_FlattenPath( PHYSDEV dev ) DECLSPEC_HIDDEN;
368 extern BOOL nulldrv_FrameRgn( PHYSDEV dev, HRGN rgn, HBRUSH brush, INT width, INT height ) DECLSPEC_HIDDEN;
369 extern LONG nulldrv_GetBitmapBits( HBITMAP bitmap, void *bits, LONG size ) DECLSPEC_HIDDEN;
370 extern COLORREF nulldrv_GetNearestColor( PHYSDEV dev, COLORREF color ) DECLSPEC_HIDDEN;
371 extern COLORREF nulldrv_GetPixel( PHYSDEV dev, INT x, INT y ) DECLSPEC_HIDDEN;
372 extern BOOL nulldrv_GradientFill( PHYSDEV dev, TRIVERTEX *vert_array, ULONG nvert,
373                                   void * grad_array, ULONG ngrad, ULONG mode ) DECLSPEC_HIDDEN;
374 extern INT  nulldrv_IntersectClipRect( PHYSDEV dev, INT left, INT top, INT right, INT bottom ) DECLSPEC_HIDDEN;
375 extern BOOL nulldrv_InvertRgn( PHYSDEV dev, HRGN rgn ) DECLSPEC_HIDDEN;
376 extern BOOL nulldrv_ModifyWorldTransform( PHYSDEV dev, const XFORM *xform, DWORD mode ) DECLSPEC_HIDDEN;
377 extern INT  nulldrv_OffsetClipRgn( PHYSDEV dev, INT x, INT y ) DECLSPEC_HIDDEN;
378 extern BOOL nulldrv_OffsetViewportOrgEx( PHYSDEV dev, INT x, INT y, POINT *pt ) DECLSPEC_HIDDEN;
379 extern BOOL nulldrv_OffsetWindowOrgEx( PHYSDEV dev, INT x, INT y, POINT *pt ) DECLSPEC_HIDDEN;
380 extern BOOL nulldrv_PolyBezier( PHYSDEV dev, const POINT *points, DWORD count ) DECLSPEC_HIDDEN;
381 extern BOOL nulldrv_PolyBezierTo( PHYSDEV dev, const POINT *points, DWORD count ) DECLSPEC_HIDDEN;
382 extern BOOL nulldrv_PolyDraw( PHYSDEV dev, const POINT *points, const BYTE *types, DWORD count ) DECLSPEC_HIDDEN;
383 extern BOOL nulldrv_PolylineTo( PHYSDEV dev, const POINT *points, INT count ) DECLSPEC_HIDDEN;
384 extern BOOL nulldrv_RestoreDC( PHYSDEV dev, INT level ) DECLSPEC_HIDDEN;
385 extern INT  nulldrv_SaveDC( PHYSDEV dev ) DECLSPEC_HIDDEN;
386 extern BOOL nulldrv_ScaleViewportExtEx( PHYSDEV dev, INT x_num, INT x_denom, INT y_num, INT y_denom, SIZE *size ) DECLSPEC_HIDDEN;
387 extern BOOL nulldrv_ScaleWindowExtEx( PHYSDEV dev, INT x_num, INT x_denom, INT y_num, INT y_denom, SIZE *size ) DECLSPEC_HIDDEN;
388 extern BOOL nulldrv_SelectClipPath( PHYSDEV dev, INT mode ) DECLSPEC_HIDDEN;
389 extern HFONT nulldrv_SelectFont( PHYSDEV dev, HFONT font, UINT *ggo_flags ) DECLSPEC_HIDDEN;
390 extern INT nulldrv_SetDIBitsToDevice( PHYSDEV dev, INT x_dst, INT y_dst, DWORD width, DWORD height,
391                                       INT x_src, INT y_src, UINT start, UINT lines,
392                                       const void *bits, BITMAPINFO *info, UINT coloruse ) DECLSPEC_HIDDEN;
393 extern INT  nulldrv_SetMapMode( PHYSDEV dev, INT mode ) DECLSPEC_HIDDEN;
394 extern BOOL nulldrv_SetViewportExtEx( PHYSDEV dev, INT cx, INT cy, SIZE *size ) DECLSPEC_HIDDEN;
395 extern BOOL nulldrv_SetViewportOrgEx( PHYSDEV dev, INT x, INT y, POINT *pt ) DECLSPEC_HIDDEN;
396 extern BOOL nulldrv_SetWindowExtEx( PHYSDEV dev, INT cx, INT cy, SIZE *size ) DECLSPEC_HIDDEN;
397 extern BOOL nulldrv_SetWindowOrgEx( PHYSDEV dev, INT x, INT y, POINT *pt ) DECLSPEC_HIDDEN;
398 extern BOOL nulldrv_SetWorldTransform( PHYSDEV dev, const XFORM *xform ) DECLSPEC_HIDDEN;
399 extern BOOL nulldrv_StretchBlt( PHYSDEV dst_dev, struct bitblt_coords *dst,
400                                 PHYSDEV src_dev, struct bitblt_coords *src, DWORD rop ) DECLSPEC_HIDDEN;
401 extern INT  nulldrv_StretchDIBits( PHYSDEV dev, INT xDst, INT yDst, INT widthDst, INT heightDst,
402                                    INT xSrc, INT ySrc, INT widthSrc, INT heightSrc, const void *bits,
403                                    BITMAPINFO *info, UINT coloruse, DWORD rop ) DECLSPEC_HIDDEN;
404 extern BOOL nulldrv_StrokeAndFillPath( PHYSDEV dev ) DECLSPEC_HIDDEN;
405 extern BOOL nulldrv_StrokePath( PHYSDEV dev ) DECLSPEC_HIDDEN;
406 extern BOOL nulldrv_WidenPath( PHYSDEV dev ) DECLSPEC_HIDDEN;
407
408 static inline DC *get_nulldrv_dc( PHYSDEV dev )
409 {
410     return CONTAINING_RECORD( dev, DC, nulldrv );
411 }
412
413 /* Undocumented value for DIB's iUsage: Indicates a mono DIB w/o pal entries */
414 #define DIB_PAL_MONO 2
415
416 BOOL WINAPI FontIsLinked(HDC);
417
418 BOOL WINAPI SetVirtualResolution(HDC hdc, DWORD horz_res, DWORD vert_res, DWORD horz_size, DWORD vert_size);
419
420 static inline BOOL is_rect_empty( const RECT *rect )
421 {
422     return (rect->left >= rect->right || rect->top >= rect->bottom);
423 }
424
425 static inline BOOL intersect_rect( RECT *dst, const RECT *src1, const RECT *src2 )
426 {
427     dst->left   = max( src1->left, src2->left );
428     dst->top    = max( src1->top, src2->top );
429     dst->right  = min( src1->right, src2->right );
430     dst->bottom = min( src1->bottom, src2->bottom );
431     return !is_rect_empty( dst );
432 }
433
434 static inline void offset_rect( RECT *rect, int offset_x, int offset_y )
435 {
436     rect->left   += offset_x;
437     rect->top    += offset_y;
438     rect->right  += offset_x;
439     rect->bottom += offset_y;
440 }
441
442 static inline void order_rect( RECT *rect )
443 {
444     if (rect->left > rect->right)
445     {
446         int tmp = rect->left;
447         rect->left = rect->right;
448         rect->right = tmp;
449     }
450     if (rect->top > rect->bottom)
451     {
452         int tmp = rect->top;
453         rect->top = rect->bottom;
454         rect->bottom = tmp;
455     }
456 }
457
458 static inline void get_bounding_rect( RECT *rect, int x, int y, int width, int height )
459 {
460     rect->left   = x;
461     rect->right  = x + width;
462     rect->top    = y;
463     rect->bottom = y + height;
464     if (rect->left > rect->right)
465     {
466         int tmp = rect->left;
467         rect->left = rect->right + 1;
468         rect->right = tmp + 1;
469     }
470     if (rect->top > rect->bottom)
471     {
472         int tmp = rect->top;
473         rect->top = rect->bottom + 1;
474         rect->bottom = tmp + 1;
475     }
476 }
477
478 static inline void reset_bounds( RECT *bounds )
479 {
480     bounds->left = bounds->top = INT_MAX;
481     bounds->right = bounds->bottom = INT_MIN;
482 }
483
484 static inline void add_bounds_rect( RECT *bounds, const RECT *rect )
485 {
486     if (is_rect_empty( rect )) return;
487     bounds->left   = min( bounds->left, rect->left );
488     bounds->top    = min( bounds->top, rect->top );
489     bounds->right  = max( bounds->right, rect->right );
490     bounds->bottom = max( bounds->bottom, rect->bottom );
491 }
492
493 static inline int get_bitmap_stride( int width, int bpp )
494 {
495     return ((width * bpp + 15) >> 3) & ~1;
496 }
497
498 static inline int get_dib_stride( int width, int bpp )
499 {
500     return ((width * bpp + 31) >> 3) & ~3;
501 }
502
503 static inline int get_dib_image_size( const BITMAPINFO *info )
504 {
505     return get_dib_stride( info->bmiHeader.biWidth, info->bmiHeader.biBitCount )
506         * abs( info->bmiHeader.biHeight );
507 }
508
509 /* only for use on sanitized BITMAPINFO structures */
510 static inline int get_dib_info_size( const BITMAPINFO *info, UINT coloruse )
511 {
512     if (info->bmiHeader.biCompression == BI_BITFIELDS)
513         return sizeof(BITMAPINFOHEADER) + 3 * sizeof(DWORD);
514     if (coloruse == DIB_PAL_COLORS)
515         return sizeof(BITMAPINFOHEADER) + info->bmiHeader.biClrUsed * sizeof(WORD);
516     return FIELD_OFFSET( BITMAPINFO, bmiColors[info->bmiHeader.biClrUsed] );
517 }
518
519 /* only for use on sanitized BITMAPINFO structures */
520 static inline void copy_bitmapinfo( BITMAPINFO *dst, const BITMAPINFO *src )
521 {
522     memcpy( dst, src, get_dib_info_size( src, DIB_RGB_COLORS ));
523 }
524
525 extern void free_heap_bits( struct gdi_image_bits *bits ) DECLSPEC_HIDDEN;
526
527 extern HMODULE gdi32_module DECLSPEC_HIDDEN;
528
529 #endif /* __WINE_GDI_PRIVATE_H */