I would love to retract ? and ! from the list of binary selectors.
I’m super super frustrated that predicates cannot be easily identifiable. for example is lineUpBlockBrackets an action or a testing method. I think that we are trapped in mistakes from the past. In racket and scheme and I guess ruby too we can use ? in the method and this change the game. self lineUpBlockBrackets? We have plenty of binary selector parts that are not used and think that it is frustrating. Let us check: Character specialCharacters '+-/\*~<>=@,%|&?!·÷±×' + - / \ ~ < > = @ , & | % those are ok I have no idea what is · nor how to type it. ÷ looks from the past. ± so funny × no idea what it is and…. Then we have two that could really improve our language ? and ! Do not tell me that there is a value in these selectors? (#(#+ #- #/ #\ #* #~ #< #> #= #@ #, #% #| #& #? #!) combinations select: [ :each | each size = 3 and: [ each includesAnyOf: #(#? #!) ] ]) collect: [ :each | each first, each second, each third ] #(#'+-?' #'+-!' #'+/?' #'+/!' #'+\?' #'+\!' #'+*?' #'+*!' #'+~?' #'+~!' #'+<?' #'+<!' #'+>?' #'+>!' #'+=?' #'+=!' #'+@?' #'+@!' #'+,?' #'+,!' #'+%?' #'+%!' #'+|?' #'+|!' #'+&?' #'+&!' #'+?!' #'-/?' #'-/!' #'-\?' #'-\!' #'-*?' #'-*!' #'-~?' #'-~!' #'-<?' #'-<!' #'->?' #'->!' #'-=?' #'-=!' #'-@?' #'-@!' #'-,?' #'-,!' #'-%?' #'-%!' #'-|?' #'-|!' #'-&?' #'-&!' #'-?!' #'/\?' #'/\!' #'/*?' #'/*!' #'/~?' #'/~!' #'/<?' #'/<!' #'/>?' #'/>!' #'/=?' #'/=!' #'/@?' #'/@!' #'/,?' #'/,!' #'/%?' #'/%!' #'/|?' #'/|!' #'/&?' #'/&!' #'/?!' #'\*?' #'\*!' #'\~?' #'\~!' #'\<?' #'\<!' #'\>?' #'\>!' #'\=?' #'\=!' #'\@?' #'\@!' #'\,?' #'\,!' #'\%?' #'\%!' #'\|?' #'\|!' #'\&?' #'\&!' #'\?!' #'*~?' #'*~!' #'*<?' #'*<!' #'*>?' #'*>!' #'*=?' #'*=!' #'*@?' #'*@!' #'*,?' #'*,!' #'*%?' #'*%!' #'*|?' #'*|!' #'*&?' #'*&!' #'*?!' #'~<?' #'~<!' #'~>?' #'~>!' #'~=?' #'~=!' #'~@?' #'~@!' #'~,?' #'~,!' #'~%?' #'~%!' #'~|?' #'~|!' #'~&?' #'~&!' #'~?!' #'<>?' #'<>!' #'<=?' #'<=!' #'<@?' #'<@!' #'<,?' #'<,!' #'<%?' #'<%!' #'<|?' #'<|!' #'<&?' #'<&!' #'<?!' #'>=?' #'>=!' #'>@?' #'>@!' #'>,?' #'>,!' #'>%?' #'>%!' #'>|?' #'>|!' #'>&?' #'>&!' #'>?!' #'=@?' #'=@!' #'=,?' #'=,!' #'=%?' #'=%!' #'=|?' #'=|!' #'=&?' #'=&!' #'=?!' #'@,?' #'@,!' #'@%?' #'@%!' #'@|?' #'@|!' #'@&?' #'@&!' #'@?!' #',%?' #',%!' #',|?' #',|!' #',&?' #',&!' #',?!' #'%|?' #'%|!' #'%&?' #'%&!' #'%?!' #'|&?' #'|&!' #'|?!' #'&?!’) may be this one #&?! is useful for WTF! And because of that we sacrifice having nice method names! I really think that we should change that. S. |
> On 10 Sep 2019, at 22:14, ducasse <[hidden email]> wrote: > > Then we have two that could really improve our language > ? and ! I never thought about that, but indeed, that would be quite nice. |
Yes, it would. On Tue, Sep 10, 2019 at 10:55 PM Sven Van Caekenberghe <[hidden email]> wrote:
|
In reply to this post by ducasse
Looks like Christmas season opened early this year :) Jokes aside, I'm in favor of changing some of the characters we use for binary selectors to allow it to be used in keyword/unary messages. I'll include % in that list. For me its more useful as a way to create percentages ( 5 % ) than to be used as a binary message for keeping an ugly name from C-like languages.
One thing that would be really cool is that we can use the full power of Unicode in methods/class names. Projects like polymath and DSLs can clearly take advantage of that. Some examples I've just invented, but can be supported:
On Tue, Sep 10, 2019 at 5:15 PM ducasse <[hidden email]> wrote: I would love to retract ? and ! from the list of binary selectors. |
In reply to this post by ducasse
Would use of ? and ! in unary/keyword selectors be convention or somehow required? If simply convention, then we should start with renaming testing methods to be named is* or has*.
flag1 := anInteger even. “not good" flag2 := anInteger isEven. “better" flag3 := anInteger even?. “how much better?” flag4 := #(1 2 3) includes?: 2. “how much better?" I’m not convinced that having another way to indicate a testing method will help if people still don’t name methods well. Also, can you give an example of where ! would clarify the meaning? Are you thinking of the following: myPoint x!: 3. myArray at: 1 put!: nil. Those don’t seem to be much improved! I’m not arguing for “compatibility" or "staying in the past." I’m just trying to understand the benefit. Thanks, James > On Sep 10, 2019, at 1:14 PM, ducasse <[hidden email]> wrote: > > I would love to retract ? and ! from the list of binary selectors. > I’m super super frustrated that predicates cannot be easily identifiable. > > for example is > lineUpBlockBrackets an action or a testing method. > > I think that we are trapped in mistakes from the past. > In racket and scheme and I guess ruby too we can use ? in the method and > this change the game. > > self lineUpBlockBrackets? > > We have plenty of binary selector parts that are not used and think that > it is frustrating. > > Let us check: > > Character specialCharacters > > '+-/\*~<>=@,%|&?!·÷±×' > > + > - > / > \ > ~ > < >> > = > @ > , > & > | > % > > those are ok > > I have no idea what is · nor how to type it. > ÷ looks from the past. > ± so funny > × no idea what it is and…. > > Then we have two that could really improve our language > ? and ! > > Do not tell me that there is a value in these selectors? > > > (#(#+ #- #/ #\ #* #~ #< #> #= #@ #, #% #| #& #? #!) combinations > select: [ :each | each size = 3 and: [ each includesAnyOf: #(#? #!) ] ]) collect: [ :each | each first, each second, each third ] > > #(#'+-?' #'+-!' #'+/?' #'+/!' #'+\?' #'+\!' #'+*?' #'+*!' #'+~?' #'+~!' #'+<?' #'+<!' #'+>?' #'+>!' #'+=?' #'+=!' #'+@?' #'+@!' #'+,?' #'+,!' #'+%?' #'+%!' #'+|?' #'+|!' #'+&?' #'+&!' #'+?!' #'-/?' #'-/!' #'-\?' #'-\!' #'-*?' #'-*!' #'-~?' #'-~!' #'-<?' #'-<!' #'->?' #'->!' #'-=?' #'-=!' #'-@?' #'-@!' #'-,?' #'-,!' #'-%?' #'-%!' #'-|?' #'-|!' #'-&?' #'-&!' #'-?!' #'/\?' #'/\!' #'/*?' #'/*!' #'/~?' #'/~!' #'/<?' #'/<!' #'/>?' #'/>!' #'/=?' #'/=!' #'/@?' #'/@!' #'/,?' #'/,!' #'/%?' #'/%!' #'/|?' #'/|!' #'/&?' #'/&!' #'/?!' #'\*?' #'\*!' #'\~?' #'\~!' #'\<?' #'\<!' #'\>?' #'\>!' #'\=?' #'\=!' #'\@?' #'\@!' #'\,?' #'\,!' #'\%?' #'\%!' #'\|?' #'\|!' #'\&?' #'\&!' #'\?!' #'*~?' #'*~!' #'*<?' #'*<!' #'*>?' #'*>!' #'*=?' #'*=!' #'*@?' #'*@!' #'*,?' #'*,!' #'*%?' #'*%!' #'*|?' #'*|!' #'*&?' #'*&!' #'*?!' #'~<?' #'~<!' #'~>?' #'~>!' #'~=?' #'~=!' #'~@?' #'~@!' #'~,?' #'~,!' #'~%?' #'~%!' #'~|?' #'~|!' #'~&?' #'~&!' #'~?!' #'<>?' #'<>!' #'<=?' #'<=!' #'<@?' #'<@!' #'<,?' #'<,!' #'<%?' #'<%!' #'<|?' #'<|!' #'<&?' #'<&!' #'<?!' #'>=?' #'>=!' #'>@?' #'>@!' #'>,?' #'>,!' #'>%?' #'>%!' #'>|?' #'>|!' #'>&?' #'>&!' #'>?!' #'=@?' #'=@!' #'=,?' #'=,!' #'=%?' #'=%!' #'=|?' #'=|!' #'=&?' #'=&!' #'=?!' #'@,?' #'@,!' #'@%?' #'@%!' #'@|?' #'@|!' #'@&?' #'@&!' #'@?!' #',%?' #',%!' #',|?' #',|!' #',&?' #',&!' #',?!' #'%|?' #'%|!' #'%&?' #'%&!' #'%?!' #'|&?' #'|&!' #'|?!' #'&?!’) > > may be this one #&?! is useful for WTF! > > And because of that we sacrifice having nice method names! > I really think that we should change that. > > S. > > > > |
In reply to this post by gcotelli
I feel an APL forcefield growing. Phil On Wed, Sep 11, 2019, 02:14 Gabriel Cotelli <[hidden email]> wrote:
|
sorry, how do you type unicode characters?
Bernardo E.C. Sent from a cheap desktop computer in South America. |
In reply to this post by gcotelli
Yes I know. We can let them rot in peace.
:) Why not :) For me the first step is to be able to rescue ? and ! from decay and give us a MUCH better way to convey meaning. Just for the fun look at the method of the BIContext to see what I mean. I’m refactoring the API of the new formatter and it is so frustrating to not being able to express interrogation nicely.
|
In reply to this post by jgfoster
> On 11 Sep 2019, at 04:07, James Foster <[hidden email]> wrote: > > Would use of ? and ! in unary/keyword selectors be convention or somehow required? If simply convention, then we should start with renaming testing methods to be named is* or has*. > flag1 := anInteger even. “not good" > flag2 := anInteger isEven. “better" > flag3 := anInteger even?. “how much better?” > flag4 := #(1 2 3) includes?: 2. “how much better?” I think that I would use ? mainly for unary message Now I’m sure that if you look carefully some people use include for the action includes for the tests I took include as an example and this is super not intention revealing. >> lineUpBlockBrackets lineUpBlockBrackets? Now I will rewrite them all as shouldLineUpBlockBrackets or isLineUpBlockBrackets and to me for unary message ? makes it a lot better. > I’m not convinced that having another way to indicate a testing method will help if people still don’t name methods well. > > Also, can you give an example of where ! would clarify the meaning? Are you thinking of the following: > myPoint x!: 3. > myArray at: 1 put!: nil. > Those don’t seem to be much improved! Pay attention you cannot use ! as separator. For ! I do not care now. > I’m not arguing for “compatibility" or "staying in the past." I’m just trying to understand the benefit. The question ? > > Thanks, > > James > >> On Sep 10, 2019, at 1:14 PM, ducasse <[hidden email]> wrote: >> >> I would love to retract ? and ! from the list of binary selectors. >> I’m super super frustrated that predicates cannot be easily identifiable. >> >> for example is >> lineUpBlockBrackets an action or a testing method. >> >> I think that we are trapped in mistakes from the past. >> In racket and scheme and I guess ruby too we can use ? in the method and >> this change the game. >> >> self lineUpBlockBrackets? >> >> We have plenty of binary selector parts that are not used and think that >> it is frustrating. >> >> Let us check: >> >> Character specialCharacters >> >> '+-/\*~<>=@,%|&?!·÷±×' >> >> + >> - >> / >> \ >> ~ >> < >>> >> = >> @ >> , >> & >> | >> % >> >> those are ok >> >> I have no idea what is · nor how to type it. >> ÷ looks from the past. >> ± so funny >> × no idea what it is and…. >> >> Then we have two that could really improve our language >> ? and ! >> >> Do not tell me that there is a value in these selectors? >> >> >> (#(#+ #- #/ #\ #* #~ #< #> #= #@ #, #% #| #& #? #!) combinations >> select: [ :each | each size = 3 and: [ each includesAnyOf: #(#? #!) ] ]) collect: [ :each | each first, each second, each third ] >> >> #(#'+-?' #'+-!' #'+/?' #'+/!' #'+\?' #'+\!' #'+*?' #'+*!' #'+~?' #'+~!' #'+<?' #'+<!' #'+>?' #'+>!' #'+=?' #'+=!' #'+@?' #'+@!' #'+,?' #'+,!' #'+%?' #'+%!' #'+|?' #'+|!' #'+&?' #'+&!' #'+?!' #'-/?' #'-/!' #'-\?' #'-\!' #'-*?' #'-*!' #'-~?' #'-~!' #'-<?' #'-<!' #'->?' #'->!' #'-=?' #'-=!' #'-@?' #'-@!' #'-,?' #'-,!' #'-%?' #'-%!' #'-|?' #'-|!' #'-&?' #'-&!' #'-?!' #'/\?' #'/\!' #'/*?' #'/*!' #'/~?' #'/~!' #'/<?' #'/<!' #'/>?' #'/>!' #'/=?' #'/=!' #'/@?' #'/@!' #'/,?' #'/,!' #'/%?' #'/%!' #'/|?' #'/|!' #'/&?' #'/&!' #'/?!' #'\*?' #'\*!' #'\~?' #'\~!' #'\<?' #'\<!' #'\>?' #'\>!' #'\=?' #'\=!' #'\@?' #'\@!' #'\,?' #'\,!' #'\%?' #'\%!' #'\|?' #'\|!' #'\&?' #'\&!' #'\?!' #'*~?' #'*~!' #'*<?' #'*<!' #'*>?' #'*>!' #'*=?' #'*=!' #'*@?' #'*@!' #'*,?' #'*,!' #'*%?' #'*%!' #'*|?' #'*|!' #'*&?' #'*&!' #'*?!' #'~<?' #'~<!' #'~>?' #'~>!' #'~=?' #'~=!' #'~@?' #'~@!' #'~,?' #'~,!' #'~%?' #'~%!' #'~|?' #'~|!' #'~&?' #'~&!' #'~?!' #'<>?' #'<>!' #'<=?' #'<=!' #'<@?' #'<@!' #'<,?' #'<,!' #'<%?' #'<%!' #'<|?' #'<|!' #'<&?' #'<&!' #'<?!' #'>=?' #'>=!' #'>@?' #'>@!' #'>,?' #'>,!' #'>%?' #'>%!' #'>|?' #'>|!' #'>&?' #'>&!' #'>?!' #'=@?' #'=@!' #'=,?' #'=,!' #'=%?' #'=%!' #'=|?' #'=|!' #'=&?' #'=&!' #'=?!' #'@,?' #'@,!' #'@%?' #'@%!' #'@|?' #'@|!' #'@&?' #'@&!' #'@?!' #',%?' #',%!' #',|?' #',|!' #',&?' #',&!' #',?!' #'%|?' #'%|!' #'%&?' #'%&!' #'%?!' #'|&?' #'|&!' #'|?!' #'&?!’) >> >> may be this one #&?! is useful for WTF! >> >> And because of that we sacrifice having nice method names! >> I really think that we should change that. >> >> S. >> >> >> >> > > |
In reply to this post by gcotelli
On Wed, Sep 11, 2019 at 2:14 AM Gabriel Cotelli <[hidden email]> wrote:
Yes I would like to have something like that for PolyMath :-) Is it possible to use Unicode characters for identifiers already ? I working on the port of : https://github.com/len/Domains to Pharo. The author modify the Cuis parser, so he can do things like that : "⊕ is used for direct sums, ⊗ for tensor products, × for cartesian
product, direct product of groups, ring products, and in general for
categorical products." and also define ^ as a binary method: "The ^ (hat) operator is used for exponentiation as well as conjugation
by group elements, and for creating free modules of tuples and matrices." I'm not sure this is a good idea, because ^ is used also to return values. A+ Serge Stinckwic h Int. Research Unit on Modelling/Simulation of Complex Systems (UMMISCO) Sorbonne University (SU) French National Research Institute for Sustainable Development (IRD) U niversity of Yaoundé I, Cameroon
|
In reply to this post by ducasse
Using ? for unary messages does not compose so well when you want to do some logical conditions. For example self isClass? or: [ self isTrait? ] . It's readable, but probably you want the ? just at the end of the sentence. For ! one use case is to use it for factorial, like we do in Math. So 5 ! --> 120. Also I don't know any good use case for ! as binary selector. ? has only one implementor in the Pharo image in some Url related code for query parameters. BTW, still using * for multiplication feels so 90's. :) On Wed, Sep 11, 2019 at 4:10 AM ducasse <[hidden email]> wrote:
|
In reply to this post by SergeStinckwich
Le mer. 11 sept. 2019 à 10:40, Serge Stinckwich <[hidden email]> a écrit :
Of course we want to be able to use those selectors:
⊕
⊗
etc... Not using those selectors in core image is one thing, forbiding their usage for every package is another thing Concerning the selectors with more than 2 characters, there are two examples in use in Squeak ==> logical implication (I use it a lot when writing tests cases) <=> space ship operator /// has been used in the past (but is rather deprecated) What is questionable is cultural acceptance of universal meaning of a Symbol <=> could have meant logical equivalence, but it would be pointless, because = (and == thanks to singleton) are already equivalence. It has been expunged from Pharo to my regrets,
because it is - beautifully self defined as < = > - culturally legitimate - the art of original author (Travis Griggs) There is no sacred cow, but respect of author has a value for me. It's sure that every binary selector might be questionable, at least in core image. For application, you never know (think DSL) we can create a lot of not completely inaesthetic ASCII styles <|> >< <+> <-> /+/ |*| For example
+/-
could be used for interval arithmetic (if we don't want to pay the burden of typing unicode, which ain't easy)
/\ \/ intersection and union |\| the Nicolas operator - I didn't fin a usage for it yet ;) etc... So why would one want to forbid them? For ? and ! I do not foresee elegant usage as binary, but would not miss them as regular letters eithers. It means accepting huge??? - understand isReallyHuge :) huge?:or!:???and: which are not less questionable. Ideally, it should be really easy to define one's own syntax in any class (already possible with own compiler/parser/scanner/whatever), or maybe any method I find that it's somehow more complex with the well engineered new Compiler than it was with the very hackish legacy one, but that's a detail.
There is no ambiguity for ^ and i have proposed that in Squeak years ago, it's a very simple change (here for legacy Compiler) The only argument against it is that omitting the point ending last but one sentence would not be detected as invalid syntax self doThis. ^self doThat versus self doThis ^self doThat To address this concern, we could have rules concerning the formatting: normally we would write self doThis ^ self doThat or eventually if on several lines, we would generally indent self doThis ^ self doThat An unusual formatting is a code smell IMO And in fact, this is not much different from un-detecting when we send a message #self when forgetting the point self doThis self doThat
self doThis self doThat.
|
Ah, and I forgot about your argumentation Stef: you cannot forbid binary selectors altogether because some are ugly @@*+!!! (I think I read this one in Asterix le gaulois) for the same reasons that youCanNOtfOrBIDunaYSElectORSWIthletTersBECauSESoMeaREUgly Le mer. 11 sept. 2019 à 19:44, Nicolas Cellier <[hidden email]> a écrit :
|
Wait I do not understand what you are saying :)
I never said that I want to forbid anything. I just say that I would like that ? is not consider as a part of a binary selector. Am’i clearer? Stef
|
It was just an answer to: > Do not tell me that there is a value in these selectors? I used the same argument for huge?:or!:???and: But I don't think it's a valid argument: it's making induction starting with a restricted set of examples... I also tried to answer to why and when a binary selector would be a "good" selector (elected for core libraries). (since you gave a list of selectors which were OK) I said that I don't really need ? nor ! in binary selectors, but neither do I in unary/keyword selectors (though I also thought using ? for boolean answer, I don't think it's really useful) Le mer. 11 sept. 2019 à 20:10, ducasse <[hidden email]> a écrit :
|
Note that I also cared to handle ^ as binary selector for Opal Unfortunately the issue staled (for good or bad reasons, don't know...) Le mer. 11 sept. 2019 à 21:21, Nicolas Cellier <[hidden email]> a écrit :
|
And to finish with ^, hare is an older implementation And the classical refutation (we should not bother too much about it) Le jeu. 12 sept. 2019 à 20:37, Nicolas Cellier <[hidden email]> a écrit :
|
Funnily, in same period you could find defenders of ? in binary selectors: and more geenral discussion about binary selectors: Stef, u gonna hate me for living in the past ;) But you don't have to be stuck of course :) Le jeu. 12 sept. 2019 à 21:39, Nicolas Cellier <[hidden email]> a écrit :
|
In reply to this post by ducasse
On Wed, Sep 11, 2019 at 4:10 AM ducasse <[hidden email]> wrote:
Hi Stef, I have been facing this ambiguity a lot too. And my workaround, most of the times, was also to prefer the "question" method with #should. #is just doesn't sound right in my cases, but #should does sound good in most of them. I would still like to find a better one, but for the moment, in my recent years, I am stuck with #should. Mariano Martinez Peck Email: [hidden email] Twitter: @MartinezPeck |
+1 for #shouldXxx I recall I use it a lot too, and #isXxx where that reads better but am struggling for examples.
Tim Sent from my iPhone
|
Free forum by Nabble | Edit this page |