6 * Copyright (C) 2002 Robert Dickenson <robd@reactos.org>
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
26 #define WIN32_LEAN_AND_MEAN // Exclude rarely-used stuff from Windows headers
43 ////////////////////////////////////////////////////////////////////////////////
51 #ifdef USE_GLOBAL_STRUCT
52 WINFILE_GLOBALS Globals
;
72 TCHAR drives
[BUFFER_LEN
];
73 BOOL prescan_node
; //TODO
76 UINT wStringTableOffset
;
79 TCHAR szTitle
[MAX_LOADSTRING
];
80 TCHAR szFrameClass
[MAX_LOADSTRING
];
81 TCHAR szChildClass
[MAX_LOADSTRING
];
84 ////////////////////////////////////////////////////////////////////////////////
87 // FUNCTION: InitInstance(HANDLE, int)
89 // PURPOSE: Saves instance handle and creates main window
93 // In this function, we save the instance handle in a global variable and
94 // create and display the main program window.
96 BOOL
InitInstance(HINSTANCE hInstance
, int nCmdShow
)
98 // char TCHAR[MAX_PATH];
102 WNDCLASSEX wcFrame
= {
104 CS_HREDRAW
| CS_VREDRAW
/*style*/,
109 LoadIcon(hInstance
, MAKEINTRESOURCE(IDI_WINFILE
)),
110 LoadCursor(0, IDC_ARROW
),
114 (HICON
)LoadImage(hInstance
, MAKEINTRESOURCE(IDI_WINFILE
), IMAGE_ICON
,
115 GetSystemMetrics(SM_CXSMICON
), GetSystemMetrics(SM_CYSMICON
), LR_SHARED
)
117 ATOM hFrameWndClass
= RegisterClassEx(&wcFrame
); // register frame window class
120 CS_CLASSDC
|CS_DBLCLKS
|CS_VREDRAW
,
126 LoadCursor(0, IDC_ARROW
),
132 ATOM hChildClass
= RegisterClass(&wcChild
); // register child windows class
134 HMENU hMenuFrame
= LoadMenu(hInstance
, MAKEINTRESOURCE(IDC_WINFILE
));
135 HMENU hMenuWindow
= GetSubMenu(hMenuFrame
, GetMenuItemCount(hMenuFrame
)-2);
137 CLIENTCREATESTRUCT ccs
= {
138 hMenuWindow
, IDW_FIRST_CHILD
141 INITCOMMONCONTROLSEX icc
= {
142 sizeof(INITCOMMONCONTROLSEX
),
146 // TCHAR path[MAX_PATH];
150 // hMenuFrame = hMenuFrame;
151 Globals
.hMenuView
= GetSubMenu(hMenuFrame
, 3);
152 Globals
.hMenuOptions
= GetSubMenu(hMenuFrame
, 4);
153 Globals
.hAccel
= LoadAccelerators(hInstance
, MAKEINTRESOURCE(IDC_WINFILE
));
154 Globals
.hFont
= CreateFont(-MulDiv(8,GetDeviceCaps(hdc
,LOGPIXELSY
),72), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, _T("MS Sans Serif"));
157 Globals
.hMainWnd
= CreateWindowEx(0, (LPCTSTR
)(int)hFrameWndClass
, szTitle
,
158 WS_OVERLAPPEDWINDOW
| WS_CLIPCHILDREN
,
159 CW_USEDEFAULT
, CW_USEDEFAULT
, CW_USEDEFAULT
, CW_USEDEFAULT
,
160 0/*hWndParent*/, hMenuFrame
, hInstance
, 0/*lpParam*/);
161 if (!Globals
.hMainWnd
) {
165 if (InitCommonControlsEx(&icc
)) {
166 // TBBUTTON drivebarBtn = {0, 0, TBSTATE_ENABLED, TBSTYLE_SEP};
167 TBBUTTON drivebarBtn
= {0, 0, TBSTATE_ENABLED
, TBSTYLE_SEP
};
171 Globals
.hDriveBar
= CreateToolbarEx(Globals
.hMainWnd
,
172 WS_CHILD
|WS_VISIBLE
|CCS_NOMOVEY
|TBSTYLE_FLAT
|TBSTYLE_LIST
|TBSTYLE_WRAPABLE
,
173 // WS_CHILD|WS_VISIBLE|CCS_NOMOVEY|TBSTYLE_LIST|TBSTYLE_TRANSPARENT|TBSTYLE_WRAPABLE,
174 IDW_DRIVEBAR
, 2, hInstance
, IDB_DRIVEBAR
,
175 &drivebarBtn
, 1/*iNumButtons*/,
176 25/*dxButton*/, 16/*dyButton*/,
177 0/*dxBitmap*/, 0/*dyBitmap*/, sizeof(TBBUTTON
));
178 // 16/*dxButton*/, 13/*dyButton*/,
179 // 16/*dxBitmap*/, 13/*dyBitmap*/, sizeof(TBBUTTON));
180 CheckMenuItem(Globals
.hMenuOptions
, ID_OPTIONS_DRIVEBAR
, MF_BYCOMMAND
|MF_CHECKED
);
181 GetLogicalDriveStrings(BUFFER_LEN
, Globals
.drives
);
182 drivebarBtn
.fsStyle
= TBSTYLE_BUTTON
;
183 #ifndef _NO_EXTENSIONS
184 // register windows drive root strings
185 SendMessage(Globals
.hDriveBar
, TB_ADDSTRING
, 0, (LPARAM
)Globals
.drives
);
187 drivebarBtn
.idCommand
= ID_DRIVE_FIRST
;
188 for (p
= Globals
.drives
; *p
;) {
189 #ifdef _NO_EXTENSIONS
190 // insert drive letter
191 TCHAR b
[3] = { tolower(*p
) };
192 SendMessage(Globals
.hDriveBar
, TB_ADDSTRING
, 0, (LPARAM
)b
);
194 switch(GetDriveType(p
)) {
195 case DRIVE_REMOVABLE
: drivebarBtn
.iBitmap
= 1; break;
196 case DRIVE_CDROM
: drivebarBtn
.iBitmap
= 3; break;
197 case DRIVE_REMOTE
: drivebarBtn
.iBitmap
= 4; break;
198 case DRIVE_RAMDISK
: drivebarBtn
.iBitmap
= 5; break;
199 default:/*DRIVE_FIXED*/ drivebarBtn
.iBitmap
= 2;
201 SendMessage(Globals
.hDriveBar
, TB_INSERTBUTTON
, btn
++, (LPARAM
)&drivebarBtn
);
202 drivebarBtn
.idCommand
++;
203 drivebarBtn
.iString
++;
208 #define DRIVEBOX_WIDTH 200
209 #define DRIVEBOX_HEIGHT 8
211 TBBUTTON toolbarBtns
[] = {
212 {DRIVEBOX_WIDTH
+10, 0, 0, TBSTYLE_SEP
},
213 {0, 0, 0, TBSTYLE_SEP
},
215 // {1, ID_FILE_OPEN, TBSTATE_ENABLED, TBSTYLE_BUTTON, 0, ID_FILE_OPEN },
216 {2, ID_FILE_MOVE
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
, 0, ID_FILE_MOVE
},
217 {3, ID_FILE_COPY
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
, 0, ID_FILE_COPY
},
218 {4, ID_FILE_COPY_CLIPBOARD
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
, 0, ID_FILE_COPY_CLIPBOARD
},
219 {5, ID_FILE_DELETE
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
, 0, ID_FILE_DELETE
},
220 {6, ID_FILE_RENAME
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
221 {7, ID_FILE_PROPERTIES
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
222 {8, ID_FILE_COMPRESS
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
223 {9, ID_FILE_UNCOMPRESS
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
224 // {10, ID_FILE_RUN, TBSTATE_ENABLED, TBSTYLE_BUTTON},
225 {10, ID_FILE_PRINT
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
226 {11, ID_FILE_ASSOCIATE
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
227 {12, ID_FILE_CREATE_DIRECTORY
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
228 {13, ID_FILE_SEARCH
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
229 {14, ID_FILE_SELECT_FILES
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
230 // {16, ID_FILE_EXIT, TBSTATE_ENABLED, TBSTYLE_BUTTON},
231 {15, ID_DISK_COPY_DISK
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
232 {16, ID_DISK_LABEL_DISK
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
233 {17, ID_DISK_FORMAT_DISK
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
234 {18, ID_DISK_CONNECT_NETWORK_DRIVE
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
235 {19, ID_DISK_DISCONNECT_NETWORK_DRIVE
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
236 {20, ID_DISK_SHARE_AS
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
237 {21, ID_DISK_STOP_SHARING
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
238 // {24, ID_DISK_SELECT_DRIVE, TBSTATE_ENABLED, TBSTYLE_BUTTON},
239 // {25, ID_TREE_EXPAND_ONE_LEVEL, TBSTATE_ENABLED, TBSTYLE_BUTTON},
240 // {26, ID_TREE_EXPAND_BRANCH, TBSTATE_ENABLED, TBSTYLE_BUTTON},
241 // {27, ID_TREE_EXPAND_ALL, TBSTATE_ENABLED, TBSTYLE_BUTTON},
242 // {28, ID_TREE_COLLAPSE_BRANCH, TBSTATE_ENABLED, TBSTYLE_BUTTON},
243 {22, ID_TREE_INDICATE_EXPANDABLE_BRANCHES
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
244 // {30, ID_VIEW_TREE_DIRECTORY, TBSTATE_ENABLED, TBSTYLE_BUTTON},
245 // {31, ID_VIEW_TREE_ONLY, TBSTATE_ENABLED, TBSTYLE_BUTTON},
246 // {32, ID_VIEW_DIRECTORY_ONLY, TBSTATE_ENABLED, TBSTYLE_BUTTON},
247 // {33, ID_VIEW_SPLIT, TBSTATE_ENABLED, TBSTYLE_BUTTON},
248 {23, ID_VIEW_NAME
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
249 {24, ID_VIEW_ALL_FILE_DETAILS
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
250 {25, ID_VIEW_PARTIAL_DETAILS
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
251 // {37, ID_VIEW_SORT_BY_NAME, TBSTATE_ENABLED, TBSTYLE_BUTTON},
252 // {38, ID_VIEW_SORT_BY_TYPE, TBSTATE_ENABLED, TBSTYLE_BUTTON},
253 // {39, ID_VIEW_SORT_BY_SIZE, TBSTATE_ENABLED, TBSTYLE_BUTTON},
254 // {40, ID_VIEW_SORT_BY_DATE, TBSTATE_ENABLED, TBSTYLE_BUTTON},
255 {26, ID_VIEW_BY_FILE_TYPE
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
256 {27, ID_OPTIONS_CONFIRMATION
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
257 {28, ID_OPTIONS_FONT
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
258 {29, ID_OPTIONS_CUSTOMISE_TOOLBAR
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
259 // {45, ID_OPTIONS_TOOLBAR, TBSTATE_ENABLED, TBSTYLE_BUTTON},
260 // {46, ID_OPTIONS_DRIVEBAR, TBSTATE_ENABLED, TBSTYLE_BUTTON},
261 // {47, ID_OPTIONS_STATUSBAR, TBSTATE_ENABLED, TBSTYLE_BUTTON},
262 {30, ID_OPTIONS_OPEN_NEW_WINDOW_ON_CONNECT
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
263 {31, ID_OPTIONS_MINIMISE_ON_USE
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
264 {32, ID_OPTIONS_SAVE_ON_EXIT
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
265 {33, ID_SECURITY_PERMISSIONS
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
266 {34, ID_SECURITY_AUDITING
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
267 {35, ID_SECURITY_OWNER
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
268 {36, ID_WINDOW_NEW_WINDOW
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
269 {37, ID_WINDOW_CASCADE
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
270 {38, ID_WINDOW_TILE_HORZ
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
271 {39, ID_WINDOW_TILE_VERT
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
272 {40, ID_WINDOW_ARRANGE_ICONS
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
273 {41, ID_WINDOW_REFRESH
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
274 {42, ID_HELP_CONTENTS
, TBSTATE_ENABLED
, TBSTYLE_BUTTON
},
275 // {61, ID_HELP_SEARCH_HELP, TBSTATE_ENABLED, TBSTYLE_BUTTON},
276 // {62, ID_HELP_HOW_TO_USE_HELP, TBSTATE_ENABLED, TBSTYLE_BUTTON},
277 // {63, ID_HELP_ABOUT, TBSTATE_ENABLED, TBSTYLE_BUTTON},
280 // {0, ID_WINDOW_NEW_WINDOW, TBSTATE_ENABLED, TBSTYLE_BUTTON},
281 // {1, ID_WINDOW_CASCADE, TBSTATE_ENABLED, TBSTYLE_BUTTON},
282 // {2, ID_WINDOW_TILE_HORZ, TBSTATE_ENABLED, TBSTYLE_BUTTON},
283 // {3, ID_WINDOW_TILE_VERT, TBSTATE_ENABLED, TBSTYLE_BUTTON},
284 // {4, 2/*TODO: ID_...*/, TBSTATE_ENABLED, TBSTYLE_BUTTON},
285 // {5, 2/*TODO: ID_...*/, TBSTATE_ENABLED, TBSTYLE_BUTTON},
288 // Globals.hToolBar = CreateToolbarEx(Globals.hMainWnd, WS_CHILD|WS_VISIBLE|TBSTYLE_TOOLTIPS|TBSTYLE_FLAT,
289 Globals
.hToolBar
= CreateToolbarEx(Globals
.hMainWnd
, WS_CHILD
|WS_VISIBLE
|TBSTYLE_TOOLTIPS
|CCS_ADJUSTABLE
,
290 IDW_TOOLBAR
, 2, hInstance
, IDB_TOOLBAR
, toolbarBtns
,
291 sizeof(toolbarBtns
)/sizeof(TBBUTTON
), 16, 15, 16, 15, sizeof(TBBUTTON
));
292 CheckMenuItem(Globals
.hMenuOptions
, ID_OPTIONS_TOOLBAR
, MF_BYCOMMAND
|MF_CHECKED
);
295 // Create the edit control. Notice that hWndParent, parent of
296 // the toolbar, is used as the parent of the edit control.
298 //HWND hWndEdit = CreateWindowEx(0L, WC_COMBOBOXEX, NULL, WS_CHILD | WS_BORDER | WS_VISIBLE
299 HWND hWndEdit
= CreateWindowEx(0L, "ComboBox", NULL
, WS_CHILD
| WS_BORDER
| WS_VISIBLE
300 | CBS_DROPDOWN
| ES_LEFT
| ES_AUTOVSCROLL
| ES_MULTILINE
,
301 10, 0, DRIVEBOX_WIDTH
, DRIVEBOX_HEIGHT
, Globals
.hMainWnd
, (HMENU
)IDW_DRIVEBOX
, hInstance
, 0);
303 // Set the toolbar window as the parent of the edit control
304 // window. You must set the toolbar as the parent of the edit
305 // control for it to appear embedded in the toolbar.
306 SetParent (hWndEdit
, Globals
.hToolBar
);
314 // Create the status bar
315 Globals
.hStatusBar
= CreateStatusWindow(WS_VISIBLE
|WS_CHILD
|WS_CLIPSIBLINGS
|SBT_NOBORDERS
,
316 _T(""), Globals
.hMainWnd
, IDW_STATUS_WINDOW
);
317 if (!Globals
.hStatusBar
)
319 CheckMenuItem(Globals
.hMenuOptions
, ID_OPTIONS_STATUSBAR
, MF_BYCOMMAND
|MF_CHECKED
);
321 // Create the status bar panes
322 SetupStatusBar(FALSE
);
328 SendMessage(Globals.hStatusBar, SB_SETPARTS, 4, (long)nParts);
331 //Globals.hstatusbar = CreateStatusWindow(WS_CHILD|WS_VISIBLE, 0, Globals.Globals.hMainWnd, IDW_STATUSBAR);
332 //CheckMenuItem(Globals.Globals.hMenuOptions, ID_OPTIONS_STATUSBAR, MF_BYCOMMAND|MF_CHECKED);
333 /* CreateStatusWindow does not accept WS_BORDER */
334 /* Globals.hstatusbar = CreateWindowEx(WS_EX_NOPARENTNOTIFY, STATUSCLASSNAME, 0,
335 WS_CHILD|WS_VISIBLE|WS_CLIPSIBLINGS|WS_BORDER|CCS_NODIVIDER, 0,0,0,0,
336 Globals.Globals.hMainWnd, (HMENU)IDW_STATUSBAR, hinstance, 0);*/
337 //TODO: read paths and window placements from registry
338 GetCurrentDirectory(MAX_PATH
, path
);
339 child
= alloc_child_window(path
);
340 child
->pos
.showCmd
= SW_SHOWMAXIMIZED
;
341 child
->pos
.rcNormalPosition
.left
= 0;
342 child
->pos
.rcNormalPosition
.top
= 0;
343 child
->pos
.rcNormalPosition
.right
= 320;
344 child
->pos
.rcNormalPosition
.bottom
= 280;
345 if (!create_child_window(child
))
347 SetWindowPlacement(child
->hWnd
, &child
->pos
);
348 Globals
.himl
= ImageList_LoadBitmap(Globals
.hInstance
, MAKEINTRESOURCE(IDB_IMAGES
), 16, 0, RGB(0,255,0));
349 Globals
.prescan_node
= FALSE
;
352 ShowWindow(Globals
.hMainWnd
, nCmdShow
);
353 UpdateWindow(Globals
.hMainWnd
);
359 Globals.hMDIClient = CreateWindowEx(0, _T("MDICLIENT"), NULL,
360 // Globals.hMDIClient = CreateWindowEx(0, (LPCTSTR)(int)hChildClass, NULL,
361 WS_CHILD|WS_CLIPCHILDREN|WS_VSCROLL|WS_HSCROLL|WS_VISIBLE|WS_BORDER,
363 Globals.hMainWnd, 0, hInstance, &ccs);
364 if (!Globals.hMDIClient) {
369 void SetupStatusBar(BOOL bResize
)
372 // int parts[] = {300, 500};
373 // SendMessage(Globals.hStatusBar, WM_SIZE, 0, 0);
374 // SendMessage(Globals.hStatusBar, SB_SETPARTS, 2, (LPARAM)&parts);
376 // Create the status bar panes
383 SendMessage(Globals
.hStatusBar
, WM_SIZE
, 0, 0);
384 SendMessage(Globals
.hStatusBar
, SB_SETPARTS
, 4, (long)nParts
);
387 void UpdateStatusBar(void)
392 // size = sizeof(text)/sizeof(TCHAR);
393 // GetUserName(text, &size);
394 // SendMessage(Globals.hStatusBar, SB_SETTEXT, 0, (LPARAM)text);
395 // size = sizeof(text)/sizeof(TCHAR);
396 // GetComputerName(text, &size);
397 // SendMessage(Globals.hStatusBar, SB_SETTEXT, 1, (LPARAM)text);
401 static int g_foundPrevInstance
= 0;
403 // search for already running instances
404 static BOOL CALLBACK
EnumWndProc(HWND hWnd
, LPARAM lparam
)
408 GetClassName(hWnd
, cls
, 128);
409 if (!lstrcmp(cls
, (LPCTSTR
)lparam
)) {
410 g_foundPrevInstance
++;
411 SetForegroundWindow(hWnd
);
418 void ExitInstance(void)
421 ImageList_Destroy(Globals
.himl
);
427 BYTE DefaultChar[MAX_DEFAULTCHAR];
428 BYTE LeadByte[MAX_LEADBYTES];
432 int APIENTRY
WinMain(HINSTANCE hInstance
,
433 HINSTANCE hPrevInstance
,
443 OemCodePage
= GetOEMCP();
444 AnsiCodePage
= GetACP();
445 UserDefaultLCID
= GetUserDefaultLCID();
446 if (GetCPInfo(UserDefaultLCID
, &CPinfo
)) {
450 // Initialize global strings
451 LoadString(hInstance
, IDS_APP_TITLE
, szTitle
, MAX_LOADSTRING
);
452 LoadString(hInstance
, IDC_WINFILE
, szFrameClass
, MAX_LOADSTRING
);
453 LoadString(hInstance
, IDC_WINFILE_CHILD
, szChildClass
, MAX_LOADSTRING
);
455 // Allow only one running instance
456 EnumWindows(EnumWndProc
, (LPARAM
)szFrameClass
);
457 if (g_foundPrevInstance
) {
461 // Store instance handle in our global variable
466 // Perform application initialization:
467 if (!InitInstance(hInstance
, nCmdShow
)) {
471 // hAccel = LoadAccelerators(hInstance, (LPCTSTR)IDC_WINFILE);
472 hAccel
= LoadAccelerators(hInstance
, (LPCTSTR
)IDR_ACCELERATOR1
);
474 hMDIClient
= GetWindow(Globals
.hMainWnd
, GW_CHILD
);
476 // Main message loop:
477 while (GetMessage(&msg
, (HWND
)NULL
, 0, 0)) {
478 if (!TranslateMDISysAccel(hMDIClient
, &msg
) &&
479 !TranslateAccelerator(Globals
.hMainWnd
/*hwndFrame*/, hAccel
, &msg
)) {
480 TranslateMessage(&msg
);
481 DispatchMessage(&msg
);
490 void _GetFreeSpaceEx(void)
493 TCHAR szDrive
[MAX_PATH
];
494 ULARGE_INTEGER i64FreeBytesToCaller
;
495 ULARGE_INTEGER i64TotalBytes
;
496 ULARGE_INTEGER i64FreeBytes
;
498 fResult
= GetDiskFreeSpaceEx(szDrive
,
499 (PULARGE_INTEGER
)&i64FreeBytesToCaller
,
500 (PULARGE_INTEGER
)&i64TotalBytes
,
501 (PULARGE_INTEGER
)&i64FreeBytes
);