* RE: About the :distant-foreground face attribute [not found] ` <<83fvowdf4j.fsf@gnu.org> @ 2014-01-09 22:27 ` Drew Adams 0 siblings, 0 replies; 57+ messages in thread From: Drew Adams @ 2014-01-09 22:27 UTC (permalink / raw) To: Eli Zaretskii, Drew Adams; +Cc: cyd, monnier, jan.h.d, emacs-devel > > > Why do you assume that the previous form will not be accepted? > > > Of course, it will be. > > > > Accepted by what? Are you thinking of `defface'? Why would you > > assume that I assume that? > > What else can you possibly think of, when we are talking about > defface? Yes, and why would you assume that I assume that the previous form would not be accepted by (an updated) `defface'? Of course I assume the opposite, as I said. I assume that you will DTRT for defface, to handle the new form. `defface' is not the problem I see. > > That's not the point. It's about being accepted by, recognized > > by, and useful for other, existing code. > > Other existing code should never see this. We are talking about > defface, and defface alone. At least I was. And I was not. I was talking, as Yidong pointed out, about existing code trying to deal with a redefined `foreground' attribute value (soon to be allowed to be a cons perhaps). First, the idea was to use an additional face attribute; lately, the talk is about a redefined attribute value, allowing it to be a list (of two strings), in addition to a string. IIUC. Mille excuses, if I did not understand the latest proposal correctly. ^ permalink raw reply [flat|nested] 57+ messages in thread
[parent not found: <<87bnzo9cja.fsf@gnu.org>]
[parent not found: <<59B7E7FC-48D0-4737-B1BB-FFAC5BA9E07A@swipnet.se>]
[parent not found: <<874n5f3162.fsf@gnu.org>]
[parent not found: <<83fvozf86g.fsf@gnu.org>]
[parent not found: <<87r48javwe.fsf@gnu.org>]
[parent not found: <<83bnzmfjxe.fsf@gnu.org>]
[parent not found: <<87bnzlyvwb.fsf@gnu.org>]
[parent not found: <<jwvppo1dr9r.fsf-monnier+emacs@gnu.org>]
[parent not found: <<b53f01f5-1974-417a-b95b-a7e1b6906467@default>]
[parent not found: <<83wqi9cakl.fsf@gnu.org>]
* RE: About the :distant-foreground face attribute [not found] ` <<83wqi9cakl.fsf@gnu.org> @ 2014-01-09 21:12 ` Drew Adams 2014-01-09 21:22 ` Eli Zaretskii 0 siblings, 1 reply; 57+ messages in thread From: Drew Adams @ 2014-01-09 21:12 UTC (permalink / raw) To: Eli Zaretskii, Drew Adams; +Cc: cyd, monnier, jan.h.d, emacs-devel > > > > been a source of annoyance over the years. Introducing > > > > another such situation should, in my view, be avoided as > > > > far as possible. > > > > > > That's a good point. Basically, what you're saying is that > > > instead of :distant-foreground we could have a :foreground that > > > can be of the form (NORMAL-FOREGROUND . ALTERNATE-FOREGROUND), > > > where ALTERNATE-FOREGROUND is used when NORMAL-FOREGROUND would > > > lead to a lack of contrast. > > > > Please don't. That too would break code that expects :foreground > > to be as it is now. > > Why do you assume that the previous form will not be accepted? Of > course, it will be. Accepted by what? Are you thinking of `defface'? Why would you assume that I assume that? I'm sure you will make `defface' etc. work. I'm sure that you will make all distributed `emacs -Q' code work, for this. That's not the point. It's about being accepted by, recognized by, and useful for other, existing code. If code expects a string foreground value then it is not designed to DTRT with a cons etc. This should be obvious, no? ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-09 21:12 ` Drew Adams @ 2014-01-09 21:22 ` Eli Zaretskii 0 siblings, 0 replies; 57+ messages in thread From: Eli Zaretskii @ 2014-01-09 21:22 UTC (permalink / raw) To: Drew Adams; +Cc: cyd, monnier, jan.h.d, emacs-devel > Date: Thu, 9 Jan 2014 13:12:59 -0800 (PST) > From: Drew Adams <drew.adams@oracle.com> > Cc: monnier@iro.umontreal.ca, cyd@gnu.org, jan.h.d@swipnet.se, > emacs-devel@gnu.org > > > Why do you assume that the previous form will not be accepted? Of > > course, it will be. > > Accepted by what? Are you thinking of `defface'? Why would you assume > that I assume that? What else can you possibly think of, when we are talking about defface? > That's not the point. It's about being accepted by, recognized by, and > useful for other, existing code. Other existing code should never see this. We are talking about defface, and defface alone. At least I was. ^ permalink raw reply [flat|nested] 57+ messages in thread
* About the :distant-foreground face attribute @ 2014-01-07 12:55 Chong Yidong 2014-01-07 15:00 ` Jan Djärv 2014-01-08 3:13 ` Darren Hoo 0 siblings, 2 replies; 57+ messages in thread From: Chong Yidong @ 2014-01-07 12:55 UTC (permalink / raw) To: emacs-devel What is the purpose of this face attribute, newly introduced for 24.4? It seems to be unused in Emacs itself. Is there a concrete example of this being needed in external packages or themes? First of all, the name :distant-foreground is not intuitive. What does "distant" mean in this context? Also, this feature has one ugly consequence. Previously, the `default' face must have all its face attributes specified, but now its :distant-foreground face is unspecified. Besides that, the implementation seems rather incomplete. The Customize interface, `modify-face', `face-spec-reset-face', and other parts of Emacs haven't been updated for the existence of this face attribute. It's unclear what functions like `face-foreground' should now do if there's a :distant-foreground. This all sounds like an invitation for more bugs. In my opinion, this feature is a bad idea. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-07 12:55 Chong Yidong @ 2014-01-07 15:00 ` Jan Djärv 2014-01-07 17:28 ` Drew Adams ` (2 more replies) 2014-01-08 3:13 ` Darren Hoo 1 sibling, 3 replies; 57+ messages in thread From: Jan Djärv @ 2014-01-07 15:00 UTC (permalink / raw) To: Chong Yidong; +Cc: emacs-devel Hello. 7 jan 2014 kl. 13:55 skrev Chong Yidong <cyd@gnu.org>: > What is the purpose of this face attribute, newly introduced for 24.4? Too lazy to read documentation? "`:distant-foreground' Alternative foreground color, a string. This is like `:foreground' but the color is only used as a foreground when the background color is near to the foreground that would have been used. This is useful for example when marking text (i.e. the region face). If the text has a foreground that is visible with the region face, that foreground is used. If the foreground is near the region face background, `:distant-foreground' is used instead so the text is readable. " > It seems to be unused in Emacs itself. Is there a concrete example of > this being needed in external packages or themes? Too lazy too read the code? faces.el: (defface region '((((class color) (min-colors 88) (background dark)) :background "blue3") (((class color) (min-colors 88) (background light) (type gtk)) :distant-foreground "gtk_selection_fg_color" :background "gtk_selection_bg_color") (((class color) (min-colors 88) (background light) (type ns)) :distant-foreground "ns_selection_fg_color" :background "ns_selection_bg_color") (((class color) (min-colors 88) (background light)) :background "lightgoldenrod2") (((class color) (min-colors 16) (background dark)) :background "blue3") (((class color) (min-colors 16) (background light)) :background "lightgoldenrod2") (((class color) (min-colors 8)) :background "blue" :foreground "white") (((type tty) (class mono)) :inverse-video t) (t :background "gray")) "Basic face for highlighting the region." :version "21.1" :group 'basic-faces) > > First of all, the name :distant-foreground is not intuitive. What does > "distant" mean in this context? > The same as in any other context, far removed from something else, i.e. the background. > Also, this feature has one ugly consequence. Previously, the `default' > face must have all its face attributes specified, but now its > :distant-foreground face is unspecified. Default face does not need to have its font specified, so this is not new. > > Besides that, the implementation seems rather incomplete. The Customize > interface, `modify-face', `face-spec-reset-face', and other parts of > Emacs haven't been updated for the existence of this face attribute. That is on purpose. It is supposed to be automatically calculated. > It's unclear what functions like `face-foreground' should now do if > there's a :distant-foreground. > No it is not. > This all sounds like an invitation for more bugs. In my opinion, this > feature is a bad idea. All new features invite new bugs, so are you saying we should never add new features? Your opinion is not very interesting, but if you have core for an alternative approach that would be interesting. Jan D. ^ permalink raw reply [flat|nested] 57+ messages in thread
* RE: About the :distant-foreground face attribute 2014-01-07 15:00 ` Jan Djärv @ 2014-01-07 17:28 ` Drew Adams 2014-01-07 18:01 ` Eli Zaretskii ` (2 more replies) 2014-01-07 21:57 ` Chong Yidong 2014-01-07 22:50 ` Jan Djärv 2 siblings, 3 replies; 57+ messages in thread From: Drew Adams @ 2014-01-07 17:28 UTC (permalink / raw) To: Jan Djärv, Chong Yidong; +Cc: emacs-devel > > What is the purpose of this face attribute, newly introduced for > > 24.4? > > Too lazy to read documentation? > > "`:distant-foreground' > Alternative foreground color, a string. This is like > `:foreground' > but the color is only used as a foreground when the background > color is near to the foreground that would have been used. > This is useful for example when marking text (i.e. the region > face). > If the text has a foreground that is visible with the region > face, that foreground is used. If the foreground is near the > region face background, `:distant-foreground' is used instead > so the text is readable." I see. And just how does a user override this automatic "cleverness"? How can a user really make her preference for the face take effect? This kind of DWIMity should always allow users to take control back, and preferably easily. What you think might be best for all users all the time might not be what some user thinks is best for herself. And what about all of the existing code that tests :foreground or otherwise expects it to reflect the actual foreground used? Is that code broken now, because Emacs substitutes a :distant-foreground color behind its back? Must all such code now change to test first one and then the other? When was this design OK'd (and why)? > > First of all, the name :distant-foreground is not intuitive. What > > does "distant" mean in this context? > > The same as in any other context, far removed from something else, > i.e. the background. I agree with Yidong about the name. This is apparently a fallback, alternative color, when (you) think the color specified by the user or program is inappropriate. > > Besides that, the implementation seems rather incomplete. The > > Customize interface, `modify-face', `face-spec-reset-face', and > > other parts of Emacs haven't been updated for the existence of > > this face attribute. > > That is on purpose. It is supposed to be automatically calculated. So what? All the more reason to bring it out into the open, so users can know about it (and try to find some way to work around it, if they like). > > It's unclear what functions like `face-foreground' should now do > > if there's a :distant-foreground. > > No it is not. Yes it is. See above. Search the distributed code and the Internet for uses of "foreground" in Emacs Lisp code. How much of that code now needs to be modified to accommodate this gratuitous change. Was there a real problem, reported by a real user, that this change attempts to fix? Or is this just someone's clever brainchild for making Emacs smarter? > > This all sounds like an invitation for more bugs. In my opinion, > > this feature is a bad idea. +1 > All new features invite new bugs, so are you saying we should never > add new features? All new features should be proposed and discussed, before being cast into the product. That's my humble opinion. > Your opinion is not very interesting, but if you have core for an > alternative approach that would be interesting. Why is any approach needed? What is the (real) problem that needs solving? ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-07 17:28 ` Drew Adams @ 2014-01-07 18:01 ` Eli Zaretskii 2014-01-07 18:09 ` Joel Mccracken [not found] ` <<8361pvsmbk.fsf@gnu.org> 2 siblings, 0 replies; 57+ messages in thread From: Eli Zaretskii @ 2014-01-07 18:01 UTC (permalink / raw) To: Drew Adams; +Cc: jan.h.d, cyd, emacs-devel > Date: Tue, 7 Jan 2014 09:28:05 -0800 (PST) > From: Drew Adams <drew.adams@oracle.com> > Cc: emacs-devel <emacs-devel@gnu.org> > > All new features should be proposed and discussed, before being cast > into the product. This one was. It solved a bug. > Why is any approach needed? What is the (real) problem that needs > solving? See http://debbugs.gnu.org/cgi/bugreport.cgi?bug=15668. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-07 17:28 ` Drew Adams 2014-01-07 18:01 ` Eli Zaretskii @ 2014-01-07 18:09 ` Joel Mccracken [not found] ` <<8361pvsmbk.fsf@gnu.org> 2 siblings, 0 replies; 57+ messages in thread From: Joel Mccracken @ 2014-01-07 18:09 UTC (permalink / raw) To: Drew Adams; +Cc: Jan Djärv, Chong Yidong, emacs-devel It seems like "contrast" could be used to explain the difference in a more intuitive way. On Jan 7, 2014, at 12:28 PM, Drew Adams <drew.adams@oracle.com> wrote: >>> What is the purpose of this face attribute, newly introduced for >>> 24.4? >> >> Too lazy to read documentation? >> >> "`:distant-foreground' >> Alternative foreground color, a string. This is like >> `:foreground' >> but the color is only used as a foreground when the background >> color is near to the foreground that would have been used. >> This is useful for example when marking text (i.e. the region >> face). >> If the text has a foreground that is visible with the region >> face, that foreground is used. If the foreground is near the >> region face background, `:distant-foreground' is used instead >> so the text is readable." > > I see. And just how does a user override this automatic "cleverness"? > How can a user really make her preference for the face take effect? > > This kind of DWIMity should always allow users to take control back, > and preferably easily. What you think might be best for all users > all the time might not be what some user thinks is best for herself. > > And what about all of the existing code that tests :foreground or > otherwise expects it to reflect the actual foreground used? Is that > code broken now, because Emacs substitutes a :distant-foreground > color behind its back? Must all such code now change to test first > one and then the other? > > When was this design OK'd (and why)? > >>> First of all, the name :distant-foreground is not intuitive. What >>> does "distant" mean in this context? >> >> The same as in any other context, far removed from something else, >> i.e. the background. > > I agree with Yidong about the name. This is apparently a fallback, > alternative color, when (you) think the color specified by the > user or program is inappropriate. > >>> Besides that, the implementation seems rather incomplete. The >>> Customize interface, `modify-face', `face-spec-reset-face', and >>> other parts of Emacs haven't been updated for the existence of >>> this face attribute. >> >> That is on purpose. It is supposed to be automatically calculated. > > So what? All the more reason to bring it out into the open, so > users can know about it (and try to find some way to work around it, > if they like). > >>> It's unclear what functions like `face-foreground' should now do >>> if there's a :distant-foreground. >> >> No it is not. > > Yes it is. See above. Search the distributed code and the Internet > for uses of "foreground" in Emacs Lisp code. How much of that code > now needs to be modified to accommodate this gratuitous change. > > Was there a real problem, reported by a real user, that this change > attempts to fix? Or is this just someone's clever brainchild for > making Emacs smarter? > >>> This all sounds like an invitation for more bugs. In my opinion, >>> this feature is a bad idea. > > +1 > >> All new features invite new bugs, so are you saying we should never >> add new features? > > All new features should be proposed and discussed, before being cast > into the product. That's my humble opinion. > >> Your opinion is not very interesting, but if you have core for an >> alternative approach that would be interesting. > > Why is any approach needed? What is the (real) problem that needs > solving? > ^ permalink raw reply [flat|nested] 57+ messages in thread
[parent not found: <<8361pvsmbk.fsf@gnu.org>]
* RE: About the :distant-foreground face attribute [not found] ` <<8361pvsmbk.fsf@gnu.org> @ 2014-01-07 18:44 ` Drew Adams 2014-01-07 19:01 ` Eli Zaretskii [not found] ` <<83zjn7r4z3.fsf@gnu.org> 0 siblings, 2 replies; 57+ messages in thread From: Drew Adams @ 2014-01-07 18:44 UTC (permalink / raw) To: Eli Zaretskii, Drew Adams; +Cc: jan.h.d, cyd, emacs-devel > > All new features should be proposed and discussed, before being > > cast into the product. That's my humble opinion. > > This one was. It solved a bug. The new feature was not proposed on emacs-devel and discussed. It was dreamt up in passing, in one short bug thread, and discussed there by only two developers. > > Why is any approach needed? What is the (real) problem that needs > > solving? > > See http://debbugs.gnu.org/cgi/bugreport.cgi?bug=15668. So the real problem was to have a reasonable background color for face `region' by default. On some platforms a bad color choice was (and apparently still is) being used as the default. That problem does not require this particular "fix". Even that bug thread shows that this was thought to be a nice-to-have new feature that could also take care of this bug. It is not needed, to fix the bug. "It would be nice if one could define a face with a foreground color to be used when foreground and background otherwise are to[o] similar." And from that dream onward to this one (still unimplemented, I hope): >>> It would be nice if... >> >> Sounds like a simple enough extension to defface. > > Or maybe every face should do that by default. IMO, the implementation, and probably the feature itself, is not TRT. Note, BTW, that even the OP had to back you off the first enthusiastic fix, so that he could still customize normally and theme designers would have a simpler time of it. > I envisioned that querying the face for the foreground would > automatically give the "fallback"... At least that was thought of. But is that the case for all code that "queries" a face :foreground or modifies it? Is all such code somehow automatically adjusted now so that it always DTRT? I don't see how that would be the case. It seems that for one tiny piece of the distributed Emacs code that dream behavior was implemented. The problem is all other code that tries to use the :foreground, which attribute might not even be respected (unused, because of a DWIM substitution). Such code thinks that it is getting or changing the foreground color by dealing with just :foreground. But it is wrong, because a clever DWIM feature went behind its back. To DTRT, it will now have to jump through extra hoops. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-07 18:44 ` Drew Adams @ 2014-01-07 19:01 ` Eli Zaretskii [not found] ` <<83zjn7r4z3.fsf@gnu.org> 1 sibling, 0 replies; 57+ messages in thread From: Eli Zaretskii @ 2014-01-07 19:01 UTC (permalink / raw) To: Drew Adams; +Cc: jan.h.d, cyd, emacs-devel > Date: Tue, 7 Jan 2014 10:44:26 -0800 (PST) > From: Drew Adams <drew.adams@oracle.com> > Cc: jan.h.d@swipnet.se, cyd@gnu.org, emacs-devel@gnu.org > > > > All new features should be proposed and discussed, before being > > > cast into the product. That's my humble opinion. > > > > This one was. It solved a bug. > > The new feature was not proposed on emacs-devel and discussed. emacs-devel is not the only place where Emacs development is discussed. The bug list and the bug reports are another. > IMO, the implementation, and probably the feature itself, is not > TRT. Sorry, I disagree. I think it's exactly right. ^ permalink raw reply [flat|nested] 57+ messages in thread
[parent not found: <<83zjn7r4z3.fsf@gnu.org>]
* RE: About the :distant-foreground face attribute [not found] ` <<83zjn7r4z3.fsf@gnu.org> @ 2014-01-07 19:06 ` Drew Adams 2014-01-07 19:15 ` Eli Zaretskii 0 siblings, 1 reply; 57+ messages in thread From: Drew Adams @ 2014-01-07 19:06 UTC (permalink / raw) To: Eli Zaretskii, Drew Adams; +Cc: jan.h.d, cyd, emacs-devel > > IMO, the implementation, and probably the feature itself, is not > > TRT. > > Sorry, I disagree. I think it's exactly right. And what do you say about code that expects that a face's `foreground' attribute actually reflects the face's current foreground appearance? Silence on that question, so far. When examining attribute `foreground' tells you nothing about the foreground, and changing the attribute value turns silently into a no-op, I'd say that something basic has been broken. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-07 19:06 ` Drew Adams @ 2014-01-07 19:15 ` Eli Zaretskii 0 siblings, 0 replies; 57+ messages in thread From: Eli Zaretskii @ 2014-01-07 19:15 UTC (permalink / raw) To: Drew Adams; +Cc: jan.h.d, cyd, emacs-devel > Date: Tue, 7 Jan 2014 11:06:15 -0800 (PST) > From: Drew Adams <drew.adams@oracle.com> > Cc: jan.h.d@swipnet.se, cyd@gnu.org, emacs-devel@gnu.org > > > > IMO, the implementation, and probably the feature itself, is not > > > TRT. > > > > Sorry, I disagree. I think it's exactly right. > > And what do you say about code that expects that a face's > `foreground' attribute actually reflects the face's current > foreground appearance? I don't understand the issue, but regardless, the fact that bugs exist (if they exist) doesn't mean the design and the general implementation are flawed. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-07 15:00 ` Jan Djärv 2014-01-07 17:28 ` Drew Adams @ 2014-01-07 21:57 ` Chong Yidong 2014-01-08 3:45 ` Eli Zaretskii 2014-01-07 22:50 ` Jan Djärv 2 siblings, 1 reply; 57+ messages in thread From: Chong Yidong @ 2014-01-07 21:57 UTC (permalink / raw) To: Jan Djärv; +Cc: emacs-devel Jan Djärv <jan.h.d@swipnet.se> writes: > Too lazy to read documentation? > > "`:distant-foreground' > Alternative foreground color, a string. This is like `:foreground' > but the color is only used as a foreground when the background > color is near to the foreground that would have been used. This > is useful for example when marking text (i.e. the region face). > If the text has a foreground that is visible with the region face, > that foreground is used. If the foreground is near the region > face background, `:distant-foreground' is used instead so the text > is readable. I read that, but the explanation was pretty darn cryptic. But OK: from your message, I gather that this feature was introduced to deal with the problem which setting the `region' face from system (GTK or NS) settings. But is there any other even vaguely envisioned usage? Because, as explained before, there are better ways to deal with this problem than something so intrusive as defining a new face attribute. >> First of all, the name :distant-foreground is not intuitive. What does >> "distant" mean in this context? >> > > The same as in any other context, far removed from something else, > i.e. the background. Things that are "distant" are in the BACKGROUND, so "distant foreground" sounds tautological. The fact that there isn't a good name for this face attribute is an indicator that it's not well-conceived. The feature does not fit well with the design of the rest of the face-handling code. We already have a mechanism for checking to see when to use a particular face: the DISPLAY element in a face spec. The :distant-foreground face attribute, by its very existence, is redundant with what the DISPLAY element was meant to do. This adds extra complexity to the design, for no good reason. If you need to check for a background, the right thing would be to extend the DISPLAY feature to do what you need. For example, a DISPLAY element of `(background dark)' is used to test for a dark background. Maybe what you want is to be able to specify a color in place of `dark', which would mean a background close to that color. >> Also, this feature has one ugly consequence. Previously, the `default' >> face must have all its face attributes specified, but now its >> :distant-foreground face is unspecified. > > Default face does not need to have its font specified, so this is not > new. M-: (face-attribute 'default :font) RET => #<font-object "-unknown-DejaVu Sans Mono-normal-normal-normal-*-13-*-*-*-m-0-iso10646-1"> M-: (face-attribute 'default :distant-foreground) RET => unspecified ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-07 21:57 ` Chong Yidong @ 2014-01-08 3:45 ` Eli Zaretskii 2014-01-08 5:24 ` Chong Yidong 0 siblings, 1 reply; 57+ messages in thread From: Eli Zaretskii @ 2014-01-08 3:45 UTC (permalink / raw) To: Chong Yidong; +Cc: jan.h.d, emacs-devel > From: Chong Yidong <cyd@gnu.org> > Date: Wed, 08 Jan 2014 05:57:41 +0800 > Cc: emacs-devel <emacs-devel@gnu.org> > > The feature does not fit well with the design of the rest of the > face-handling code. We already have a mechanism for checking to see > when to use a particular face: the DISPLAY element in a face spec. The > :distant-foreground face attribute, by its very existence, is redundant > with what the DISPLAY element was meant to do. This adds extra > complexity to the design, for no good reason. > > If you need to check for a background, the right thing would be to > extend the DISPLAY feature to do what you need. For example, a DISPLAY > element of `(background dark)' is used to test for a dark background. > Maybe what you want is to be able to specify a color in place of `dark', > which would mean a background close to that color. I don't understand this criticism. How is this attribute different from min-colors? ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-08 3:45 ` Eli Zaretskii @ 2014-01-08 5:24 ` Chong Yidong 2014-01-08 9:35 ` Jan Djärv ` (2 more replies) 0 siblings, 3 replies; 57+ messages in thread From: Chong Yidong @ 2014-01-08 5:24 UTC (permalink / raw) To: Eli Zaretskii; +Cc: jan.h.d, emacs-devel Eli Zaretskii <eliz@gnu.org> writes: >> The feature does not fit well with the design of the rest of the >> face-handling code. We already have a mechanism for checking to see >> when to use a particular face: the DISPLAY element in a face spec. The >> :distant-foreground face attribute, by its very existence, is redundant >> with what the DISPLAY element was meant to do. This adds extra >> complexity to the design, for no good reason. > > I don't understand this criticism. How is this attribute different > from min-colors? The min-colors feature doesn't involve adding an extra face attribute. The analogy would be if there was a :low-color-foreground face attribute which would override :foreground on low-color displays. That would be ugly, as I hope you agree. OK, after poking around a bit I understand the problem better. You want to be free to set face background colors without worrying about making text illegible (which can be difficult to figure out ahead of time, because of face inheritance etc). So here's a proposal: Change the feature so it applies to all faces, but in a configurable way. Introduce a new Lisp variable, `face-minimum-contrast', which specifies the minimum allowed contrast between the background and foreground of any face (or nil, which means to disable the feature). If the contrast of a face is lower than specified, the foreground color is adjusted (say, by changing its V component) to conform to the minimum contrast. This would avoid having to introduce a :distant-foreground attribute for all faces, only to use that attribute for just one face (`region') and for one special purpose (to cope with the GTK selection color). It would handle the generic class of problems involving text becoming illegible, such as due to bad themes. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-08 5:24 ` Chong Yidong @ 2014-01-08 9:35 ` Jan Djärv 2014-01-08 9:52 ` Chong Yidong 2014-01-08 14:05 ` Stefan Monnier 2014-01-08 17:43 ` Eli Zaretskii 2 siblings, 1 reply; 57+ messages in thread From: Jan Djärv @ 2014-01-08 9:35 UTC (permalink / raw) To: Chong Yidong; +Cc: Eli Zaretskii, emacs-devel Hi. 8 jan 2014 kl. 06:24 skrev Chong Yidong <cyd@gnu.org>: > Change the feature so it applies to all faces, but in a configurable > way. Introduce a new Lisp variable, `face-minimum-contrast', which > specifies the minimum allowed contrast between the background and > foreground of any face (or nil, which means to disable the feature). If > the contrast of a face is lower than specified, the foreground color is > adjusted (say, by changing its V component) to conform to the minimum > contrast. > On Gtk and NS the region color to use is in that case specified by the system and should not be generated by modifying a color component. How do you specify that? Also, it isn't the contrast between the background and the foreground of a face, but the contrast between the background and foreground to be rendered, which comes from different faces in the case at hand. > This would avoid having to introduce a :distant-foreground attribute for > all faces, only to use that attribute for just one face (`region') and > for one special purpose (to cope with the GTK selection color). It > would handle the generic class of problems involving text becoming > illegible, such as due to bad themes. distant-foreground can be used on any face, it just isn't. Jan D. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-08 9:35 ` Jan Djärv @ 2014-01-08 9:52 ` Chong Yidong 2014-01-08 10:10 ` Jan Djärv 0 siblings, 1 reply; 57+ messages in thread From: Chong Yidong @ 2014-01-08 9:52 UTC (permalink / raw) To: Jan Djärv; +Cc: Eli Zaretskii, emacs-devel Jan Djärv <jan.h.d@swipnet.se> writes: > On Gtk and NS the region color to use is in that case specified by the > system and should not be generated by modifying a color component. > How do you specify that? The reason this feature was introduced was so that Emacs could get away with not using the specified *_foreground_color, and use the underlying face color instead. It is inconsistent to suddenly want to start honoring it. > Also, it isn't the contrast between the background and the foreground > of a face, but the contrast between the background and foreground to > be rendered, which comes from different faces in the case at hand. Yep. >> This would avoid having to introduce a :distant-foreground attribute for >> all faces, only to use that attribute for just one face (`region') and >> for one special purpose (to cope with the GTK selection color). It >> would handle the generic class of problems involving text becoming >> illegible, such as due to bad themes. > > distant-foreground can be used on any face, it just isn't. Yep, not sure what your point is. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-08 9:52 ` Chong Yidong @ 2014-01-08 10:10 ` Jan Djärv 2014-01-08 14:49 ` Chong Yidong 0 siblings, 1 reply; 57+ messages in thread From: Jan Djärv @ 2014-01-08 10:10 UTC (permalink / raw) To: Chong Yidong; +Cc: Eli Zaretskii, emacs-devel 8 jan 2014 kl. 10:52 skrev Chong Yidong <cyd@gnu.org>: > Jan Djärv <jan.h.d@swipnet.se> writes: > >> On Gtk and NS the region color to use is in that case specified by the >> system and should not be generated by modifying a color component. >> How do you specify that? > > The reason this feature was introduced was so that Emacs could get away > with not using the specified *_foreground_color, and use the underlying > face color instead. It is inconsistent to suddenly want to start > honoring it. Honoring what? Your statement makes no sense. I'm talking about the fact that your proposal does not do what the current implementation does. In your proposal, the foreground to use (distant foreground) would be calculated by Emacs. In the current implementation, the foreground to use is specified by the system (Gtk+/NS). How do you specify that in your proposal? Jan D. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-08 10:10 ` Jan Djärv @ 2014-01-08 14:49 ` Chong Yidong 2014-01-08 16:37 ` Jan Djärv 2014-01-08 16:57 ` Drew Adams 0 siblings, 2 replies; 57+ messages in thread From: Chong Yidong @ 2014-01-08 14:49 UTC (permalink / raw) To: Jan Djärv; +Cc: Eli Zaretskii, emacs-devel Jan Djärv <jan.h.d@swipnet.se> writes: > Honoring what? Your statement makes no sense. I'm talking about the > fact that your proposal does not do what the current implementation > does. In your proposal, the foreground to use (distant foreground) > would be calculated by Emacs. In the current implementation, the > foreground to use is specified by the system (Gtk+/NS). How do you > specify that in your proposal? Why is the current behavior TRT? You are already choosing to ignore gtk_selection_fg_color under some (arbitrarily hard-coded) circumstances. So if you care about obeying gtk_selection_fg_color, why not just set it to :foreground? When gtk_selection_bg_color is in use, we might as well use gtk_selection_fg_color with it. Users who want a region background color that works properly with font lock might as well disable the GTK selection color stuff (it's unfortunate that it's the default, but oh well). ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-08 14:49 ` Chong Yidong @ 2014-01-08 16:37 ` Jan Djärv 2014-01-08 17:08 ` Drew Adams 2014-01-08 16:57 ` Drew Adams 1 sibling, 1 reply; 57+ messages in thread From: Jan Djärv @ 2014-01-08 16:37 UTC (permalink / raw) To: Chong Yidong; +Cc: Eli Zaretskii, emacs-devel Hi. 8 jan 2014 kl. 15:49 skrev Chong Yidong <seewhydee@gmail.com>: > So if you care about obeying gtk_selection_fg_color, why not just set it > to :foreground? When gtk_selection_bg_color is in use, we might as well > use gtk_selection_fg_color with it. Users who want a region background > color that works properly with font lock might as well disable the GTK > selection color stuff (it's unfortunate that it's the default, but oh > well). You obviously don't understand the issue, so I'll try to be very clear. 1) Font lock uses faces with specified fore- and background. 2) When text is marked with the mouse, the region face is applied on (overrides) the font lock face. 3) If the region face blindly uses the foreground from the region face (as per your suggestion), for example gtk_selection_fg_color, font lock is lost. That is what bug 15668 is about. 4) On the other hand, if we always ignore the region foreground color, and use the font lock foregrpund color bug 15668 would be solved. However, if the font lock foreground and the region background is similar, text is not readable. So in that case, distant-foreground is used. 5) When making a theme, I suspect one wishes to specify all colors, not use some arbitrary generated color, which most certainly don't match the theme. So we need a way to specify that color, hence distant-foreground. Your proposals: 1) Use the selection foreground color when the selection background is used => Bug 15668. 2) Disable GTK selection color stuff This might lead to unreadable text as the region bacground may be close to the foreground. There is no "region background color that works properly with font lock" for all font lock faces, because the colors in font lock faces are unknown, esp. with themes. If you can get your scheme to let theme designers specify all colors without adding a new face parameter, via the display property somehow, that could be something. Not that it would make anything simpler or a better design, it just sounds more involved to me. Using generated colors is right out IMHO, it makes themes impossible to fully specify. Jan D. ^ permalink raw reply [flat|nested] 57+ messages in thread
* RE: About the :distant-foreground face attribute 2014-01-08 16:37 ` Jan Djärv @ 2014-01-08 17:08 ` Drew Adams 0 siblings, 0 replies; 57+ messages in thread From: Drew Adams @ 2014-01-08 17:08 UTC (permalink / raw) To: Jan Djärv, Chong Yidong; +Cc: Eli Zaretskii, emacs-devel > 1) Font lock uses faces with specified fore- and background. > 2) When text is marked with the mouse, the region face is applied on > (overrides) the font lock face. As it should. > 3) If the region face blindly uses the foreground from the region > face (as per your suggestion), for example gtk_selection_fg_color, > font lock is lost. That is what bug 15668 is about. Font lock is not "lost". Font-lock highlighting is covered by the region highlighting. And that is what should happen. This "bug" should not have been "fixed", IMHO. This is what text selection highlighting is all about. A user needs to be able to see which text is highlighted - each selected char. And you should not assume that font-locking affects only foregrounds. Are you going to make the same "fix" for backgrounds also, so that selecting text lets font-locked (or otherwise highlighted) backgrounds show through the region highlighting? And if font locking highlights both the foreground and background of a character? Bingo - you cannot see which text you have selected. This kind of change seems so misguided. Hard to believe we've arrived here. ^ permalink raw reply [flat|nested] 57+ messages in thread
* RE: About the :distant-foreground face attribute 2014-01-08 14:49 ` Chong Yidong 2014-01-08 16:37 ` Jan Djärv @ 2014-01-08 16:57 ` Drew Adams 1 sibling, 0 replies; 57+ messages in thread From: Drew Adams @ 2014-01-08 16:57 UTC (permalink / raw) To: Chong Yidong, Jan Djärv; +Cc: Eli Zaretskii, emacs-devel The foreground attribute for a face should always reflect the actual appearance of that face (in isolation - this is not about the effects of combining faces etc.). Anything different from that is asking for trouble. IIUC, this change was made because on some platforms the default color for the `region' face background is inappropriate, given the default color for its foreground. To me, that sounds like the kind of thing that Eli recently declared to be not-an-Emacs-problem. But so be it - if Emacs can reasonably work around that problem, why not? If Emacs wants to make an attempt to compensate for that bad defaulting behavior, then I would think that the right approach would be to automatically tweak the color of the `region' face's foreground attribute itself. And preferably only for those situations where the problem actually arises. Adding a variable, as Yidong suggested, just spreads the pollution of this misguided fix across all faces. And it still does not sync the attribute value with the appearance. What the attribute says you should get is not what you get. The color is being changed behind the back of the face spec. If the face attribute value does not reflect the face appearance for an attribute, code that examines that attribute, e.g., to base its behavior on what the face's foreground is, will likely not DTRT. And code that modifies the face's foreground attribute will likewise likely not do what it is expected to do. Code becomes less transparent and dependable. Foreground attribute and actual foreground should be and remain one-to-one - no surprises (again, not counting face mergings etc.). Can't you please find a way to keep the foreground attribute in sync with the actual foreground color you need in this scenario? Can't you perform whatever machinations are needed to change the foreground attribute itself so that you get the visual effect needed? OK, so changing the attribute overrides whatever setting the user might fix for the attribute. But that would be done only when the problem arises. And it should be done only with the user's permission. IOW, I agree with Stefan (almost mentioned it myself) that users and Lisp code should be able, for whatever reason, to specify that the foreground and background for a given face are the exact same color. IOW, any automatic overriding of what the face definition specifies should be optional, under user control. And that user control should be *per face*. One should not be obliged to choose either preventing the overriding or allowing it for all faces. The choice should be a function of the particular face. Now *that* could be done using a new face attribute, if you want. (Or a function.) The important thing is to preserve the correspondence between each face's current appearance and its current attribute values. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-08 5:24 ` Chong Yidong 2014-01-08 9:35 ` Jan Djärv @ 2014-01-08 14:05 ` Stefan Monnier 2014-01-08 17:43 ` Eli Zaretskii 2 siblings, 0 replies; 57+ messages in thread From: Stefan Monnier @ 2014-01-08 14:05 UTC (permalink / raw) To: Chong Yidong; +Cc: Eli Zaretskii, jan.h.d, emacs-devel > way. Introduce a new Lisp variable, `face-minimum-contrast', which > specifies the minimum allowed contrast between the background and > foreground of any face (or nil, which means to disable the feature). Some packages use a face with foreground=background so as to hide the text (while still taking up space). IOW this "make sure there's enough contrast" should not apply to all faces. Stefan ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-08 5:24 ` Chong Yidong 2014-01-08 9:35 ` Jan Djärv 2014-01-08 14:05 ` Stefan Monnier @ 2014-01-08 17:43 ` Eli Zaretskii 2014-01-09 16:15 ` Chong Yidong 2 siblings, 1 reply; 57+ messages in thread From: Eli Zaretskii @ 2014-01-08 17:43 UTC (permalink / raw) To: Chong Yidong; +Cc: jan.h.d, emacs-devel > From: Chong Yidong <cyd@gnu.org> > Cc: jan.h.d@swipnet.se, emacs-devel@gnu.org > Date: Wed, 08 Jan 2014 13:24:17 +0800 > > Eli Zaretskii <eliz@gnu.org> writes: > > >> The feature does not fit well with the design of the rest of the > >> face-handling code. We already have a mechanism for checking to see > >> when to use a particular face: the DISPLAY element in a face spec. The > >> :distant-foreground face attribute, by its very existence, is redundant > >> with what the DISPLAY element was meant to do. This adds extra > >> complexity to the design, for no good reason. > > > > I don't understand this criticism. How is this attribute different > > from min-colors? > > The min-colors feature doesn't involve adding an extra face attribute. This is an implementation detail, while your criticism above seems to be about the design. > The analogy would be if there was a :low-color-foreground face attribute > which would override :foreground on low-color displays. That would be > ugly, as I hope you agree. I'm not sure I see the ugliness, please elaborate. > Change the feature so it applies to all faces, but in a configurable > way. Introduce a new Lisp variable, `face-minimum-contrast', which > specifies the minimum allowed contrast between the background and > foreground of any face (or nil, which means to disable the feature). If > the contrast of a face is lower than specified, the foreground color is > adjusted (say, by changing its V component) to conform to the minimum > contrast. I don't think it will be a good idea to have a single global setting, because this would preclude a Lisp program from defining a face that will always use the specified foreground, no matter what. E.g., I could imagine an application that would like to make the text invisible by specifying the same fore- and background colors. While probably rare, such use cases are entirely legitimate, I think. So I think we need this to be specified on the level of individual faces. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-08 17:43 ` Eli Zaretskii @ 2014-01-09 16:15 ` Chong Yidong 2014-01-09 17:02 ` Stefan Monnier 2014-01-09 17:05 ` Eli Zaretskii 0 siblings, 2 replies; 57+ messages in thread From: Chong Yidong @ 2014-01-09 16:15 UTC (permalink / raw) To: Eli Zaretskii; +Cc: jan.h.d, emacs-devel Eli Zaretskii <eliz@gnu.org> writes: >> The analogy would be if there was a :low-color-foreground face attribute >> which would override :foreground on low-color displays. That would be >> ugly, as I hope you agree. > > I'm not sure I see the ugliness, please elaborate. One face attribute should govern one aspect of how the face is displayed. In some cases, it may be hard to avoid having multiple attributes with overlapping effects, but the results are not pretty. For example, the interactions between :family, :foundry and :font have been a source of annoyance over the years. Introducing another such situation should, in my view, be avoided as far as possible. An example of a face attribute that handles things right is the :height attribute. An absolute height is given by an integer, while a relative height can be specified by a float. Allowing both in a single attribute is good, because absolute height and the relative height are just different ways to specify height. We don't have a :height and a separate :relative-height attribute. The DISPLAY spec is another example of avoiding adding extra face attributes---it allows different sets of face attributes for different display conditions. If I cannot convince anyone that there is a problem here, then forget it. I don't have time to keep arguing, so I'll just stop working on this stuff. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-09 16:15 ` Chong Yidong @ 2014-01-09 17:02 ` Stefan Monnier 2014-01-09 17:07 ` Drew Adams 2014-01-09 17:05 ` Eli Zaretskii 1 sibling, 1 reply; 57+ messages in thread From: Stefan Monnier @ 2014-01-09 17:02 UTC (permalink / raw) To: Chong Yidong; +Cc: Eli Zaretskii, jan.h.d, emacs-devel > been a source of annoyance over the years. Introducing another such > situation should, in my view, be avoided as far as possible. That's a good point. Basically, what you're saying is that instead of :distant-foreground we could have a :foreground that can be of the form (NORMAL-FOREGROUND . ALTERNATE-FOREGROUND), where ALTERNATE-FOREGROUND is used when NORMAL-FOREGROUND would lead to a lack of contrast. Stefan ^ permalink raw reply [flat|nested] 57+ messages in thread
* RE: About the :distant-foreground face attribute 2014-01-09 17:02 ` Stefan Monnier @ 2014-01-09 17:07 ` Drew Adams 2014-01-09 17:46 ` Eli Zaretskii 0 siblings, 1 reply; 57+ messages in thread From: Drew Adams @ 2014-01-09 17:07 UTC (permalink / raw) To: Stefan Monnier, Chong Yidong; +Cc: Eli Zaretskii, jan.h.d, emacs-devel > > been a source of annoyance over the years. Introducing another > > such situation should, in my view, be avoided as far as possible. > > That's a good point. Basically, what you're saying is that instead > of :distant-foreground we could have a :foreground that can be of > the form (NORMAL-FOREGROUND . ALTERNATE-FOREGROUND), where > ALTERNATE-FOREGROUND is used when NORMAL-FOREGROUND would lead to a > lack of contrast. Please don't. That too would break code that expects :foreground to be as it is now. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-09 17:07 ` Drew Adams @ 2014-01-09 17:46 ` Eli Zaretskii 2014-01-09 18:21 ` Chong Yidong 0 siblings, 1 reply; 57+ messages in thread From: Eli Zaretskii @ 2014-01-09 17:46 UTC (permalink / raw) To: Drew Adams; +Cc: cyd, monnier, jan.h.d, emacs-devel > Date: Thu, 9 Jan 2014 09:07:43 -0800 (PST) > From: Drew Adams <drew.adams@oracle.com> > Cc: Eli Zaretskii <eliz@gnu.org>, jan.h.d@swipnet.se, emacs-devel@gnu.org > > > > been a source of annoyance over the years. Introducing another > > > such situation should, in my view, be avoided as far as possible. > > > > That's a good point. Basically, what you're saying is that instead > > of :distant-foreground we could have a :foreground that can be of > > the form (NORMAL-FOREGROUND . ALTERNATE-FOREGROUND), where > > ALTERNATE-FOREGROUND is used when NORMAL-FOREGROUND would lead to a > > lack of contrast. > > Please don't. That too would break code that expects :foreground to > be as it is now. Why do you assume that the previous form will not be accepted? Of course, it will be. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-09 17:46 ` Eli Zaretskii @ 2014-01-09 18:21 ` Chong Yidong 2014-01-09 22:25 ` Drew Adams 2014-01-09 22:48 ` David Engster 0 siblings, 2 replies; 57+ messages in thread From: Chong Yidong @ 2014-01-09 18:21 UTC (permalink / raw) To: Eli Zaretskii; +Cc: jan.h.d, monnier, Drew Adams, emacs-devel Eli Zaretskii <eliz@gnu.org> writes: >> Please don't. That too would break code that expects :foreground to >> be as it is now. > > Why do you assume that the previous form will not be accepted? Of > course, it will be. What Drew is worrying about, I think, is that third-party code, or old versions of Emacs, will barf when they come across the new :foreground form in user customizations or themes. I don't know whether this would be a major problem in practice. Personally, I agree with David Engster that If you really really want font-lock on a marked region, then you will have to choose a region background which will play well with your color theme. Introducing a new face attribute for such a small annoyance looks like overkill to me. But IF people feel really strongly about having this feature, doing it by adding a new :foreground type seems like the least bad option, from a code cleanliness perspective. ^ permalink raw reply [flat|nested] 57+ messages in thread
* RE: About the :distant-foreground face attribute 2014-01-09 18:21 ` Chong Yidong @ 2014-01-09 22:25 ` Drew Adams 2014-01-09 22:48 ` David Engster 1 sibling, 0 replies; 57+ messages in thread From: Drew Adams @ 2014-01-09 22:25 UTC (permalink / raw) To: Chong Yidong, Eli Zaretskii; +Cc: jan.h.d, monnier, emacs-devel > >> Please don't. That too would break code that expects :foreground > >> to be as it is now. > > > > Why do you assume that the previous form will not be accepted? Of > > course, it will be. > > What Drew is worrying about, I think, is that third-party code, or > old versions of Emacs, will barf when they come across the new > :foreground form in user customizations or themes. Yes, that is exactly what motivated my reply there. But that is not the main point I argue. The main point is that this feature is misguided. A selection (e.g. Emacs region) highlight _should_ override other highlighting. You need to be able to see clearly which text has been selected, each and every character. IIUC, this enhancement request came about because some platforms impose default region backgrounds that are inappropriate, being the same as or too close to the default foreground. My answer to that would be: (a) not Emacs's problem (a la Eli) - lobby the platform, (b) too bad, (c) let the user customize face `region' to get a better background. Users can define both the foreground and background of face `region'. It should be trivial to do that so there is no conflict and all text selected is easily readable. End of story, no? Why is it "necessary" that font lock highlighting show through the text selection (region)? Answer: it's not. It's not only not necessary (YAGNI), but it is wrong (misguided). The selection _should_ take precedence. > I don't know whether this would be a major problem in practice. > Personally, I agree with David Engster that > > If you really really want font-lock on a marked region, then you > will have to choose a region background which will play well with > your color theme. Introducing a new face attribute for such a small > annoyance looks like overkill to me. > > But IF people feel really strongly about having this feature, doing > it by adding a new :foreground type seems like the least bad option, > from a code cleanliness perspective. It is backward incompatible. It solves a non-problem. It imposes unconventional, unexpected, confusing UI interaction that can reduce a user's ability to tell just which characters have been selected. Not a bug. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-09 18:21 ` Chong Yidong 2014-01-09 22:25 ` Drew Adams @ 2014-01-09 22:48 ` David Engster 2014-01-12 11:14 ` David Engster 1 sibling, 1 reply; 57+ messages in thread From: David Engster @ 2014-01-09 22:48 UTC (permalink / raw) To: Chong Yidong; +Cc: Eli Zaretskii, jan.h.d, monnier, Drew Adams, emacs-devel Chong Yidong writes: > Eli Zaretskii <eliz@gnu.org> writes: > >>> Please don't. That too would break code that expects :foreground to >>> be as it is now. >> >> Why do you assume that the previous form will not be accepted? Of >> course, it will be. > > What Drew is worrying about, I think, is that third-party code, or old > versions of Emacs, will barf when they come across the new :foreground > form in user customizations or themes. I'm not too fond of that for the same reason. I'm wondering: We already can set different face attributes depending on DISPLAY's 'background' property, which can be 'light' or 'dark'. Say the user is working with a 'dark' background by default, but we now detect that one of the font-lock faces has not enough contrast when highlighted by the region: why not simply switch to the face that is defined for 'light' background instead? -David ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-09 22:48 ` David Engster @ 2014-01-12 11:14 ` David Engster 2014-01-12 11:40 ` Jan Djärv 2014-01-12 20:14 ` Chong Yidong 0 siblings, 2 replies; 57+ messages in thread From: David Engster @ 2014-01-12 11:14 UTC (permalink / raw) To: Chong Yidong; +Cc: Eli Zaretskii, jan.h.d, monnier, Drew Adams, emacs-devel David Engster writes: > I'm wondering: We already can set different face attributes depending on > DISPLAY's 'background' property, which can be 'light' or 'dark'. Say the > user is working with a 'dark' background by default, but we now detect > that one of the font-lock faces has not enough contrast when highlighted > by the region: why not simply switch to the face that is defined for > 'light' background instead? Hey look, a tumbleweed! I'm assuming everybody's simply stunned by my ingenious proposal? (;-), etc.) -David ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-12 11:14 ` David Engster @ 2014-01-12 11:40 ` Jan Djärv 2014-01-12 12:21 ` David Engster 2014-01-12 20:14 ` Chong Yidong 1 sibling, 1 reply; 57+ messages in thread From: Jan Djärv @ 2014-01-12 11:40 UTC (permalink / raw) To: David Engster Cc: Eli Zaretskii, Chong Yidong, Stefan Monnier, Drew Adams, emacs-devel Hello. 12 jan 2014 kl. 12:14 skrev David Engster <deng@randomsample.de>: > David Engster writes: >> I'm wondering: We already can set different face attributes depending on >> DISPLAY's 'background' property, which can be 'light' or 'dark'. Say the >> user is working with a 'dark' background by default, but we now detect >> that one of the font-lock faces has not enough contrast when highlighted >> by the region: why not simply switch to the face that is defined for >> 'light' background instead? > > Hey look, a tumbleweed! > > I'm assuming everybody's simply stunned by my ingenious proposal? > A theme does not have to suppy colors for properties light or dark. > (;-), etc.) Jan D. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-12 11:40 ` Jan Djärv @ 2014-01-12 12:21 ` David Engster 2014-01-12 12:56 ` Jan Djärv 0 siblings, 1 reply; 57+ messages in thread From: David Engster @ 2014-01-12 12:21 UTC (permalink / raw) To: Jan Djärv Cc: Eli Zaretskii, Chong Yidong, Stefan Monnier, Drew Adams, emacs-devel Jan Djärv writes: > 12 jan 2014 kl. 12:14 skrev David Engster <deng@randomsample.de>: > >> David Engster writes: >>> I'm wondering: We already can set different face attributes depending on >>> DISPLAY's 'background' property, which can be 'light' or 'dark'. Say the >>> user is working with a 'dark' background by default, but we now detect >>> that one of the font-lock faces has not enough contrast when highlighted >>> by the region: why not simply switch to the face that is defined for >>> 'light' background instead? >> >> Hey look, a tumbleweed! >> >> I'm assuming everybody's simply stunned by my ingenious proposal? >> > > A theme does not have to suppy colors for properties light or dark. So? It also does not have to supply the distant-foreground attribute. -David ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-12 12:21 ` David Engster @ 2014-01-12 12:56 ` Jan Djärv 2014-01-12 13:07 ` David Engster 0 siblings, 1 reply; 57+ messages in thread From: Jan Djärv @ 2014-01-12 12:56 UTC (permalink / raw) To: David Engster Cc: Eli Zaretskii, Chong Yidong, Stefan Monnier, Drew Adams, emacs-devel Hello. 12 jan 2014 kl. 13:21 skrev David Engster <deng@randomsample.de>: > Jan Djärv writes: >> 12 jan 2014 kl. 12:14 skrev David Engster <deng@randomsample.de>: >> >>> David Engster writes: >>>> I'm wondering: We already can set different face attributes depending on >>>> DISPLAY's 'background' property, which can be 'light' or 'dark'. Say the >>>> user is working with a 'dark' background by default, but we now detect >>>> that one of the font-lock faces has not enough contrast when highlighted >>>> by the region: why not simply switch to the face that is defined for >>>> 'light' background instead? >>> >>> Hey look, a tumbleweed! >>> >>> I'm assuming everybody's simply stunned by my ingenious proposal? >>> >> >> A theme does not have to suppy colors for properties light or dark. > > So? It also does not have to supply the distant-foreground attribute. Right. But distant-foreground is implemented, you proposal is not and does not add anything except moving colors to some other place in the defface definition. Also, for a theme that does have a dark and light version, there is no guarantee that applying the dark version on the light version (or vice versa) is consistent with the theme look. Jan D. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-12 12:56 ` Jan Djärv @ 2014-01-12 13:07 ` David Engster 2014-01-12 13:17 ` Jan Djärv 0 siblings, 1 reply; 57+ messages in thread From: David Engster @ 2014-01-12 13:07 UTC (permalink / raw) To: Jan Djärv Cc: Eli Zaretskii, Chong Yidong, Stefan Monnier, Drew Adams, emacs-devel Jan Djärv writes: > Hello. > > 12 jan 2014 kl. 13:21 skrev David Engster <deng@randomsample.de>: > >> Jan Djärv writes: >>> 12 jan 2014 kl. 12:14 skrev David Engster <deng@randomsample.de>: >>> >>>> David Engster writes: >>>>> I'm wondering: We already can set different face attributes depending on >>>>> DISPLAY's 'background' property, which can be 'light' or 'dark'. Say the >>>>> user is working with a 'dark' background by default, but we now detect >>>>> that one of the font-lock faces has not enough contrast when highlighted >>>>> by the region: why not simply switch to the face that is defined for >>>>> 'light' background instead? >>>> >>>> Hey look, a tumbleweed! >>>> >>>> I'm assuming everybody's simply stunned by my ingenious proposal? >>>> >>> >>> A theme does not have to suppy colors for properties light or dark. >> >> So? It also does not have to supply the distant-foreground attribute. > > Right. But distant-foreground is implemented, It can be removed again. That is what this thread is about. > you proposal is not and does not add anything except moving colors to > some other place in the defface definition. Exactly. I want to fix the original bug by Darren without the need to introduce another face attribute. > Also, for a theme that does have a dark and light > version, there is no guarantee that applying the dark version on the > light version (or vice versa) is consistent with the theme look. A consistent color theme will choose the region's background color in a way that the font-lock colors are always visible in the first place. The problem is with the default colors. We can easily add a 'dark'/'light' foreground attribute to our default font-lock colors that work well with the default region background from GTK/NS. -David ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-12 13:07 ` David Engster @ 2014-01-12 13:17 ` Jan Djärv 0 siblings, 0 replies; 57+ messages in thread From: Jan Djärv @ 2014-01-12 13:17 UTC (permalink / raw) To: David Engster Cc: Eli Zaretskii, Chong Yidong, Stefan Monnier, Drew Adams, emacs-devel Hello. 12 jan 2014 kl. 14:07 skrev David Engster <deng@randomsample.de>: > A consistent color theme will choose the region's background color in a > way that the font-lock colors are always visible in the first place. That is impossible in principle. Any mode (or elisp code) can define a new face with new colors that didn't even exist when the theme was designed. Distant-foreground gives theme designers a way to cope with this, even if no theme has done so yet. And in a way that is consistent with other theme colors. Dark/light just don't do that. EOD. Jan D. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-12 11:14 ` David Engster 2014-01-12 11:40 ` Jan Djärv @ 2014-01-12 20:14 ` Chong Yidong 2014-01-12 21:20 ` Drew Adams ` (2 more replies) 1 sibling, 3 replies; 57+ messages in thread From: Chong Yidong @ 2014-01-12 20:14 UTC (permalink / raw) To: Eli Zaretskii; +Cc: jan.h.d, monnier, Drew Adams, emacs-devel David Engster <deng@randomsample.de> writes: >> I'm wondering: We already can set different face attributes depending on >> DISPLAY's 'background' property, which can be 'light' or 'dark'. Say the >> user is working with a 'dark' background by default, but we now detect >> that one of the font-lock faces has not enough contrast when highlighted >> by the region: why not simply switch to the face that is defined for >> 'light' background instead? > > Hey look, a tumbleweed! > > I'm assuming everybody's simply stunned by my ingenious proposal? This would not work with customized faces, because Custom sets them with a DISPLAY spec of t by default. Anyway, this proposal would be hard to implement technically, because DISPLAY spec is handled (in Lisp) before the foreground and background attributes are settled on (which takes face inheritance into account and is done in C). Instead, here's a compromise proposal: - Allow :foreground to take the value of (fallback COLOR) or something like that, which would be equivalent to setting :foreground to unspecified and :distant-foreground to COLOR. (We still need a replacement term for "distant foreground". As mentioned before, this term sounds nonsensical.) - In order to avoid incompatibilities, set the :foreground of the `region' face to "*_selection_fg_color". In other words, avoid using the above feature in the `region' face, at least for Emacs 24.4. The rationale is that (i) we can live with having a fixed foreground color for the `region' face, since that was the case in Emacs 24.3 on GTK anyway. And (ii) not using this feature immediately gives third-party packages a "transition period" to adapt to its presence, without immediately failing by encountering it in a standard face. If there are no objections, I can implement this. ^ permalink raw reply [flat|nested] 57+ messages in thread
* RE: About the :distant-foreground face attribute 2014-01-12 20:14 ` Chong Yidong @ 2014-01-12 21:20 ` Drew Adams 2014-01-12 22:07 ` Jan Djärv 2014-01-12 22:59 ` Stefan Monnier 2 siblings, 0 replies; 57+ messages in thread From: Drew Adams @ 2014-01-12 21:20 UTC (permalink / raw) To: Chong Yidong, Eli Zaretskii; +Cc: jan.h.d, monnier, emacs-devel > Instead, here's a compromise proposal: > > - Allow :foreground to take the value of (fallback COLOR) or > something like that, which would be equivalent to setting > :foreground to unspecified and :distant-foreground to COLOR. I think you are saying to set the face's foreground attribute to whatever the dwim thingie calculates, which is what I suggested too. Is that what you mean? > (We still need a replacement term for "distant foreground". As > mentioned before, this term sounds nonsensical.) Yes, if a term is needed at all. IIUC, there would be no new face attribute, at least. The ordinary foreground attribute would be given whatever clever value is deemed more appropriate, right? So if a new term is needed for this clever color, then that would be only for, say, a function name and its doc, not for a new face attribute - right? > - In order to avoid incompatibilities, set the :foreground of the > `region' face to "*_selection_fg_color". I don't know what the latter is. Not that I necessarily need to. I've already expressed my concerns, and am hoping that they are taken into account in some way. I have confidence that you, at least, understand what my concerns are and will think about them. > In other words, avoid using the above feature in the `region' > face, at least for Emacs 24.4. I guess you are saying that the region foreground will not be adapted automatically to compensate for an unfortunate region background default choice. For Emacs 24.4, at least. Is that right? > The rationale is that (i) we can live with having a fixed > foreground color for the `region' face, since that was the > case in Emacs 24.3 on GTK anyway. Can't we live with that as a continuing feature? That sounds like TRT, to me. Let's not forget that the user can define the `region' face any way s?he wants. It is not only the foreground that can "conflict", and it is not only the background that might be defined. Similarly, font-lock highlighting can use faces with backgrounds defined, as well as foregrounds. Would this clever feature do the same thing for letting font-lock backgrounds show through as it aims to do for letting font-lock foregrounds show through? If not, why not? There is nothing inherently asymmetrical between foreground and background, for either face `region' or font-locking. > And (ii) not using this feature immediately gives > third-party packages a "transition period" to adapt to its > presence, Which means what? > without immediately failing by encountering it in a standard > face. What is it that will eventually be encountered in a face, standard or otherwise? Are back to an additional face attribute? Sorry, but I don't understand the proposal. What is it, in concrete terms (user terms, Lisp terms)? What will 3rd-party code need to know? What adaptation is needed, in general terms at least? > If there are no objections, I can implement this. I replied so that you know that I don't yet understand what is being proposed. I understand that you had problems with this new feature, as implemented (you filed the bug report). So I suppose that you will DTRT. Still, I would like to understand what the change will be, if possible. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-12 20:14 ` Chong Yidong 2014-01-12 21:20 ` Drew Adams @ 2014-01-12 22:07 ` Jan Djärv 2014-01-13 0:57 ` Drew Adams 2014-01-12 22:59 ` Stefan Monnier 2 siblings, 1 reply; 57+ messages in thread From: Jan Djärv @ 2014-01-12 22:07 UTC (permalink / raw) To: Chong Yidong; +Cc: Eli Zaretskii, Stefan Monnier, Drew Adams, emacs-devel Hello. 12 jan 2014 kl. 21:14 skrev Chong Yidong <cyd@gnu.org>: > Instead, here's a compromise proposal: > > - Allow :foreground to take the value of (fallback COLOR) or something > like that, which would be equivalent to setting :foreground to > unspecified and :distant-foreground to COLOR. > > (We still need a replacement term for "distant foreground". As > mentioned before, this term sounds nonsensical.) > There is a function called distant_color in the source, thats where it comes from. > - In order to avoid incompatibilities, set the :foreground of the > `region' face to "*_selection_fg_color". In other words, avoid using > the above feature in the `region' face, at least for Emacs 24.4. > > The rationale is that (i) we can live with having a fixed foreground > color for the `region' face, since that was the case in Emacs 24.3 on > GTK anyway. And (ii) not using this feature immediately gives > third-party packages a "transition period" to adapt to its presence, > without immediately failing by encountering it in a standard face. > > If there are no objections, I can implement this. Count this as an objection. (i) means reopening a fixed bug BTW, don't forget that. I don't think this should be done at all, but lets just consider 24.4: 1) We are talking about a replacing a feature that has no outstanding bugs, and has been in place for about 2 months. 2) The only reason too replace it is some personal feelings about "clean design", based on unknown principles, that are not documented in any Emacs or GNU document. 3) The code for this proposal will be messier. Distant-foreground is quite separate in the code, you can easily find any place where the source handles to it. This proposal suggests modifying foreground, thus changing a lot of places where foreground are handeled. Not only is this bound to introduce bugs, but the feature is not as easily seen in the source. And all this during a feature freeze? It makes feature freeze kind of pointless if any feature can be replaced willy nilly based on a persons design feelings. But this is Stefans call. Jan D. ^ permalink raw reply [flat|nested] 57+ messages in thread
* RE: About the :distant-foreground face attribute 2014-01-12 22:07 ` Jan Djärv @ 2014-01-13 0:57 ` Drew Adams 0 siblings, 0 replies; 57+ messages in thread From: Drew Adams @ 2014-01-13 0:57 UTC (permalink / raw) To: Jan Djärv, Chong Yidong; +Cc: Eli Zaretskii, Stefan Monnier, emacs-devel > Count this as an objection. (i) means reopening a fixed bug BTW, > don't forget that. On the contrary. It fixed a non-bug, and introduced a regression. It forces Lisp code to access and manipulate actual face foregrounds (what is really shown, not counting effects of other faces etc.) in a new, kludgy way. > 1) We are talking about a replacing a feature that has no > outstanding bugs, and has been in place for about 2 months. Do you want me to file a bug for this regression? > 2) The only reason too replace it is some personal feelings about > "clean design", based on unknown principles, that are not documented > in any Emacs or GNU document. Among the reasons to remove this regression are: (a) it breaks existing Lisp code and complicates future code, (b) it is lousy UI, going counter to selection in other apps, (c) it is not needed for anything, (d) it treats foreground differently than background (asymmetric), and so does not solve the problem it purports to, since both `region' and font-lock can specify either foreground or background, or both, (e) it tries to work around a non-Emacs problem of certain platforms providing poor default selection background colors. > 3) The code for this proposal will be messier. Distant-foreground > is quite separate in the code, you can easily find any place where > the source handles to it. This proposal suggests modifying > foreground, thus changing a lot of places where foreground are > handeled. Not only is this bound to introduce bugs, but the > feature is not as easily seen in the source. The introduction of an additional face attribute that is not independent of attribute foreground, and that affects the perceived foreground of the face, and so breaks the one-to-one relation between a face's foreground attribute and the face's perceived foreground, is an ill-conceived, error-prone hack. It complicates any Lisp code that tries to deal with the actual face foreground based on its foreground attribute. And that's in the best of cases: future code. Existing code is simply broken, if it expects the face's foreground attribute and appearance to correspond. > And all this during a feature freeze? This new "feature" should never have been approved. It is simply an unfortunate regression. It should be pulled out pronto. > It makes feature freeze kind of pointless if any feature can be > replaced willy nilly based on a persons design feelings. Feature freeze is the time to test the product, including changes that have been made. This change does not pass the smell test, let alone any usability tests for Lisp code. It will even confuse users in UI terms, when they try to check the foreground at some position. > But this is Stefans call. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-12 20:14 ` Chong Yidong 2014-01-12 21:20 ` Drew Adams 2014-01-12 22:07 ` Jan Djärv @ 2014-01-12 22:59 ` Stefan Monnier 2014-01-13 4:14 ` chad 2 siblings, 1 reply; 57+ messages in thread From: Stefan Monnier @ 2014-01-12 22:59 UTC (permalink / raw) To: Chong Yidong; +Cc: Eli Zaretskii, jan.h.d, Drew Adams, emacs-devel > - Allow :foreground to take the value of (fallback COLOR) or something > like that, which would be equivalent to setting :foreground to > unspecified and :distant-foreground to COLOR. This syntax implies that a face can't set both :foreground and :distant-foreground at the same time, even tho the combination of the two is meaningful (it means "use color X if that's readable and color Y otherwise"). So I think it makes more sense to use a syntax that can specify both, such as (COLOR . FALLBACK) or (choose COLOR1 COLOR2). Now, what happens in the following case: - face1 sets foreground to (choose COLOR1 COLOR2) - face2 sets foreground to COLOR3 and inherits from face1. Is the resulting "merge" equivalent to COLOR3 or to (choose COLOR3 COLOR2) or to (choose COLOR3 COLOR1 COLOR2)? I think, to be a useful feature, the merge can't be COLOR3, so it would have to be (choose COLOR3 COLOR2) or (choose COLOR3 COLOR1 COLOR2). Is that really better than what we have now? But now I wonder: what's the benefit from folding this "alternate" color into :foreground compared to having it in a new property :distant-foreground? > (We still need a replacement term for "distant foreground". As > mentioned before, this term sounds nonsensical.) Agreed. Maybe :alternative-foreground? Stefan ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-12 22:59 ` Stefan Monnier @ 2014-01-13 4:14 ` chad 0 siblings, 0 replies; 57+ messages in thread From: chad @ 2014-01-13 4:14 UTC (permalink / raw) To: Emacs developers On 12 Jan 2014, at 14:59, Stefan Monnier <monnier@iro.umontreal.ca> wrote: > (We still need a replacement term for "distant foreground". As >> mentioned before, this term sounds nonsensical.) > > Agreed. Maybe :alternative-foreground? I hate to shed the bike, but maybe “contrast” is a helpful word here? ~Chad ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-09 16:15 ` Chong Yidong 2014-01-09 17:02 ` Stefan Monnier @ 2014-01-09 17:05 ` Eli Zaretskii 2014-01-09 17:22 ` David Engster ` (2 more replies) 1 sibling, 3 replies; 57+ messages in thread From: Eli Zaretskii @ 2014-01-09 17:05 UTC (permalink / raw) To: Chong Yidong; +Cc: jan.h.d, emacs-devel > From: Chong Yidong <cyd@gnu.org> > Cc: jan.h.d@swipnet.se, emacs-devel@gnu.org > Date: Fri, 10 Jan 2014 00:15:00 +0800 > > Eli Zaretskii <eliz@gnu.org> writes: > > >> The analogy would be if there was a :low-color-foreground face attribute > >> which would override :foreground on low-color displays. That would be > >> ugly, as I hope you agree. > > > > I'm not sure I see the ugliness, please elaborate. > > One face attribute should govern one aspect of how the face is > displayed. In some cases, it may be hard to avoid having multiple > attributes with overlapping effects, but the results are not pretty. > For example, the interactions between :family, :foundry and :font have > been a source of annoyance over the years. Introducing another such > situation should, in my view, be avoided as far as possible. > > An example of a face attribute that handles things right is the :height > attribute. An absolute height is given by an integer, while a relative > height can be specified by a float. Allowing both in a single attribute > is good, because absolute height and the relative height are just > different ways to specify height. We don't have a :height and a > separate :relative-height attribute. If you are arguing for a change in the syntax of :foreground such that it could convey the information about both the "normal" color, and the alternate color to be used when the background is too similar to that "normal" color, then I agree it will probably be a nicer and cleaner feature. But that means :foreground will no longer be a simple string, but some more complex data structure, e.g. a list. > If I cannot convince anyone that there is a problem here, then forget > it. Don't give up just yet ;-) The solution should be able to cope with the need to dynamically decide which color is used as a foreground, based on the current background. It also needs to support the possibility that a face will want to force use of a specific fixed foreground color, regardless of the background. (Jan, did I miss some additional requirements?) If you can propose a cleaner solution that satisfies these requirements, please do, and let's discuss that. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-09 17:05 ` Eli Zaretskii @ 2014-01-09 17:22 ` David Engster 2014-01-09 17:27 ` Lars Magne Ingebrigtsen ` (2 more replies) 2014-01-09 17:39 ` Josh 2014-01-09 17:49 ` Jan D. 2 siblings, 3 replies; 57+ messages in thread From: David Engster @ 2014-01-09 17:22 UTC (permalink / raw) To: Eli Zaretskii; +Cc: Chong Yidong, jan.h.d, emacs-devel Eli Zaretskii writes: > The solution should be able to cope with the need to dynamically > decide which color is used as a foreground, based on the current > background. It also needs to support the possibility that a face will > want to force use of a specific fixed foreground color, regardless of > the background. (Jan, did I miss some additional requirements?) If > you can propose a cleaner solution that satisfies these requirements, > please do, and let's discuss that. I still wonder why it is necessary in the first place. From my experience, editors usually simply drop font-lock when you mark text (at least Eclipse does that, and in gvim it seems to be configurable), and I think that is a good default. When you mark a region, you want to apply some kind of operation on it, after which the region will be gone and font lock is restored. If you really really want font-lock on a marked region, then you will have to choose a region background which will play well with your color theme. Introducing a new face attribute for such a small annoyance looks like overkill to me. However, I also don't feel very strong about this issue. -David ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-09 17:22 ` David Engster @ 2014-01-09 17:27 ` Lars Magne Ingebrigtsen 2014-01-09 17:50 ` Jan D. 2014-01-09 20:58 ` Darren Hoo 2014-01-09 22:24 ` Drew Adams 2 siblings, 1 reply; 57+ messages in thread From: Lars Magne Ingebrigtsen @ 2014-01-09 17:27 UTC (permalink / raw) To: Eli Zaretskii; +Cc: Chong Yidong, jan.h.d, emacs-devel David Engster <deng@randomsample.de> writes: > I still wonder why it is necessary in the first place. color.el has functions for calculating "different enough" colours. I think using that (or something like that) for computing new foreground colours when the background changes would be a better idea... -- (domestic pets only, the antidote for overdose, milk.) bloggy blog: http://lars.ingebrigtsen.no ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-09 17:27 ` Lars Magne Ingebrigtsen @ 2014-01-09 17:50 ` Jan D. 0 siblings, 0 replies; 57+ messages in thread From: Jan D. @ 2014-01-09 17:50 UTC (permalink / raw) To: Lars Magne Ingebrigtsen; +Cc: Eli Zaretskii, Chong Yidong, emacs-devel Hello. Lars Magne Ingebrigtsen skrev 2014-01-09 18:27: > David Engster <deng@randomsample.de> writes: > >> I still wonder why it is necessary in the first place. > color.el has functions for calculating "different enough" colours. I > think using that (or something like that) for computing new foreground > colours when the background changes would be a better idea... Generated colors don't usually go well with custom themes. For the default theme it might be OK, but if you are defining a new theme you should be able to specify all colors. Jan D. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-09 17:22 ` David Engster 2014-01-09 17:27 ` Lars Magne Ingebrigtsen @ 2014-01-09 20:58 ` Darren Hoo 2014-01-09 21:17 ` David Engster 2014-01-09 22:25 ` Drew Adams 2014-01-09 22:24 ` Drew Adams 2 siblings, 2 replies; 57+ messages in thread From: Darren Hoo @ 2014-01-09 20:58 UTC (permalink / raw) To: emacs-devel David Engster <deng@randomsample.de> writes: > Eli Zaretskii writes: >> The solution should be able to cope with the need to dynamically >> decide which color is used as a foreground, based on the current >> background. It also needs to support the possibility that a face will >> want to force use of a specific fixed foreground color, regardless of >> the background. (Jan, did I miss some additional requirements?) If >> you can propose a cleaner solution that satisfies these requirements, >> please do, and let's discuss that. > > I still wonder why it is necessary in the first place. > > From my experience, editors usually simply drop font-lock when you mark > text (at least Eclipse does that, and in gvim it seems to be > configurable), and I think that is a good default. When you mark a > region, you want to apply some kind of operation on it, after which the > region will be gone and font lock is restored. > That's quite contrary to my experience. Even for old emacs like emacs22 font-lock is kept on marked text with transient-mark-mode enabled. As to other tools like Eclipse, Netbeans,Xcode selected text does not lose syntax highlight either. Especially for Eclipse I remembered that when I used it about a decade ago copying selected code from Eclipse to other WYSIWYG applications like MS PowerPoint the syntax highlight is also copied ie, rich formatted. > If you really really want font-lock on a marked region, then you will > have to choose a region background which will play well with your color > theme. Introducing a new face attribute for such a small annoyance looks > like overkill to me. I must say here that my experience with color theme is way much better and much less flaws than before it's integerated thanks to the work of all the developers especially cyd. I hope the feature be kept without introducing too much maitainabitly burden, with code both easier for user to understand and theme writers to customize. > However, I also don't feel very strong about this issue. I do. I find myself get an uneasy feeling when font-lock is lost on marked text. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-09 20:58 ` Darren Hoo @ 2014-01-09 21:17 ` David Engster 2014-01-09 22:29 ` Darren Hoo 2014-01-09 22:25 ` Drew Adams 1 sibling, 1 reply; 57+ messages in thread From: David Engster @ 2014-01-09 21:17 UTC (permalink / raw) To: Darren Hoo; +Cc: emacs-devel Darren Hoo writes: > David Engster <deng@randomsample.de> writes: >> Eli Zaretskii writes: >>> The solution should be able to cope with the need to dynamically >>> decide which color is used as a foreground, based on the current >>> background. It also needs to support the possibility that a face will >>> want to force use of a specific fixed foreground color, regardless of >>> the background. (Jan, did I miss some additional requirements?) If >>> you can propose a cleaner solution that satisfies these requirements, >>> please do, and let's discuss that. >> >> I still wonder why it is necessary in the first place. >> >> From my experience, editors usually simply drop font-lock when you mark >> text (at least Eclipse does that, and in gvim it seems to be >> configurable), and I think that is a good default. When you mark a >> region, you want to apply some kind of operation on it, after which the >> region will be gone and font lock is restored. >> > > That's quite contrary to my experience. Even for old emacs like emacs22 > font-lock is kept on marked text with transient-mark-mode enabled. > As to other tools like Eclipse, Netbeans,Xcode selected text does not > lose syntax highlight either. My Eclipse does that. I use the Zenburn color theme, though. Maybe it is configurable, I don't know. Anyway, I think that it is the right *default* behavior: making the region clearly visible and not caring about font lock. > Especially for Eclipse I remembered that when I used it about a decade > ago copying selected code from Eclipse to other WYSIWYG applications > like MS PowerPoint the syntax highlight is also copied ie, rich formatted. And what do those editors do when the highlight background color is very similar to one of the font-lock colors? > I find myself get an uneasy feeling when font-lock is lost on marked > text. Well, I don't. -David ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-09 21:17 ` David Engster @ 2014-01-09 22:29 ` Darren Hoo 0 siblings, 0 replies; 57+ messages in thread From: Darren Hoo @ 2014-01-09 22:29 UTC (permalink / raw) To: emacs-devel David Engster <deng@randomsample.de> writes: > My Eclipse does that. I use the Zenburn color theme, though. Maybe it is > configurable, I don't know. Anyway, I think that it is the right > *default* behavior: making the region clearly visible and not caring > about font lock. I see. I never used customized Eclipse color theme. I assume Zenburn might be a dark theme. I think that by default (No color theme) Emacs should work as what it did before. But with color themes especially for the dark ones I would not insist on the the region font lock. >> Especially for Eclipse I remembered that when I used it about a decade >> ago copying selected code from Eclipse to other WYSIWYG applications >> like MS PowerPoint the syntax highlight is also copied ie, rich formatted. > > And what do those editors do when the highlight background color is very > similar to one of the font-lock colors? > I am quite happy with Intellij Idea's dark theme (Dracula), I have used it for quite a while and have never seen illegilbe selected text. But I don't know how it does well so I can not provide any useful information here. ^ permalink raw reply [flat|nested] 57+ messages in thread
* RE: About the :distant-foreground face attribute 2014-01-09 20:58 ` Darren Hoo 2014-01-09 21:17 ` David Engster @ 2014-01-09 22:25 ` Drew Adams 1 sibling, 0 replies; 57+ messages in thread From: Drew Adams @ 2014-01-09 22:25 UTC (permalink / raw) To: Darren Hoo, emacs-devel > > From my experience, editors usually simply drop font-lock when you > > mark text (at least Eclipse does that, and in gvim it seems to be > > configurable), and I think that is a good default. When you mark a > > region, you want to apply some kind of operation on it, after > > which the region will be gone and font lock is restored. > > That's quite contrary to my experience. Even for old emacs like > emacs22 font-lock is kept on marked text with transient-mark-mode > enabled. As to other tools like Eclipse, Netbeans,Xcode selected > text does not lose syntax highlight either. Yes and no. You might think that, just because (a) by default, face `region' does not specify a foreground color and (b) most font locking (maybe all default font-locking) does not affect the background. > Especially for Eclipse I remembered that when I used it about a > decade ago copying selected code from Eclipse to other WYSIWYG > applications like MS PowerPoint the syntax highlight is also copied > ie, rich formatted. But this is the point: does the selection highlighting take precedence over the underlying text highlighting (syntax highlighting or other)? My guess is that in *all* of the cases you cite the answer is yes. Selection highlighting _should_ take precedence, so you can tell clearly which text has been selected. When you are selecting text, that is generally more important than other highlighting considerations. > I must say here that my experience with color theme is way much > better and much less flaws than before it's integerated thanks to > the work of all the developers especially cyd. I'm not sure what you mean by that. Color theme was not integrated into Emacs. It is still a separate library (and it still works with Emacs 24.4). What CYD did was to enhance Emacs custom themes to do some of what color themes do (in a different way), and to do some things that color themes do not do. `color-theme.el' is here: http://www.nongnu.org/color-theme . See also http://www.emacswiki.org/emacs/ColorTheme. > I do. I find myself get an uneasy feeling when font-lock is lost on > marked text. It was lost in the context you describe (IIUC), because the platform provided a bad default color for the `region' background. This was not the right "fix" for that problem, IMO (IIUC). ^ permalink raw reply [flat|nested] 57+ messages in thread
* RE: About the :distant-foreground face attribute 2014-01-09 17:22 ` David Engster 2014-01-09 17:27 ` Lars Magne Ingebrigtsen 2014-01-09 20:58 ` Darren Hoo @ 2014-01-09 22:24 ` Drew Adams 2 siblings, 0 replies; 57+ messages in thread From: Drew Adams @ 2014-01-09 22:24 UTC (permalink / raw) To: David Engster, Eli Zaretskii; +Cc: Chong Yidong, jan.h.d, emacs-devel > > The solution should be able to cope with the need to dynamically > > decide which color is used as a foreground, based on the current > > background. It also needs to support the possibility that a face > > will want to force use of a specific fixed foreground color, > > regardless of the background. (Jan, did I miss some additional > > requirements?) If you can propose a cleaner solution that satisfies > > these requirements, please do, and let's discuss that. IMO, there are no such "requirements", and no bug to be "fixed" here. > I still wonder why it is necessary in the first place. I don't think it was. > From my experience, editors usually simply drop font-lock when you > mark text (at least Eclipse does that, and in gvim it seems to be > configurable), and I think that is a good default. Yes, of course; it is the normal, and expected, behavior. Users should be able to easily see which text is selected - each character. Selection highlighting should be (and is, everywhere else that I am aware of) "on top", taking precedence over other highlighting. > When you mark a region, you want to apply some kind of operation on > it, after which the region will be gone and font lock is restored. > > If you really really want font-lock on a marked region, then you > will have to choose a region background which will play well with > your color theme. > > Introducing a new face attribute for such a small annoyance looks > like overkill to me. It's not just the chosen fix that is misguided. It is the belief that other highlighting (such as font lock) should "show through" the selection highlighting. This should have been tossed as "not a bug". ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-09 17:05 ` Eli Zaretskii 2014-01-09 17:22 ` David Engster @ 2014-01-09 17:39 ` Josh 2014-01-09 17:57 ` Eli Zaretskii 2014-01-09 17:49 ` Jan D. 2 siblings, 1 reply; 57+ messages in thread From: Josh @ 2014-01-09 17:39 UTC (permalink / raw) To: Eli Zaretskii; +Cc: Chong Yidong, Jan Djärv, emacs-devel On Thu, Jan 9, 2014 at 9:05 AM, Eli Zaretskii <eliz@gnu.org> wrote: >> From: Chong Yidong <cyd@gnu.org> >> Cc: jan.h.d@swipnet.se, emacs-devel@gnu.org >> Date: Fri, 10 Jan 2014 00:15:00 +0800 >> >> Eli Zaretskii <eliz@gnu.org> writes: >> >> >> The analogy would be if there was a :low-color-foreground face attribute >> >> which would override :foreground on low-color displays. That would be >> >> ugly, as I hope you agree. >> > >> > I'm not sure I see the ugliness, please elaborate. >> >> One face attribute should govern one aspect of how the face is >> displayed. In some cases, it may be hard to avoid having multiple >> attributes with overlapping effects, but the results are not pretty. >> For example, the interactions between :family, :foundry and :font have >> been a source of annoyance over the years. Introducing another such >> situation should, in my view, be avoided as far as possible. >> >> An example of a face attribute that handles things right is the :height >> attribute. An absolute height is given by an integer, while a relative >> height can be specified by a float. Allowing both in a single attribute >> is good, because absolute height and the relative height are just >> different ways to specify height. We don't have a :height and a >> separate :relative-height attribute. > > If you are arguing for a change in the syntax of :foreground such that > it could convey the information about both the "normal" color, and the > alternate color to be used when the background is too similar to that > "normal" color, then I agree it will probably be a nicer and cleaner > feature. But that means :foreground will no longer be a simple > string, but some more complex data structure, e.g. a list. > >> If I cannot convince anyone that there is a problem here, then forget >> it. > > Don't give up just yet ;-) > > The solution should be able to cope with the need to dynamically > decide which color is used as a foreground, based on the current > background. It also needs to support the possibility that a face will > want to force use of a specific fixed foreground color, regardless of > the background. (Jan, did I miss some additional requirements?) If > you can propose a cleaner solution that satisfies these requirements, > please do, and let's discuss that. Instead of explicitly specifying alternative foreground colors, whether by introducing a new face attribute or extending the current :foreground attribute, perhaps we could introduce a new `minimum-color-distance' user preference that would be used something like this: (defun choose-foreground-color (fg bg minimum-color-distance) (if (or (> (color-distance fg bg) minimum-color-distance) ;; ^^^ foreground and background are sufficiently different (= fg bg)) ;; ^^^ special case for text invisibility via fg==bg fg ;; preferred foreground color is ok; use it ;; otherwise, compute new foreground color -- not necessarily ;; via logxor but somehow guaranteed to be distant from bg (cl-mapcar 'logxor fg bg))) Though such computed colors are likely to be ugly, clash with color themes, etc. this approach is less invasive than the others being discussed and I think it accomplishes the primary goal of ensuring that bad combinations of foreground and background colors cannot render text illegible. Josh ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-09 17:39 ` Josh @ 2014-01-09 17:57 ` Eli Zaretskii 0 siblings, 0 replies; 57+ messages in thread From: Eli Zaretskii @ 2014-01-09 17:57 UTC (permalink / raw) To: Josh; +Cc: cyd, jan.h.d, emacs-devel > From: Josh <josh@foxtail.org> > Date: Thu, 9 Jan 2014 09:39:43 -0800 > Cc: Chong Yidong <cyd@gnu.org>, Jan Djärv <jan.h.d@swipnet.se>, > emacs-devel <emacs-devel@gnu.org> > > Instead of explicitly specifying alternative foreground colors, > whether by introducing a new face attribute or extending the > current :foreground attribute, perhaps we could introduce a new > `minimum-color-distance' user preference that would be used > something like this: First, such preferences should be per face, not global, for the reasons already explained in this thread. And second, this is not necessarily a user-level issue. It could be a requirement that text in a certain face be legible, come what may. In that case, we would like to give the Lisp programmer a way to put this requirement into the face definition. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-09 17:05 ` Eli Zaretskii 2014-01-09 17:22 ` David Engster 2014-01-09 17:39 ` Josh @ 2014-01-09 17:49 ` Jan D. 2 siblings, 0 replies; 57+ messages in thread From: Jan D. @ 2014-01-09 17:49 UTC (permalink / raw) To: Eli Zaretskii; +Cc: Chong Yidong, emacs-devel Eli Zaretskii skrev 2014-01-09 18:05: > The solution should be able to cope with the need to dynamically > decide which color is used as a foreground, based on the current > background. It also needs to support the possibility that a face will > want to force use of a specific fixed foreground color, regardless of > the background. (Jan, did I miss some additional requirements?) If you > can propose a cleaner solution that satisfies these requirements, > please do, and let's discuss that. If you have :foreground as a list and can specify the normal foreground as nil, that is equivalent to :distant-foreground. Jan D. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-07 15:00 ` Jan Djärv 2014-01-07 17:28 ` Drew Adams 2014-01-07 21:57 ` Chong Yidong @ 2014-01-07 22:50 ` Jan Djärv 2 siblings, 0 replies; 57+ messages in thread From: Jan Djärv @ 2014-01-07 22:50 UTC (permalink / raw) To: Chong Yidong; +Cc: emacs-devel > If you need to check for a background, the right thing would be to > extend the DISPLAY feature to do what you need. For example, a DISPLAY > element of `(background dark)' is used to test for a dark background. > Maybe what you want is to be able to specify a color in place of `dark', > which would mean a background close to that color. Patches welcome. Jan D. ^ permalink raw reply [flat|nested] 57+ messages in thread
* Re: About the :distant-foreground face attribute 2014-01-07 12:55 Chong Yidong 2014-01-07 15:00 ` Jan Djärv @ 2014-01-08 3:13 ` Darren Hoo 1 sibling, 0 replies; 57+ messages in thread From: Darren Hoo @ 2014-01-08 3:13 UTC (permalink / raw) To: emacs-devel I originally reported bug 15668 Just FYI, the `font-lock on region' thing is still not available in these bundled themes: wombat, wheatgrass, misterioso. ^ permalink raw reply [flat|nested] 57+ messages in thread
end of thread, other threads:[~2014-01-13 4:14 UTC | newest] Thread overview: 57+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- [not found] <<35efc77e-e132-4700-ae0f-d95079293ff5@default> [not found] ` <<83fvowdf4j.fsf@gnu.org> 2014-01-09 22:27 ` About the :distant-foreground face attribute Drew Adams [not found] <<87bnzo9cja.fsf@gnu.org> [not found] ` <<59B7E7FC-48D0-4737-B1BB-FFAC5BA9E07A@swipnet.se> [not found] ` <<874n5f3162.fsf@gnu.org> [not found] ` <<83fvozf86g.fsf@gnu.org> [not found] ` <<87r48javwe.fsf@gnu.org> [not found] ` <<83bnzmfjxe.fsf@gnu.org> [not found] ` <<87bnzlyvwb.fsf@gnu.org> [not found] ` <<jwvppo1dr9r.fsf-monnier+emacs@gnu.org> [not found] ` <<b53f01f5-1974-417a-b95b-a7e1b6906467@default> [not found] ` <<83wqi9cakl.fsf@gnu.org> 2014-01-09 21:12 ` Drew Adams 2014-01-09 21:22 ` Eli Zaretskii 2014-01-07 12:55 Chong Yidong 2014-01-07 15:00 ` Jan Djärv 2014-01-07 17:28 ` Drew Adams 2014-01-07 18:01 ` Eli Zaretskii 2014-01-07 18:09 ` Joel Mccracken [not found] ` <<8361pvsmbk.fsf@gnu.org> 2014-01-07 18:44 ` Drew Adams 2014-01-07 19:01 ` Eli Zaretskii [not found] ` <<83zjn7r4z3.fsf@gnu.org> 2014-01-07 19:06 ` Drew Adams 2014-01-07 19:15 ` Eli Zaretskii 2014-01-07 21:57 ` Chong Yidong 2014-01-08 3:45 ` Eli Zaretskii 2014-01-08 5:24 ` Chong Yidong 2014-01-08 9:35 ` Jan Djärv 2014-01-08 9:52 ` Chong Yidong 2014-01-08 10:10 ` Jan Djärv 2014-01-08 14:49 ` Chong Yidong 2014-01-08 16:37 ` Jan Djärv 2014-01-08 17:08 ` Drew Adams 2014-01-08 16:57 ` Drew Adams 2014-01-08 14:05 ` Stefan Monnier 2014-01-08 17:43 ` Eli Zaretskii 2014-01-09 16:15 ` Chong Yidong 2014-01-09 17:02 ` Stefan Monnier 2014-01-09 17:07 ` Drew Adams 2014-01-09 17:46 ` Eli Zaretskii 2014-01-09 18:21 ` Chong Yidong 2014-01-09 22:25 ` Drew Adams 2014-01-09 22:48 ` David Engster 2014-01-12 11:14 ` David Engster 2014-01-12 11:40 ` Jan Djärv 2014-01-12 12:21 ` David Engster 2014-01-12 12:56 ` Jan Djärv 2014-01-12 13:07 ` David Engster 2014-01-12 13:17 ` Jan Djärv 2014-01-12 20:14 ` Chong Yidong 2014-01-12 21:20 ` Drew Adams 2014-01-12 22:07 ` Jan Djärv 2014-01-13 0:57 ` Drew Adams 2014-01-12 22:59 ` Stefan Monnier 2014-01-13 4:14 ` chad 2014-01-09 17:05 ` Eli Zaretskii 2014-01-09 17:22 ` David Engster 2014-01-09 17:27 ` Lars Magne Ingebrigtsen 2014-01-09 17:50 ` Jan D. 2014-01-09 20:58 ` Darren Hoo 2014-01-09 21:17 ` David Engster 2014-01-09 22:29 ` Darren Hoo 2014-01-09 22:25 ` Drew Adams 2014-01-09 22:24 ` Drew Adams 2014-01-09 17:39 ` Josh 2014-01-09 17:57 ` Eli Zaretskii 2014-01-09 17:49 ` Jan D. 2014-01-07 22:50 ` Jan Djärv 2014-01-08 3:13 ` Darren Hoo
Code repositories for project(s) associated with this public inbox https://git.savannah.gnu.org/cgit/emacs.git This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).