source: trunk/dll/misc.c@ 919

Last change on this file since 919 was 907, checked in by Steven Levine, 18 years ago

Avoid out of memory traps in Compare Directories
Rework Compare Directories progress display for 2 second update rate
Start refactoring to reduce dependence on fm3dll.h
Add timer services (IsITimerExpired etc.)

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 64.4 KB
RevLine 
[70]1
2/***********************************************************************
3
4 $Id: misc.c 907 2008-01-06 07:26:17Z stevenhl $
5
[406]6 Misc GUI support functions
[70]7
8 Copyright (c) 1993-98 M. Kimes
[907]9 Copyright (c) 2003, 2008 Steven H. Levine
[70]10
[161]11 11 Jun 03 SHL Add JFS and FAT32 support
12 01 Aug 04 SHL Rework lstrip/rstrip usage
13 01 Aug 04 SHL LoadLibPath: avoid buffer overflow
[198]14 07 Jun 05 SHL Drop obsoletes
[231]15 24 Jul 05 SHL Beautify
[245]16 24 Jul 05 SHL Correct longname display option
[350]17 17 Jul 06 SHL Use Runtime_Error
[369]18 26 Jul 06 SHL Use chop_at_crnl
[397]19 27 Jul 06 SHL Comments, apply indent
[406]20 29 Jul 06 SHL Use xfgets_bstripcr
[451]21 16 Aug 06 SHL Comments
[468]22 31 Aug 06 SHL disable_menuitem: rework args to match name - sheesh
[526]23 10 Oct 06 GKY Add NDFS32 support
[552]24 18 Feb 07 GKY More drive type and drive icon support
[688]25 10 Jun 07 GKY Add IsFm2Window as part of work around PM drag limit
[730]26 05 Jul 07 GKY Fix menu removals for WORKPLACE_PROCESS=YES
[737]27 23 Jul 07 SHL Sync with CNRITEM updates (ticket#24)
[751]28 31 Jul 07 SHL Clean up and report errors (ticket#24)
[756]29 03 Aug 07 GKY Direct editting fixed (ticket#24)
[773]30 06 Aug 07 SHL Use BldQuotedFileName
[775]31 06 Aug 07 GKY Increase Subject EA to 1024
32 06 Aug 07 GKY Reduce DosSleep times (ticket 148)
[787]33 14 Aug 07 SHL Delete obsoletes
34 14 Aug 07 SHL Move #pragma alloc_text to end for OpenWatcom compat
[827]35 01 Sep 07 GKY Use xDosSetPathInfo to fix case where FS3 buffer crosses 64k boundry
[860]36 05 Nov 07 GKY Use commafmtULL to display file sizes for large file support
[872]37 22 Nov 07 GKY Use CopyPresParams to fix presparam inconsistencies in menus
[70]38
39***********************************************************************/
40
[907]41#include <stdlib.h>
42#include <string.h>
43#include <ctype.h>
44#include <share.h>
45#include <malloc.h> // _heapmin
46
[2]47#define INCL_DOS
48#define INCL_WIN
49#define INCL_GPI
[841]50#define INCL_LONGLONG
[2]51
52#include "fm3dlg.h"
53#include "fm3str.h"
[907]54#include "pathutil.h" // BldQuotedFileName
55#include "errutil.h" // Dos_Error...
56#include "strutil.h" // GetPString
57#include "fm3dll.h"
[2]58
59#pragma data_seg(DATA1)
[350]60
61static PSZ pszSrcFile = __FILE__;
62
[2]63#ifndef BEGIN_LIBPATH
[231]64#define BEGIN_LIBPATH 1
[2]65#endif
[231]66
[2]67#ifndef END_LIBPATH
[231]68#define END_LIBPATH 2
[2]69#endif
[231]70
[2]71#ifndef ORD_DOS32QUERYEXTLIBPATH
[231]72#define ORD_DOS32QUERYEXTLIBPATH 874
[2]73#endif
74
[687]75BOOL IsFm2Window(HWND hwnd, BOOL chkTid)
76{
77 PIB *ppib;
78 TIB *ptib;
[751]79 BOOL yes;
80 APIRET rc = DosGetInfoBlocks(&ptib, &ppib);
[687]81
[733]82 if (rc) {
[687]83 Dos_Error(MB_CANCEL, rc, HWND_DESKTOP, pszSrcFile, __LINE__,
84 "DosGetInfoBlocks");
[751]85 yes = FALSE;
[733]86 }
[687]87 else {
88 PID pid;
89 TID tid;
90
[751]91 // Check window owned by FM2 process
92 // Check say same thread too, if requested
93 // OK for window to be dead - just return FALSE
94 yes = WinQueryWindowProcess(hwnd, &pid, &tid) &&
95 pid == ppib->pib_ulpid &&
96 (!chkTid || tid == ptib->tib_ptib2->tib2_ultid);
[687]97 }
[751]98 return yes;
[687]99}
100
[231]101VOID SetShiftState(VOID)
102{
[397]103 shiftstate = 0;
104 if (WinGetKeyState(HWND_DESKTOP, VK_CTRL) & 0x8000)
105 shiftstate |= KC_CTRL;
106 if (WinGetKeyState(HWND_DESKTOP, VK_SHIFT) & 0x8000)
107 shiftstate |= KC_SHIFT;
108 if (WinGetKeyState(HWND_DESKTOP, VK_ALT) & 0x8000)
109 shiftstate |= KC_ALT;
[2]110}
111
[231]112void EmphasizeButton(HWND hwnd, BOOL on)
113{
[397]114 HPS hps = DrgGetPS(hwnd);
[2]115
[397]116 // fixme to complain?
117 if (hps) {
118 POINTL ptl;
119 SWP swp;
[2]120
[397]121 WinQueryWindowPos(hwnd, &swp);
122 ptl.x = 1;
123 ptl.y = 1;
124 GpiMove(hps, &ptl);
[787]125 GpiSetColor(hps, on ? CLR_BLACK : CLR_PALEGRAY);
[397]126 ptl.x = swp.cx - 2;
127 ptl.y = swp.cy - 2;
128 GpiBox(hps, DRO_OUTLINE, &ptl, 0, 0);
129 DrgReleasePS(hps);
[551]130 if (remove) //fixme always true
[397]131 WinInvalidateRect(hwnd, NULL, FALSE);
132 }
[2]133}
134
[231]135void DrawTargetEmphasis(HWND hwnd, BOOL on)
136{
[397]137 HPS hps = DrgGetPS(WinQueryWindow(hwnd, QW_PARENT));
[551]138
[397]139 if (hps) {
[787]140 BoxWindow(hwnd, hps, on ? CLR_BLACK : CLR_PALEGRAY);
[397]141 DrgReleasePS(hps);
142 }
[2]143}
144
[231]145void BoxWindow(HWND hwnd, HPS hps, LONG color)
146{
[397]147 POINTL ptl;
148 SWP swp;
149 BOOL releaseme = FALSE;
[2]150
[397]151 if (!hps) {
152 hps = WinGetPS(WinQueryWindow(hwnd, QW_PARENT));
153 releaseme = TRUE;
154 }
155 if (hps && WinQueryWindowPos(hwnd, &swp)) {
156 ptl.x = swp.x - 2;
157 ptl.y = swp.y - 2;
158 GpiMove(hps, &ptl);
159 GpiSetColor(hps, color);
160 ptl.x = swp.x + swp.cx + 1;
161 ptl.y = swp.y + swp.cy + 1;
162 GpiBox(hps, DRO_OUTLINE, &ptl, 0, 0);
163 }
164 if (releaseme && hps)
165 WinReleasePS(hps);
[2]166}
167
[231]168void PaintSTextWindow(HWND hwnd, HPS hps)
169{
[397]170 /*
171 * paint a text window such that the rightmost part of the text is
172 * always visible even if the text length exceeds the length of the
173 * window -- otherwise, paint the window so that it is left-justified
174 * and vertically centered.
175 */
[2]176
[397]177 char *s = NULL;
178 long len;
179 POINTL aptl[TXTBOX_COUNT], ptl;
180 RECTL rcl;
181 char *p;
182 BOOL releaseme = FALSE;
[2]183
[397]184 if (!hps) {
185 releaseme = TRUE;
186 hps = WinGetPS(hwnd);
187 }
188 if (hps) {
189 WinQueryWindowRect(hwnd, &rcl);
190 WinFillRect(hps, &rcl, CLR_PALEGRAY);
191 len = WinQueryWindowTextLength(hwnd);
192 if (len)
193 s = xmalloc(len + 1, pszSrcFile, __LINE__);
194 if (s) {
195 *s = 0;
196 WinQueryWindowText(hwnd, CCHMAXPATH, s);
197 if (*s) {
198 rcl.xRight -= 3;
199 p = s;
200 GpiQueryTextBox(hps, 3, "...", TXTBOX_COUNT, aptl);
201 len = aptl[TXTBOX_TOPRIGHT].x;
202 do {
203 GpiQueryTextBox(hps, strlen(p), p, TXTBOX_COUNT, aptl);
[787]204 if (aptl[TXTBOX_TOPRIGHT].x > (rcl.xRight - (p != s ? len : 0)))
[397]205 p++;
206 else
207 break;
[231]208 }
[397]209 while (*p);
210 if (*p) {
211 GpiSetMix(hps, FM_OVERPAINT);
212 GpiSetColor(hps, CLR_BLACK);
213 ptl.x = 3;
214 ptl.y = ((rcl.yTop / 2) -
215 ((aptl[TXTBOX_TOPRIGHT].y +
216 aptl[TXTBOX_BOTTOMLEFT].y) / 2));
217 GpiMove(hps, &ptl);
218 if (p != s)
219 GpiCharString(hps, 3, "...");
220 GpiCharString(hps, strlen(p), p);
221 }
222 }
223 free(s);
[231]224 }
[397]225 if (releaseme)
226 WinReleasePS(hps);
227 }
[2]228}
229
[231]230VOID PaintRecessedWindow(HWND hwnd, HPS hps, BOOL outtie, BOOL dbl)
231{
[397]232 /*
233 * paint a recessed box around the window
234 * two pixels width required around window for painting...
235 */
236 BOOL releaseme = FALSE;
[2]237
[397]238 if (!hps) {
239 hps = WinGetPS(WinQueryWindow(hwnd, QW_PARENT));
240 releaseme = TRUE;
241 }
242 if (hps) {
[2]243
[397]244 POINTL ptl;
245 SWP swp;
[2]246
[397]247 WinQueryWindowPos(hwnd, &swp);
248 ptl.x = swp.x - 1;
249 ptl.y = swp.y - 1;
250 GpiMove(hps, &ptl);
251 if (!outtie)
252 GpiSetColor(hps, CLR_WHITE);
253 else
254 GpiSetColor(hps, CLR_DARKGRAY);
255 ptl.x = swp.x + swp.cx;
256 GpiLine(hps, &ptl);
257 ptl.y = swp.y + swp.cy;
258 GpiLine(hps, &ptl);
259 if (dbl) {
260 ptl.x = swp.x - 2;
261 ptl.y = swp.y - 2;
262 GpiMove(hps, &ptl);
263 ptl.x = swp.x + swp.cx + 1;
264 GpiLine(hps, &ptl);
265 ptl.y = swp.y + swp.cy + 1;
266 GpiLine(hps, &ptl);
[2]267 }
[397]268 if (!outtie)
269 GpiSetColor(hps, CLR_DARKGRAY);
270 else
271 GpiSetColor(hps, CLR_WHITE);
272 if (dbl) {
273 ptl.x = swp.x - 2;
274 GpiLine(hps, &ptl);
275 ptl.y = swp.y - 2;
276 GpiLine(hps, &ptl);
277 ptl.x = swp.x + swp.cx;
278 ptl.y = swp.y + swp.cy;
279 GpiMove(hps, &ptl);
280 }
281 ptl.x = swp.x - 1;
282 GpiLine(hps, &ptl);
283 ptl.y = swp.y - 1;
284 GpiLine(hps, &ptl);
285 GpiSetColor(hps, CLR_PALEGRAY);
286 ptl.x = swp.x - (2 + (dbl != FALSE));
287 ptl.y = swp.y - (2 + (dbl != FALSE));
288 GpiMove(hps, &ptl);
289 ptl.x = swp.x + swp.cx + (1 + (dbl != FALSE));
290 GpiLine(hps, &ptl);
291 ptl.y = swp.y + swp.cy + (1 + (dbl != FALSE));
292 GpiLine(hps, &ptl);
293 ptl.x = swp.x - (2 + (dbl != FALSE));
294 GpiLine(hps, &ptl);
295 ptl.y = swp.y - (2 + (dbl != FALSE));
296 GpiLine(hps, &ptl);
297 if (releaseme)
298 WinReleasePS(hps);
299 }
[2]300}
301
[231]302BOOL AdjustCnrColVis(HWND hwndCnr, CHAR * title, BOOL visible, BOOL toggle)
303{
[551]304 PFIELDINFO pfi = (PFIELDINFO) WinSendMsg(hwndCnr,
305 CM_QUERYDETAILFIELDINFO,
306 MPVOID, MPFROMSHORT(CMA_FIRST));
307
[397]308 while (pfi) {
309 if (!strcmp(pfi->pTitleData, title)) {
310 if (toggle) {
311 if (pfi->flData & CFA_INVISIBLE)
312 pfi->flData &= (~CFA_INVISIBLE);
313 else
314 pfi->flData |= CFA_INVISIBLE;
315 return !(pfi->flData & CFA_INVISIBLE);
316 }
317 else {
318 if (visible)
319 pfi->flData &= (~CFA_INVISIBLE);
320 else
321 pfi->flData |= CFA_INVISIBLE;
322 }
323 return TRUE;
[2]324 }
[397]325 pfi = pfi->pNextFieldInfo;
326 }
327 return FALSE;
[2]328}
329
[231]330BOOL AdjustCnrColRO(HWND hwndCnr, CHAR * title, BOOL readonly, BOOL toggle)
[70]331{
[551]332 PFIELDINFO pfi = (PFIELDINFO) WinSendMsg(hwndCnr,
333 CM_QUERYDETAILFIELDINFO,
334 MPVOID, MPFROMSHORT(CMA_FIRST));
335
[397]336 while (pfi) {
337 if (!strcmp(pfi->pTitleData, title)) {
338 if (toggle) {
339 if (pfi->flData & CFA_FIREADONLY)
340 pfi->flData &= (~CFA_FIREADONLY);
341 else
342 pfi->flData |= CFA_FIREADONLY;
343 return (pfi->flData & CFA_FIREADONLY);
344 }
345 else {
346 if (!readonly)
347 pfi->flData &= (~CFA_FIREADONLY);
348 else
349 pfi->flData |= CFA_FIREADONLY;
350 }
351 return TRUE;
[2]352 }
[397]353 pfi = pfi->pNextFieldInfo;
354 }
355 return FALSE;
[2]356}
357
[397]358VOID AdjustCnrColsForFSType(HWND hwndCnr, CHAR * directory, DIRCNRDATA * dcd)
[231]359{
[397]360 CHAR FileSystem[CCHMAXPATH];
361 INT x;
362 BOOL hasCreateDT;
363 BOOL hasAccessDT;
364 BOOL hasLongNames;
365 BOOL *pBool;
[2]366
[397]367 if (!directory || !*directory)
368 return;
369 x = CheckDrive(toupper(*directory), FileSystem, NULL);
370 if (x != -1) {
371 if (!stricmp(FileSystem, HPFS) ||
372 !stricmp(FileSystem, JFS) ||
[551]373 !stricmp(FileSystem, FAT32) ||
[751]374 !stricmp(FileSystem, RAMFS) ||
375 !stricmp(FileSystem, NDFS32) ||
376 !stricmp(FileSystem, NTFS) ||
377 !stricmp(FileSystem, HPFS386)) {
[397]378 hasCreateDT = TRUE;
379 hasAccessDT = TRUE;
380 hasLongNames = TRUE;
[2]381 }
[552]382 else if (!strcmp(FileSystem, CDFS) || !strcmp(FileSystem, ISOFS)) {
[397]383 hasCreateDT = TRUE;
384 hasAccessDT = FALSE;
385 hasLongNames = FALSE;
[2]386 }
[397]387 else {
388 // Assume FAT
389 hasCreateDT = FALSE;
390 hasAccessDT = FALSE;
391 hasLongNames = FALSE;
392 }
393 }
394 else {
395 // Assume FAT
396 hasCreateDT = FALSE;
397 hasAccessDT = FALSE;
398 hasLongNames = FALSE;
399 }
[787]400 pBool = dcd ? &dcd->detailsladate : &detailsladate;
401 AdjustCnrColVis(hwndCnr,
402 GetPString(IDS_LADATE),
403 *pBool ? hasAccessDT : FALSE,
404 FALSE);
405 pBool = dcd ? &dcd->detailslatime : &detailslatime;
406 AdjustCnrColVis(hwndCnr,
407 GetPString(IDS_LATIME),
408 *pBool ? hasAccessDT : FALSE,
409 FALSE);
410 pBool = dcd ? &dcd->detailscrdate : &detailscrdate;
411 AdjustCnrColVis(hwndCnr,
412 GetPString(IDS_CRDATE),
413 *pBool ? hasCreateDT : FALSE,
414 FALSE);
415 pBool = dcd ? &dcd->detailscrtime : &detailscrtime;
416 AdjustCnrColVis(hwndCnr,
417 GetPString(IDS_CRTIME),
418 *pBool ? hasCreateDT : FALSE,
419 FALSE);
420 pBool = dcd ? &dcd->detailslongname : &detailslongname;
421 AdjustCnrColVis(hwndCnr,
422 GetPString(IDS_LNAME),
423 *pBool ? hasLongNames : FALSE,
424 FALSE);
[397]425 WinSendMsg(hwndCnr, CM_INVALIDATEDETAILFIELDINFO, MPVOID, MPVOID);
[2]426}
427
[231]428VOID AdjustCnrColsForPref(HWND hwndCnr, CHAR * directory, DIRCNRDATA * dcd,
429 BOOL compare)
430{
[397]431 BOOL *bool;
[2]432
[751]433 bool = dcd ? &dcd->detailssubject : &detailssubject;
434 AdjustCnrColVis(hwndCnr,
435 compare ? GetPString(IDS_STATUS) : GetPString(IDS_SUBJ),
436 *bool,
437 FALSE);
438
439 bool = dcd ? &dcd->detailsattr : &detailsattr;
[397]440 AdjustCnrColVis(hwndCnr, GetPString(IDS_ATTR), *bool, FALSE);
[751]441 bool = dcd ? &dcd->detailsicon : &detailsicon;
[397]442 AdjustCnrColVis(hwndCnr, GetPString(IDS_ICON), *bool, FALSE);
[751]443 bool = dcd ? &dcd->detailslwdate : &detailslwdate;
[397]444 AdjustCnrColVis(hwndCnr, GetPString(IDS_LWDATE), *bool, FALSE);
[751]445 bool = dcd ? &dcd->detailslwtime : &detailslwtime;
[397]446 AdjustCnrColVis(hwndCnr, GetPString(IDS_LWTIME), *bool, FALSE);
[751]447 bool = dcd ? &dcd->detailsea : &detailsea;
[397]448 AdjustCnrColVis(hwndCnr, GetPString(IDS_EA), *bool, FALSE);
[751]449 bool = dcd ? &dcd->detailssize : &detailssize;
[397]450 AdjustCnrColVis(hwndCnr, GetPString(IDS_SIZE), *bool, FALSE);
[751]451
[397]452 if (!directory) {
[751]453 bool = dcd ? &dcd->detailsladate : &detailsladate;
[397]454 AdjustCnrColVis(hwndCnr, GetPString(IDS_LADATE), *bool, FALSE);
[751]455 bool = dcd ? &dcd->detailslatime : &detailslatime;
[397]456 AdjustCnrColVis(hwndCnr, GetPString(IDS_LATIME), *bool, FALSE);
[751]457 bool = dcd ? &dcd->detailscrdate : &detailscrdate;
[397]458 AdjustCnrColVis(hwndCnr, GetPString(IDS_CRDATE), *bool, FALSE);
[751]459 bool = dcd ? &dcd->detailscrtime : &detailscrtime;
[397]460 AdjustCnrColVis(hwndCnr, GetPString(IDS_CRTIME), *bool, FALSE);
[751]461 bool = dcd ? &dcd->detailslongname : &detailslongname;
[397]462 AdjustCnrColVis(hwndCnr, GetPString(IDS_LNAME), *bool, FALSE);
463 WinSendMsg(hwndCnr, CM_INVALIDATEDETAILFIELDINFO, MPVOID, MPVOID);
464 }
465 else
466 AdjustCnrColsForFSType(hwndCnr, directory, dcd);
[2]467}
468
[751]469BOOL SetCnrCols(HWND hwndCnr, BOOL isCompCnr)
[231]470{
[397]471 BOOL fSuccess = TRUE;
472 PFIELDINFO pfi, pfiLastLeftCol, pfiIconCol;
[2]473
[397]474 // Allocate storage for container column data
[2]475
[397]476 pfi = WinSendMsg(hwndCnr, CM_ALLOCDETAILFIELDINFO,
477 MPFROMLONG(CONTAINER_COLUMNS), NULL);
[2]478
[751]479 if (!pfi) {
480 Win_Error(hwndCnr, HWND_DESKTOP, pszSrcFile, __LINE__, "CM_ALLOCDETAILFIELDINFO");
481 fSuccess = FALSE;
482 }
483 else {
[2]484
[397]485 PFIELDINFO pfiFirst;
486 FIELDINFOINSERT fii;
[2]487
[397]488 // Store original value of pfi so we won't lose it when it changes.
489 // This will be needed on the CM_INSERTDETAILFIELDINFO message.
[2]490
[397]491 pfiFirst = pfi;
[2]492
[397]493 // Fill in column information for the icon column
[2]494
[397]495 pfi->flData = CFA_BITMAPORICON | CFA_CENTER | CFA_FIREADONLY;
496 pfi->flTitle = CFA_CENTER | CFA_FITITLEREADONLY;
497 pfi->pTitleData = GetPString(IDS_ICON);
498 pfi->offStruct = FIELDOFFSET(MINIRECORDCORE, hptrIcon);
[2]499
[397]500 pfiIconCol = pfi;
[2]501
[397]502 // Fill in column information for the file name. Note that we are
[737]503 // using the pszDisplayName variable rather than pszFileName. We do this
504 // because the container does not always display the full path file name.
[2]505
[397]506 pfi = pfi->pNextFieldInfo;
[856]507
[397]508 pfi->flData = CFA_STRING | CFA_LEFT | CFA_SEPARATOR;
[792]509 pfi->flTitle = CFA_LEFT;
[397]510 pfi->pTitleData = GetPString(IDS_FILENAME);
[737]511 pfi->offStruct = FIELDOFFSET(CNRITEM, pszDisplayName);
[2]512
[397]513 // Fill in column information for the longname.
[2]514
[397]515 pfi = pfi->pNextFieldInfo;
516 pfi->flData = CFA_STRING | CFA_LEFT;
[792]517 pfi->flTitle = CFA_LEFT | CFA_FITITLEREADONLY;
[397]518 pfi->pTitleData = GetPString(IDS_LNAME);
[762]519 pfi->offStruct = FIELDOFFSET(CNRITEM, pszLongName);
[2]520
[397]521 // Fill in column info for subjects
[2]522
[796]523 if (fSubjectInLeftPane) {
524 pfi = pfi->pNextFieldInfo;
525 pfi->flData = CFA_STRING | CFA_LEFT | CFA_SEPARATOR;
526 if (isCompCnr)
[827]527 pfi->flData |= CFA_FIREADONLY;
[796]528 pfi->flTitle = CFA_LEFT | CFA_FITITLEREADONLY;
529 pfi->pTitleData = isCompCnr ? GetPString(IDS_STATUS) :
[787]530 GetPString(IDS_SUBJ);
[796]531 pfi->offStruct = FIELDOFFSET(CNRITEM, pszSubject);
532 pfi->cxWidth = SubjectDisplayWidth;
[2]533
[796]534 // Store the current pfi value as that will be used to indicate the
535 // last column in the lefthand container window (we have a splitbar)
[792]536
[796]537 pfiLastLeftCol = pfi;
538 }
539 else {
540 // Store the current pfi value as that will be used to indicate the
541 // last column in the lefthand container window (we have a splitbar)
[792]542
[796]543 pfiLastLeftCol = pfi;
544 pfi = pfi->pNextFieldInfo;
545 pfi->flData = CFA_STRING | CFA_LEFT | CFA_SEPARATOR;
546 if (isCompCnr)
[827]547 pfi->flData |= CFA_FIREADONLY;
[796]548 pfi->flTitle = CFA_LEFT | CFA_FITITLEREADONLY;
549 pfi->pTitleData = isCompCnr ? GetPString(IDS_STATUS) :
550 GetPString(IDS_SUBJ);
551 pfi->offStruct = FIELDOFFSET(CNRITEM, pszSubject);
552 pfi->cxWidth = SubjectDisplayWidth;
553 }
554
[397]555 // Fill in column information for the file size
[2]556
557
[859]558 pfi = pfi->pNextFieldInfo;
559 pfi->flData = CFA_STRING | CFA_RIGHT | CFA_SEPARATOR | CFA_FIREADONLY;
560 pfi->flTitle = CFA_CENTER;
561 pfi->pTitleData = GetPString(IDS_SIZE);
562 pfi->offStruct = FIELDOFFSET(CNRITEM, pszFmtFileSize);
563
564
[397]565 // Fill in the column information for the file's ea size
[2]566
[397]567 pfi = pfi->pNextFieldInfo;
568 pfi->flData = CFA_ULONG | CFA_RIGHT | CFA_SEPARATOR | CFA_FIREADONLY;
569 pfi->flTitle = CFA_CENTER;
570 pfi->pTitleData = GetPString(IDS_EA);
571 pfi->offStruct = FIELDOFFSET(CNRITEM, easize);
[2]572
[397]573 // Fill in the column information for the file attribute
[2]574
[397]575 pfi = pfi->pNextFieldInfo;
576 pfi->flData = CFA_STRING | CFA_CENTER | CFA_SEPARATOR | CFA_FIREADONLY;
577 pfi->flTitle = CFA_CENTER | CFA_FITITLEREADONLY;
578 pfi->pTitleData = GetPString(IDS_ATTR);
579 pfi->offStruct = FIELDOFFSET(CNRITEM, pszDispAttr);
[2]580
[397]581 // Fill in column information for last write file date
[2]582
[397]583 pfi = pfi->pNextFieldInfo;
584 pfi->flData = CFA_DATE | CFA_RIGHT | CFA_FIREADONLY;
585 pfi->flTitle = CFA_CENTER;
586 pfi->pTitleData = GetPString(IDS_LWDATE);
587 pfi->offStruct = FIELDOFFSET(CNRITEM, date);
[2]588
[397]589 // Fill in column information for the last write file time
[2]590
[397]591 pfi = pfi->pNextFieldInfo;
592 pfi->flData = CFA_TIME | CFA_RIGHT | CFA_SEPARATOR | CFA_FIREADONLY;
593 pfi->flTitle = CFA_CENTER;
594 pfi->pTitleData = GetPString(IDS_LWTIME);
595 pfi->offStruct = FIELDOFFSET(CNRITEM, time);
[2]596
[397]597 // Fill in column information for last access file date
[2]598
[397]599 pfi = pfi->pNextFieldInfo;
600 pfi->flData = CFA_DATE | CFA_RIGHT | CFA_FIREADONLY;
601 pfi->flTitle = CFA_CENTER;
602 pfi->pTitleData = GetPString(IDS_LADATE);
603 pfi->offStruct = FIELDOFFSET(CNRITEM, ladate);
[2]604
[397]605 // Fill in column information for the last access file time
[2]606
[397]607 pfi = pfi->pNextFieldInfo;
608 pfi->flData = CFA_TIME | CFA_RIGHT | CFA_SEPARATOR | CFA_FIREADONLY;
609 pfi->flTitle = CFA_CENTER;
610 pfi->pTitleData = GetPString(IDS_LATIME);
611 pfi->offStruct = FIELDOFFSET(CNRITEM, latime);
[2]612
[397]613 // Fill in column information for create file date
[2]614
[397]615 pfi = pfi->pNextFieldInfo;
616 pfi->flData = CFA_DATE | CFA_RIGHT | CFA_FIREADONLY;
617 pfi->flTitle = CFA_CENTER;
618 pfi->pTitleData = GetPString(IDS_CRDATE);
619 pfi->offStruct = FIELDOFFSET(CNRITEM, crdate);
[2]620
[397]621 // Fill in column information for the create file time
[2]622
[397]623 pfi = pfi->pNextFieldInfo;
624 pfi->flData = CFA_TIME | CFA_RIGHT | CFA_FIREADONLY;
625 pfi->flTitle = CFA_CENTER;
626 pfi->pTitleData = GetPString(IDS_CRTIME);
627 pfi->offStruct = FIELDOFFSET(CNRITEM, crtime);
[2]628
[397]629 // Use the CM_INSERTDETAILFIELDINFO message to tell the container
630 // all the column information it needs to function properly. Place
631 // this column info first in the column list and update the display
632 // after they are inserted (fInvalidateFieldInfo = TRUE)
[2]633
[397]634 (void)memset(&fii, 0, sizeof(FIELDINFOINSERT));
[2]635
[397]636 fii.cb = sizeof(FIELDINFOINSERT);
637 fii.pFieldInfoOrder = (PFIELDINFO) CMA_FIRST;
638 fii.cFieldInfoInsert = (SHORT) CONTAINER_COLUMNS;
639 fii.fInvalidateFieldInfo = TRUE;
[2]640
[397]641 if (!WinSendMsg(hwndCnr, CM_INSERTDETAILFIELDINFO, MPFROMP(pfiFirst),
[751]642 MPFROMP(&fii))) {
643 Win_Error(hwndCnr, HWND_DESKTOP, pszSrcFile, __LINE__, "CM_INSERTDETAILFIELDINFO");
[397]644 fSuccess = FALSE;
[751]645 }
[397]646 }
[2]647
[397]648 if (fSuccess) {
[2]649
[397]650 CNRINFO cnri;
651 ULONG size;
[2]652
[397]653 // Tell the container about the splitbar and where it goes
[2]654
[397]655 cnri.cb = sizeof(CNRINFO);
656 cnri.pFieldInfoLast = pfiLastLeftCol;
657 cnri.xVertSplitbar = DIR_SPLITBAR_OFFSET - 32;
658 cnri.pFieldInfoObject = pfiIconCol;
659 size = sizeof(LONG);
660 PrfQueryProfileData(fmprof,
661 appname, "CnrSplitBar", &cnri.xVertSplitbar, &size);
662 if (cnri.xVertSplitbar <= 0)
663 cnri.xVertSplitbar = DIR_SPLITBAR_OFFSET - 32;
664 if (!WinSendMsg(hwndCnr, CM_SETCNRINFO, MPFROMP(&cnri),
665 MPFROMLONG(CMA_PFIELDINFOLAST | CMA_PFIELDINFOOBJECT |
[751]666 CMA_XVERTSPLITBAR))) {
667 Win_Error(hwndCnr, HWND_DESKTOP, pszSrcFile, __LINE__, "CM_SETCNRINFO");
[397]668 fSuccess = FALSE;
[751]669 }
[397]670 }
[2]671
[397]672 return fSuccess;
[2]673}
674
[231]675MRESULT CnrDirectEdit(HWND hwnd, ULONG msg, MPARAM mp1, MPARAM mp2)
[161]676{
[397]677 switch (SHORT2FROMMP(mp1)) {
678 case CN_BEGINEDIT:
679 if (mp2) {
680 PFIELDINFO pfi = ((PCNREDITDATA) mp2)->pFieldInfo;
681 PCNRITEM pci = (PCNRITEM) ((PCNREDITDATA) mp2)->pRecord;
[2]682
[397]683 if (pci &&
[551]684 (INT) pci != -1 &&
[730]685 !IsRoot(pci->pszFileName) &&
[397]686 !(pci->flags & RECFLAGS_ENV) && !(pci->flags & RECFLAGS_UNDERENV)) {
[756]687 if (!pfi || pfi->offStruct == FIELDOFFSET(CNRITEM, pszDisplayName)) {
[730]688 PostMsg(hwnd, UM_FIXEDITNAME, MPFROMP(pci->pszFileName), MPVOID);
[231]689 }
[397]690 else if (pfi->offStruct == FIELDOFFSET(CNRITEM, pszSubject))
691 PostMsg(hwnd, UM_FIXCNRMLE, MPFROMLONG(40), MPVOID);
692 else
693 PostMsg(hwnd, UM_FIXCNRMLE, MPFROMLONG(CCHMAXPATH), MPVOID);
694 }
695 else
696 PostMsg(hwnd, CM_CLOSEEDIT, MPVOID, MPVOID);
697 }
698 break;
[2]699
[397]700 case CN_REALLOCPSZ:
701 if (mp2) {
702 PFIELDINFO pfi = ((PCNREDITDATA) mp2)->pFieldInfo;
703 PCNRITEM pci = (PCNRITEM) ((PCNREDITDATA) mp2)->pRecord;
[689]704 CHAR szData[CCHMAXPATH], testname[CCHMAXPATH];
[397]705 HWND hwndMLE = WinWindowFromID(hwnd, CID_MLE);
[2]706
[730]707 if (pci && (INT) pci != -1 && !IsRoot(pci->pszFileName)) {
[397]708 if (pfi && pfi->offStruct == FIELDOFFSET(CNRITEM, pszSubject)) {
[2]709
[397]710 APIRET rc;
711 EAOP2 eaop;
712 PFEA2LIST pfealist = NULL;
[771]713 CHAR szSubject[1048];
[397]714 ULONG ealen;
715 USHORT len;
[751]716 CHAR *eaval;
717 LONG retlen;
[2]718
[747]719 retlen = WinQueryWindowText(hwndMLE, sizeof(szSubject), szSubject);
720 szSubject[retlen + 1] = 0;
[756]721 //chop_at_crnl(szSubject);
[787]722 bstrip(szSubject);
723 pci->pszSubject = xrealloc(pci->pszSubject, retlen + 1, pszSrcFile, __LINE__);
[397]724 WinSetWindowText(hwndMLE, szSubject);
725 len = strlen(szSubject);
726 if (len)
727 ealen = sizeof(FEA2LIST) + 9 + len + 4;
728 else
729 ealen = sizeof(FEALIST) + 9;
[747]730 rc = DosAllocMem((PPVOID) & pfealist, ealen + 64,
[397]731 OBJ_TILE | PAG_COMMIT | PAG_READ | PAG_WRITE);
732 if (rc)
733 Dos_Error(MB_CANCEL, rc, HWND_DESKTOP, pszSrcFile,
734 __LINE__, GetPString(IDS_OUTOFMEMORY));
735 else {
736 memset(pfealist, 0, ealen + 1);
737 pfealist->cbList = ealen;
[747]738 pfealist->list[0].oNextEntryOffset = 0;
[397]739 pfealist->list[0].fEA = 0;
740 pfealist->list[0].cbName = 8;
741 strcpy(pfealist->list[0].szName, SUBJECT);
742 if (len) {
743 eaval = pfealist->list[0].szName + 9;
744 *(USHORT *) eaval = (USHORT) EAT_ASCII;
745 eaval += sizeof(USHORT);
746 *(USHORT *) eaval = (USHORT) len;
747 eaval += sizeof(USHORT);
748 memcpy(eaval, szSubject, len);
749 pfealist->list[0].cbValue = len + (sizeof(USHORT) * 2);
750 }
751 else
752 pfealist->list[0].cbValue = 0;
753 eaop.fpGEA2List = (PGEA2LIST) 0;
754 eaop.fpFEA2List = pfealist;
755 eaop.oError = 0L;
[827]756 rc = xDosSetPathInfo(pci->pszFileName, FIL_QUERYEASIZE,
757 &eaop, sizeof(eaop), DSPI_WRTTHRU);
[397]758 DosFreeMem(pfealist);
759 if (rc)
760 return FALSE;
761 }
762 return (MRESULT) TRUE;
763 }
[762]764 else if (pfi && pfi->offStruct == FIELDOFFSET(CNRITEM, pszLongName)) {
[2]765
[397]766 CHAR longname[CCHMAXPATHCOMP];
[751]767 LONG retlen;
[2]768
[397]769 *longname = 0;
[747]770 retlen = WinQueryWindowText(hwndMLE, sizeof(longname), longname);
771 longname[retlen + 1] = 0;
[787]772 //chop_at_crnl(longname);
773 pci->pszLongName = xrealloc(pci->pszLongName, retlen + 1, pszSrcFile, __LINE__);
[751]774 WinSetWindowText(hwndMLE, longname);
[756]775 pci->pszFileName = xrealloc(pci->pszFileName, retlen + 1, pszSrcFile, __LINE__);
[730]776 return (MRESULT) WriteLongName(pci->pszFileName, longname);
[397]777 }
[787]778 else {
779 WinQueryWindowText(hwndMLE, sizeof(szData), szData);
[397]780 if (strchr(szData, '?') ||
[730]781 strchr(szData, '*') || IsRoot(pci->pszFileName))
[397]782 return (MRESULT) FALSE;
[751]783 /* If the text changed, rename the file system object. */
[397]784 chop_at_crnl(szData);
[751]785 bstrip(szData);
[397]786 if (!IsFullName(szData))
787 Runtime_Error(pszSrcFile, __LINE__, "bad name");
788 else {
789 if (DosQueryPathInfo(szData,
790 FIL_QUERYFULLNAME,
791 testname, sizeof(testname)))
[751]792 return FALSE;
[730]793 if (DosQueryPathInfo(pci->pszFileName,
[787]794 FIL_QUERYFULLNAME, szData, sizeof(szData))){
795 pci->pszFileName = xrealloc(pci->pszFileName, sizeof(szData), pszSrcFile, __LINE__);
796 strcpy(szData, pci->pszFileName);
797 }
[397]798 WinSetWindowText(hwndMLE, szData);
799 if (strcmp(szData, testname)) {
800 if (stricmp(szData, testname) && IsFile(testname) != -1) {
801 DosBeep(50, 100); /* exists; disallow */
802 return (MRESULT) FALSE;
803 }
804 if (docopyf(MOVE, szData, "%s", testname))
805 Runtime_Error(pszSrcFile, __LINE__, "docopyf");
806 else {
807 CHAR *filename;
[2]808
[397]809 filename = xstrdup(testname, pszSrcFile, __LINE__);
810 if (filename) {
811 if (!PostMsg(hwnd,
812 UM_FIXEDITNAME, MPVOID, MPFROMP(filename)))
813 free(filename);
[231]814 }
[730]815 if (stricmp(testname, pci->pszFileName)) {
[397]816 PostMsg(hwnd, UM_FIXEDITNAME, MPFROMLONG(-1), MPFROMP(pci));
[730]817 filename = xstrdup(pci->pszFileName, pszSrcFile, __LINE__);
[397]818 if (filename) {
819 if (!PostMsg(hwnd,
820 UM_FIXEDITNAME, MPVOID, MPFROMP(filename)))
821 free(filename);
822 }
[231]823 }
[397]824 }
[231]825 }
[397]826 }
[231]827 }
[397]828 }
829 }
830 return FALSE;
[2]831
[397]832 case CN_ENDEDIT:
833 if (mp2) {
834 PFIELDINFO pfi = ((PCNREDITDATA) mp2)->pFieldInfo;
835 PCNRITEM pci = (PCNRITEM) ((PCNREDITDATA) mp2)->pRecord;
[2]836
[730]837 if (pci && (INT) pci != -1 && !IsRoot(pci->pszFileName)) {
[397]838 WinSendMsg(hwnd,
839 CM_INVALIDATERECORD,
840 MPFROMP(&pci),
841 MPFROM2SHORT(1, CMA_ERASE | CMA_TEXTCHANGED));
[756]842 if (pfi && pfi->offStruct == FIELDOFFSET(CNRITEM, pszDisplayName))
[397]843 PostMsg(hwnd, UM_SORTRECORD, MPVOID, MPVOID);
844 }
845 else {
846 USHORT cmd = 0;
[2]847
[756]848 if (!pfi || pfi->offStruct == FIELDOFFSET(CNRITEM, pszDisplayName))
[397]849 cmd = IDM_SORTSMARTNAME;
850 else if (pfi->offStruct == FIELDOFFSET(CNRITEM, cbFile))
851 cmd = IDM_SORTSIZE;
852 else if (pfi->offStruct == FIELDOFFSET(CNRITEM, easize))
853 cmd = IDM_SORTEASIZE;
854 else if (pfi->offStruct == FIELDOFFSET(CNRITEM, date))
855 cmd = IDM_SORTLWDATE;
856 else if (pfi->offStruct == FIELDOFFSET(CNRITEM, time))
857 cmd = IDM_SORTLWDATE;
858 else if (pfi->offStruct == FIELDOFFSET(CNRITEM, ladate))
859 cmd = IDM_SORTLADATE;
860 else if (pfi->offStruct == FIELDOFFSET(CNRITEM, latime))
861 cmd = IDM_SORTLADATE;
862 else if (pfi->offStruct == FIELDOFFSET(CNRITEM, crdate))
863 cmd = IDM_SORTCRDATE;
864 else if (pfi->offStruct == FIELDOFFSET(CNRITEM, crtime))
865 cmd = IDM_SORTCRDATE;
866 if (cmd)
867 PostMsg(hwnd, WM_COMMAND, MPFROM2SHORT(cmd, 0), MPVOID);
868 }
[231]869 }
[397]870 break;
871 }
872 return (MRESULT) - 1;
[2]873}
874
[231]875BOOL SetMenuCheck(HWND hwndMenu, USHORT id, BOOL * bool, BOOL toggle,
876 CHAR * savename)
877{
[397]878 if (toggle) {
[787]879 *bool = *bool ? FALSE : TRUE;
[397]880 if (savename && *savename)
881 PrfWriteProfileData(fmprof, appname, savename, bool, sizeof(BOOL));
882 }
883 WinSendMsg(hwndMenu, MM_SETITEMATTR,
884 MPFROM2SHORT(id, 1),
[468]885 MPFROM2SHORT(MIA_CHECKED, (*bool ? MIA_CHECKED : 0)));
[397]886 return *bool;
[2]887}
888
[468]889//== disable_menuitem() disable or enable_menuitem ==
890
891VOID disable_menuitem(HWND hwndMenu, USHORT id, BOOL disable)
[231]892{
[397]893 WinSendMsg(hwndMenu, MM_SETITEMATTR,
894 MPFROM2SHORT(id, TRUE),
[468]895 MPFROM2SHORT(MIA_DISABLED, (disable ? MIA_DISABLED : 0)));
[2]896}
897
[451]898//== ViewHelp() invoke view.exe, return TRUE if OK ==
899
[231]900BOOL ViewHelp(CHAR * filename)
901{
[397]902 CHAR s[CCHMAXPATH + 81];
[891]903 CHAR szQuotedFileName[CCHMAXPATH];
[397]904 FILE *fp;
905 INT ret = -1;
[2]906
[397]907 fp = _fsopen(filename, "rb", SH_DENYNO);
908 if (fp) {
909 *s = 0;
910 fread(s, 1, 3, fp);
911 if (*s != 'H' || s[1] != 'S' || s[2] != 'P') {
912 fclose(fp);
913 return FALSE;
[2]914 }
[397]915 fclose(fp);
[888]916 ret = runemf2(SEPARATE | WINDOWED, HWND_DESKTOP, pszSrcFile, __LINE__,
917 NULL, NULL,
[891]918 "VIEW.EXE \"%s\"",
919 BldQuotedFileName(szQuotedFileName, filename));
[397]920 }
[2]921
[397]922 return (ret != -1);
[2]923}
924
[451]925//== ExecFile() run file, return 1 if OK 0 if skipped -1 if can't run ==
926
[231]927INT ExecFile(HWND hwnd, CHAR * filename)
928{
[397]929 EXECARGS ex;
930 CHAR cl[1001], path[CCHMAXPATH], *p;
931 APIRET ret;
932 static INT lastflags = 0;
[2]933
[397]934 strcpy(path, filename);
935 p = strrchr(path, '\\');
936 if (!p)
937 p = strrchr(path, ':');
938 if (p) {
939 if (*p == ':') {
940 p++;
941 *p = '\\';
942 p++;
[2]943 }
[397]944 *p = 0;
945 }
946 else
947 *path = 0;
948 *cl = 0;
[773]949 BldQuotedFileName(cl, filename);
[397]950 memset(&ex, 0, sizeof(ex));
951 ex.flags = lastflags;
952 ex.commandline = cl;
953 *ex.path = 0;
954 *ex.environment = 0;
955 ret = WinDlgBox(HWND_DESKTOP, hwnd, CmdLineDlgProc, FM3ModHandle,
956 EXEC_FRAME, &ex);
957 if (ret == 1) {
958 lastflags = ex.flags;
[888]959 return runemf2(ex.flags, hwnd, pszSrcFile, __LINE__, path,
[787]960 *ex.environment ? ex.environment : NULL,
961 "%s", cl) != -1;
[397]962 }
963 else if (ret != 0)
964 return -1;
965 return 0;
[2]966}
967
[231]968VOID SetDetailsSwitches(HWND hwnd, DIRCNRDATA * dcd)
969{
[397]970 WinCheckMenuItem(hwnd, IDM_SHOWLNAMES,
[751]971 dcd ? dcd->detailslongname : detailslongname);
[397]972 WinCheckMenuItem(hwnd, IDM_SHOWSUBJECT,
[751]973 dcd ? dcd->detailssubject : detailssubject);
974 WinCheckMenuItem(hwnd, IDM_SHOWEAS, dcd ? dcd->detailsea : detailsea);
[397]975 WinCheckMenuItem(hwnd, IDM_SHOWSIZE,
[751]976 dcd ? dcd->detailssize : detailssize);
[397]977 WinCheckMenuItem(hwnd, IDM_SHOWICON,
[751]978 dcd ? dcd->detailsicon : detailsicon);
[397]979 WinCheckMenuItem(hwnd, IDM_SHOWLWDATE,
[751]980 dcd ? dcd->detailslwdate : detailslwdate);
[397]981 WinCheckMenuItem(hwnd, IDM_SHOWLWTIME,
[751]982 dcd ? dcd->detailslwtime : detailslwtime);
[397]983 WinCheckMenuItem(hwnd, IDM_SHOWLADATE,
[751]984 dcd ? dcd->detailsladate : detailsladate);
[397]985 WinCheckMenuItem(hwnd, IDM_SHOWLATIME,
[751]986 dcd ? dcd->detailslatime : detailslatime);
[397]987 WinCheckMenuItem(hwnd, IDM_SHOWCRDATE,
[751]988 dcd ? dcd->detailscrdate : detailscrdate);
[397]989 WinCheckMenuItem(hwnd, IDM_SHOWCRTIME,
[751]990 dcd ? dcd->detailscrtime : detailscrtime);
[397]991 WinCheckMenuItem(hwnd, IDM_SHOWATTR,
[751]992 dcd ? dcd->detailsattr : detailsattr);
[2]993}
994
[231]995VOID AdjustDetailsSwitches(HWND hwnd, HWND hwndMenu, USHORT cmd,
996 CHAR * directory, CHAR * keyroot,
997 DIRCNRDATA * dcd, BOOL compare)
998{
[397]999 CHAR s[CCHMAXPATH], *eos = s;
1000 BOOL *bool = NULL;
[2]1001
[397]1002 *s = 0;
1003 if (keyroot) {
1004 strcpy(s, keyroot);
1005 strcat(s, ".");
1006 eos = &s[strlen(s)];
1007 }
1008 switch (cmd) {
1009 case IDM_SHOWLNAMES:
[751]1010 bool = dcd ? &dcd->detailslongname : &detailslongname;
[397]1011 strcpy(eos, "DetailsLongname");
1012 break;
1013 case IDM_SHOWSUBJECT:
[751]1014 bool = dcd ? &dcd->detailssubject : &detailssubject;
[397]1015 strcpy(eos, "DetailsSubject");
1016 break;
1017 case IDM_SHOWEAS:
[751]1018 bool = dcd ? &dcd->detailsea : &detailsea;
[397]1019 strcpy(eos, "DetailsEA");
1020 break;
1021 case IDM_SHOWSIZE:
[751]1022 bool = dcd ? &dcd->detailssize : &detailssize;
[397]1023 strcpy(eos, "DetailsSize");
1024 break;
1025 case IDM_SHOWICON:
[751]1026 bool = dcd ? &dcd->detailsicon : &detailsicon;
[397]1027 strcpy(eos, "DetailsIcon");
1028 break;
1029 case IDM_SHOWLWDATE:
[751]1030 bool = dcd ? &dcd->detailslwdate : &detailslwdate;
[397]1031 strcpy(eos, "DetailsLWDate");
1032 break;
1033 case IDM_SHOWLWTIME:
[751]1034 bool = dcd ? &dcd->detailslwtime : &detailslwtime;
[397]1035 strcpy(eos, "DetailsLWTime");
1036 break;
1037 case IDM_SHOWLADATE:
[751]1038 bool = dcd ? &dcd->detailsladate : &detailsladate;
[397]1039 strcpy(eos, "DetailsLADate");
1040 break;
1041 case IDM_SHOWLATIME:
[751]1042 bool = dcd ? &dcd->detailslatime : &detailslatime;
[397]1043 strcpy(eos, "DetailsLATime");
1044 break;
1045 case IDM_SHOWCRDATE:
[751]1046 bool = dcd ? &dcd->detailscrdate : &detailscrdate;
[397]1047 strcpy(eos, "DetailsCRDate");
1048 break;
1049 case IDM_SHOWCRTIME:
[751]1050 bool = dcd ? &dcd->detailscrtime : &detailscrtime;
[397]1051 strcpy(eos, "DetailsCRTime");
1052 break;
1053 case IDM_SHOWATTR:
[751]1054 bool = dcd ? &dcd->detailsattr : &detailsattr;
[397]1055 strcpy(eos, "DetailsAttr");
1056 break;
1057 default:
[231]1058 if (hwndMenu)
[397]1059 SetDetailsSwitches(hwndMenu, dcd);
1060 return;
1061 }
1062 if (bool)
[787]1063 *bool = *bool ? FALSE : TRUE;
[397]1064 if (*s && bool)
1065 PrfWriteProfileData(fmprof, appname, s, bool, sizeof(BOOL));
1066 if (hwnd)
1067 AdjustCnrColsForPref(hwnd, directory, dcd, compare);
1068 if (hwndMenu)
1069 SetDetailsSwitches(hwndMenu, dcd);
[2]1070}
1071
[231]1072VOID SetConditionalCascade(HWND hwndMenu, USHORT id, USHORT def)
1073{
[397]1074 MENUITEM mi;
[2]1075
[397]1076 mi.iPosition = MIT_END;
1077 mi.hItem = 0L;
1078 mi.hwndSubMenu = (HWND) 0;
1079 mi.afAttribute = 0;
1080 mi.afStyle = MIS_TEXT;
1081 if (WinSendMsg
1082 (hwndMenu, MM_QUERYITEM, MPFROM2SHORT(id, TRUE), MPFROMP(&mi))) {
1083 WinSetWindowBits(mi.hwndSubMenu, QWL_STYLE, MS_CONDITIONALCASCADE,
1084 MS_CONDITIONALCASCADE);
1085 WinSendMsg(mi.hwndSubMenu, MM_SETDEFAULTITEMID, MPFROMSHORT(def), MPVOID);
1086 WinCheckMenuItem(mi.hwndSubMenu, def, TRUE);
1087 }
[2]1088}
1089
[231]1090VOID SetSortChecks(HWND hwndMenu, INT sortflags)
1091{
[397]1092 WinCheckMenuItem(hwndMenu, IDM_SORTNONE, FALSE);
1093 WinCheckMenuItem(hwndMenu, IDM_SORTFIRST, FALSE);
1094 WinCheckMenuItem(hwndMenu, IDM_SORTLAST, FALSE);
1095 WinCheckMenuItem(hwndMenu, IDM_SORTSIZE, FALSE);
1096 WinCheckMenuItem(hwndMenu, IDM_SORTEASIZE, FALSE);
1097 WinCheckMenuItem(hwndMenu, IDM_SORTLWDATE, FALSE);
1098 WinCheckMenuItem(hwndMenu, IDM_SORTLADATE, FALSE);
1099 WinCheckMenuItem(hwndMenu, IDM_SORTCRDATE, FALSE);
1100 WinCheckMenuItem(hwndMenu, IDM_SORTFILENAME, FALSE);
1101 WinCheckMenuItem(hwndMenu, IDM_SORTNAME, FALSE);
1102 WinCheckMenuItem(hwndMenu, IDM_SORTSUBJECT, FALSE);
1103 WinCheckMenuItem(hwndMenu, IDM_SORTDIRSFIRST, FALSE);
1104 WinCheckMenuItem(hwndMenu, IDM_SORTDIRSLAST, FALSE);
1105 WinCheckMenuItem(hwndMenu, IDM_SORTREVERSE, FALSE);
1106 if (sortflags & SORT_FIRSTEXTENSION)
1107 WinCheckMenuItem(hwndMenu, IDM_SORTFIRST, TRUE);
1108 else if (sortflags & SORT_LASTEXTENSION)
1109 WinCheckMenuItem(hwndMenu, IDM_SORTLAST, TRUE);
1110 else if (sortflags & SORT_SIZE)
1111 WinCheckMenuItem(hwndMenu, IDM_SORTSIZE, TRUE);
1112 else if (sortflags & SORT_EASIZE)
1113 WinCheckMenuItem(hwndMenu, IDM_SORTEASIZE, TRUE);
1114 else if (sortflags & SORT_LWDATE)
1115 WinCheckMenuItem(hwndMenu, IDM_SORTLWDATE, TRUE);
1116 else if (sortflags & SORT_LADATE)
1117 WinCheckMenuItem(hwndMenu, IDM_SORTLADATE, TRUE);
1118 else if (sortflags & SORT_CRDATE)
1119 WinCheckMenuItem(hwndMenu, IDM_SORTCRDATE, TRUE);
1120 else if (sortflags & SORT_FILENAME)
1121 WinCheckMenuItem(hwndMenu, IDM_SORTFILENAME, TRUE);
1122 else if (sortflags & SORT_NOSORT)
1123 WinCheckMenuItem(hwndMenu, IDM_SORTNONE, TRUE);
1124 else if (sortflags & SORT_SUBJECT)
1125 WinCheckMenuItem(hwndMenu, IDM_SORTSUBJECT, TRUE);
1126 else
1127 WinCheckMenuItem(hwndMenu, IDM_SORTNAME, TRUE);
1128 if (sortflags & SORT_DIRSFIRST)
1129 WinCheckMenuItem(hwndMenu, IDM_SORTDIRSFIRST, TRUE);
1130 else if (sortflags & SORT_DIRSLAST)
1131 WinCheckMenuItem(hwndMenu, IDM_SORTDIRSLAST, TRUE);
1132 if (sortflags & SORT_REVERSE)
1133 WinCheckMenuItem(hwndMenu, IDM_SORTREVERSE, TRUE);
[2]1134}
1135
[231]1136VOID FcloseFile(FILE * fp)
1137{
[397]1138 /* for use by apps that don't use the DLLs runtime library */
1139 fclose(fp);
[2]1140}
1141
[231]1142VOID SetupCommandMenu(HWND hwndMenu, HWND hwndCnr)
1143{
[397]1144 MENUITEM mi, mit;
1145 INT x;
1146 SHORT numitems;
1147 LINKCMDS *info;
[2]1148
[397]1149 if (!cmdloaded)
1150 load_commands();
1151 mi.iPosition = MIT_END;
1152 mi.hwndSubMenu = (HWND) 0;
1153 mi.hItem = 0L;
1154 mi.afAttribute = 0;
1155 mi.afStyle = MIS_TEXT;
1156 memset(&mit, 0, sizeof(MENUITEM));
1157 if (WinQueryWindowUShort(hwndMenu, QWS_ID) == IDM_COMMANDSMENU)
1158 mit.hwndSubMenu = hwndMenu;
1159 else
1160 WinSendMsg(hwndMenu, MM_QUERYITEM,
1161 MPFROM2SHORT(IDM_COMMANDSMENU, TRUE), MPFROMP(&mit));
1162 if (mit.hwndSubMenu) {
1163 numitems = (SHORT) WinSendMsg(mit.hwndSubMenu, MM_QUERYITEMCOUNT,
1164 MPVOID, MPVOID);
1165 WinSendMsg(mit.hwndSubMenu, MM_DELETEITEM, MPFROMSHORT(-1), MPVOID);
1166 for (x = 0; x < numitems; x++)
1167 WinSendMsg(mit.hwndSubMenu, MM_DELETEITEM,
1168 MPFROMSHORT((SHORT) (x + IDM_COMMANDSTART)), MPVOID);
1169 if (hwndCnr && cmdhead) {
1170 x = 0;
1171 info = cmdhead;
1172 while (info) {
[2]1173
[397]1174 CHAR s[CCHMAXPATH + 24];
[2]1175
[397]1176 sprintf(s,
1177 "%s%s%s",
1178 info->title,
[787]1179 x < 20 ? "\tCtrl + " : NullStr,
1180 x < 20 && x > 9 ? "Shift + " : NullStr);
[397]1181 if (x < 20)
1182 sprintf(&s[strlen(s)], "%d",
[787]1183 ((x % 10) + 1) == 10 ? 0 : (x % 10) + 1);
[397]1184 mi.id = IDM_COMMANDSTART + x;
[787]1185 mi.afAttribute = (info->flags & ONCE ? MIA_CHECKED : 0) |
1186 (info->flags & PROMPT ? MIA_FRAMED : 0);
[397]1187 mi.afStyle = MIS_TEXT;
1188 if (!(x % 24) && x && info->next)
1189 mi.afStyle |= MIS_BREAK;
1190 WinSendMsg(mit.hwndSubMenu, MM_INSERTITEM, MPFROMP(&mi), MPFROMP(s));
1191 x++;
1192 info = info->next;
1193 }
[2]1194 }
[397]1195 }
[2]1196}
1197
[231]1198VOID LoadDetailsSwitches(CHAR * keyroot, DIRCNRDATA * dcd)
1199{
[397]1200 ULONG size;
1201 CHAR s[CCHMAXPATH], *eos = s;
1202 BOOL *bool;
[2]1203
[397]1204 *s = 0;
1205 if (keyroot) {
1206 strcpy(s, keyroot);
1207 strcat(s, ".");
1208 eos = &s[strlen(s)];
1209 }
1210 strcpy(eos, "DetailsLongname");
1211 if (dcd)
1212 bool = &dcd->detailslongname;
1213 else
1214 bool = &detailslongname;
1215 *bool = detailslongname;
1216 size = sizeof(BOOL);
1217 PrfQueryProfileData(fmprof, appname, s, (PVOID) bool, &size);
1218 strcpy(eos, "DetailsSubject");
1219 if (dcd)
1220 bool = &dcd->detailssubject;
1221 else
1222 bool = &detailssubject;
1223 *bool = detailssubject;
1224 size = sizeof(BOOL);
1225 PrfQueryProfileData(fmprof, appname, s, (PVOID) bool, &size);
1226 strcpy(eos, "DetailsEA");
1227 if (dcd)
1228 bool = &dcd->detailsea;
1229 else
1230 bool = &detailsea;
1231 *bool = detailsea;
1232 size = sizeof(BOOL);
1233 PrfQueryProfileData(fmprof, appname, s, (PVOID) bool, &size);
1234 strcpy(eos, "DetailsSize");
1235 if (dcd)
1236 bool = &dcd->detailssize;
1237 else
1238 bool = &detailssize;
1239 *bool = detailssize;
1240 size = sizeof(BOOL);
1241 PrfQueryProfileData(fmprof, appname, s, (PVOID) bool, &size);
1242 strcpy(eos, "DetailsIcon");
1243 if (dcd)
1244 bool = &dcd->detailsicon;
1245 else
1246 bool = &detailsicon;
1247 *bool = detailsicon;
1248 size = sizeof(BOOL);
1249 PrfQueryProfileData(fmprof, appname, s, (PVOID) bool, &size);
1250 strcpy(eos, "DetailsAttr");
1251 if (dcd)
1252 bool = &dcd->detailsattr;
1253 else
1254 bool = &detailsattr;
1255 *bool = detailsattr;
1256 size = sizeof(BOOL);
1257 PrfQueryProfileData(fmprof, appname, s, (PVOID) bool, &size);
1258 strcpy(eos, "DetailsCRDate");
1259 if (dcd)
1260 bool = &dcd->detailscrdate;
1261 else
1262 bool = &detailscrdate;
1263 *bool = detailscrdate;
1264 size = sizeof(BOOL);
1265 PrfQueryProfileData(fmprof, appname, s, (PVOID) bool, &size);
1266 strcpy(eos, "DetailsCRTime");
1267 if (dcd)
1268 bool = &dcd->detailscrtime;
1269 else
1270 bool = &detailscrtime;
1271 *bool = detailscrtime;
1272 size = sizeof(BOOL);
1273 PrfQueryProfileData(fmprof, appname, s, (PVOID) bool, &size);
1274 strcpy(eos, "DetailsLWDate");
1275 if (dcd)
1276 bool = &dcd->detailslwdate;
1277 else
1278 bool = &detailslwdate;
1279 *bool = detailslwdate;
1280 size = sizeof(BOOL);
1281 PrfQueryProfileData(fmprof, appname, s, (PVOID) bool, &size);
1282 strcpy(eos, "DetailsLWTime");
1283 if (dcd)
1284 bool = &dcd->detailslwtime;
1285 else
1286 bool = &detailslwtime;
1287 *bool = detailslwtime;
1288 size = sizeof(BOOL);
1289 PrfQueryProfileData(fmprof, appname, s, (PVOID) bool, &size);
1290 strcpy(eos, "DetailsLADate");
1291 if (dcd)
1292 bool = &dcd->detailsladate;
1293 else
1294 bool = &detailsladate;
1295 *bool = detailsladate;
1296 size = sizeof(BOOL);
1297 PrfQueryProfileData(fmprof, appname, s, (PVOID) bool, &size);
1298 strcpy(eos, "DetailsLATime");
1299 if (dcd)
1300 bool = &dcd->detailslatime;
1301 else
1302 bool = &detailslatime;
1303 *bool = detailslatime;
1304 size = sizeof(BOOL);
1305 PrfQueryProfileData(fmprof, appname, s, (PVOID) bool, &size);
[2]1306}
1307
[231]1308HWND FindDirCnr(HWND hwndParent)
1309{
[397]1310 HWND found, hwndDir = (HWND) 0;
1311 HENUM henum;
[2]1312
[397]1313 henum = WinBeginEnumWindows(hwndParent);
1314 while ((found = WinGetNextWindow(henum)) != NULLHANDLE) {
1315 hwndDir = WinWindowFromID(found, FID_CLIENT);
1316 if (hwndDir) {
1317 hwndDir = WinWindowFromID(hwndDir, DIR_CNR);
1318 if (hwndDir)
1319 break;
1320 hwndDir = (HWND) 0;
[2]1321 }
[397]1322 }
1323 WinEndEnumWindows(henum);
[2]1324
[397]1325 return hwndDir;
[2]1326}
1327
[231]1328VOID HeapThread(VOID * dummy)
1329{
[397]1330 ULONG postcount;
1331 APIRET rc;
[2]1332
[397]1333 rc = DosCreateEventSem(NULL, &CompactSem, 0L, FALSE);
1334 if (rc)
1335 Dos_Error(MB_CANCEL, rc, HWND_DESKTOP, pszSrcFile, __LINE__,
1336 "DosCreateEventSem");
1337 else {
1338 priority_normal();
1339 for (;;) {
1340 if (DosWaitEventSem(CompactSem, SEM_INDEFINITE_WAIT))
1341 break;
1342 _heapmin();
1343 DosResetEventSem(CompactSem, &postcount);
[2]1344 }
[397]1345 }
[2]1346}
1347
[231]1348VOID FixSwitchList(HWND hwnd, CHAR * text)
1349{
[397]1350 HSWITCH hswitch;
1351 SWCNTRL swctl;
[2]1352
[397]1353 hswitch = WinQuerySwitchHandle(hwnd, 0);
1354 if (hswitch) {
1355 if (!WinQuerySwitchEntry(hswitch, &swctl)) {
1356 strcpy(swctl.szSwtitle, "FM/2");
1357 WinChangeSwitchEntry(hswitch, &swctl);
[2]1358 }
[397]1359 }
[2]1360}
1361
[231]1362VOID QuickPopup(HWND hwnd, DIRCNRDATA * dcd, HWND hwndMenu, USHORT id)
1363{
[397]1364 dcd->hwndLastMenu = hwndMenu;
1365 if (dcd->hwndLastMenu && !dcd->cnremphasized) {
1366 WinSendMsg(hwnd, CM_SETRECORDEMPHASIS, MPVOID,
1367 MPFROM2SHORT(TRUE, CRA_SOURCE));
1368 dcd->cnremphasized = TRUE;
1369 }
1370 if (dcd->flWindowAttr & CV_MINI)
1371 WinCheckMenuItem(dcd->hwndLastMenu, IDM_MINIICONS, TRUE);
1372 if (!WinPopupMenu(hwnd, hwnd, dcd->hwndLastMenu,
1373 8, 8, 0,
1374 PU_HCONSTRAIN | PU_VCONSTRAIN |
1375 PU_KEYBOARD | PU_MOUSEBUTTON1)) {
1376 if (dcd->cnremphasized) {
1377 WinSendMsg(hwnd, CM_SETRECORDEMPHASIS, MPVOID,
1378 MPFROM2SHORT(FALSE, CRA_SOURCE));
1379 dcd->cnremphasized = FALSE;
[2]1380 }
[397]1381 }
1382 else
1383 WinSendMsg(dcd->hwndLastMenu, MM_SELECTITEM,
1384 MPFROM2SHORT(id, TRUE), MPFROM2SHORT(0, FALSE));
[2]1385}
1386
[231]1387PMINIRECORDCORE CurrentRecord(HWND hwndCnr)
1388{
[787]1389 SHORT attrib = fSelectedAlways ? CRA_SELECTED : CRA_CURSORED;
[397]1390 PMINIRECORDCORE pmi;
[2]1391
[397]1392 for (;;) {
1393 pmi = (PMINIRECORDCORE) WinSendMsg(hwndCnr, CM_QUERYRECORDEMPHASIS,
1394 MPFROMLONG(CMA_FIRST),
1395 MPFROMSHORT(attrib));
1396 if ((!pmi || (INT) pmi == -1) && attrib == CRA_SELECTED) /* punt */
1397 attrib = CRA_CURSORED;
1398 else
1399 break;
1400 }
[787]1401 return ((INT)pmi == -1) ? NULL : pmi;
[2]1402}
1403
[231]1404BOOL PostMsg(HWND h, ULONG msg, MPARAM mp1, MPARAM mp2)
1405{
[397]1406 BOOL rc = WinPostMsg(h, msg, mp1, mp2);
[2]1407
[397]1408 if (!rc) {
[2]1409
[882]1410 // If window owned by some other process or some other thread?
1411 if (!IsFm2Window(h, 1)) {
1412 QMSG qmsg;
1413 for (;;) {
1414 DosSleep(1);
1415 rc = WinPostMsg(h, msg, mp1, mp2);
1416 if (rc)
1417 break; // OK
1418 if (!WinIsWindow((HAB) 0, h))
1419 break; // Window gone
1420 if (WinPeekMsg((HAB) 0, &qmsg, (HWND) 0, 0, 0, PM_NOREMOVE))
1421 break; // Queue has message(s)
1422 } // for
[2]1423 }
[882]1424 }
[397]1425 return rc;
[2]1426}
1427
[231]1428VOID OpenEdit(HWND hwnd)
1429{
[397]1430 CNREDITDATA ced;
1431 PCNRITEM pci;
1432 PFIELDINFO pfi;
[2]1433
[397]1434 pci = (PCNRITEM) WinSendMsg(hwnd,
1435 CM_QUERYRECORDEMPHASIS,
1436 MPFROMLONG(CMA_FIRST),
1437 MPFROMSHORT(CRA_CURSORED));
1438 if (pci && (INT) pci != -1) {
1439 memset(&ced, 0, sizeof(ced));
1440 ced.cb = sizeof(ced);
1441 ced.hwndCnr = hwnd;
1442 ced.id = WinQueryWindowUShort(hwnd, QWS_ID);
1443 ced.pRecord = (PRECORDCORE) pci;
1444 pfi = (PFIELDINFO) WinSendMsg(hwnd,
1445 CM_QUERYDETAILFIELDINFO,
1446 MPVOID, MPFROMSHORT(CMA_FIRST));
1447 if (!pfi)
1448 WinSendMsg(hwnd, CM_OPENEDIT, MPFROMP(&ced), MPVOID);
1449 else {
1450 while (pfi && (INT) pfi != -1 &&
1451 pfi->offStruct != FIELDOFFSET(CNRITEM, pszFileName))
[231]1452 pfi = (PFIELDINFO) WinSendMsg(hwnd,
1453 CM_QUERYDETAILFIELDINFO,
[397]1454 MPFROMP(pfi), MPFROMSHORT(CMA_NEXT));
1455 if (pfi && (INT) pfi != -1) {
1456 ced.pFieldInfo = pfi;
[231]1457 {
[397]1458 CNRINFO cnri;
[2]1459
[397]1460 memset(&cnri, 0, sizeof(CNRINFO));
1461 cnri.cb = sizeof(CNRINFO);
1462 WinSendMsg(hwnd,
1463 CM_QUERYCNRINFO,
1464 MPFROMP(&cnri), MPFROMLONG(sizeof(CNRINFO)));
1465 if (cnri.flWindowAttr & CV_DETAIL)
1466 ced.id = CID_LEFTDVWND;
[231]1467 }
[397]1468 WinSendMsg(hwnd, CM_OPENEDIT, MPFROMP(&ced), MPVOID);
1469 }
[2]1470 }
[397]1471 }
[2]1472}
1473
1474#ifdef NEVER
[231]1475VOID QuickView(HWND hwnd, CHAR * filename)
1476{
[397]1477 if (filename && IsFile(filename) == 1) {
1478 if (TestBinary(filename) && *binview) {
[2]1479
[397]1480 CHAR *list[2];
[2]1481
[397]1482 list[0] = filename;
1483 list[1] = NULL;
[888]1484 ExecOnList(hwnd, binview, WINDOWED | SEPARATE, NULL, list, NULL,
1485 pszSrcFile, __LINE__);
[397]1486 return;
1487 }
1488 else if (*viewer) {
[2]1489
[397]1490 CHAR *list[2];
[2]1491
[397]1492 list[0] = filename;
1493 list[1] = NULL;
[787]1494 ExecOnList(hwnd, viewer,
1495 WINDOWED | SEPARATE | (fViewChild ? CHILD : 0),
[888]1496 NULL, list, NULL, pszSrcFile, __LINE__);
[397]1497 return;
[2]1498 }
[397]1499 StartMLEEditor(HWND_DESKTOP, 5, filename, (HWND) 0);
1500 }
[2]1501}
1502
[231]1503VOID QuickEdit(HWND hwnd, CHAR * filename)
1504{
[397]1505 if (filename && IsFile(filename) == 1) {
1506 if (TestBinary(filename) && *bined) {
[2]1507
[397]1508 CHAR *list[2];
[2]1509
[397]1510 list[0] = filename;
1511 list[1] = NULL;
[888]1512 ExecOnList(hwnd, bined, WINDOWED | SEPARATE, NULL, list, NULL,
1513 pszSrcFile, __LINE__);
[397]1514 return;
1515 }
1516 else if (*editor) {
[2]1517
[397]1518 CHAR *list[2];
[2]1519
[397]1520 list[0] = filename;
1521 list[1] = NULL;
[888]1522 ExecOnList(hwnd, editor, WINDOWED | SEPARATE, NULL, list, NULL,
1523 pszSrcFile, __LINE__);
[397]1524 return;
[2]1525 }
[397]1526 StartMLEEditor(HWND_DESKTOP, 4, filename, (HWND) 0);
1527 }
[2]1528}
1529#endif
1530
[231]1531VOID PortholeInit(HWND hwndNew, MPARAM mp1, MPARAM mp2)
1532{
[397]1533 static HWND DefMenu = (HWND) 0;
1534 HWND hwndMenu = (HWND) mp2;
[2]1535
[397]1536 {
1537 ULONG style;
1538
1539 style = WinQueryWindowULong(hwndMenu, QWL_STYLE);
1540 if (!(style & MS_ACTIONBAR))
1541 return;
1542 }
1543
1544 switch (SHORT1FROMMP(mp1)) {
1545 case 0:
[231]1546 {
[397]1547 HWND hwndNow;
1548 MENUITEM mi;
1549 ULONG ulStyle;
[2]1550
[397]1551 memset(&mi, 0, sizeof(mi));
1552 mi.iPosition = MIT_END;
1553 mi.afStyle = MIS_TEXT;
1554 WinSendMsg(hwndMenu, MM_QUERYITEM,
1555 MPFROM2SHORT(IDM_FILESMENU, TRUE), MPFROMP(&mi));
1556 if (!DefMenu)
1557 DefMenu = WinLoadMenu(HWND_DESKTOP, FM3ModHandle, DEFMENU);
1558 hwndNow = mi.hwndSubMenu;
1559 mi.hwndSubMenu = hwndNew;
1560 if (!mi.hwndSubMenu)
1561 mi.hwndSubMenu = DefMenu;
1562 WinSetParent(hwndNow, WinQueryObjectWindow(HWND_DESKTOP), FALSE);
1563 WinSetOwner(hwndNow, WinQueryObjectWindow(HWND_DESKTOP));
1564 WinSetOwner(mi.hwndSubMenu, hwndMenu);
1565 WinSetParent(mi.hwndSubMenu, hwndMenu, FALSE);
1566 WinSetWindowUShort(mi.hwndSubMenu, QWS_ID, IDM_FILESMENU);
1567 mi.afStyle = MIS_SUBMENU;
1568 ulStyle = WinQueryWindowULong(mi.hwndSubMenu, QWL_STYLE);
1569 ulStyle &= -WS_SAVEBITS;
1570 ulStyle |= MS_POPUP | WS_CLIPSIBLINGS | WS_SAVEBITS;
1571 WinSetWindowULong(mi.hwndSubMenu, QWL_STYLE, ulStyle);
1572 WinSendMsg(hwndMenu, MM_SETITEM, MPFROM2SHORT(0, TRUE), MPFROMP(&mi));
[231]1573 }
[397]1574 break;
[2]1575
[397]1576 case 1:
[231]1577 {
[397]1578 HWND hwndNow;
1579 MENUITEM mi;
1580 ULONG ulStyle;
[2]1581
[397]1582 memset(&mi, 0, sizeof(mi));
1583 mi.iPosition = MIT_END;
1584 mi.afStyle = MIS_TEXT;
1585 WinSendMsg(hwndMenu, MM_QUERYITEM,
1586 MPFROM2SHORT(IDM_VIEWSMENU, TRUE), MPFROMP(&mi));
1587 if (!DefMenu)
1588 DefMenu = WinLoadMenu(HWND_DESKTOP, FM3ModHandle, DEFMENU);
1589 hwndNow = mi.hwndSubMenu;
1590 mi.hwndSubMenu = hwndNew;
1591 if (!mi.hwndSubMenu)
1592 mi.hwndSubMenu = DefMenu;
1593 WinSetParent(hwndNow, WinQueryObjectWindow(HWND_DESKTOP), FALSE);
1594 WinSetOwner(hwndNow, WinQueryObjectWindow(HWND_DESKTOP));
1595 WinSetOwner(mi.hwndSubMenu, hwndMenu);
1596 WinSetParent(mi.hwndSubMenu, hwndMenu, FALSE);
1597 WinSetWindowUShort(mi.hwndSubMenu, QWS_ID, IDM_VIEWSMENU);
1598 mi.afStyle = MIS_SUBMENU;
1599 ulStyle = WinQueryWindowULong(mi.hwndSubMenu, QWL_STYLE);
1600 ulStyle &= -WS_SAVEBITS;
1601 ulStyle |= MS_POPUP | WS_CLIPSIBLINGS | WS_SAVEBITS;
1602 WinSetWindowULong(mi.hwndSubMenu, QWL_STYLE, ulStyle);
1603 WinSendMsg(hwndMenu, MM_SETITEM, MPFROM2SHORT(0, TRUE), MPFROMP(&mi));
[231]1604 }
[397]1605 break;
1606 }
[2]1607}
1608
[872]1609HWND CheckMenu(HWND hwnd, HWND * hwndMenu, USHORT id)
[231]1610{
[397]1611 /* load and adjust menus as required */
1612 if (!*hwndMenu || !WinIsWindow((HAB) 0, *hwndMenu)) {
1613 *hwndMenu = WinLoadMenu(HWND_DESKTOP, FM3ModHandle, id);
[877]1614 CopyPresParams(*hwndMenu, hwnd);
[397]1615 if (hwndMenu == &DirMenu) {
1616 WinSetWindowUShort(DirMenu, QWS_ID, IDM_FILESMENU);
1617 SetConditionalCascade(DirMenu, IDM_COMMANDSMENU, IDM_DOITYOURSELF);
1618 SetConditionalCascade(DirMenu, IDM_COPYMENU, IDM_COPY);
1619 SetConditionalCascade(DirMenu, IDM_MOVEMENU, IDM_MOVE);
1620 SetConditionalCascade(DirMenu, IDM_SAVESUBMENU, IDM_SAVETOCLIP);
1621 SetConditionalCascade(DirMenu, IDM_VIEWSUBMENU, IDM_INFO);
1622 SetConditionalCascade(DirMenu, IDM_EDITSUBMENU, IDM_ATTRS);
1623 SetConditionalCascade(DirMenu, IDM_DELETESUBMENU,
[787]1624 fDefaultDeletePerm ? IDM_PERMDELETE : IDM_DELETE);
[397]1625 SetConditionalCascade(DirMenu, IDM_MISCSUBMENU, IDM_SIZES);
1626 SetConditionalCascade(DirMenu, IDM_OPENSUBMENU, IDM_OPENWINDOW);
1627 if (fWorkPlace) {
1628 WinSendMsg(DirMenu, MM_DELETEITEM,
1629 MPFROM2SHORT(IDM_OPENSUBMENU, TRUE), MPVOID);
1630 WinSendMsg(DirMenu, MM_DELETEITEM,
1631 MPFROM2SHORT(IDM_OBJECTSUBMENU, TRUE), MPVOID);
1632 }
[2]1633 }
[397]1634 else if (hwndMenu == &TreeMenu) {
1635 WinSetWindowUShort(TreeMenu, QWS_ID, IDM_FILESMENU);
1636 SetConditionalCascade(TreeMenu, IDM_COMMANDSMENU, IDM_DOITYOURSELF);
1637 SetConditionalCascade(TreeMenu, IDM_SAVESUBMENU, IDM_SAVETOCLIP);
1638 SetConditionalCascade(TreeMenu, IDM_EDITSUBMENU, IDM_ATTRS);
1639 SetConditionalCascade(TreeMenu, IDM_EXPANDSUBMENU, IDM_EXPAND);
1640 SetConditionalCascade(TreeMenu, IDM_MISCSUBMENU, IDM_SIZES);
1641 SetConditionalCascade(TreeMenu, IDM_OPENSUBMENU, IDM_OPENWINDOW);
1642 if (fWorkPlace) {
1643 WinSendMsg(TreeMenu, MM_DELETEITEM,
1644 MPFROM2SHORT(IDM_OPENSUBMENU, TRUE), MPVOID);
1645 WinSendMsg(TreeMenu, MM_DELETEITEM,
1646 MPFROM2SHORT(IDM_OBJECTSUBMENU, TRUE), MPVOID);
1647 }
1648 }
1649 else if (hwndMenu == &ArcMenu) {
1650 WinSetWindowUShort(ArcMenu, QWS_ID, IDM_FILESMENU);
1651 SetConditionalCascade(ArcMenu, IDM_EXTRACTSUBMENU, IDM_EXTRACT);
1652 SetConditionalCascade(ArcMenu, IDM_EDITSUBMENU, IDM_EDIT);
1653 SetConditionalCascade(ArcMenu, IDM_VIEWSUBMENU, IDM_VIEW);
1654 if (fWorkPlace)
1655 WinSendMsg(ArcMenu, MM_DELETEITEM,
1656 MPFROM2SHORT(IDM_FOLDERAFTEREXTRACT, TRUE), MPVOID);
1657 }
1658 else if (hwndMenu == &FileMenu) {
1659 WinSetWindowUShort(FileMenu, QWS_ID, IDM_FILESMENU);
1660 SetConditionalCascade(FileMenu, IDM_COMMANDSMENU, IDM_DOITYOURSELF);
1661 SetConditionalCascade(FileMenu, IDM_COPYMENU, IDM_COPY);
1662 SetConditionalCascade(FileMenu, IDM_MOVEMENU, IDM_MOVE);
1663 SetConditionalCascade(FileMenu, IDM_SAVESUBMENU, IDM_SAVETOCLIP);
1664 SetConditionalCascade(FileMenu, IDM_VIEWSUBMENU, IDM_VIEW);
1665 SetConditionalCascade(FileMenu, IDM_EDITSUBMENU, IDM_EDIT);
1666 SetConditionalCascade(FileMenu, IDM_COLLECTMENU, IDM_COLLECT);
1667 SetConditionalCascade(FileMenu, IDM_DELETESUBMENU,
[787]1668 fDefaultDeletePerm ? IDM_PERMDELETE : IDM_DELETE);
[397]1669 SetConditionalCascade(FileMenu, IDM_OPENSUBMENU, IDM_OPENDEFAULT);
1670 SetConditionalCascade(FileMenu, IDM_OBJECTSUBMENU, IDM_SHADOW);
1671 if (fWorkPlace) {
1672 WinSendMsg(FileMenu, MM_DELETEITEM,
1673 MPFROM2SHORT(IDM_OPENSUBMENU, TRUE), MPVOID);
1674 WinSendMsg(FileMenu, MM_DELETEITEM,
1675 MPFROM2SHORT(IDM_OBJECTSUBMENU, TRUE), MPVOID);
1676 }
1677 }
1678 else if (hwndMenu == &DirCnrMenu) {
1679 WinSetWindowUShort(DirCnrMenu, QWS_ID, IDM_VIEWSMENU);
1680 SetConditionalCascade(DirCnrMenu, IDM_MISCSUBMENU, IDM_SIZES);
1681 SetConditionalCascade(DirCnrMenu, IDM_OPENSUBMENU, IDM_OPENSETTINGSME);
1682 if (fWorkPlace)
1683 WinSendMsg(DirCnrMenu, MM_DELETEITEM,
1684 MPFROM2SHORT(IDM_OPENSUBMENU, TRUE), MPVOID);
1685 }
[489]1686 else if (hwndMenu == &TreeCnrMenu) {
[397]1687 WinSetWindowUShort(TreeCnrMenu, QWS_ID, IDM_VIEWSMENU);
[468]1688 SetConditionalCascade(TreeCnrMenu, IDM_PARTITIONSMENU, IDM_PARTITION);
1689 }
[397]1690 else if (hwndMenu == &ArcCnrMenu) {
1691 WinSetWindowUShort(ArcCnrMenu, QWS_ID, IDM_VIEWSMENU);
1692 SetConditionalCascade(ArcCnrMenu, IDM_EXTRACTSUBMENU, IDM_ARCEXTRACT);
1693 if (fWorkPlace)
1694 WinSendMsg(ArcCnrMenu, MM_DELETEITEM,
1695 MPFROM2SHORT(IDM_FOLDERAFTEREXTRACT, TRUE), MPVOID);
1696 }
1697 else if (hwndMenu == &CollectorCnrMenu) {
1698 WinSetWindowUShort(CollectorCnrMenu, QWS_ID, IDM_VIEWSMENU);
1699 SetConditionalCascade(CollectorCnrMenu, IDM_COLLECTMENU,
1700 IDM_COLLECTFROMCLIP);
1701 }
1702 else if (hwndMenu == &CollectorFileMenu) {
1703 WinSetWindowUShort(CollectorFileMenu, QWS_ID, IDM_FILESMENU);
1704 SetConditionalCascade(CollectorFileMenu, IDM_COMMANDSMENU,
1705 IDM_DOITYOURSELF);
1706 SetConditionalCascade(CollectorFileMenu, IDM_COPYMENU, IDM_COPY);
1707 SetConditionalCascade(CollectorFileMenu, IDM_MOVEMENU, IDM_MOVE);
1708 SetConditionalCascade(CollectorFileMenu, IDM_SAVESUBMENU,
1709 IDM_SAVETOCLIP);
1710 SetConditionalCascade(CollectorFileMenu, IDM_VIEWSUBMENU, IDM_VIEW);
1711 SetConditionalCascade(CollectorFileMenu, IDM_EDITSUBMENU, IDM_EDIT);
1712 SetConditionalCascade(CollectorFileMenu, IDM_DELETESUBMENU,
[787]1713 fDefaultDeletePerm ? IDM_PERMDELETE : IDM_DELETE);
[397]1714 SetConditionalCascade(CollectorFileMenu, IDM_OPENSUBMENU,
1715 IDM_OPENDEFAULT);
1716 SetConditionalCascade(CollectorFileMenu, IDM_OBJECTSUBMENU, IDM_SHADOW);
1717 if (fWorkPlace) {
1718 WinSendMsg(CollectorFileMenu, MM_DELETEITEM,
1719 MPFROM2SHORT(IDM_OPENSUBMENU, TRUE), MPVOID);
1720 WinSendMsg(CollectorFileMenu, MM_DELETEITEM,
1721 MPFROM2SHORT(IDM_OBJECTSUBMENU, TRUE), MPVOID);
1722 }
1723 }
1724 else if (hwndMenu == &CollectorDirMenu) {
1725 WinSetWindowUShort(CollectorDirMenu, QWS_ID, IDM_FILESMENU);
1726 SetConditionalCascade(CollectorDirMenu, IDM_COMMANDSMENU,
1727 IDM_DOITYOURSELF);
1728 SetConditionalCascade(CollectorDirMenu, IDM_COPYMENU, IDM_COPY);
1729 SetConditionalCascade(CollectorDirMenu, IDM_MOVEMENU, IDM_MOVE);
1730 SetConditionalCascade(CollectorDirMenu, IDM_SAVESUBMENU,
1731 IDM_SAVETOCLIP);
1732 SetConditionalCascade(CollectorDirMenu, IDM_VIEWSUBMENU, IDM_INFO);
1733 SetConditionalCascade(CollectorDirMenu, IDM_EDITSUBMENU, IDM_ATTRS);
1734 SetConditionalCascade(CollectorDirMenu, IDM_DELETESUBMENU,
[787]1735 fDefaultDeletePerm ? IDM_PERMDELETE : IDM_DELETE);
[397]1736 SetConditionalCascade(CollectorDirMenu, IDM_MISCSUBMENU, IDM_SIZES);
1737 SetConditionalCascade(CollectorDirMenu, IDM_OPENSUBMENU,
1738 IDM_OPENWINDOW);
1739 if (fWorkPlace) {
1740 WinSendMsg(CollectorDirMenu, MM_DELETEITEM,
1741 MPFROM2SHORT(IDM_OPENSUBMENU, TRUE), MPVOID);
1742 WinSendMsg(CollectorDirMenu, MM_DELETEITEM,
1743 MPFROM2SHORT(IDM_OBJECTSUBMENU, TRUE), MPVOID);
1744 }
1745 }
1746 else if (hwndMenu == &MainPopupMenu) {
1747 WinSetWindowUShort(MainPopupMenu, QWS_ID, IDM_MAINPOPUP);
1748 SetConditionalCascade(MainPopupMenu, IDM_TOOLSUBMENU, IDM_TOOLBAR);
1749 SetConditionalCascade(MainPopupMenu, IDM_AUTOVIEWSUBMENU, IDM_AUTOVIEW);
1750 }
1751 }
[877]1752 CopyPresParams(*hwndMenu, hwnd);
[397]1753 return *hwndMenu;
[2]1754}
1755
[231]1756SHORT AddToListboxBottom(HWND hwnd, CHAR * str)
1757{
[397]1758 SHORT ln;
[2]1759
[397]1760 ln = (SHORT) WinSendMsg(hwnd, LM_INSERTITEM, MPFROM2SHORT(LIT_END, 0),
1761 MPFROMP(str));
1762 if (ln)
1763 WinSendMsg(hwnd, LM_SELECTITEM, MPFROM2SHORT(ln, 0), MPVOID);
1764 return ln;
[2]1765}
1766
[231]1767VOID SetSysMenu(HWND hwndSysMenu)
1768{
[397]1769 CHAR s[128], *p;
[2]1770
[397]1771 if (WinSendMsg(hwndSysMenu, MM_QUERYITEMTEXT,
1772 MPFROM2SHORT(SC_RESTORE, 128), MPFROMP(s))) {
1773 p = strchr(s, '\t');
1774 if (p) {
1775 p++;
1776 strcpy(p, "Ctrl+Alt+F5");
1777 WinSetMenuItemText(hwndSysMenu, SC_RESTORE, s);
[2]1778 }
[397]1779 }
1780 if (WinSendMsg(hwndSysMenu, MM_QUERYITEMTEXT,
1781 MPFROM2SHORT(SC_CLOSE, 128), MPFROMP(s))) {
1782 p = strchr(s, '\t');
1783 if (p) {
1784 p++;
1785 strcpy(p, "Ctrl+Alt+F4");
1786 WinSetMenuItemText(hwndSysMenu, SC_CLOSE, s);
[2]1787 }
[397]1788 }
1789 if (WinSendMsg(hwndSysMenu, MM_QUERYITEMTEXT,
1790 MPFROM2SHORT(SC_MOVE, 128), MPFROMP(s))) {
1791 p = strchr(s, '\t');
1792 if (p) {
1793 p++;
1794 strcpy(p, "Ctrl+Alt+F7");
1795 WinSetMenuItemText(hwndSysMenu, SC_MOVE, s);
[2]1796 }
[397]1797 }
1798 if (WinSendMsg(hwndSysMenu, MM_QUERYITEMTEXT,
1799 MPFROM2SHORT(SC_SIZE, 128), MPFROMP(s))) {
1800 p = strchr(s, '\t');
1801 if (p) {
1802 p++;
1803 strcpy(p, "Ctrl+Alt+F8");
1804 WinSetMenuItemText(hwndSysMenu, SC_SIZE, s);
[2]1805 }
[397]1806 }
1807 if (WinSendMsg(hwndSysMenu, MM_QUERYITEMTEXT,
1808 MPFROM2SHORT(SC_MINIMIZE, 128), MPFROMP(s))) {
1809 p = strchr(s, '\t');
1810 if (p) {
1811 p++;
1812 strcpy(p, "Ctrl+Alt+F9");
1813 WinSetMenuItemText(hwndSysMenu, SC_MINIMIZE, s);
[2]1814 }
[397]1815 }
1816 if (WinSendMsg(hwndSysMenu,
1817 MM_QUERYITEMTEXT,
1818 MPFROM2SHORT(SC_MAXIMIZE, 128), MPFROMP(s))) {
1819 p = strchr(s, '\t');
1820 if (p) {
1821 p++;
1822 strcpy(p, "Ctrl+Alt+F10");
1823 WinSetMenuItemText(hwndSysMenu, SC_MAXIMIZE, s);
[2]1824 }
[397]1825 }
1826 if (WinSendMsg(hwndSysMenu,
1827 MM_QUERYITEMTEXT, MPFROM2SHORT(SC_HIDE, 128), MPFROMP(s))) {
1828 p = strchr(s, '\t');
1829 if (p) {
1830 p++;
1831 strcpy(p, "Ctrl+Alt+F11");
1832 WinSetMenuItemText(hwndSysMenu, SC_HIDE, s);
[2]1833 }
[397]1834 }
[2]1835}
1836
[231]1837VOID LoadLibPath(CHAR * str, LONG len)
1838{
[397]1839 ULONG ver[2];
1840 CHAR configsys[] = "C:\\CONFIG.SYS";
1841 static CHAR var[8192], beg[16384], end[16384];
1842 BOOL warp;
1843 FILE *fp;
1844 PFN DQELIBPATH = NULL;
1845 HMODULE hmod;
[2]1846
[397]1847 if (str && len) {
1848 *str = 0;
1849 if (DosQuerySysInfo(QSV_BOOT_DRIVE,
1850 QSV_BOOT_DRIVE, (PVOID) ver, (ULONG) sizeof(ULONG)))
1851 ver[0] = 3L;
1852 *configsys = (CHAR) ver[0] + '@';
1853 if (!DosQuerySysInfo(QSV_VERSION_MAJOR,
1854 QSV_VERSION_MINOR,
1855 (PVOID) ver, (ULONG) sizeof(ver)) && ver[1] >= 30)
1856 warp = TRUE;
1857 *var = *beg = *end = 0;
1858 if (warp) {
1859 if (!DosLoadModule(var, sizeof(var), "DOSCALL1.DLL", &hmod)) {
1860 if (!DosQueryProcAddr(hmod,
1861 ORD_DOS32QUERYEXTLIBPATH,
1862 NULL, (PFN *) & DQELIBPATH)) {
1863 DQELIBPATH(beg, BEGIN_LIBPATH);
1864 DQELIBPATH(end, END_LIBPATH);
[231]1865 }
[397]1866 DosFreeModule(hmod);
1867 }
1868 *var = 0;
1869 }
1870 fp = xfopen(configsys, "r", pszSrcFile, __LINE__);
1871 if (fp) {
1872 while (!feof(fp)) {
[551]1873 if (!xfgets_bstripcr(var, sizeof(var), fp, pszSrcFile, __LINE__))
[397]1874 break;
1875 if (!strnicmp(var, "LIBPATH=", 8)) {
1876 memmove(var, var + 8, strlen(var + 8) + 1);
1877 lstrip(var);
1878 break;
[231]1879 }
[397]1880 }
1881 fclose(fp);
[2]1882 }
[397]1883 strncpy(str, beg, len);
1884 strncat(str, var, len - strlen(str));
1885 strncat(str, end, len - strlen(str));
1886 str[len - 1] = 0;
1887 }
[2]1888}
1889
[231]1890void SetViewMenu(HWND hwndMenu, ULONG flWindowAttr)
1891{
[397]1892 WinCheckMenuItem(hwndMenu, IDM_MINIICONS, ((flWindowAttr & CV_MINI)));
1893 WinCheckMenuItem(hwndMenu, IDM_TEXT, ((flWindowAttr & CV_TEXT)));
1894 WinCheckMenuItem(hwndMenu, IDM_ICON, ((flWindowAttr & CV_ICON) &&
1895 !(flWindowAttr & CV_TREE)));
1896 WinCheckMenuItem(hwndMenu, IDM_TREEVIEW, ((flWindowAttr & CV_TREE)));
1897 WinCheckMenuItem(hwndMenu, IDM_DETAILS, ((flWindowAttr & CV_DETAIL)));
1898 WinCheckMenuItem(hwndMenu, IDM_NAME, ((flWindowAttr & CV_NAME)));
[2]1899}
1900
[231]1901void SaySort(HWND hwnd, INT sortflags, BOOL archive)
1902{
[397]1903 char *s = NULL;
[2]1904
[397]1905 s = xmalloc(CCHMAXPATH, pszSrcFile, __LINE__);
1906 if (s) {
1907 sprintf(s, "S:%s%s",
[787]1908 sortflags & SORT_REVERSE ? "^" : NullStr,
1909 (sortflags & SORT_FIRSTEXTENSION) ?
1910 GetPString(IDS_FIRSTX) : (sortflags & SORT_LASTEXTENSION) ?
1911 GetPString(IDS_LASTX) : (sortflags & SORT_SIZE) ?
1912 "Size" : (sortflags & SORT_EASIZE) ?
1913 (archive == 0) ?
1914 GetPString(IDS_EASIZE) : GetPString(IDS_CSIZE) :
1915 (sortflags & SORT_LWDATE) ?
1916 (archive == 0) ?
1917 GetPString(IDS_LWDATE) : GetPString(IDS_DATE) :
1918 (sortflags & SORT_LADATE) ?
1919 GetPString(IDS_LADATE) : (sortflags & SORT_CRDATE) ?
1920 GetPString(IDS_CRDATE) :
1921 (sortflags & SORT_PATHNAME) ?
1922 GetPString(IDS_PATH) : (sortflags & SORT_NOSORT) ?
1923 GetPString(IDS_NONE) : (sortflags & SORT_SUBJECT) ?
1924 GetPString(IDS_SUBJ) : GetPString(IDS_NAME));
[397]1925 WinSetWindowText(hwnd, s);
1926 free(s);
1927 }
[2]1928}
1929
[231]1930void SayView(HWND hwnd, ULONG flWindowAttr)
1931{
[397]1932 char *s = NULL;
[2]1933
[397]1934 s = xmalloc(CCHMAXPATH, pszSrcFile, __LINE__);
1935 if (s) {
1936 sprintf(s, "V:%s%s",
1937 (flWindowAttr & CV_TREE) ? GetPString(IDS_TREE) :
1938 (flWindowAttr & CV_NAME) ? GetPString(IDS_NAME) :
1939 (flWindowAttr & CV_DETAIL) ? GetPString(IDS_DETAIL) :
1940 (flWindowAttr & CV_TEXT) ? GetPString(IDS_TEXT) :
1941 GetPString(IDS_ICON),
1942 ((flWindowAttr & CV_MINI) &&
1943 !(flWindowAttr & CV_TEXT)) ? GetPString(IDS_MINI) : NullStr);
1944 WinSetWindowText(hwnd, s);
1945 free(s);
1946 }
[2]1947}
1948
[231]1949void SayFilter(HWND hwnd, MASK * mask, BOOL archive)
1950{
[397]1951 char *s = NULL;
[2]1952
[397]1953 s = xmalloc(CCHMAXPATH * 2, pszSrcFile, __LINE__);
1954 if (s) {
1955 sprintf(s, "F:%s%s",
1956 mask->szMask,
1957 (!archive && (mask->attrFile != ALLATTRS ||
1958 mask->antiattr != 0)) ? " " : NullStr,
1959 (!archive && (mask->attrFile != ALLATTRS ||
1960 mask->antiattr !=
1961 0)) ? GetPString(IDS_ATTRTEXT) : NullStr);
1962 if (!s[2])
1963 sprintf(s, "F:%s", GetPString(IDS_ALLTEXT));
1964 WinSetWindowText(hwnd, s);
1965 free(s);
1966 }
[2]1967}
1968
[231]1969char *GetCmdSpec(BOOL dos)
1970{
[397]1971 char *cmspec;
[2]1972
[397]1973 if (!dos) {
1974 cmspec = getenv("OS2_SHELL");
1975 if (!cmspec)
1976 cmspec = getenv("COMSPEC");
1977 if (!cmspec)
1978 cmspec = "CMD.EXE";
1979 }
1980 else {
1981 cmspec = getenv("DOS_SHELL");
1982 if (!cmspec)
1983 cmspec = "COMMAND.COM";
1984 }
1985 return cmspec;
[2]1986}
1987
[231]1988void Broadcast(HAB hab, HWND hwnd, ULONG msg, MPARAM mp1, MPARAM mp2)
1989{
[397]1990 if (hwndMain)
1991 WinBroadcastMsg(hwndMain, msg, mp1, mp2, BMSG_SEND | BMSG_FRAMEONLY);
1992 if (hwnd &&
1993 hwnd != HWND_DESKTOP &&
1994 hwnd != hwndMain &&
1995 hwnd != WinQueryDesktopWindow(hab, NULLHANDLE) &&
1996 WinIsWindow(hab, hwnd) && (!hwndMain || !WinIsChild(hwnd, hwndMain)))
1997 WinSendMsg(hwnd, msg, mp1, mp2);
[2]1998}
1999
[231]2000void SetupWinList(HWND hwndMenu, HWND hwndTop, HWND hwndFrame)
2001{
[397]2002 /*
2003 * add switchlist entries to end of pulldown menu
2004 */
[2]2005
[397]2006 SHORT sItemCount, x = 0, y = 0;
2007 MENUITEM mi;
[2]2008
[397]2009 sItemCount = (SHORT) WinSendMsg(hwndMenu,
2010 MM_QUERYITEMCOUNT, MPVOID, MPVOID);
[2]2011
[397]2012 /* clean out old additions */
2013 while ((SHORT) WinSendMsg(hwndMenu,
2014 MM_DELETEITEM,
2015 MPFROM2SHORT(IDM_SWITCHSTART + x++,
2016 TRUE), MPVOID) < sItemCount)
2017 sItemCount--;
2018 x = 0;
2019 while ((SHORT) WinSendMsg(hwndMenu,
2020 MM_DELETEITEM,
2021 MPFROM2SHORT(IDM_WINDOWSTART + x++,
2022 TRUE), MPVOID) < sItemCount)
2023 sItemCount--;
[2]2024
[397]2025 x = 0;
2026 if (hwndTop) {
[2]2027
[397]2028 char wtext[CCHMAXPATH + 8];
2029 HENUM henum;
2030 HWND hwndChild;
[2]2031
[397]2032 /* add children of the main FM/2 client */
2033 henum = WinBeginEnumWindows(hwndTop);
2034 memset(&mi, 0, sizeof(mi));
2035 while ((hwndChild = WinGetNextWindow(henum)) != NULLHANDLE) {
2036 if (WinQueryWindowUShort(hwndChild, QWS_ID) && hwndChild != hwndFrame) {
2037 *wtext = 0;
2038 WinQueryWindowText(hwndChild, CCHMAXPATH + 8, wtext);
2039 if (*wtext) {
2040 wtext[CCHMAXPATH + 7] = 0;
2041 mi.afStyle = MIS_TEXT;
2042 if (!((x + sItemCount) % 28))
2043 mi.afStyle |= MIS_BREAK;
2044 mi.id = IDM_WINDOWSTART + x;
2045 mi.iPosition = MIT_END;
2046 if ((SHORT) WinSendMsg(hwndMenu,
2047 MM_INSERTITEM,
2048 MPFROMP(&mi), MPFROMP(wtext)) >= 0)
2049 x++;
[231]2050 }
[397]2051 }
[2]2052 }
[397]2053 WinEndEnumWindows(henum);
2054 }
[2]2055
[397]2056 /* add external FM/2 windows */
2057 {
2058 PSWBLOCK pswb;
2059 ULONG ulSize, ulcEntries;
2060 HWND hwndTopFrame;
2061 register INT i;
[2]2062
[787]2063 hwndTopFrame = hwndTop ? WinQueryWindow(hwndTop, QW_PARENT) : (HWND)0;
[397]2064 /* Get the switch list information */
2065 x = 0;
2066 ulcEntries = WinQuerySwitchList(0, NULL, 0);
2067 ulSize = sizeof(SWBLOCK) + sizeof(HSWITCH) + (ulcEntries + 4L) *
2068 (LONG) sizeof(SWENTRY);
2069 /* Allocate memory for list */
2070 pswb = xmalloc(ulSize, pszSrcFile, __LINE__);
2071 if (pswb) {
2072 /* Put the info in the list */
2073 ulcEntries = WinQuerySwitchList(0, pswb, ulSize - sizeof(SWENTRY));
2074 /* do the dirty deed */
2075 memset(&mi, 0, sizeof(mi));
2076 for (i = 0; i < pswb->cswentry; i++) {
2077 if (pswb->aswentry[i].swctl.uchVisibility == SWL_VISIBLE &&
2078 pswb->aswentry[i].swctl.fbJump == SWL_JUMPABLE &&
2079 (pswb->aswentry[i].swctl.idProcess != mypid ||
2080 !hwndFrame ||
2081 pswb->aswentry[i].swctl.hwnd != hwndFrame) &&
2082 (pswb->aswentry[i].swctl.idProcess != mypid ||
2083 !hwndTopFrame ||
2084 pswb->aswentry[i].swctl.hwnd != hwndTopFrame ||
2085 !WinIsChild(hwndFrame, hwndTop))) {
2086 if (!strnicmp(pswb->aswentry[i].swctl.szSwtitle, "AV/2", 4)
2087 || !stricmp(pswb->aswentry[i].swctl.szSwtitle, "File Manager/2")
2088 || !stricmp(pswb->aswentry[i].swctl.szSwtitle, "Collector")
2089 || !strnicmp(pswb->aswentry[i].swctl.szSwtitle, "VTree", 5)
2090 || !strnicmp(pswb->aswentry[i].swctl.szSwtitle, "VDir", 4)
2091 || !strnicmp(pswb->aswentry[i].swctl.szSwtitle, FM2Str, 4)) {
2092 mi.afStyle = MIS_TEXT;
2093 if (x && !(x % 28))
2094 mi.afStyle |= MIS_BREAK;
2095 mi.id = IDM_SWITCHSTART + y;
2096 mi.iPosition = MIT_END;
2097 switches[y] = pswb->aswentry[i].hswitch;
2098 if ((SHORT) WinSendMsg(hwndMenu,
2099 MM_INSERTITEM,
2100 MPFROMP(&mi),
2101 MPFROMP(pswb->aswentry[i].
2102 swctl.szSwtitle)) >= 0) {
2103 y++;
2104 x++;
[231]2105 }
[397]2106 }
[231]2107 }
[397]2108 }
2109 numswitches = y;
2110 free(pswb);
2111 DosPostEventSem(CompactSem);
[2]2112 }
[397]2113 }
[2]2114}
2115
[231]2116BOOL SwitchCommand(HWND hwndMenu, USHORT cmd)
2117{
[397]2118 BOOL ret = FALSE;
[2]2119
[397]2120 if (hwndMain && hwndMenu && cmd >= IDM_WINDOWSTART && cmd < IDM_SWITCHSTART) {
2121 /*
2122 * select a child window (of client)
2123 */
[2]2124
[397]2125 MENUITEM mi;
2126 HWND hwndSubMenu = (HWND) 0, hwndChild;
2127 CHAR s[CCHMAXPATH + 8];
[2]2128
[397]2129 if (WinQueryWindowUShort(hwndMenu, QWS_ID) != IDM_WINDOWSMENU) {
2130 memset(&mi, 0, sizeof(mi));
2131 mi.iPosition = MIT_END;
2132 mi.afStyle = MIS_TEXT;
2133 if (WinSendMsg(hwndMenu,
2134 MM_QUERYITEM,
2135 MPFROM2SHORT(IDM_WINDOWSMENU, TRUE), MPFROMP(&mi)))
2136 hwndSubMenu = mi.hwndSubMenu;
2137 }
2138 else
2139 hwndSubMenu = hwndMenu;
2140 if (hwndSubMenu) {
2141 *s = 0;
2142 if (WinSendMsg(hwndSubMenu,
2143 MM_QUERYITEMTEXT,
2144 MPFROM2SHORT(cmd, CCHMAXPATH + 8), MPFROMP(s)) && *s) {
[2]2145
[397]2146 HENUM henum;
2147 CHAR checkText[CCHMAXPATH + 8];
2148 SWP swp;
[2]2149
[397]2150 s[CCHMAXPATH + 7] = 0;
2151 henum = WinBeginEnumWindows(hwndMain);
2152 while ((hwndChild = WinGetNextWindow(henum)) != NULLHANDLE) {
2153 if (WinQueryWindowUShort(hwndChild, QWS_ID)) {
2154 *checkText = 0;
2155 WinQueryWindowText(hwndChild, CCHMAXPATH + 8, checkText);
2156 checkText[CCHMAXPATH + 7] = 0;
2157 if (!stricmp(checkText, s)) {
2158 if (WinQueryWindowPos(hwndChild, &swp)) {
2159 if (swp.fl & (SWP_MINIMIZE | SWP_HIDE))
2160 WinSetWindowPos(hwndChild,
2161 HWND_TOP,
2162 0, 0, 0, 0, SWP_RESTORE | SWP_ZORDER);
2163 }
2164 WinSetActiveWindow(HWND_DESKTOP, hwndChild);
2165 ret = TRUE;
2166 break;
[231]2167 }
[397]2168 }
[231]2169 }
[397]2170 WinEndEnumWindows(henum);
2171 }
[2]2172 }
[397]2173 }
2174 else if (cmd >= IDM_SWITCHSTART && cmd < IDM_SWITCHSTART + 499) {
2175 if (cmd - IDM_SWITCHSTART < numswitches) {
2176 WinSwitchToProgram(switches[cmd - IDM_SWITCHSTART]);
2177 ret = TRUE;
[2]2178 }
[397]2179 }
[2]2180
[397]2181 return ret;
[2]2182}
[787]2183
2184#pragma alloc_text(MAINWND5,SetSysMenu)
2185#pragma alloc_text(MISC1,BoxWindow,PaintRecessedWindow,PostMsg,PaintSTextWindow,IsFm2Window)
2186#pragma alloc_text(MISC1,FixSwitchList,FindDirCnr,CurrentRecord,SetShiftState,AddToListboxBottom)
2187#pragma alloc_text(CNR_MISC1,AdjustCnrColVis,AdjustCnrColsForFSType)
2188#pragma alloc_text(CNR_MISC1,AdjustCnrColsForPref,SetCnrCols)
2189#pragma alloc_text(CNR_MISC2,CnrDirectEdit,OpenEdit)
2190#pragma alloc_text(MISC2,SetMenuCheck,disable_menuitem,SetSortChecks)
2191#pragma alloc_text(MISC2,SetDetailsSwitches,SetViewMenu)
2192#pragma alloc_text(MISC3,SetupCommandMenu,AdjustDetailsSwitches)
2193#pragma alloc_text(MISC3,ViewHelp,GetCmdSpec)
2194#pragma alloc_text(MISC3,ExecFile,SetConditionalCascade,LoadDetailsSwitches)
2195#pragma alloc_text(MISC4,PortholeInit,CheckMenu,Broadcast,SetupWinList,SwitchCommand)
2196#pragma alloc_text(MISC6,DrawTargetEmphasis,EmphasizeButton)
2197#pragma alloc_text(MISC_LIBPATH,LoadLibPath)
2198#pragma alloc_text(MISC_SAY,SayView,SaySort,SayFilter)
2199
Note: See TracBrowser for help on using the repository browser.