459 lines
12 KiB
C
459 lines
12 KiB
C
/************************************************************/
|
||
/* Windows Write, Copyright 1985-1992 Microsoft Corporation */
|
||
/************************************************************/
|
||
|
||
/* DiaPara.c -- Paragraph Format dialog box specific routines */
|
||
#define NOGDICAPMASKS
|
||
#define NOVIRTUALKEYCODES
|
||
#define NOWINSTYLES
|
||
#define NOCLIPBOARD
|
||
#define NOSYSMETRICS
|
||
#define NOMENUS
|
||
#define NOCOMM
|
||
#define NOSOUND
|
||
#define NOSCROLL
|
||
#define NOCOLOR
|
||
#define NOBITMAP
|
||
#define NOFONT
|
||
#define NODRAWTEXT
|
||
#define NOMSG
|
||
#define NOWNDCLASS
|
||
#define NOKEYSTATE
|
||
#define NORASTEROPS
|
||
#define NOGDI
|
||
#define NOBRUSH
|
||
#define NOPEN
|
||
#include <windows.h>
|
||
|
||
#include "mw.h"
|
||
#include "cmddefs.h"
|
||
#include "docdefs.h"
|
||
#include "prmdefs.h"
|
||
#include "propdefs.h"
|
||
#include "editdefs.h"
|
||
#include "dlgdefs.h"
|
||
#include "dispdefs.h"
|
||
#include "str.h"
|
||
#include "wwdefs.h"
|
||
|
||
extern struct WWD *pwwdCur;
|
||
extern HANDLE hParentWw;
|
||
extern struct PAP vpapAbs;
|
||
extern struct PAP *vppapNormal;
|
||
extern int rgval[];
|
||
extern typeCP cpMacCur;
|
||
extern int utCur;
|
||
extern struct SEL selCur; /* Current selection (i.e., sel in current ww */
|
||
extern int docCur; /* Document in current ww */
|
||
extern CHAR stBuf[];
|
||
extern HWND vhWndMsgBoxParent;
|
||
extern int vfCursorVisible;
|
||
extern HCURSOR vhcArrow;
|
||
|
||
#ifdef RULERALSO /* enable out because no need to bring ruler up when tab or indents is invoked */
|
||
extern int docRulerSprm;
|
||
extern struct TBD rgtbdRuler[];
|
||
extern HWND vhDlgIndent;
|
||
extern BOOL vfDisableMenus;
|
||
extern int vfTabsChanged;
|
||
extern int vfTempRuler;
|
||
extern struct WWD rgwwd[];
|
||
#endif
|
||
|
||
|
||
#ifdef CASHMERE
|
||
/* D O F O R M A T P A R A */
|
||
DoFormatPara(rgval)
|
||
VAL rgval[];
|
||
/* add para sprms */
|
||
|
||
int val, ival;
|
||
int *pval;
|
||
int sprm;
|
||
struct PAP *ppap;
|
||
typeCP dcp;
|
||
typeCP cpFirst, cpLim;
|
||
struct SEL selSave;
|
||
/* this temp array is used to assemble sprm values */
|
||
CHAR rgb[cchTBD * itbdMax + 2/* >> cwPAPBase */];
|
||
int rgw[cwPAPBase];
|
||
ppap = (struct PAP *)&rgw[0];
|
||
|
||
if (!FWriteCk(fwcNil))
|
||
return; /* Check for munging end mark in footnote window */
|
||
|
||
if (docRulerSprm != docNil) ClearRulerSprm();
|
||
ExpandCurSel(&selSave);
|
||
|
||
dcp = (cpLim = selCur.cpLim) - (cpFirst = selCur.cpFirst);
|
||
if (cpLim > cpMacCur)
|
||
{
|
||
SetUndo(uacReplNS, docCur, cpFirst, dcp,
|
||
docNil, cpNil, dcp - ccpEol, 0);
|
||
InsertEolInsert(docCur, cpMacCur);
|
||
}
|
||
else
|
||
SetUndo(uacReplNS, docCur, cpFirst, dcp,
|
||
docNil, cpNil, dcp, 0);
|
||
/* reset adjusted selCur */
|
||
selCur.cpFirst = cpFirst;
|
||
selCur.cpLim = cpLim;
|
||
|
||
|
||
/* any gray fields ? */
|
||
for (ival = 0; ival <= 8; ival++)
|
||
if (rgval[ival] == valNil)
|
||
{
|
||
/* yes. generate sprms for any that are not gray */
|
||
for (ival = 0; ival <= 8; ival++)
|
||
if ((val = rgval[ival]) != valNil)
|
||
{
|
||
switch(ival)
|
||
{
|
||
case 0:
|
||
sprm = sprmPJc;
|
||
goto LPara1;
|
||
case 1:
|
||
val = !val;
|
||
sprm = sprmPKeep;
|
||
goto LPara1;
|
||
case 2:
|
||
sprm = sprmPLMarg;
|
||
break;
|
||
case 3:
|
||
sprm = sprmPFIndent;
|
||
break;
|
||
case 4:
|
||
sprm = sprmPRMarg;
|
||
break;
|
||
case 5:
|
||
sprm = sprmPDyaLine;
|
||
break;
|
||
case 6:
|
||
sprm = sprmPDyaBefore;
|
||
break;
|
||
case 7:
|
||
sprm = sprmPDyaAfter;
|
||
break;
|
||
case 8:
|
||
val = !val;
|
||
sprm = sprmPKeepFollow;
|
||
goto LPara1;
|
||
}
|
||
/* we come here with one word value */
|
||
bltbyte(&val, &rgb[1], cchINT);
|
||
goto LPara2;
|
||
/* we come here with one char value */
|
||
LPara1: rgb[1] = val;
|
||
LPara2: rgb[0] = sprm;
|
||
AddSprm(rgb);
|
||
}
|
||
goto ParaCommon;
|
||
}
|
||
/* otherwise generate a sprm that applies all properties except the tabs */
|
||
blt(vppapNormal, ppap, cwPAPBase);
|
||
pval = &rgval[0];
|
||
ppap->jc = *pval++;
|
||
ppap->fKeep = !*pval++;
|
||
ppap->dxaLeft = *pval++;
|
||
ppap->dxaLeft1 = *pval++;
|
||
ppap->dxaRight = *pval++;
|
||
ppap->dyaLine = *pval++;
|
||
ppap->dyaBefore = *pval++;
|
||
ppap->dyaAfter = *pval++;
|
||
ppap->fKeepFollow = !*pval++;
|
||
bltbyte(ppap, &rgb[2], cwPAPBase * cchINT);
|
||
rgb[1] = cwPAPBase * cchINT;
|
||
/* we have: sprm, rgb[1 - n] set up */
|
||
rgb[0] = sprmPSame;
|
||
CachePara(docCur, selCur.cpFirst);
|
||
if (CchDiffer(&vpapAbs, ppap, cwPAPBase * cchINT))
|
||
AddSprm(rgb);
|
||
ParaCommon: ;
|
||
if (vfTabsChanged)
|
||
{
|
||
int itbd;
|
||
int cchRgtbd;
|
||
/* some tab changes were also made in the ruler */
|
||
for (itbd = 0; rgtbdRuler[itbd].dxa != 0; itbd++);
|
||
bltbyte((CHAR *)rgtbdRuler, &rgb[2], cchRgtbd = cwTBD * cchINT * itbd);
|
||
rgb[1] = cchRgtbd;
|
||
rgb[0] = sprmPRgtbd;
|
||
AddSprm(rgb);
|
||
}
|
||
EndLookSel(&selSave, fTrue);
|
||
SetRgvalAgain(rgval, uacFormatPara);
|
||
}
|
||
|
||
#else /* MEMO, not CASHMERE */
|
||
|
||
/* D O F O R M A T P A R A */
|
||
DoFormatPara(rgval)
|
||
VAL rgval[];
|
||
{
|
||
/* add para sprms */
|
||
|
||
int val, ival;
|
||
int *pval;
|
||
int sprm;
|
||
struct PAP *ppap;
|
||
typeCP dcp;
|
||
typeCP cpFirst, cpLim;
|
||
struct SEL selSave;
|
||
/* this temp array is used to assemble sprm values */
|
||
CHAR rgb[cchTBD * itbdMax + 2/* >> cwPAPBase */];
|
||
int rgw[cwPAPBase];
|
||
ppap = (struct PAP *)&rgw[0];
|
||
|
||
if (!FWriteOk( fwcNil ))
|
||
return;
|
||
|
||
#ifdef ENABLE /* no ClearRulerSprm yet */
|
||
if (docRulerSprm != docNil) ClearRulerSprm();
|
||
#endif
|
||
ExpandCurSel(&selSave);
|
||
|
||
dcp = (cpLim = selCur.cpLim) - (cpFirst = selCur.cpFirst);
|
||
if (cpLim > cpMacCur)
|
||
{
|
||
SetUndo(uacReplNS, docCur, cpFirst, dcp,
|
||
docNil, cpNil, dcp - ccpEol, 0);
|
||
InsertEolInsert(docCur, cpMacCur);
|
||
}
|
||
else
|
||
SetUndo(uacReplNS, docCur, cpFirst, dcp,
|
||
docNil, cpNil, dcp, 0);
|
||
/* reset adjusted selCur */
|
||
selCur.cpFirst = cpFirst;
|
||
selCur.cpLim = cpLim;
|
||
|
||
for (ival = 0; ival <= 2; ival++)
|
||
if ((val = rgval[ival]) != valNil)
|
||
{
|
||
switch(ival)
|
||
{
|
||
case 0:
|
||
sprm = sprmPLMarg;
|
||
break;
|
||
case 1:
|
||
sprm = sprmPFIndent;
|
||
break;
|
||
case 2:
|
||
sprm = sprmPRMarg;
|
||
break;
|
||
}
|
||
/* we come here with one word value */
|
||
bltbyte(&val, &rgb[1], cchINT);
|
||
rgb[0] = sprm;
|
||
AddSprm(rgb);
|
||
}
|
||
|
||
#ifdef RULERALSO /* tabs in format para dialog box */
|
||
if (vfTabsChanged)
|
||
{
|
||
int itbd;
|
||
int cchRgtbd;
|
||
/* some tab changes were also made in the ruler */
|
||
for (itbd = 0; rgtbdRuler[itbd].dxa != 0; itbd++);
|
||
bltbyte((CHAR *)rgtbdRuler, &rgb[2], cchRgtbd = cwTBD * cchINT * itbd);
|
||
rgb[1] = cchRgtbd;
|
||
rgb[0] = sprmPRgtbd;
|
||
AddSprm(rgb);
|
||
}
|
||
#endif
|
||
|
||
EndLookSel(&selSave, fTrue);
|
||
#ifdef ENABLE
|
||
SetRgvalAgain(rgval, uacFormatPara);
|
||
#endif
|
||
} /* end of DoFormatPara */
|
||
#endif /* MEMO, not CASHMERE */
|
||
|
||
|
||
/* P U T P A R A N U M */
|
||
/* convert n according to unit ut, and leave result in stBuf */
|
||
PutParaNum(n, ut)
|
||
int n, ut;
|
||
{
|
||
CHAR *pch = &stBuf[1];
|
||
stBuf[0] = CchExpZa(&pch, n, ut, cchMaxNum);
|
||
}
|
||
|
||
|
||
BOOL far PASCAL DialogParaFormats( hDlg, message, wParam, lParam )
|
||
HWND hDlg; /* Handle to the dialog box */
|
||
unsigned message;
|
||
WORD wParam;
|
||
LONG lParam;
|
||
{
|
||
/* This routine handles input to the Paragraph Formats dialog box. */
|
||
extern struct SEP vsepNormal;
|
||
extern int ferror;
|
||
unsigned dxaText;
|
||
int wLowLim;
|
||
int i;
|
||
TSV rgtsv[itsvchMax]; /* gets attributes and gray flags from CHP */
|
||
|
||
switch (message)
|
||
{
|
||
case WM_INITDIALOG:
|
||
#ifdef RULERALSO /* enable out because no need to bring ruler up */
|
||
InitSpecialDialog(&vhDlgIndent, hDlg);
|
||
#else
|
||
EnableOtherModeless(FALSE);
|
||
#endif
|
||
GetRgtsvPapSel(rgtsv); /* get paragraph properties */
|
||
|
||
/* note the following loop assumes that the
|
||
itsv Indent codes are in the same order as
|
||
the idiPar Indent codes */
|
||
|
||
for (i = 0; i < 3; i++)
|
||
if (rgtsv[itsvLIndent + i].fGray == 0)
|
||
{
|
||
PutParaNum(rgtsv[itsvLIndent + i].wTsv, utCur);
|
||
SetDlgItemText(hDlg, (idiParLfIndent + i),
|
||
(LPSTR)&stBuf[1]);
|
||
}
|
||
|
||
SelectIdiText(hDlg, idiParLfIndent);
|
||
break;
|
||
|
||
case WM_SETVISIBLE:
|
||
if (wParam)
|
||
EndLongOp(vhcArrow);
|
||
return(FALSE);
|
||
|
||
case WM_ACTIVATE:
|
||
if (wParam)
|
||
vhWndMsgBoxParent = hDlg;
|
||
if (vfCursorVisible)
|
||
ShowCursor(wParam);
|
||
return(FALSE); /* so that we leave the activate message to
|
||
the dialog manager to take care of setting the focus right */
|
||
|
||
case WM_COMMAND:
|
||
switch (wParam)
|
||
{
|
||
case idiOk:
|
||
/* Get xaLeft, First line, and xaRight */
|
||
if (!WPdxaFromItDxa2WId(&rgval[0], hDlg, idiParLfIndent, 0, dxaText = vsepNormal.dxaText,
|
||
wBlank | wSpaces, IDPMTNOTDXA))
|
||
{
|
||
ferror = FALSE; /* minor error, stay in dialog */
|
||
break;
|
||
}
|
||
if (rgval[0] == valNil)
|
||
wLowLim = 0;
|
||
else
|
||
wLowLim = (int) -rgval[0];
|
||
if (!WPdxaFromItDxa2WId(&rgval[1], hDlg, idiParFirst, wLowLim, dxaText,
|
||
wBlank | wSpaces, IDPMTNOTDXA) ||
|
||
!WPdxaFromItDxa2WId(&rgval[2], hDlg, idiParRtIndent, 0, dxaText,
|
||
wBlank | wSpaces, IDPMTNOTDXA))
|
||
{
|
||
ferror = FALSE; /* minor error, stay in dialog */
|
||
break;
|
||
}
|
||
/* we have in rgval:
|
||
0 xaLeft
|
||
1 xaLeft1
|
||
2 xaRight */
|
||
DoFormatPara(rgval);
|
||
/* FALL THROUGH */
|
||
case idiCancel:
|
||
#ifdef RULERALSO /* enable out because no need to bring up ruler */
|
||
CancelSpecialDialog(&vhDlgIndent);
|
||
#else
|
||
OurEndDialog(hDlg, TRUE);
|
||
#endif
|
||
break;
|
||
default:
|
||
return(FALSE);
|
||
}
|
||
break;
|
||
|
||
case WM_CLOSE:
|
||
#ifdef RULERALSO /* enable out because no need to bring up ruler */
|
||
CancelSpecialDialog(&vhDlgIndent);
|
||
#else
|
||
OurEndDialog(hDlg, TRUE);
|
||
#endif
|
||
break;
|
||
|
||
default:
|
||
return(FALSE);
|
||
}
|
||
return(TRUE);
|
||
}
|
||
/* end of DialogParaFormats */
|
||
|
||
|
||
#ifdef RULERALSO/* no need to bring up ruler when tab or indent dialog box was invoked */
|
||
InitSpecialDialog(phDlg, hDlg)
|
||
HANDLE *phDlg;
|
||
HANDLE hDlg;
|
||
{
|
||
/* Special dialog box is a modal dialog box that needs to invoke a ruler if
|
||
not already there. Since the ruler is a child window, the parent has to
|
||
be enabled and other children except the ruler and/or modeless dialog
|
||
boxes has to be disabled. Top level menu and the system menu have to
|
||
be locked.
|
||
|
||
phDlg : address of the global handle to store the special
|
||
dialog created (ptr to either vhDlgIndent or vhDlgTab)
|
||
Ruler relies on these global handle to see if need to
|
||
update any dialog's items when tabs or indents are moved.
|
||
hDlg : handle to the special dialog box created.
|
||
*/
|
||
|
||
*phDlg = hDlg;
|
||
EnableOtherModeless(FALSE); /* disable other modeless dialogs */
|
||
EnableWindow(hParentWw, TRUE);
|
||
EnableWindow(wwdCurrentDoc.wwptr, FALSE);
|
||
if (!pwwdCur->fRuler)
|
||
{
|
||
vfTempRuler = TRUE;
|
||
pwwdCur->fRuler = TRUE;
|
||
CreateRuler();
|
||
}
|
||
else
|
||
UpdateRuler();
|
||
vfTabsChanged = FALSE;
|
||
vfDisableMenus = TRUE;
|
||
} /* InitSpecialDialog */
|
||
|
||
|
||
CancelSpecialDialog(phDlg)
|
||
HANDLE * phDlg;
|
||
{
|
||
/* Destroy the special dialog box involves destroying the ruler if it is
|
||
invoked by the creation of the dialog box, then enable the children
|
||
and/or any modeless dialogs that were disabled in InitSpecialDialog.
|
||
System menu and the top level menu has to be unlocked.
|
||
The last thing is to reset the global dialog handle (vhDlgTab or
|
||
vhDlgIndent). Ruler relies on these global handle to see if need to
|
||
update any dialog's items when tabs or indents are moved.
|
||
|
||
phDlg : address of the global handle that stores the special
|
||
dialog created (ptr to either vhDlgIndent or vhDlgTab)
|
||
*/
|
||
HANDLE hDlg = *phDlg;
|
||
|
||
if (vfTempRuler)
|
||
{
|
||
DestroyRuler();
|
||
vfTempRuler = FALSE;
|
||
pwwdCur->fRuler = FALSE;
|
||
}
|
||
else
|
||
UpdateRuler();
|
||
EndDialog(hDlg, TRUE);
|
||
EnableWindow(wwdCurrentDoc.wwptr, TRUE);
|
||
EnableOtherModeless(TRUE); /* enable other modeless dialogs */
|
||
*phDlg = (HANDLE)NULL;
|
||
vfDisableMenus = FALSE;
|
||
|
||
} /* CancelSpecialDialog */
|
||
#endif /* RULERALSO -- no need to bring up ruler when tab or indent dialog box is invoked */
|
||
|