r3wp [groups: 83 posts: 189283]
  • Home
  • Script library
  • AltME Archive
  • Mailing list
  • Articles Index
  • Site search
 

World: r3wp

[!REBOL3 Proposals] For discussion of feature proposals

BrianH
12-Nov-2010
[391]
I've noticed that FOREACH, FORALL and MAP-EACH are used the most.
Ladislav
12-Nov-2010
[392x2]
In mezzanine functions?
(I do not use Forall)
BrianH
12-Nov-2010
[394]
Though FORSKIP is used a lot too. LOOP, REPEAT and WHILE aren't used 
much anymore, and I can't remember the last time I saw FOR used in 
real code, though I use it a lot in adhoc file management code.
Ladislav
12-Nov-2010
[395]
How about the general loop, is there a will to have it as a mezzanine?
Maxim
12-Nov-2010
[396]
you forgot until.... its usually the most practical loop for varying 
lenght loops.
BrianH
12-Nov-2010
[397x2]
I like it. And yes, I forgot UNTIL. I haven't seen UNTIL used in 
R3 except in text and example code.
All of the loops in R3 are native, so the optimization balance of 
them is different now.
Ladislav
12-Nov-2010
[399]
I find While more comfortable, usually, but the fact is, that Until 
does not have some problems While does
BrianH
12-Nov-2010
[400]
I like your general cycle (except the name), and would use it in 
user code if it were available.
Maxim
12-Nov-2010
[401]
yes its nice that all loops are native... this is especially cool 
on  forskip... it was prohibitive in R2...
BrianH
12-Nov-2010
[402]
WHILE's biggest problem afaik is #1519.
Ladislav
12-Nov-2010
[403]
I originally called it Cfor, but that name is even less appropriate, 
I guess
Maxim
12-Nov-2010
[404]
could it be called  ITERATE
Ladislav
12-Nov-2010
[405]
aha, looks acceptable
BrianH
12-Nov-2010
[406x2]
Looks good to me. I don't like the word "cycle" for mezzanines, too 
academic (no offence, Ladislav :), and "general" is too long.
I know, "iterate" is a bit academic too, but at least it's one word.
Ladislav
12-Nov-2010
[408x2]
That "general cycle" is the "official" (encyclopedic) name for such 
a cycle, but it does not look short enough for the real use.
, i.e. it is more appropriate in for the documentation purposes, 
than as a function name
BrianH
12-Nov-2010
[410x2]
Ladislav, Maxim, could you show some support for SELFLESS? Go to 
#1758 and leave comments. Carl changed it to "waiting".
SELFLESS? -> SELFLESS ?
Ladislav
12-Nov-2010
[412]
No problem
BrianH
12-Nov-2010
[413]
I did my best to argue for it by doing a thorough ticket and writing 
best-possible-without-it example code for LET and BIND-TO-NEW, to 
show how much it is needed.
Maxim
12-Nov-2010
[414x2]
I really like LET
especially when you put GET and SET besides it... all of a sudden 
I wondered... well, shoudn't LET have been the very first function 
evaluator  :-D
BrianH
12-Nov-2010
[416]
Yup. I've been meaning to write a LET for years, but this has been 
the first excuse :)
Ladislav
12-Nov-2010
[417x2]
Gregg: thanks for the "inverted programming" notion, I like it a 
lot. (used it in the #1758 comment)
Brian, BTW, there is one reason why to prefer LET instead of CONTEXT: 
CONTEXT always yields the block it reates, while LET could yield 
a result that is wanted more.
BrianH
12-Nov-2010
[419]
I agree, especially when that is what you want more. SELFLESS is 
more comparable to CONTEXT.
Ladislav
12-Nov-2010
[420]
err, block: :object, in my post
Maxim
12-Nov-2010
[421]
Q:  is the self word of a context something that can be bound to 
blocks within a method of that object?
Ladislav
12-Nov-2010
[422x2]
did not understand your question probably; did you mean something 
like this?

>> same? 'self first bind [self] make object! [a: 1]
== false
Or, maybe more in the line with what you wrote:

make object! [method: func [block] [bind block self]]
Maxim
12-Nov-2010
[424x2]
yes that'ts it.
because with SELFLESS it would be interesting!
BrianH
12-Nov-2010
[426x2]
>> a: context [a: 1]  same? a first bind [self] a
== true
With selfless contexts it wouldn't work. In certain circumstances 
this can be useful.
Maxim
12-Nov-2010
[428]
but if SELFLESS simply ignored the self word, then self would be 
bound to object SELFLESS was called in... which is very nice to allow 
loops which can access contexts.
Ladislav
12-Nov-2010
[429]
that does not look right to me at all
BrianH
12-Nov-2010
[430]
Loops in OO code can be helpful :)
Ladislav
12-Nov-2010
[431]
aha, maybe I misunderstood again
BrianH
12-Nov-2010
[432x2]
Ladislav, you are right.
>> a: context [a: 1]  same? a first do bind [self] a
== true
Dammit.
>> a: context [a: 1]  same? a do bind [self] a
== true
Maxim
12-Nov-2010
[434x2]
Q: would SELFLESS rebind values given with /set  ?

that is what I would expect, but its not defined in your ticket.
though maybe its better if it didn't.
BrianH
12-Nov-2010
[436x2]
No, it wouldn't rebind the values. For that matter it doesn't bind 
the original words.
It just uses SET semantics for the values.
Maxim
12-Nov-2010
[438x2]
I am thinking that SELFLESS could be used to build classes if we 
specified self as a word.
since self could be set to another context... it would be interesting 
since 

a  and  self/a  would effectively be different values  :-)
BrianH
12-Nov-2010
[440]
Yup, though that is likely not as good an idea as other words other 
than self. Regular object self binding is really helpful for OOP, 
even class-based OOP.