From: Chong Yidong Date: Sun, 26 Jul 2009 12:58:56 +0000 (+0000) Subject: * nsfont.m (nsfont_draw): Revert 2009-07-15 change. X-Git-Tag: emacs-pretest-23.1.90~2024 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=4fbe2306e05a21f73a9a3ff90b0487c02fafa0d7;p=emacs.git * nsfont.m (nsfont_draw): Revert 2009-07-15 change. * nsterm.m (ns_maybe_dumpglyphs_background): Revert 2009-07-15 change. (ns_get_color): Revert 2009-07-16 change. --- diff --git a/src/ChangeLog b/src/ChangeLog index f9f1e335384..164fdbccce4 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,11 @@ +2009-07-26 Chong Yidong + + * nsfont.m (nsfont_draw): Revert 2009-07-15 change. + + * nsterm.m (ns_maybe_dumpglyphs_background): Revert 2009-07-15 + change. + (ns_get_color): Revert 2009-07-16 change. + 2009-07-25 Eli Zaretskii * lread.c (syms_of_lread) : New variable. diff --git a/src/nsfont.m b/src/nsfont.m index 100676762a8..89b42901f42 100644 --- a/src/nsfont.m +++ b/src/nsfont.m @@ -1097,19 +1097,15 @@ nsfont_draw (struct glyph_string *s, int from, int to, int x, int y, br.size.width -= 2*correction; } -#if 0 if (!s->face->stipple) -#endif [(NS_FACE_BACKGROUND (face) != 0 ? ns_lookup_indexed_color (NS_FACE_BACKGROUND (face), s->f) : FRAME_BACKGROUND_COLOR (s->f)) set]; -#if 0 /* This is tiling, not stippling. */ else { struct ns_display_info *dpyinfo = FRAME_NS_DISPLAY_INFO (s->f); [[dpyinfo->bitmaps[face->stipple-1].img stippleMask] set]; } -#endif NSRectFill (br); } diff --git a/src/nsterm.m b/src/nsterm.m index 6249f217281..6b5da82a511 100644 --- a/src/nsterm.m +++ b/src/nsterm.m @@ -1348,11 +1348,15 @@ ns_get_color (const char *name, NSColor **col) /* -------------------------------------------------------------------------- /* On *Step, we recognize several color formats, in addition to a catalog of colors found in the file Emacs.clr. Color formats include: - - #rrggbb where rr, gg, bb specify red, green and blue in hex. */ + - #rrggbb or RGBrrggbb where rr, gg, bb specify red, green and blue in hex + - ARGBaarrggbb is similar, with aa being the alpha channel (FF = opaque) + - HSVhhssvv and AHSVaahhssvv (or HSB/AHSB) are similar for hue, saturation, + value; + - CMYKccmmyykk is similar for cyan, magenta, yellow, black. */ { NSColor * new = nil; const char *hex = NULL; - enum { rgb } color_space; + enum { rgb, argb, hsv, ahsv, cmyk, gray } color_space; NSString *nsname = [NSString stringWithUTF8String: name]; /*fprintf (stderr, "ns_get_color: '%s'\n", name); */ @@ -1377,11 +1381,46 @@ ns_get_color (const char *name, NSColor **col) return 0; } + /* FIXME: emacs seems to downcase everything before passing it here, + which we can work around, except for GRAY, since gray##, where ## is + decimal between 0 and 99, is also an X11 colorname. */ if (name[0] == '#') /* X11 format */ { hex = name + 1; color_space = rgb; } + else if (!memcmp (name, "RGB", 3) || !memcmp (name, "rgb", 3)) + { + hex = name + 3; + color_space = rgb; + } + else if (!memcmp (name, "ARGB", 4) || !memcmp (name, "argb", 4)) + { + hex = name + 4; + color_space = argb; + } + else if (!memcmp (name, "HSV", 3) || !memcmp (name, "hsv", 3) || + !memcmp (name, "HSB", 3) || !memcmp (name, "hsb", 3)) + { + hex = name + 3; + color_space = hsv; + } + else if (!memcmp (name, "AHSV", 4) || !memcmp (name, "ahsv", 4) || + !memcmp (name, "AHSB", 4) || !memcmp (name, "ahsb", 4)) + { + hex = name + 4; + color_space = ahsv; + } + else if (!memcmp (name, "CMYK", 4) || !memcmp (name, "cmyk", 4)) + { + hex = name + 4; + color_space = cmyk; + } + else if (!memcmp (name, "GRAY", 4) /*|| !memcmp (name, "gray", 4)*/) + { + hex = name + 4; + color_space = gray; + } /* Direct colors (hex values) */ if (hex) @@ -1411,6 +1450,34 @@ ns_get_color (const char *name, NSColor **col) blue: f4 alpha: 1.0]; break; + case argb: + *col = [NSColor colorWithCalibratedRed: f2 + green: f3 + blue: f4 + alpha: f1]; + break; + case hsv: + *col = [NSColor colorWithCalibratedHue: f2 + saturation: f3 + brightness: f4 + alpha: 1.0]; + break; + case ahsv: + *col = [NSColor colorWithCalibratedHue: f2 + saturation: f3 + brightness: f4 + alpha: f1]; + break; + case gray: + *col = [NSColor colorWithCalibratedWhite: f3 alpha: f4]; + break; + case cmyk: + *col = [NSColor colorWithDeviceCyan: f1 + magenta: f2 + yellow: f3 + black: f4 + alpha: 1.0]; + break; } *col = [*col colorUsingColorSpaceName: NSCalibratedRGBColorSpace]; UNBLOCK_INPUT; @@ -2653,7 +2720,8 @@ ns_dumpglyphs_box_or_relief (struct glyph_string *s) r = ns_fix_rect_ibw (r, FRAME_INTERNAL_BORDER_WIDTH (s->f), FRAME_PIXEL_WIDTH (s->f)); - /* TODO: Sometimes box_color is 0 and this seems wrong; should investigate. */ if (s->face->box == FACE_SIMPLE_BOX && s->face->box_color) + /* TODO: Sometimes box_color is 0 and this seems wrong; should investigate. */ + if (s->face->box == FACE_SIMPLE_BOX && s->face->box_color) { ns_draw_box (r, abs (thickness), ns_lookup_indexed_color (face->box_color, s->f), @@ -2692,19 +2760,15 @@ ns_maybe_dumpglyphs_background (struct glyph_string *s, char force_p) } else face = FACE_FROM_ID (s->f, s->first_glyph->face_id); -#if 0 if (!face->stipple) -#endif [(NS_FACE_BACKGROUND (face) != 0 ? ns_lookup_indexed_color (NS_FACE_BACKGROUND (face), s->f) : FRAME_BACKGROUND_COLOR (s->f)) set]; -#if 0 /* This is tiling, not stippling. */ else { struct ns_display_info *dpyinfo = FRAME_NS_DISPLAY_INFO (s->f); [[dpyinfo->bitmaps[face->stipple-1].img stippleMask] set]; } -#endif if (s->hl != DRAW_CURSOR) {