2020-09-30 16:53:55 +02:00

419 lines
8.2 KiB
C
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/************************************************************/
/* Windows Write, Copyright 1985-1992 Microsoft Corporation */
/************************************************************/
/* util2.c -- less frequently used utility routines */
#define NOVIRTUALKEYCODES
#define NOCTLMGR
#define NOWINMESSAGES
#define NOWINSTYLES
#define NOCLIPBOARD
#define NOGDICAPMASKS
#define NOSYSMETRICS
#define NOMENUS
#define NOCOMM
#define NOSOUND
#include <windows.h>
#include "mw.h"
#include "doslib.h"
#include "str.h"
#include "machdefs.h"
#include "cmddefs.h"
#include "propdefs.h"
#include "fkpdefs.h"
#include "docdefs.h"
#include "debug.h"
#include "editdefs.h"
#include "wwdefs.h"
#define NOKCCODES
#include "ch.h"
extern struct DOD (**hpdocdod)[];
extern HANDLE hMmwModInstance;
extern CHAR vchDecimal; /* "decimal point" character */
extern int viDigits;
extern BOOL vbLZero;
CHAR *PchFillPchId(PCH, int, int);
FillStId(st, idpmt, cchIn)
CHAR *st;
IDPMT idpmt;
int cchIn;
{ /* load string from resource file to buffer, the string is zero
terminated, make it into a st, i.e. cch (excluding '\0' is stored
in the 1st byte of the string) */
int cch = LoadString(hMmwModInstance, idpmt, (LPSTR)&st[1], cchIn-1);
Assert(cch != 0);
st[0] = cch;
} /* FillStId */
CHAR *PchFillPchId(sz, idstr, cchIn)
register CHAR * sz;
register int idstr;
int cchIn;
{ /*
Description: load string from resource file to buffer, the
string loaded is zero terminated
Returns: pointer to '\0' last loaded
*/
int cch = LoadString(hMmwModInstance, idstr, (LPSTR)sz, cchIn);
/* Note: cch does not include the '\0' */
{
char msg[80];
if (cch == 0)
{
wsprintf(msg,"bad resource id: 0x%x\n\r",idstr);
OutputDebugString(msg);
}
Assert(cch != 0);
}
return(sz + cch);
} /* end of PchFillPchId */
int FDirtyDoc(doc)
register int doc;
{ /* Return true if killing this doc would lose editing */
register struct DOD *pdod;
return ((pdod = &(**hpdocdod)[doc])->fDirty && pdod->cref == 1);
} /* end of F D i r t y D o c */
int ncvtu(n, ppch)
register int n;
CHAR **ppch;
{
register int cch = 0;
if (n < 0)
{
*(*ppch)++ = '-';
n = -n;
++cch;
}
if (n >= 10)
{
cch += ncvtu(n / 10, ppch);
n %= 10;
}
else if ((n == 0) && !vbLZero) // then no leading zero
return 0;
*(*ppch)++ = '0' + n;
return cch + 1;
} /* end of n c v t uR */
HANDLE HszGlobalCreate( sz )
CHAR *sz;
{ /* Create handle for string in global windows heap. return the handle. */
HANDLE h;
LPCH lpch;
int cch=CchSz( sz );
if ((h=GlobalAlloc( GMEM_MOVEABLE, (LONG)cch )) != NULL)
{
if ((lpch = GlobalLock( h )) != NULL )
{
bltbx( (LPSTR) sz, lpch, cch );
GlobalUnlock( h );
}
else
{
GlobalFree( h );
return NULL;
}
}
return h;
}
#ifdef DEBUG
fnScribble( dchPos, ch )
int dchPos;
CHAR ch;
{ /* Scribble a char dchPos char positions from the UR screen corner */
/* We create a special device context to avoid interfering with the */
/* ones MEMO uses */
extern struct WWD rgwwd[];
static unsigned dxpScribbleChar=0;
static unsigned dypScribbleChar;
static unsigned ypScribble;
int xp = wwdCurrentDoc.xpMac - (dxpScribbleChar * (dchPos+1));
int ilevel = SaveDC( wwdCurrentDoc.hDC );
SelectObject( wwdCurrentDoc.hDC, GetStockObject(ANSI_FIXED_FONT) );
if ( dxpScribbleChar == 0 )
{ /* First time through */
TEXTMETRIC tm;
GetTextMetrics( wwdCurrentDoc.hDC, (LPTEXTMETRIC)&tm );
dxpScribbleChar = tm.tmAveCharWidth;
dypScribbleChar = tm.tmHeight + tm.tmInternalLeading;
ypScribble = (dypScribbleChar >> 2) + wwdCurrentDoc.ypMin;
}
PatBlt( wwdCurrentDoc.hDC, xp, ypScribble, dxpScribbleChar, dypScribbleChar,
WHITENESS );
TextOut( wwdCurrentDoc.hDC, xp, ypScribble, (LPSTR) &ch, 1 );
RestoreDC( wwdCurrentDoc.hDC, ilevel );
}
#endif /* DEBUG */
/* original util3.c starts from here */
#define iMaxOver10 3276
extern int utCur;
/* Must agree with cmddefs.h */
extern CHAR *mputsz[];
/* Must agree with cmddefs.h */
unsigned mputczaUt[utMax] =
{
czaInch, czaCm, czaP10, czaP12, czaPoint,
czaLine
};
int FZaFromSs(pza, ss, cch, ut)
int *pza;
CHAR ss[];
int cch,
ut;
{ /* Return za in *pza from string representation in ss. True if valid za */
long lza = 0;
register CHAR *pch = ss;
register CHAR *pchMac = &ss[cch];
int ch;
unsigned czaUt;
int fNeg;
if (cch <= 0)
return false;
switch (*--pchMac)
{ /* Check for units */
case 'n': /* inch */
if (*--pchMac != 'i')
goto NoUnits;
case '"': /* inch */
ut = utInch;
break;
#ifdef CASHMERE /* units such as pt, pt12, pt10 */
case '0': /* pt10 */
if (*--pchMac != '1' || *--pchMac != 'p')
goto NoUnits;
ut = utP10;
break;
case '2': /* pt12 */
if (*--pchMac != '1' || *--pchMac != 'p')
goto NoUnits;
ut = utP12;
break;
case 'i': /* line */
if (*--pchMac != 'l')
goto NoUnits;
ut = utLine;
break;
case 't': /* pt */
if (*--pchMac != 'p')
goto NoUnits;
ut = utPoint;
break;
#endif /* CASHMERE */
case 'm': /* cm */
if (*--pchMac != 'c')
goto NoUnits;
ut = utCm;
break;
default:
++pchMac;
break;
NoUnits:
pchMac = &ss[cch];
}
while (pch < pchMac && *(pchMac - 1) == chSpace)
--pchMac;
czaUt = mputczaUt[ut];
/* extract leading blanks */
while (*pch == ' ')
pch++;
fNeg = *pch == '-';
if (fNeg) ++pch; /* skip past minus sign */
while ((ch = *pch++) != vchDecimal)
{
if ((ch < '0' || ch > '9') || lza >= iMaxOver10)
return false;
lza = lza * 10 + (ch - '0') * czaUt;
if (pch >= pchMac)
goto GotNum;
}
while (pch < pchMac)
{
ch = *pch++;
if (ch < '0' || ch > '9')
return false;
lza += ((ch - '0') * czaUt + 5) / 10;
czaUt = (czaUt + 5) / 10;
}
GotNum:
if (lza > ((long) (22 * czaInch)))
return false;
*pza = fNeg ? (int) -lza : (int) lza;
return true;
}
int
CchExpZa(ppch, za, ut, cchMax)
CHAR **ppch;
int ut, cchMax;
register int za;
{ /* Stuff the expansion of linear measure za in unit ut into pch.
Return # of chars stuffed. Don't exceed cchMax. */
register int cch = 0;
unsigned czaUt;
int zu;
/* If not in point mode and even half line, display as half lines v. points */
if (ut == utPoint && utCur != utPoint &&
(za / (czaLine / 2) * (czaLine / 2)) == za)
ut = utLine;
czaUt = mputczaUt[ut];
if (cchMax < cchMaxNum)
return 0;
if (za < 0)
{ /* Output minus sign and make positive */
*(*ppch)++ = '-';
za = -za;
cch++;
}
/* round off to two decimal places */
za += czaUt / 200;
zu = za / czaUt; /* Get integral part */
cch += ncvtu(zu, ppch); /* Expand integral part */
za -= zu * czaUt; /* Retain fraction part */
if (((za *= 10) >= czaUt || za * 10 >= czaUt) && (viDigits > 0))
{ /* Check *10 first because of possible overflow */
zu = za / czaUt;
*(*ppch)++ = vchDecimal;
cch++;
*(*ppch)++ = '0' + zu;
cch++;
zu = ((za - zu * czaUt) * 10) / czaUt;
if ((zu != 0) && (viDigits > 1))
{
*(*ppch)++ = '0' + zu;
cch++;
}
}
if (cch <= 1)
/* force zeroes */
{
if ((cch == 0) && vbLZero) // then no leading zero
{
*(*ppch)++ = '0';
cch++;
}
*(*ppch)++ = vchDecimal;
cch++;
if (viDigits > 0)
{
*(*ppch)++ = '0';
cch++;
}
if (viDigits > 1)
{
*(*ppch)++ = '0';
cch++;
}
}
cch += CchStuff(ppch, mputsz[ut], cchMax - cch);
return cch;
}
#ifdef KEEPALL /* Use FPdxaFromItDxa2Id */
int DxaFromSt(st, ut)
register CHAR *st;
int ut;
{
int za;
if (*st > 0 && FZaFromSs(&za, st+1, *st, ut)) /* see util.c */
return za;
else
return valNil;
}
int DxaFromItem(it)
int it;
{
int za;
register CHAR stBuf[32];
GetItTextValue(it, stBuf);
if (*stBuf > 0 && FZaFromSs(&za, stBuf+1, *stBuf, utCur)) /* see util.c */
return (za == valNil) ? 0 : za;
else
return valNil;
}
#endif
int CchStuff(ppch, sz, cchMax)
CHAR **ppch, sz[];
int cchMax;
{
register int cch = 0;
register CHAR *pch = *ppch;
while (cchMax-- > 0 && (*pch = *sz++) != 0)
{
cch++;
pch++;
}
if (cchMax < 0)
bltbyte("...", pch - 3, 3);
*ppch = pch;
return cch;
}