mirror of
https://github.com/reactos/wine.git
synced 2025-02-16 19:10:35 +00:00
![Alexandre Julliard](/assets/img/avatar_default.png)
Sat Aug 23 00:05:23 1997 Andreas Mohr <100.30936@germany.net> * [if1632/kernel.spec] [if1632/mmsystem.spec] Added some stubs. * [include/neexe.h] [loader/module.c] Added warning for OS/2 executables. * [multimedia/midi.c] Shortened MIDIOUT driver version string to be less than 31 chars. * [objects/gdiobj.c] Fixed DeleteObject32() to react properly when called with stock object. Fri Aug 22 18:03:26 1997 Dimitrie O. Paun <dimi@cs.toronto.edu> * [controls/updown.c] [include/updown.h] First attempt at implementiong the UpDown class. * [controls/widgets.c] Added the UpDown class to be initialized by InitCommonControls(). Wed Aug 20 18:01:33 1997 Doug Ridgway <ridgway@routh.UCSD.EDU> * [graphics/*] [objects/*] [include/gdi.h] Made all GDI objects (except DCs) moveable. Mon Aug 18 03:25:30 1997 Alex Korobka <alex@trantor.pharm.sunysb.edu> * [windows/event.c] [misc/winsock.c] [misc/winsock_dns.c] Removed IPC communication to speed up winsock services (tested only with 16-bit netscape 3.03). * [graphics/x11drv/xfont.c] [documentation/fonts] Miscellaneous improvements. Updated docs. Sun Aug 17 20:39:55 1997 Ingo Schneider <schneidi@informatik.tu-muenchen.de> * [misc/comm.c] A couple of bug fixes. Sun Aug 17 19:29:22 1997 Alexandre Julliard <julliard@lrc.epfl.ch> * [debugger/dbg.y] Display next instruction after stepi/nexti. * [if1632/relay.c] [include/callback.h] [tools/build.c] Replaced CallTo32_LargeStack with the CALL_LARGE_STACK macro for better Winelib support. * [include/sigcontext.h] Renamed to sig_context.h to avoid conflicts with libc. * [*/*] All API functions are now prefixed with WINAPI in prevision of future Winelib integration. * [loader/signal.c] [memory/ldt.c] Fixed assembly code to be -fPIC compatible. Thu Aug 14 14:38:15 1997 Marcus Meissner <msmeissn@cip.informatik.uni-erlangen.de> * [if1632/crtdll.spec][win32/except.c] _global_unwind, _local_unwind stub added. * [objects/dib.c] Don't read memory you don't even need for the target bitmap (fixes one 'lazy' program). * [if1632/relay.c][if1632/thunk.c][if1632/kernel32.spec] [win32/ordinals.c][memory/selector.c][memory/global.c] [include/callback.h] Added/moved some more win95 ordinal stuff. Implemented QT_Thunk (not 100% correct yet) and some friends. * [loader/pe_image.c] Add possibility to break at the DLL entrypoint. * [controls/static.c][misc/commdlg.c][scheduler/thread.c] Misc bugfixes and additions. * [misc/registry.c] The registry seems to be case-preserving but case-insensitive. * [memory/global.c] Adapted to new /proc/meminfo format. * [objects/font.c][graphics/x11drv/xfont.c] FONT_SelectObject and GetTextMetrics* get passed ranges in logical and not device points (thanks to Marion Reyzl for pointing this out). * [windows/caret.c] Use the windows own DC if present (The caret coordinates are logical coordinates based on it). Fixes another AMIPRO problem. Wed Aug 6 18:22:22 1997 Morten Welinder <terra@diku.dk> * [controls/menu.c] General clean-up and Win32 work: split item_flags into fType and fState; split item_id into wID and hSubMenu. Improved debug-printing. Implemented InsertMenuItem32[AW], SetMenuDefaultItem32, and SetMenuItemInfo32[AW]. Fixed GetMenuItemInfo32[AW]. * [if1632/user32.spec] Define above new functions. * [include/windows.h] Define MF_DEFAULT and MF_RIGHTJUSTIFY. Prototype above functions. * [include/menu.h] Don't prototype now-static MENU_InitSysMenuPopup. * [include/comm.h] Reduce MAX_PORTS to 9 (which the profile code can handle). Tue Aug 5 20:16:22 1997 Victor Schneider <vischne@ibm.net> * [library/winestub.c] [libtest/expand.c] These patches let people porting Windows apps compile them using the same conventions regarding global _argc and _argv as those on Windows C/C++ compilers.
154 lines
5.2 KiB
C
154 lines
5.2 KiB
C
/*
|
|
* System metrics functions
|
|
*
|
|
* Copyright 1994 Alexandre Julliard
|
|
*
|
|
*/
|
|
|
|
#include <stdio.h>
|
|
#include "gdi.h"
|
|
#include "options.h"
|
|
#include "tweak.h"
|
|
#include "sysmetrics.h"
|
|
|
|
short sysMetrics[SM_CMETRICS+1];
|
|
|
|
/***********************************************************************
|
|
* SYSMETRICS_Init
|
|
*
|
|
* Initialisation of the system metrics array.
|
|
*/
|
|
void SYSMETRICS_Init(void)
|
|
{
|
|
sysMetrics[SM_CXSCREEN] = screenWidth;
|
|
sysMetrics[SM_CYSCREEN] = screenHeight;
|
|
sysMetrics[SM_CXVSCROLL] =
|
|
PROFILE_GetWineIniInt("Tweak.Layout", "ScrollBarWidth", 16) + 1;
|
|
sysMetrics[SM_CYHSCROLL] = sysMetrics[SM_CXVSCROLL];
|
|
sysMetrics[SM_CYCAPTION] = 2 +
|
|
PROFILE_GetWineIniInt("Tweak.Layout", "CaptionHeight", 18);
|
|
sysMetrics[SM_CXBORDER] = 1;
|
|
sysMetrics[SM_CYBORDER] = sysMetrics[SM_CXBORDER];
|
|
sysMetrics[SM_CXDLGFRAME] =
|
|
PROFILE_GetWineIniInt("Tweak.Layout", "DialogFrameWidth",
|
|
TWEAK_Win95Look ? 2 : 4);
|
|
sysMetrics[SM_CYDLGFRAME] = sysMetrics[SM_CXDLGFRAME];
|
|
sysMetrics[SM_CYVTHUMB] = sysMetrics[SM_CXVSCROLL] - 1;
|
|
sysMetrics[SM_CXHTHUMB] = sysMetrics[SM_CYVTHUMB];
|
|
sysMetrics[SM_CXICON] = 32;
|
|
sysMetrics[SM_CYICON] = 32;
|
|
sysMetrics[SM_CYMENU] =
|
|
PROFILE_GetWineIniInt("Tweak.Layout", "MenuHeight", 18);
|
|
sysMetrics[SM_CXFULLSCREEN] = sysMetrics[SM_CXSCREEN];
|
|
sysMetrics[SM_CYFULLSCREEN] =
|
|
sysMetrics[SM_CYSCREEN] - sysMetrics[SM_CYCAPTION];
|
|
sysMetrics[SM_CYKANJIWINDOW] = 0;
|
|
sysMetrics[SM_MOUSEPRESENT] = 1;
|
|
sysMetrics[SM_CYVSCROLL] = sysMetrics[SM_CYVTHUMB];
|
|
sysMetrics[SM_CXHSCROLL] = sysMetrics[SM_CXHTHUMB];
|
|
sysMetrics[SM_DEBUG] = 0;
|
|
|
|
/* FIXME: The following should look for the registry key to see if the
|
|
buttons should be swapped. */
|
|
sysMetrics[SM_SWAPBUTTON] = 0;
|
|
|
|
sysMetrics[SM_RESERVED1] = 0;
|
|
sysMetrics[SM_RESERVED2] = 0;
|
|
sysMetrics[SM_RESERVED3] = 0;
|
|
sysMetrics[SM_RESERVED4] = 0;
|
|
|
|
/* FIXME: The following two are calculated, but how? */
|
|
sysMetrics[SM_CXMIN] = TWEAK_Win95Look ? 112 : 100;
|
|
sysMetrics[SM_CYMIN] = TWEAK_Win95Look ? 27 : 28;
|
|
|
|
sysMetrics[SM_CXSIZE] = sysMetrics[SM_CYCAPTION] - 2;
|
|
sysMetrics[SM_CYSIZE] = sysMetrics[SM_CXSIZE];
|
|
sysMetrics[SM_CXFRAME] = GetProfileInt32A("Windows", "BorderWidth", 4);
|
|
sysMetrics[SM_CYFRAME] = sysMetrics[SM_CXFRAME];
|
|
sysMetrics[SM_CXMINTRACK] = sysMetrics[SM_CXMIN];
|
|
sysMetrics[SM_CYMINTRACK] = sysMetrics[SM_CYMIN];
|
|
sysMetrics[SM_CXDOUBLECLK] =
|
|
(GetProfileInt32A("Windows", "DoubleClickWidth", 4) + 1) & ~1;
|
|
sysMetrics[SM_CYDOUBLECLK] =
|
|
(GetProfileInt32A("Windows","DoubleClickHeight", 4) + 1) & ~1;
|
|
sysMetrics[SM_CXICONSPACING] =
|
|
GetProfileInt32A("Desktop","IconSpacing", 75);
|
|
sysMetrics[SM_CYICONSPACING] =
|
|
GetProfileInt32A("Desktop", "IconVerticalSpacing", 75);
|
|
sysMetrics[SM_MENUDROPALIGNMENT] =
|
|
GetProfileInt32A("Windows", "MenuDropAlignment", 0);
|
|
sysMetrics[SM_PENWINDOWS] = 0;
|
|
sysMetrics[SM_DBCSENABLED] = 0;
|
|
|
|
/* FIXME: Need to query X for the following */
|
|
sysMetrics[SM_CMOUSEBUTTONS] = 3;
|
|
|
|
sysMetrics[SM_SECURE] = 0;
|
|
sysMetrics[SM_CXEDGE] = sysMetrics[SM_CXBORDER] + 1;
|
|
sysMetrics[SM_CYEDGE] = sysMetrics[SM_CXEDGE];
|
|
sysMetrics[SM_CXMINSPACING] = 160;
|
|
sysMetrics[SM_CYMINSPACING] = 24;
|
|
sysMetrics[SM_CXSMICON] =
|
|
sysMetrics[SM_CYSIZE] - (sysMetrics[SM_CYSIZE] % 2) - 2;
|
|
sysMetrics[SM_CYSMICON] = sysMetrics[SM_CXSMICON];
|
|
sysMetrics[SM_CYSMCAPTION] = 16;
|
|
sysMetrics[SM_CXSMSIZE] = 15;
|
|
sysMetrics[SM_CYSMSIZE] = sysMetrics[SM_CXSMSIZE];
|
|
sysMetrics[SM_CXMENUSIZE] = sysMetrics[SM_CYMENU];
|
|
sysMetrics[SM_CYMENUSIZE] = sysMetrics[SM_CXMENUSIZE];
|
|
|
|
/* FIXME: What do these mean? */
|
|
sysMetrics[SM_ARRANGE] = 8;
|
|
sysMetrics[SM_CXMINIMIZED] = 160;
|
|
sysMetrics[SM_CYMINIMIZED] = 24;
|
|
|
|
/* FIXME: How do I calculate these? */
|
|
sysMetrics[SM_CXMAXTRACK] =
|
|
sysMetrics[SM_CXSCREEN] + 4 + 2 * sysMetrics[SM_CXFRAME];
|
|
sysMetrics[SM_CYMAXTRACK] =
|
|
sysMetrics[SM_CYSCREEN] + 4 + 2 * sysMetrics[SM_CYFRAME];
|
|
sysMetrics[SM_CXMAXIMIZED] =
|
|
sysMetrics[SM_CXSCREEN] + 2 * sysMetrics[SM_CXFRAME];
|
|
sysMetrics[SM_CYMAXIMIZED] =
|
|
sysMetrics[SM_CYSCREEN] - 45;
|
|
sysMetrics[SM_NETWORK] = 3;
|
|
|
|
/* For the following: 0 = ok, 1 = failsafe, 2 = failsafe + network */
|
|
sysMetrics[SM_CLEANBOOT] = 0;
|
|
|
|
sysMetrics[SM_CXDRAG] = 0;
|
|
sysMetrics[SM_CYDRAG] = 0;
|
|
sysMetrics[SM_SHOWSOUNDS] = 0;
|
|
sysMetrics[SM_CXMENUCHECK] = 2;
|
|
sysMetrics[SM_CYMENUCHECK] = 2;
|
|
|
|
/* FIXME: Should check the type of processor for the following */
|
|
sysMetrics[SM_SLOWMACHINE] = 0;
|
|
|
|
/* FIXME: Should perform a check */
|
|
sysMetrics[SM_MIDEASTENABLED] = 0;
|
|
|
|
sysMetrics[SM_MOUSEWHEELPRESENT] = 0;
|
|
sysMetrics[SM_CMETRICS] = SM_CMETRICS;
|
|
}
|
|
|
|
|
|
/***********************************************************************
|
|
* GetSystemMetrics16 (USER.179)
|
|
*/
|
|
INT16 WINAPI GetSystemMetrics16( INT16 index )
|
|
{
|
|
if ((index < 0) || (index > SM_CMETRICS)) return 0;
|
|
else return sysMetrics[index];
|
|
}
|
|
|
|
|
|
/***********************************************************************
|
|
* GetSystemMetrics32 (USER32.291)
|
|
*/
|
|
INT32 WINAPI GetSystemMetrics32( INT32 index )
|
|
{
|
|
if ((index < 0) || (index > SM_CMETRICS)) return 0;
|
|
else return sysMetrics[index];
|
|
}
|