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

Refactored your PR #1

Open
wants to merge 27 commits into
base: property
Choose a base branch
from
Open

Conversation

anko
Copy link

@anko anko commented Feb 6, 2016

  • refactored
  • added tests
  • used method atom to denote method properties (see 98ddff3)

It's probably administratively neater to merge this into your property branch so everything about it stays in the same PR and we stay on the same page about what's happening.

I still see the issue that { set : 5 } can't be expressed, because that (object (set (a)))({ set [a](b) {} }), but this is progress.

anko added 27 commits January 26, 2016 16:27
These property changes used to treat atoms that start with a colon the
same way that lists that are a quotation are treated now.
Relics from the past shall haunt us no more.
Since it doesn't *always* unwrap a quote; just when it detects one.
The `otherwise`-branch covers the same case.
It's safe to `@compile` things multiple times (it's a no-op when done
again), and this `fold1` is neater than a loop.

Seems like `coerce-property` will always fail its conditional unless
passed the `string-is-computed` argument (in which case it's a no-op),
so the call was redundant.
That error checking was duplicated a lot.  This error message should be
specific enough.
It was pretty confusing to me what coerceProperty was doing.  Because
it's been reduced to just a single conditional at this point, might as
well write it as a conditional instead wherever it's used: that requires
holding less state in mind when reading.
There were lots of lines of code between where this was defined and the
*one place* where it was used, so I inlined it for readability.
That `i` parameter standing for the argument index currently being
processed is non-descriptive and clutters up the place.  It's neater to
prepend the "there was a problem with argument #i" type of error text in
a central place, and have the leaf conditionals just throw an error with
the details.

Also, few of these error cases were being tested.
In the previous commit, generic JavaScript errors (like TypeError, etc)
would wrongly have the "Unexpected object macro argument #i: " text
prepended to their message.

That goes away by throwing a specific error type.
Reduces duplication and guards against future changes to how the
function macro is implemented.
That's already done by the function macro.
Similarly to set/get, this keeps all the function-constructing stuff in
one place, including error checking.
It's unnecessary: the [estree spec for ES5][1] doesn't specify it, and
[the estree spec for ES6][2] only specifies it for nodes with type
"ArrowFunctionExpression", which we aren't using and which can't be used
as getters and setters anyway.

[1]: https://github.com/estree/estree/blob/master/spec.md
[2]: https://github.com/estree/estree/blob/master/es6.md
This does mean we're blocked on
estools/esvalid#7 if we want safety.
Consider an ES6 object literal with a method that has empty arguments
and an empty body:

    {
      d() { }
    }

Before this commit, that would intuitively have been written as

    (object ('d ()))

which failed because the ('d ()) list has 2 elements, which the logic
attempted to compile to an ordinary property instead of a method. It's
ambiguous with

    {
      d: null
    }

if () were to compile to null.  It currently compiles to nothing (#32),
but the argument stands.

This change hence introduces this syntax

    (object (method 'd ()))

similarly to how getters and setters already allow empty bodies with

    (object (get 'd ())
            (set 'd ()))

I also moved the check for the initial "get" / "set" / "method" atom
above the args.length==2 check, to ensure it takes precedence.
Just in case someone creates a file called "test-all".
@dead-claudia
Copy link
Owner

I understand why you're sending the PR on this branch. I'm on my phone at
the moment, but I'll be able to give a more detailed response later
tonight.

On Sat, Feb 6, 2016, 17:27 An [email protected] wrote:

  • refactored
  • added tests
  • used method atom to denote method properties (see 98ddff3
    98ddff3
    )

It's probably administratively neater to merge this into your property
branch so everything about it stays in the same PR
anko#41 and we stay on the same page
about what's happening.

I still see the issue that { set : 5 } can't be expressed, because that (object

(set (a)))→({ set a {} }), but this is progress.

You can view, comment on, or merge this pull request online at:

#1
Commit Summary

  • Doc typo: colon → quote
  • Refactor: Remove unused 2nd arg from unwrap-quote
  • Refactor: rename unwrap-quote → maybe-unwrap-quote
  • Refactor: Extract is-list check, clarify is-atom
  • Refactor: Remove redundant case in . macro
  • Refactor: Simplify . macro implementation
  • Refactor: Remove redundant stringIsComputed arg
  • Refactor: Simplify coerce-property logic
  • Refactor: Localise maybeUnwrapQuote error handling
  • Refactor: Inline "coerce property" checks
  • Refactor: Inline checkList function
  • Refactor: Catch+rethrow instead of passing arg i
  • Distinguish pattern errors from generic ones
  • Add TODO for implement generator method property
  • Refactor naming of parameters in errors
  • Use function macro to compile get/set
  • Clarify get/set parameters error and test it
  • Test that empty setter body works
  • Test for get/set parameter count errors
  • Remove get/set parameter type check
  • Simplify get/set error checking conditional
  • Use function macro to compile methods
  • Don't set expression prop on get/set or methods
  • Clarify what esvalid limit we're working around
  • Use "method" atom to denote method properties
  • Make test-all a .PHONY make-target
  • Throw descriptive errors for method properties

File Changes

Patch Links:


Reply to this email directly or view it on GitHub
#1.

@@ -374,7 +374,7 @@ Property access uses the `.` macro.
If you wish you could just write those as `a.b.c` in eslisp code, use the
[*eslisp-propertify*][10] user-macro.

For *computed* property access, omit the leading colon.
Copy link
Owner

Choose a reason for hiding this comment

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

This is probably better in another PR. It's an oversight independent of this PR, and is better judged separately.

# This makes error handling neater: the top-level macro function catches
# this type of Errors and prepends information about which parameter was
# being processed when it occurred.
class ObjectParamError extends Error
Copy link
Owner

Choose a reason for hiding this comment

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

Copy link
Owner

Choose a reason for hiding this comment

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

I would also like to mention that this really needs to be done everywhere, not just within the (object) macro. But I'll save that for a later exercise.

Also, please include the stack. It makes for easier debugging. (Code generation serves as a good example here.)

# This is sufficient. Error.captureStackTrace is V8-specific, but nearly every
# implementation has a `stack` instance property on Errors.
if Error.captureStackTrace
  Error.captureStackTrace this, ObjectParamError
else
  @stack = new Error!stack

@dead-claudia
Copy link
Owner

@anko I left several notes inline where I feel you could pull those out of this PR, and I would be much more likely to merge them.

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

Successfully merging this pull request may close these issues.

2 participants