Rubysyn: Clarifying Ruby's Syntax and Semantics

(github.com)

59 points | by petalmind 4 days ago

2 comments

  • Smalltalker-80 5 hours ago
    • amomchilov 1 hour ago
      I never understood the appeal of this talking point. It’s just an accounting trick that moves the complexity to the standard library.

      For example, SmallTalk is a class based OO system, yet this postcard doesn’t slow you how to create a class.

      • petalmind 57 minutes ago
        Yeah, I was also going to say that conflating trivial syntax and "supremely easy to learn" is a very weak flex.

        The first Smalltalk-80 book you randomly find is 560 pages.

        Also, there is a weird bargaining with "but not block temporaries" and "not an instance variable". Why not? Half of the postcard is basically empty. Also, "except primitives" — how many primitives are there?

        • Smalltalker-80 27 minutes ago
          The appeal of having a very simple, base syntax and almost everything in the library / primitives, would be that code is always easy to read and write, also on the 'reflection' level, where most languages have specific keywords that cannot be used 'first class' with the rest of the language. E.g: Types next to class objects or operator overloading, look at Swift.. (Of course the complexity of a full working system (library) does not disappear in Smalltalk, it's just easier to read and modify. :)
          • petalmind 17 minutes ago
            > on the 'reflection' level, where most languages have specific keywords that cannot be used 'first class' with the rest of the language.

            In Ruby this is also the other way around, and it's one of my pet peeves.

            `Kernel#callcc` looks like a method (arguably, of a special class), yet it's impossible to re-implement directly in the language, as far as I can tell.

            Same with `raise`, I keep forgetting that it's not a keyword even.

        • amomchilov 41 minutes ago
          Next up: “all the characters you need fit on a single keyboard!”
    • pansa2 4 hours ago
      Yes, Smalltalk's syntax fits on a postcard - and it's possible to go even more minimal than that, e.g. Lisp or Forth.

      OTOH Ruby doesn't need a postcard, it needs a full poster.

  • SeriousM 4 hours ago
    > This is an experiment in clarifying some aspects of Ruby syntax and semantics. For that we're going to introduce an alternative Lisp-based syntax for Ruby, preserving Ruby semantics.

    Lisp? Then I would use Lisp...

    > The goal is to define a comprehensive, trivially-parsable and sugar-free syntax.

    Ruby has syntax sugar, no need to remove the funny parts.

    • lifthrasiir 3 minutes ago
      S-expression is a standard representation for syntax-free semantics. For example, PLT Redex [1] is a DSL for programming language semantics and built on top of Racket which uses S-expressions.

      [1] https://redex.racket-lang.org/

    • petalmind 3 hours ago
      > Lisp? Then I would use Lisp...

      Lisp has completely different runtime semantics. Even the lexical scope in Ruby is extremely peculiar. One of the hard parts of writing this document was to remove the intuitive influence of Lisp because it just doesn't make sense for Ruby.

    • petalmind 3 hours ago
      > Ruby has syntax sugar, no need to remove the funny parts.

      This is just an intermediate representation, it's not meant to be used directly (even though you can do that, of course).