; Minor fixes to last changes

* src/w32font.h:
* src/w32font.c:
* src/w32dwrite.c:
* etc/NEWS: Minor fixes of last changes.  (Bug#73730)
This commit is contained in:
Eli Zaretskii 2024-10-25 14:36:41 +03:00
parent edf37e811c
commit 222a5207c4
4 changed files with 25 additions and 21 deletions

View file

@ -790,8 +790,11 @@ supported. As on X, the user options 'dnd-scroll-margin' and
On Windows 8.1 and later versions Emacs now uses DirectWrite to draw
text, which supports color fonts. This can be disabled by setting the
variable 'w32-inhibit-dwrite' to t. Also see 'w32-dwrite-available' and
'w32-dwrite-reinit' to check availability and to configure render
parameters.
'w32-dwrite-reinit' to check availability and to configure the
DirectWrite rendering parameters.
To show color Emoji in Emacs, customize the default fontset to use a
color Emoji font installed on your system for the 'emoji' script.
----------------------------------------------------------------------

View file

@ -469,11 +469,11 @@ typedef struct IDWriteFactory2Vtbl {
interface IDWriteFactory2 {
CONST_VTBL IDWriteFactory2Vtbl* lpVtbl;
};
#else /* ifndef MINGW_W64 */
#else /* MINGW_W64 */
# include <dwrite_3.h>
#endif
/* User configurable variables. If they are lower than 0 use
/* User configurable variables. If they are smaller than 0, use
DirectWrite's defaults, or our defaults. To set them, the user calls
'w32-dwrite-reinit' */
static float config_enhanced_contrast = -1.0f;
@ -495,7 +495,7 @@ release_com (IUnknown **i)
}
}
#define RELEASE_COM(i) release_com ( (IUnknown **) &i )
#define RELEASE_COM(i) release_com ((IUnknown **) &i)
/* Global variables for DirectWrite. */
static bool direct_write_available = false;
@ -516,7 +516,7 @@ verify_hr (HRESULT hr, const char *msg)
return true;
}
/* Gets a IDWriteFontFace from a struct font (its HFONT). Returns the
/* Gets a IDWriteFontFace from a struct font (its HFONT). Returns the
font size in points. It may fail to get a DirectWrite font, and face
will be NULL on return. This happens for some fonts like Courier.
@ -560,10 +560,10 @@ get_font_face (struct font *infont, IDWriteFontFace **face)
}
/* Cache this FontFace. */
uniscribe_font->dwrite_font_size = abs (logfont.lfHeight);
uniscribe_font->dwrite_font_size = eabs (logfont.lfHeight);
uniscribe_font->dwrite_cache = *face;
return abs (logfont.lfHeight);
return eabs (logfont.lfHeight);
}
void
@ -642,7 +642,7 @@ text_extents_internal (IDWriteFontFace *dwrite_font_face,
if (metrics->rbearing < rbearing)
metrics->rbearing = rbearing;
}
metrics->width = round(width);
metrics->width = round (width);
SAFE_FREE ();
return true;
}
@ -794,7 +794,6 @@ w32_initialize_direct_write (void)
DebPrint (("DirectWrite HRESULT failed: (%d) QueryInterface IDWriteFactory2\n", hr));
RELEASE_COM (dwrite_factory);
FreeLibrary (direct_write);
eassert (SUCCEEDED (hr));
return;
}
@ -939,12 +938,12 @@ w32_dwrite_draw (HDC hdc, int x, int y, unsigned *glyphs, int len,
glyph_run.glyphIndices = indices;
glyph_run.glyphCount = len;
glyph_run.isSideways = false;
glyph_run.bidiLevel = 0;
glyph_run.bidiLevel = 0; /* we reorder bidi text ourselves */
glyph_run.glyphOffsets = NULL;
glyph_run.glyphAdvances = advances;
IDWriteColorGlyphRunEnumerator *layers;
/* This call will tell us if we hace to handle any color glyph. */
/* This call will tell us if we have to handle any color glyphs. */
hr = dwrite_factory2->lpVtbl->TranslateColorGlyphRun (dwrite_factory2,
0, font->ascent,
&glyph_run,
@ -965,8 +964,8 @@ w32_dwrite_draw (HDC hdc, int x, int y, unsigned *glyphs, int len,
NULL);
else
{
/* If there were color glyphs, layers contains a list of GlyphRun
with a color and a position for each. We draw them
/* If there were color glyphs, 'layers' contains a list of
GlyphRun with a color and a position for each. We draw them
individually. */
if (!verify_hr (hr, "Failed at TranslateColorGlyphRun"))
{
@ -1057,11 +1056,13 @@ DirectWrite will be used if it is available and 'w32-inhibit-dwrite' is nil. */
DEFUN ("w32-dwrite-reinit", Fw32_dwrite_reinit, Sw32_dwrite_reinit, 0, 3, 0,
doc: /* Reinitialize DirectWrite with the given parameters.
If a parameter is not specified, or is out of range, it will take a default
value. Returns nil.
value.
ENHANCED_CONTRAST is in the range [0.0, 1.0]
CLEAR_TYPE_LEVEL is in the range [0.0, 1.0]
GAMMA is in the range (0.0, 256.0] */)
Return value is nil.
ENHANCED_CONTRAST is in the range [0.0, 1.0], and defaults to 0.0.
CLEAR_TYPE_LEVEL is in the range [0.0, 1.0], and defaults to 0.0.
GAMMA is in the range (0.0, 256.0], and defaults to 2.2. */)
(Lisp_Object enhanced_contrast, Lisp_Object clear_type_level,
Lisp_Object gamma)
{

View file

@ -712,7 +712,7 @@ w32font_draw (struct glyph_string *s, int from, int to,
for (i = 0; i < len; i++)
if (!w32_use_direct_write (w32font) ||
!w32_dwrite_draw (s->hdc, x, y, s->char2b + from, 1,
GetTextColor(s->hdc), s->font))
GetTextColor (s->hdc), s->font))
{
WCHAR c = s->char2b[from + i] & 0xFFFF;
ExtTextOutW (s->hdc, x + i, y, options, NULL, &c, 1, NULL);
@ -722,7 +722,7 @@ w32font_draw (struct glyph_string *s, int from, int to,
{
if (!w32_use_direct_write (w32font) ||
!w32_dwrite_draw (s->hdc, x, y,
s->char2b + from, len, GetTextColor(s->hdc),
s->char2b + from, len, GetTextColor (s->hdc),
s->font))
{
/* The number of glyphs in a glyph_string cannot be larger than

View file

@ -112,7 +112,7 @@ bool w32_dwrite_draw (HDC hdc, int x, int y, unsigned *glyphs, int len,
bool w32_dwrite_text_extents (struct font *font, const unsigned *code,
int nglyphs, struct font_metrics *metrics);
unsigned w32_dwrite_encode_char (struct font *font, int c);
void w32_dwrite_free_cached_face(void *cache);
void w32_dwrite_free_cached_face (void *cache);
void syms_of_w32dwrite (void);
extern void globals_of_w32font (void);