Skip to content

CS2 Discussion: Output: Super - CS vs ES6 semantics #4961

@coffeescriptbot

Description

@coffeescriptbot

From @mrmowgli on 2016-12-28 13:01

Currently we have classes working in connec's branch pull #4354 (read the comments) - however as we go through the tests and compatibility with ES6 classes there are a lot of edge cases around super. In particular how ES6 (currently) handles super.

The basics of ES and super:

  • super() needs to be called in a constructor for this to exist
  • super() can't be used in an bound ES constructor function () =>
  • super can't be called from an external constructor
  • super can't be called more than once in a constructor
  • super can be called in overridden methods, the syntax becomes super.methodName()

This leads to some definite breaks in how the original CS classes operated, but probably the biggest restriction is the first one: super() needs to be called in a constructor for this to exist. The reason this becomes an issue is a pretty common use case: @ parameters.

For example the following code won't compile:

class A

class B extends A
  constructor: (@name) ->

This is because to refer to @name we actually have to make a super() call. connec played with the idea of automatically inserting a super() in the generated code, which required hoisting it to the top of the method. This unfortunately means that a parent constructor is getting called without your knowledge, leading to unpredictable inheritance. You might not want to call the original constructor, but by using @ parameters you inadvertently call into the parent, potentially without fulfilling it's signature requirements.

In addition, the following leads to a race condition:

class A
  constructor(@name)

class B extends A
  constructor: (@name) ->
    super(@name)   

since the @name parameter requires this within the super call.

I understand that sneaking a super() into the constructor transparently can be an issue, but is there a way to make this available in a subclass without super? Perhaps a blend of the original CS and ES6?

I personally would want to keep as much of the existing CS syntax as possible.

Thoughts?

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions