Richard Feldman, "Pushing Boundaries with Roc"

แชร์
ฝัง
  • เผยแพร่เมื่อ 13 ม.ค. 2025

ความคิดเห็น • 23

  • @peacememories
    @peacememories 2 ปีที่แล้ว +14

    One small thing about async behavior in Rust; Depending on the implementation of get_movies, it might also only start the request once the Future is polled (Rust supports push as well as pull behavior for Futures). What that doesn't change, though, is that there are still side effects instead of type encoded effects.

  •  ปีที่แล้ว +4

    I am humbled and elated to see such great language design!!!
    Looking forward to see isomorphic Roc code, so we may use it for both web server and the browser.
    What about type classes and generics?

  • @C3POXTC
    @C3POXTC 2 ปีที่แล้ว +2

    Great talk and very interesting discussions.

  • @chrisvouga8832
    @chrisvouga8832 2 ปีที่แล้ว +11

    I’m hyped for roc

  • @anderdrache8504
    @anderdrache8504 2 ปีที่แล้ว +3

    Great talk, I'm looking forward to using this language more and more!

  • @stephenkamenar
    @stephenkamenar 2 ปีที่แล้ว +2

    i remember using livescript all the way back before node even had async await, and you had to callback hell everything.
    livescript backcalls thing was so good

  • @airman122469
    @airman122469 ปีที่แล้ว +1

    “The compiler can always infer the type.”
    Whoa. That’s pretty cool.

  • @majorhumbert676
    @majorhumbert676 ปีที่แล้ว

    Would we still need Elm if we have Roc with a corresponding Web UI library?

  • @notabene9630
    @notabene9630 2 ปีที่แล้ว +2

    I already know I'll use the catchall errors return "ahhhhhhhhhhhhhhhh"

  • @TankorSmash
    @TankorSmash 2 ปีที่แล้ว

    I had the same question about running with type errors, I'd swear that I saw the check pass without warning the user about errors, but I guess not

  • @julianavar3836
    @julianavar3836 ปีที่แล้ว

    For those interested, I recommend Koka. Really incredible language.

  • @roteschwert
    @roteschwert 2 ปีที่แล้ว

    Does NoRedInk intend to use it in any capacity

  • @RicardoValero95
    @RicardoValero95 2 ปีที่แล้ว

    Makes you think how necessary is to use zod, io-ts, or other parsing libraries in the js ecosystem

  • @32zim32
    @32zim32 2 ปีที่แล้ว

    So as i understand roc somehow stores type information ay least in test env to run program without undefined behaviour?

    • @mymoomin0952
      @mymoomin0952 2 ปีที่แล้ว +4

      he says at 54:09 that a line with a type error is replaced with just an abort, which shouldn't require them to keep type information around at runtime

  • @beeshepard
    @beeshepard 2 ปีที่แล้ว

    Very interesting!

  • @strickinato
    @strickinato 2 ปีที่แล้ว +3

    Even in tech talks 42 years later Rodney Dangerfield don’t get no respect.

  • @dat7118
    @dat7118 ปีที่แล้ว +1

    I believe the statement at 26:30 is incorrect about Rust. Calling `let fut = get_movies();` does not immediately fire an HTTP request. One must do `fut.await` afterwards (or just do `get_movies().await`.

  • @johndewey7243
    @johndewey7243 2 ปีที่แล้ว +1

    Love it, but those numbers need to be fixed, ints and reals should be distinct. Go full numeric tower.

  • @32zim32
    @32zim32 2 ปีที่แล้ว

    In PHP i can have types, IDE will complain, but I can still run the program )

    • @digitalspecter
      @digitalspecter 2 ปีที่แล้ว +7

      Sure, you can also have IDE perfectly happy and still get runtime type errors. That's what I want to avoid.

  • @edgeeffect
    @edgeeffect 8 หลายเดือนก่อน

    I don't like type-inference. "Explicit is better than implicit". Reading other people's code in languages with type-inference can sometimes be very confusing. I see type annotations as more documentation for the reader/maintainer. If a feature makes it easier to read other people's code and harder to write your own code, then reading trumps writing and it's a good feature. and If the converse is true, it's a bad feature. "Typing [as in pressing keys on the keyboard, not type-systems] is not the bottleneck".

  • @Tirka100
    @Tirka100 ปีที่แล้ว

    no mutable variables == no mass adoption