Skip to content

Conversation

@keddelzz
Copy link
Collaborator

@keddelzz keddelzz commented Apr 18, 2017

see #345

I created too huge patterns to be matched against. Those crashed the
compiler.
This change optimizes the pattern (and the runtime const) of huge
constants (numbers and characters) and other terms, whose representation
is very large (int-lists and char-lists/strings).
@keddelzz keddelzz force-pushed the splicing-and-unsplicing branch from a60604b to ebc3942 Compare April 18, 2017 21:43
@rexim rexim requested review from ForNeVeR and rexim April 22, 2017 19:28
Copy link
Member

@rexim rexim left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

QuotationMacro.scala is the bigest source code file in the entire codebase

$ ls -lhS $(find -type f -name \*.scala)
-rw-r--r-- 1 rexim users  13K Apr 23 02:40 ./macros/src/main/scala/me/rexim/morganey/meta/QuotationMacro.scala
-rw-r--r-- 1 rexim users 9.5K Feb 16 15:37 ./kernel/src/test/scala/me/rexim/morganey/ParserSpec.scala
-rw-r--r-- 1 rexim users 7.0K Apr 23 02:40 ./macros/src/test/scala/me/rexim/morganey/meta/InterpolatorSpec.scala
-rw-r--r-- 1 rexim users 4.6K Feb 16 15:37 ./kernel/src/main/scala/me/rexim/morganey/syntax/LambdaParser.scala
-rw-r--r-- 1 rexim users 4.6K Feb 16 15:37 ./kernel/src/main/scala/me/rexim/morganey/ast/LambdaTerm.scala
...

I cannot read it. Please decompose it accordingly.

case None => out = None
}
out.map(_.result())
}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think that it demands some additional tests. I understand the intention here to make it generic, but the implementation is too hard for me 😿

@ForNeVeR
Copy link
Member

ForNeVeR commented Apr 23, 2017

QuotationMacro.scala is the bigest source code file in the entire codebase

I agree.

That's due to new big methods that contain many nested functions. Probably we should somehow extract their contents to a new module with well-defined semantic.

@keddelzz
Copy link
Collaborator Author

Thank you guys for your review!

QuotationMacro.scala is the bigest source code file in the entire codebase.
Please decompose it accordingly.

I'll look into that!

I think that it demands some additional tests.

There are a few tests for the previous, non-generic sequence implementation, the change didn't break those. Nevertheless I agree! I'll add more tests.

Unfortunately, I'm very busy at the moment, so I'll look into it, when I have some time to spare. Apologies in advance for the inconvenience of leaving this PR untouched for a while.

@rexim
Copy link
Member

rexim commented Apr 26, 2017

@keddelzz yeah, I understand. I'm busy too. :) That's why I answer with such a delay. Don't worry, take your time.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants