World: r3wp
[Core] Discuss core issues
older newer | first last |
[unknown: 5] 23-Feb-2009 [12698] | correct |
Henrik 23-Feb-2009 [12699] | which makes it slightly different from FOUND? |
BrianH 23-Feb-2009 [12700] | Henrik: "BrianH, what exactly does the :value do in function header? What is passed?" What is passed in R3 is the argument, completely unevaluated. So you can write this: set quote a get/any quote b instead of this: a: :b |
Geomol 23-Feb-2009 [12701] | What does this give in R3? >> true? 1 |
Henrik 23-Feb-2009 [12702] | Geomol, true. |
[unknown: 5] 23-Feb-2009 [12703] | John, any value passed that is not none or false will give true in R3 the way I understand it. |
Geomol 23-Feb-2009 [12704] | Ah, then I was wrong in my assumption above. |
[unknown: 5] 23-Feb-2009 [12705] | It's a departure from C way. If you want the C way then use make logic! |
Geomol 23-Feb-2009 [12706] | makes sense now ... I think. ;-) |
Henrik 23-Feb-2009 [12707] | >> source true? true?: make function! [[ {Returns true! if an expression can be used as true.} val ][ not not :val ] ] Sorry for crappy formatting. |
[unknown: 5] 23-Feb-2009 [12708] | I agree with Brian, I think it is more aligned with how REBOL operates with logic. |
BrianH 23-Feb-2009 [12709] | Paul, in R2 and R1 as well. The code is exactly the same. |
[unknown: 5] 23-Feb-2009 [12710] | Yeah, I agree Brian. |
Henrik 23-Feb-2009 [12711] | Geomol, you should get the same results for: either :val [true][false] |
BrianH 23-Feb-2009 [12712] | Or pick [#[false] #[true]] not :val. |
Henrik 23-Feb-2009 [12713] | BrianH, perhaps it's time for a little cookbook recipe on MAKE. :-) |
[unknown: 5] 23-Feb-2009 [12714] | by the way, make logic! also works with TRY |
BrianH 23-Feb-2009 [12715] | The full source of TRUE? is this: true?: func [ "Returns true if an expression can be used as true." val ; Note: No [any-type!] - we want unset! to fail. ] [not not :val] |
Geomol 23-Feb-2009 [12716] | Wonderful example of REBOL. :-) |
BrianH 23-Feb-2009 [12717] | The note is important, because that type restriction is the main reason for the function, as opposed to just using NOT NOT :val. |
Henrik 23-Feb-2009 [12718] | BrianH, this is in order to combat the use of unset! as inputs? |
BrianH 23-Feb-2009 [12719x2] | Yes. |
I've backported most of R3 to R2 (it bears repeating, because it was a hell of a task). 67 functions so far. | |
Geomol 23-Feb-2009 [12721] | Cool! |
[unknown: 5] 23-Feb-2009 [12722] | So does this mean a 2.7.7? |
Henrik 23-Feb-2009 [12723] | There is so much extra code done for R2, that I would be surprised if an R2.7.7, doesn't appear. |
BrianH 23-Feb-2009 [12724] | Just do one script and you can start porting your code. And it works in 2.6.2. |
Henrik 23-Feb-2009 [12725] | Perhaps it should be called 2.8 instead. |
[unknown: 5] 23-Feb-2009 [12726x3] | Since it is all mezzanines then I don't think it should be anything more than offered as a mezzanine library. |
Keep the current version until new natives are developed. Otherwise we get nothing but mezzanine bloat with the newer version. | |
I think as a minimum for a new version in REBOL - it should contain new natives. Maybe Carl can make some of them natives. | |
BrianH 23-Feb-2009 [12729] | Paul has deciphered the plan. I think it should stay a separate script. It breaks tons of R2 code. I expect that we won't be doing a 2.7.7 soon, and when we do it will just be compatible bug fixes. The future compatibility stuff will be in the R2-Future collection. |
Henrik 23-Feb-2009 [12730] | I disagree with that plan, unless there will be a method to include all changes with a single line of code. There are also many additions in VID. |
BrianH 23-Feb-2009 [12731] | And no new natives in future R2 versions, just compatible fixes to errors in existing natives. The only changes will be to make less behavior cause errors. And you can include R2-Forward in one line of code now, in 2.6.2 even. |
Henrik 23-Feb-2009 [12732] | Are the VID changes in R2-Forward? |
[unknown: 5] 23-Feb-2009 [12733x2] | Brian, I suggest not waiting for Carl and just offer a library of all the mezzanines that can be incorporated by just 'DOing the script to import them. |
Carl, doesn't need to get diverted from his current R3 progress. | |
BrianH 23-Feb-2009 [12735x2] | Paul, I am doing that already. I'm just waiting for approval to release them as MIT licensed code. |
It's done already. | |
[unknown: 5] 23-Feb-2009 [12737] | Don't know why you need approval. Anyone should be able to release mezzanine code shouldn't they? |
BrianH 23-Feb-2009 [12738x2] | Mezzanine code has license restrictions. I can only release this at all because I wrote almost all of the original mezzanines and didn't assign copyright to REBOL Tech or Carl. |
It didn't matter - I was going to open source it anyways. | |
[unknown: 5] 23-Feb-2009 [12740] | I don't think you have any legal ramifications at all here. |
BrianH 23-Feb-2009 [12741x4] | There are a few functions that were originally written by Carl - 7 of the 67 are slight tweaks to functions Carl wrote, the rest mine. |
Everything is attributed in the file. The main difference in licensing is that you would not be restricted like REBOL mezzanine source. One of those restrictions is that it is not allowed to use mezzanine source (either in the SDK or the source function) on REBOL clones like Oscar. | |
Henrik, the R3 changes to the graphics and port models are not supported. The post-2.7.5 R2 VID changes are not R3 compatible (nor is any R2 VID or RebGUI code) so they should go in another file, which I think should still be external if it would break existing R2 code. | |
The whole point of this is to make new R2 releases mostly unnecessary, and nothing to wait for for most people. | |
Henrik 23-Feb-2009 [12745x2] | Some changes will break VID, so there is probably more reason to create a VID extension kit. |
VID extension kit == independent from R2-forward. | |
BrianH 23-Feb-2009 [12747] | Yes, and then release it. Don't wait for a new R2 release. |
older newer | first last |