Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Phasing out language version 1 #249

Open
rumblesan opened this issue Jun 16, 2015 · 6 comments
Open

Phasing out language version 1 #249

rumblesan opened this issue Jun 16, 2015 · 6 comments

Comments

@rumblesan
Copy link
Collaborator

Have we hit feature parity between the two languages yet? so we still need version 1 of the language around? I know that at some point I was talking about the possibility of having multiple languages available, but to be honest, at this point I think it would be better to just concentrate on a single one.

@davidedc
Copy link
Owner

yes there are several basic tests that don't run the same way on both though.

https://github.com/davidedc/livecodelab/blob/master/coffee/languages/livelangv1/code-preprocessor-tests.coffee

try some of them, the ones that you think should work, cause I remember I found a few surprises back then if I remember well.

(If you don't have time I can run and list the ones that I think should work).

@davidedc
Copy link
Owner

I went briefly through (the first third of) the tests and played a bit, I noted down these points (in random order):

(there are a couple of example that use times : with the colon, but if I listed such examples here it's because they seem to give trouble with times without the colon as well)

  • Math.PI (and Math.*) not supported
  • trigonometric shortcuts not supported
  • closure declarations - no arrow notation
  • comments after declaration on first line gives error turns = 1 // 1 = Möbius strip
  • crazyRibbon example gives error, not quite understanding what might be bothering it
gridSize = 4 * abs(wave 0.05)
box
2+2 times
    rotate box
rotate wave
box

@rumblesan
Copy link
Collaborator Author

ah cool, thanks for going through these, hadn't had a chance yet myself. I think that actually it's worth my going through the grammar again and doing some work the entire thing now my understanding of stuff is a bit better.

@rumblesan
Copy link
Collaborator Author

OK, going through these and seeing what needs doing

So version 2 doesn't support object dereferencing, meanin Math.Pi won't work, but it's easily fixable by adding Pi and all the trig shortcuts to the global scope. Currently I don't think we have a need for using . as an object accessor. Would be a bit of work to add to the language, but not too hard if it's something we need.

closures are something that currently aren't handled, but do need to be done. I'll start on that soon as I've implemented it in other languages before so it's not too tough.

comments do need fixing, not sure why they don't work.

Crazy Ribbon won't work for two reasons. The simpler is just that sin isn't a defined function because the trig stuff hasn't been added to the scope. The more complex issue, and one that's in other places, is that even if sin was then the language doesn't support functions calls in expressions that don't use the parenthesis.
for example

pad = 1+abs(2*wave 0.5 )  // invalid
pad = 1+abs(2*wave(0.5)) // valid

functioncalls at the beginning of a line are fine, but not in this case

pretty sure we decided not to go with the colon after times, but that times (using the with or not) does have to be followed by a new line.

also, there's no way the following should be valid, it's really confusing code

a = 2
box a + 3 times rotate peg

Having an expression before times 2+2 times should be fine though and I'll get that fixed.

wave and beat won't work anywhere because they're functions and so in v2 language they need to be invoked with parenthesis.

the ball line box example won't work as I didn't think chaining was meant to work like that. all the chains finish once you have a shape

@davidedc
Copy link
Owner

converging...

I think it's important though (key, really) to omit the parentheses for function calls (both when there are no arguments and for sure when there are), I'm hoping that's in the realm of possibilities? 🎱

@rumblesan
Copy link
Collaborator Author

I think I need to have a serious overhaul of the v2 parser and interpreter really. Will start cracking away at it

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants