418 lines
10 KiB
C
418 lines
10 KiB
C
/************************************************************/
|
||
/* Windows Write, Copyright 1985-1992 Microsoft Corporation */
|
||
/************************************************************/
|
||
|
||
/* doprm.c -- MW Property modifying routines */
|
||
#define NOCLIPBOARD
|
||
#define NOGDICAPMASKS
|
||
#define NOCTLMGR
|
||
#define NOVIRTUALKEYCODES
|
||
#define NOWINMESSAGES
|
||
#define NOWINSTYLES
|
||
#define NOSYSMETRICS
|
||
#define NOMENUS
|
||
#define NOICON
|
||
#define NOKEYSTATE
|
||
#define NORASTEROPS
|
||
#define NOSHOWWINDOW
|
||
#define NOSYSCOMMANDS
|
||
#define NOCREATESTRUCT
|
||
#define NOATOM
|
||
#define NOMETAFILE
|
||
#define NOGDI
|
||
#define NOFONT
|
||
#define NOBRUSH
|
||
#define NOPEN
|
||
#define NOBITMAP
|
||
#define NOCOLOR
|
||
#define NODRAWTEXT
|
||
#define NOWNDCLASS
|
||
#define NOSOUND
|
||
#define NOCOMM
|
||
#define NOMB
|
||
#define NOMSG
|
||
#define NOOPENFILE
|
||
#define NORESOURCE
|
||
#define NOPOINT
|
||
#define NORECT
|
||
#define NOREGION
|
||
#define NOSCROLL
|
||
#define NOTEXTMETRIC
|
||
#define NOWH
|
||
#define NOWINOFFSETS
|
||
#include <windows.h>
|
||
|
||
#include "mw.h"
|
||
#include "cmddefs.h"
|
||
#include "filedefs.h"
|
||
#include "propdefs.h"
|
||
#include "prmdefs.h"
|
||
#include "fkpdefs.h"
|
||
#include "docdefs.h"
|
||
#include "macro.h"
|
||
#include "dispdefs.h"
|
||
#include "fontdefs.h"
|
||
|
||
/* E X T E R N A L S */
|
||
extern int rgxaRulerSprm[];
|
||
extern struct PAP *vppapNormal;
|
||
extern struct CHP vchpNormal;
|
||
extern CHAR dnsprm[];
|
||
extern struct CHP vchpNormal;
|
||
extern struct SEP vsepStd;
|
||
extern struct SEP vsepNormal;
|
||
|
||
#ifdef CASHMERE
|
||
extern struct TBD rgtbdRulerSprm[];
|
||
#endif
|
||
|
||
/* List of approved font sizes, in half points */
|
||
#ifdef INTL
|
||
int rghps[csizeApprovedMax] = {8, 12, 16, 20, 24, 28, 36, 48, 60, 72, 96, 144, 254};
|
||
#else
|
||
int rghps[csizeApprovedMax] = {8, 12, 16, 20, 24, 32, 40, 48, 60, 72, 96, 144, 254};
|
||
#endif /* if-else-def INTL */
|
||
|
||
CHAR *PchFromFc();
|
||
|
||
|
||
/* D O P R M */
|
||
DoPrm(struct CHP *pchp, struct PAP *ppap, struct PRM prm)
|
||
{ /* Apply prm to char and para properties */
|
||
if (bPRMNIL(prm))
|
||
return;
|
||
if (((struct PRM *) &prm)->fComplex)
|
||
{
|
||
int cch;
|
||
CHAR *pfsprm;
|
||
struct FPRM *pfprm = (struct FPRM *) PchFromFc(fnScratch,
|
||
fcSCRATCHPRM(prm), &cch);
|
||
|
||
cch = pfprm->cch;
|
||
pfsprm = pfprm->grpfsprm;
|
||
|
||
while (cch > 0)
|
||
{
|
||
int cchT;
|
||
int sprm;
|
||
|
||
DoSprm(pchp, ppap, sprm = *pfsprm, pfsprm + 1);
|
||
if ((cchT = (dnsprm[sprm] & ESPRM_cch)) == 0)
|
||
cchT = CchPsprm(pfsprm);
|
||
cch -= cchT;
|
||
pfsprm += cchT;
|
||
}
|
||
}
|
||
else
|
||
/* Simple prm; single sprm */
|
||
DoSprm(pchp, ppap, ((struct PRM *) &prm)->sprm,
|
||
&((struct PRM *) &prm)->val);
|
||
}
|
||
|
||
/* D O S P R M */
|
||
/* Apply a single property modifier to para/char prop */
|
||
DoSprm(pchp, ppap, sprm, pval)
|
||
struct CHP *pchp;
|
||
struct PAP *ppap;
|
||
int sprm;
|
||
CHAR *pval;
|
||
{
|
||
int *pvalTo;
|
||
int val = *pval;
|
||
|
||
#ifdef DEBUG
|
||
Assert(sprm > 0 && sprm < sprmMax);
|
||
#endif
|
||
if ((dnsprm[sprm] & ESPRM_sgc) != sgcChar)
|
||
{
|
||
if (ppap != 0)
|
||
{
|
||
struct TBD *ptbd;
|
||
int rhc;
|
||
int fGraphics;
|
||
|
||
ppap->fStyled = fFalse;
|
||
switch (sprm)
|
||
{
|
||
case sprmPLMarg:
|
||
pvalTo = &ppap->dxaLeft;
|
||
break;
|
||
case sprmPRMarg:
|
||
pvalTo = &ppap->dxaRight;
|
||
break;
|
||
case sprmPFIndent:
|
||
pvalTo = &ppap->dxaLeft1;
|
||
break;
|
||
case sprmPJc:
|
||
ppap->jc = val;
|
||
return;
|
||
#ifdef CASHMERE
|
||
case sprmPRuler:
|
||
/* Ruler and Ruler1 rely on the fact that rgxaRulerSprm and PAP both
|
||
align R, L, L1 in that order.
|
||
Ruler: apply the current state of the ruler */
|
||
blt(&rgxaRulerSprm[0], &ppap->dxaRight, 3);
|
||
blt(&rgtbdRulerSprm[0], ppap->rgtbd, itbdMax * cwTBD);
|
||
return;
|
||
case sprmPRuler1:
|
||
/* as Ruler, except information is at pval+1 and pval+"7" */
|
||
bltbyte((CHAR *)(pval + 1), &ppap->dxaRight, 3 * cchINT);
|
||
/* append terminating 0 word to tab table */
|
||
bltc(bltbyte((CHAR *)(pval + 1 + (3 * cchINT)), ppap->rgtbd,
|
||
val - (3 * cchINT)), 0, cchINT);
|
||
return;
|
||
case sprmPRgtbd:
|
||
bltc(bltbyte(pval + 1, ppap->rgtbd,
|
||
val), 0, cchINT);
|
||
return;
|
||
case sprmPKeep:
|
||
ppap->fKeep = val;
|
||
return;
|
||
case sprmPKeepFollow:
|
||
ppap->fKeepFollow = val;
|
||
return;
|
||
#endif
|
||
case sprmPDyaLine:
|
||
pvalTo = &ppap->dyaLine;
|
||
break;
|
||
#ifdef CASHMERE
|
||
case sprmPDyaBefore:
|
||
pvalTo = &ppap->dyaBefore;
|
||
break;
|
||
case sprmPDyaAfter:
|
||
pvalTo = &ppap->dyaAfter;
|
||
break;
|
||
#endif
|
||
case sprmPRhc:
|
||
ppap->rhc = val;
|
||
return;
|
||
case sprmPRhcNorm:
|
||
/* (int) dxaLeftAdj + (int) dxaRightAdj */
|
||
Assert(*pval == 4);
|
||
pval++; /* skip over cch */
|
||
ppap->dxaLeft = imax( 0,
|
||
ppap->dxaLeft - *(int *) pval);
|
||
ppap->dxaRight = imax( 0,
|
||
ppap->dxaRight - *((int *) pval + 1));
|
||
return;
|
||
case sprmPNormal:
|
||
rhc = ppap->rhc;
|
||
fGraphics = ppap->fGraphics;
|
||
blt(vppapNormal, ppap, cwPAPBase);
|
||
goto LSame;
|
||
case sprmPSame:
|
||
rhc = ppap->rhc;
|
||
fGraphics = ppap->fGraphics;
|
||
/* note: tab terminating 0 MUST be part of value if tab table is to be changed */
|
||
bltbyte(pval + 1, ppap, val - 1);
|
||
LSame: ppap->rhc = rhc;
|
||
ppap->fGraphics = fGraphics;
|
||
return;
|
||
#ifdef CASHMERE
|
||
case sprmPNest:
|
||
if (ppap->rgtbd[0].dxa != 0 &&
|
||
ppap->rgtbd[0].dxa == ppap->dxaLeft &&
|
||
ppap->rgtbd[1].dxa == 0)
|
||
ppap->rgtbd[0].dxa += dxaNest;
|
||
ppap->dxaLeft += dxaNest;
|
||
return;
|
||
case sprmPUnNest:
|
||
if (ppap->rgtbd[0].dxa != 0 &&
|
||
ppap->rgtbd[0].dxa == ppap->dxaLeft &&
|
||
ppap->rgtbd[1].dxa == 0)
|
||
ppap->rgtbd[0].dxa -= dxaNest;
|
||
ppap->dxaLeft = max(0, (int)(ppap->dxaLeft - dxaNest));
|
||
return;
|
||
case sprmPHang:
|
||
ppap->dxaLeft = umin(ppap->dxaLeft + cxaInch, xaRightMax - cxaInch);
|
||
ppap->dxaLeft1 = -cxaInch;
|
||
ptbd = &ppap->rgtbd[0];
|
||
SetWords(ptbd, 0, cwTBD * 2);
|
||
ptbd->dxa = ppap->dxaLeft;
|
||
/* Inefficient:
|
||
ptbd->tlc = tlcWhite;
|
||
ptbd->jc = jcLeft;
|
||
++ptbd->dxa = 0 */
|
||
return;
|
||
#endif
|
||
default:
|
||
Assert(FALSE);
|
||
return;
|
||
}
|
||
/* common portion for those transferring a single word */
|
||
bltbyte(pval, pvalTo, cchINT);
|
||
}
|
||
return;
|
||
}
|
||
else
|
||
{
|
||
if (pchp != 0)
|
||
{
|
||
int fSpecial;
|
||
int ftc, hps;
|
||
|
||
pchp->fStyled = fFalse;
|
||
switch (sprm)
|
||
{
|
||
/* CHARACTER sprm's */
|
||
case sprmCBold:
|
||
pchp->fBold = val;
|
||
return;
|
||
case sprmCItalic:
|
||
pchp->fItalic = val;
|
||
return;
|
||
case sprmCUline:
|
||
pchp->fUline = val;
|
||
return;
|
||
#ifdef CASHMERE
|
||
case sprmCOutline:
|
||
pchp->fOutline = val;
|
||
return;
|
||
case sprmCShadow:
|
||
pchp->fShadow = val;
|
||
return;
|
||
case sprmCCsm:
|
||
pchp->csm = val;
|
||
return;
|
||
#endif
|
||
case sprmCPos:
|
||
/* If going in or out of sub/superscript, alter font size */
|
||
if (pchp->hpsPos == 0 && val != 0)
|
||
pchp->hps = HpsAlter(pchp->hps, -1);
|
||
else if (pchp->hpsPos != 0 && val == 0)
|
||
pchp->hps = HpsAlter(pchp->hps, 1);
|
||
pchp->hpsPos = val;
|
||
return;
|
||
case sprmCFtc:
|
||
case sprmCChgFtc:
|
||
pchp->ftc = val & 0x003f;
|
||
pchp->ftcXtra = (val & 0x00c0) >> 6;
|
||
return;
|
||
case sprmCHps:
|
||
pchp->hps = val;
|
||
return;
|
||
case sprmCChgHps:
|
||
pchp->hps = HpsAlter(pchp->hps,
|
||
val >= 128 ? val - 256 : val); /* sign extend from char to int */
|
||
return;
|
||
case sprmCSame:
|
||
fSpecial = pchp->fSpecial;
|
||
bltbyte(pval, pchp, cchCHP);
|
||
pchp->fSpecial = fSpecial;
|
||
return;
|
||
case sprmCPlain:
|
||
fSpecial = pchp->fSpecial;
|
||
ftc = FtcFromPchp(pchp);
|
||
hps = pchp->hps;
|
||
/* If we used to be sub/superscript, increase font size */
|
||
if (pchp->hpsPos != 0)
|
||
hps = HpsAlter(hps, 1);
|
||
blt(&vchpNormal, pchp, cwCHP);
|
||
pchp->fSpecial = fSpecial;
|
||
pchp->ftc = ftc & 0x003f;
|
||
pchp->ftcXtra = (ftc & 0x00c0) >> 6;
|
||
pchp->hps = hps;
|
||
return;
|
||
case sprmCMapFtc:
|
||
/* val is ftcMac for mapping */
|
||
/* pval+1 points to ftcMac mapping bytes */
|
||
ftc = pchp->ftc + (pchp->ftcXtra << 6);
|
||
Assert(ftc < val);
|
||
ftc = *(pval + 1 + ftc);
|
||
pchp->ftc = ftc & 0x003f;
|
||
pchp->ftcXtra = (ftc & 0x00c0) >> 6;
|
||
return;
|
||
case sprmCOldFtc:
|
||
ftc = pchp->ftc + (pchp->ftcXtra << 6);
|
||
ftc = FtcMapOldFtc(ftc, pval);
|
||
pchp->ftc = ftc & 0x003f;
|
||
pchp->ftcXtra = (ftc & 0x00c0) >> 6;
|
||
return;
|
||
default:
|
||
Assert(FALSE);
|
||
return;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
/* C C H P S P R M */
|
||
/* returns length of sprm's that are of variable or large size.
|
||
(cch = (esprm & ESPRM_cch)) == 0 must be checked before calling.*/
|
||
CchPsprm(psprm)
|
||
CHAR *psprm;
|
||
{
|
||
return (*psprm == sprmCSame ? cchCHP + 1 :
|
||
/* PSame, PRgtbd, PRuler1, CMapFtc, COldFtc: */
|
||
*(psprm + 1) + 2);
|
||
}
|
||
|
||
int HpsAlter(hps, ialter)
|
||
int hps, ialter;
|
||
{ /* Return the hps of the approved font size that is ialter steps
|
||
away from the given size. I.e.: if ialter is -1, then return
|
||
the next smaller size. If alter is 0, return hps. */
|
||
/* return 0 if request exceeds limits (11.15.91) v-dougk */
|
||
int isize;
|
||
|
||
if (ialter == 0)
|
||
return hps;
|
||
|
||
/* Find the size just larger than the given size. */
|
||
if (ialter > 0)
|
||
{
|
||
for (isize = 0; isize < csizeApprovedMax - 1; ++isize)
|
||
if (rghps[isize] > hps) break;
|
||
isize = min(csizeApprovedMax - 1, isize + ialter - 1);
|
||
return max(hps, rghps[isize]);
|
||
}
|
||
else
|
||
{
|
||
for (isize = 0; isize < csizeApprovedMax; ++isize)
|
||
if (rghps[isize] >= hps) break;
|
||
isize = max(0, isize + ialter);
|
||
return min(hps, rghps[isize]);
|
||
}
|
||
}
|
||
|
||
BOOL CanChangeFont(int howmuch)
|
||
{
|
||
extern struct CHP vchpSel;
|
||
extern struct SEL selCur;
|
||
int hps;
|
||
|
||
if (selCur.cpFirst != selCur.cpLim)
|
||
return TRUE;
|
||
|
||
hps = HpsAlter(vchpSel.hps, howmuch);
|
||
return ((hps <= rghps[csizeApprovedMax-1]) &&
|
||
(hps >= rghps[0]));
|
||
}
|
||
|
||
FtcMapOldFtc(ftc, ftctb)
|
||
/* maps an old word font code into one of our selection */
|
||
|
||
int ftc;
|
||
CHAR *ftctb;
|
||
{
|
||
#ifdef WIN30
|
||
int iftc = iftcSwiss; /* Default to SOMEthing! ..pault */
|
||
#else
|
||
int iftc ;
|
||
#endif
|
||
|
||
if (ftc == 8)
|
||
/* helvetica */
|
||
iftc = iftcSwiss;
|
||
else if (ftc < 16)
|
||
iftc = iftcModern;
|
||
else if (ftc < 32)
|
||
iftc = iftcRoman;
|
||
else if (ftc < 40)
|
||
iftc = iftcScript;
|
||
else if (ftc < 48)
|
||
iftc = iftcDecorative;
|
||
Assert(iftc < *ftctb);
|
||
return(*(ftctb + 1 + iftc));
|
||
}
|
||
|