• HiddenLayer555@lemmy.ml
    link
    fedilink
    English
    arrow-up
    2
    ·
    edit-2
    15 hours ago

    How is this implemented? Is it just functions and the language assumes the first parameter is autofilled with variable.function syntax?

    • vga@sopuli.xyz
      link
      fedilink
      arrow-up
      4
      ·
      edit-2
      5 hours ago

      Ruby is object-oriented, modelled after Smalltalk mostly. So

      irb(main):001:0> 10.class
      => Integer
      

      So you’ll just have implement the method “years” on the Integer (or something more generic like Numeric) class and then “ago” on whatever class the years method returned.

      You might imagine that you can do something like 10.years().ago() in python but the parser prevents you:

      >>> 10.years
        File "<python-input-0>", line 1
          10.years
            ^
      SyntaxError: invalid decimal literal
      

      Doesn’t seem like it would have to prevent it, back in ruby:

      irb(main):001:0> 10.0.class
      => Float
      

      Ruby is a pretty cute language in my opinion, and I find it sad that python kinda drove over it.

        • vga@sopuli.xyz
          link
          fedilink
          arrow-up
          1
          ·
          edit-2
          5 hours ago

          Yeah, I figured there would be a workaround. Also

          >>> (10).years()
          Traceback (most recent call last):
            File "<python-input-0>", line 1, in <module>
              (10).years()
              ^^^^^^^^^^
          AttributeError: 'int' object has no attribute 'years'
          

          But the other thing is also: can you add methods to the int class so that they’re available everywhere? I suspect that you cannot in python, at least without significant hackery. And I also suspect that it’s probably something they decided to prevent knowingly.

  • ArcaneSlime@lemmy.dbzer0.com
    link
    fedilink
    arrow-up
    8
    ·
    22 hours ago
    10.years.ago
    On.a.cold.dark.night
    There.was.someone.killed
    'Neath.the.town.hall.lights
    There.were.few.at.the.scene
    Though.they.all.agreed
    That.the.slayer.who.ran
    Looked.a.lot.like.me
    
      • ArcaneSlime@lemmy.dbzer0.com
        link
        fedilink
        arrow-up
        1
        ·
        13 hours ago

        Great song, despite the subject matter being somewhat disagreeable to me. One of the most covered country songs of all time, written by one of the best to touch the genre, Lefty Frizzell.

        https://www.youtube.com/watch?v=50k18gL76AU

        Personally I think he should have just spoken up. And so should she have. They never should have been doing that in the first place but it wasn’t worth taking the rap for murder. Still one of the best songs ever.

  • illusionist@lemmy.zip
    link
    fedilink
    arrow-up
    20
    ·
    1 day ago

    Looks like one is defined as years and one as days. 10 years does not necessarily equal 365 times 10.

  • Daniel Quinn@lemmy.ca
    link
    fedilink
    English
    arrow-up
    12
    ·
    1 day ago
    from datetime import datetime
    from dateutil.relativedelta import relativedelta
    
    print(datetime.now() + relativedelta(years=10))  # 2035-08-24 12:02:49.795177
    
  • Korne127@lemmy.world
    link
    fedilink
    arrow-up
    43
    ·
    1 day ago

    Never worked on Ruby, so I definitely cannot judge it, but that syntax looks so uncomfortable…

    • mesa@piefed.social
      link
      fedilink
      English
      arrow-up
      18
      ·
      1 day ago

      It can be nice to read but try debugging something like this is a horrible experience.

      I had 5 years of ruby on rails experience before jobs decided on other Lang’s. Its still not terrible persay but it hurts when you have multiple of these “smart” objects doing really silly things and debugging it all.

      • Züri@lemmy.ml
        link
        fedilink
        arrow-up
        5
        arrow-down
        1
        ·
        1 day ago

        I programm in Ruby since 2006.

        In my opinion it has some of the best debugging tools available.

        What was the horrible part you experienced?

  • HelloRoot@lemy.lol
    link
    fedilink
    English
    arrow-up
    18
    arrow-down
    4
    ·
    edit-2
    1 day ago

    Edit:

    To clarify, I looked at existing online ruby code and gave it a small test for readability. It may be outdated, use uncommon syntax, bad practice or be full of individual developer quirks - I wouldn’t know. I did that because I wanted to highlight some weaknesses of the language design that turned me away from ruby years ago. https://en.wikipedia.org/wiki/Principle_of_least_astonishment


    Yes, very nice. But here comes the ugly;

    [1,2,3].map(&:to_s)
    

    oh ok, a bit hieroglyphic, but I can figure it out, seems like ‘&’ means element and ‘:’ means what I do with it.

    files = `ls -1`
    

    Aaah so a backtick is for strings? WRONG!!! IT EXECUTES THE FUCKING COMMAND!!!

    ARGF.each { |line| puts line if /BEGIN/ .. /END/ }
    

    What the hell is | and / ? Oh but I guess .. is a range like in other languages, but what would be that range??? WRONG! I!!T’S A FLIP FLOP!!!

    %w{a b c}     # array of strings
    %i[foo bar]   # array of symbols
    %r{https?://\w+}  # regex
    %x(ls -1)     # run shell command
    

    Ah, just memorize which letter to use by heart and that % is for type and that [ = { sometimes. But { unequal to { other times.

    if line =~ /ERROR/
      warn $~.post_match
    end
    

    =~ neat!

    $~ dafuq???

    At this point I feel like ruby devs are just trolling us. There are always multiple ways to do the same thing. Every example from above also has a tidy and readable way to do it. But the alternative ways become progressively more shorthand, unreadable and unintuitive.

    • Captain Beyond@linkage.ds8.zone
      link
      fedilink
      arrow-up
      21
      ·
      edit-2
      1 day ago

      Aaah so a backtick is for strings? WRONG!!! IT EXECUTES THE FUCKING COMMAND!!!

      To be fair this is what they do in Perl and shell scripts (and in PHP too), so it’s not unexpected behavior in that world.

      • HelloRoot@lemy.lol
        link
        fedilink
        English
        arrow-up
        8
        ·
        edit-2
        1 day ago

        I’m way happier debugging “200 char wide class name + 50 line of boilerplate” code written in java that verbosely and expressively does the same thing compared to deciphering single symbol hieroglyphs in shell esque scripts where I have to pay attention which way the ticks are pointing.

      • Tanoh@lemmy.world
        link
        fedilink
        arrow-up
        8
        ·
        1 day ago

        Yeah, you could very well argue that JS and others that use it for weird interpolated strings are the weird ones here.

        • Feathercrown@lemmy.world
          link
          fedilink
          English
          arrow-up
          1
          ·
          18 hours ago

          On the other hand, interpolated strings are fucking awesome and you need them every 5 seconds for UI work

          • Tanoh@lemmy.world
            link
            fedilink
            arrow-up
            2
            ·
            7 hours ago

            Sure, but in Perl and other languages there is a difference between "$foo" and '$foo'. In that the first expands the value of foo, while the other doesn’t.

            But usually if you need to write stuff in noisy strings, just use printf/sprintf. Or a <<HERE block.

    • Does Ruby require the use of [] and {} there? Because those %w/%i/etc things look like custom quoting operators and at least in Perl you can use any delimiter you want: qw(a b c) is a list of strings, but so are qw+a b c+ and qw;a b c;.

    • Eager Eagle@lemmy.world
      link
      fedilink
      English
      arrow-up
      11
      arrow-down
      2
      ·
      1 day ago

      I prefer the one on the left because it’s evident it doesn’t account for leap days, while I’d be questioning whether the one on the right does.

      • Diplomjodler@lemmy.world
        link
        fedilink
        arrow-up
        4
        ·
        edit-2
        1 day ago

        I’ll give it a shot. Looks a bit kludgy and I’ve been typing this on my phone while sitting on the toilet. What am I doing with my life?

        from datetime import datetime 
        
        now = datetime.now()
        year = now.strftime('%Y')
        month = now.strftime('%m')
        day = now.strftime('%d')
        tenyearsago = datetime(year-10, month, day)
        print(tenyearsago.strftime('%d.%m.%Y')
        
  • waldfee@feddit.org
    link
    fedilink
    arrow-up
    12
    ·
    1 day ago

    crystal is another language that’s apparently quite similar to ruby, with the difference of being compiled and staticly type-checked, and I just love it’s ruby like syntax. I believe the equivalent code for this in crystal would be Time.local - 10.years

        • hinterlufer@lemmy.world
          link
          fedilink
          arrow-up
          2
          ·
          15 hours ago

          I don’t think this is implemented in the standard datetime library, but in principle overriding sub is easily possible and you can define it as you’d wish.

          However, I think subtracting a year is a bit ill defined, because it isn’t clear which year you’re subtracting given the leap year issue.

          • Feathercrown@lemmy.world
            link
            fedilink
            English
            arrow-up
            1
            ·
            14 hours ago

            If you’re subtracting a year from a date, you could just keep the date constant while changing the year, and adjust Feb 29 as needed.

  • Cat_Daddy [any, any]@hexbear.net
    link
    fedilink
    English
    arrow-up
    7
    ·
    1 day ago

    Ruby is awesome. Finding out that everything is an object, and because of that you can do things like in your example (10.whatever), is hilarious coming from other languages.

    • Ephera@lemmy.ml
      link
      fedilink
      English
      arrow-up
      4
      ·
      1 day ago

      By the way, it isn’t actually necessary for everything to be an object to make this work. The language just has to define 10.whatever() to be syntactic sugar for whatever(10). Some languages, like Python and Rust, have an explicit self parameter on their methods to help illustrate this.

      But yeah, a bunch of languages decided to special-case their objects instead, for whatever reason.

      • the rizzler@lemmygrad.ml
        link
        fedilink
        arrow-up
        4
        ·
        1 day ago

        this is very true but i gotta defend my object-oriented languages here (real object-oriented, not c+±style object-oriented). there’s a lot of way cooler stuff you can do with ruby or groovy or smalltalk that you just can’t do with rust, for example. objects aren’t special cases, the entire system is supposed to be implementable in itself. obviously the machine code itself can’t be objects but the good languages do their best to mask that.

      • v_krishna@lemmy.ml
        link
        fedilink
        English
        arrow-up
        3
        ·
        1 day ago

        That’s not quite right, the language has defined Int#days and 10 is actually Int(10). 10.days calls the instance method days on an instance of an Int (it has been years since I’ve used ruby so not sure if the stdlib class is actually Int)

        • TrippaSnippa@aussie.zone
          link
          fedilink
          English
          arrow-up
          2
          ·
          edit-2
          12 hours ago

          days is a method on the Numeric class in Rails, and it creates an instance of ActiveSupport::Duration with self passed to the constructor (this is a bit of a simplification, because it actually calls the class method days on Duration which converts the number of days into seconds before creating the Duration instance).

          • v_krishna@lemmy.ml
            link
            fedilink
            English
            arrow-up
            2
            ·
            10 hours ago

            Oh god good ol ActiveSupport. I’m having flashbacks of so many ruby projects trying not to bring it in and basically reinventing it but poorly documented.

            I still would say it was the language I’ve most enjoyed (professionally used most all higher level languages over 20+ years) but it might be nostalgia for a time early 2010s when rails was just freaking magic compared to the ways we used to build web apps.

        • Ephera@lemmy.ml
          link
          fedilink
          English
          arrow-up
          2
          ·
          edit-2
          1 day ago

          Ah, I’m not talking about Ruby, I’m talking about language design in general.

          I’m currently mostly doing Rust, so I can only really name that as an example (even though there’s very likely other languages that allow this, too), but yeah, here’s for example the 64-bit signed integer in Rust: https://doc.rust-lang.org/stable/std/primitive.i64.html

          That is a primitive type, not an object, so it is exactly 64-bits in size and stored on the stack, not the heap. But as you can see in the documentation, Rust allows for associated functions anyways, like for example:

          let my_number: i64 = -3;
          my_number.abs()  //returns the absolute value, so 3
          

          That’s because that last call is just syntactic sugar for calling the same function statically on the type:

          i64::abs(my_number)
          
    • 1rre@discuss.tchncs.de
      link
      fedilink
      arrow-up
      2
      ·
      1 day ago

      C# allows that. Scala allows that. I imagine a bunch of others do too, it’s just that Python is a scripting language so is simpler in terms of features

    • skisnow@lemmy.ca
      link
      fedilink
      English
      arrow-up
      11
      arrow-down
      1
      ·
      edit-2
      1 day ago

      I was on a project a while back that used Ruby, and what I concluded was that cute things like that look good at first glance if you’re skim-reading some already-correct code, but are pretty much a net wash in terms of writing or debugging code.

      It’s not unusual for people to think that code would be better if it scanned like regular English, but the problem is that English is woefully imprecise and doesn’t always correlate to what kind of operations get run by the code, and so you still end up having to learn all that syntax and mentally process it like any other programming language anyway, but now you’ve also got a bunch of false friends tricking you into thinking they do one thing but actually they do another.

      (also, the bulk of the text in that python example is the import statement, which is like… ok so what, it’s not like Ruby doesn’t have its own dependency hell problems)

      • Gamma@beehaw.org
        link
        fedilink
        English
        arrow-up
        3
        ·
        1 day ago

        I had to modify some ruby a few years ago, I don’t remember liking it! Once I understood the syntax it wasn’t terrible to work with but I still wasn’t a fan of the syntax

    • sunshine@lemmy.mlOP
      link
      fedilink
      arrow-up
      6
      ·
      1 day ago

      it works in Ruby on Rails but not in bare-naked Ruby, if that gives you a hint of how the language’s architecture makes things easy for you and also might stab you in the back one day.

  • Ŝan@piefed.zip
    link
    fedilink
    English
    arrow-up
    12
    arrow-down
    18
    ·
    1 day ago

    Ruby has þe highest POLS and most absurdly comfortable syntax, ever. Enjoy þe trip!

    Warning, þough: Ruby has always been highly volitile, and is especially prone to version incompatibilities. Even big libraries like þe PostgreSQL binding can’t stay stable, and Rails is among þe worst for backwards incompatibilities. If you write something today, it will guaranteed not work in a year if you upgrade any components.

    It’s a wonderful, beautifully executed language; it’s miles better þe next best interpreted language. Just watch out for dependency hell.

    • stingpie@lemmy.world
      link
      fedilink
      arrow-up
      2
      ·
      22 hours ago

      I really like that lemmy is small enough that I can recognize people by their individual writing style—Hello, thorn guy!

      • eldavi@lemmy.ml
        link
        fedilink
        English
        arrow-up
        5
        ·
        1 day ago

        I worked at a startup a decade+ so that learned this the hard way, but I’m not complaining since I wouldn’t have had a job if it weren’t for it.

        • mesa@piefed.social
          link
          fedilink
          English
          arrow-up
          2
          ·
          edit-2
          1 day ago

          Nice! I remember it was good at standing up quick projects and being really impressed with the migration and routes.

          I remember it paid well lol. Long term support even back then sucked!

      • Boomer Humor Doomergod@lemmy.world
        link
        fedilink
        English
        arrow-up
        3
        ·
        1 day ago

        Yeah, but for one-off scripts that solve small problems it’s way better.

        Add HTTParty for API calls and that’s like 90% of what I use Ruby for.

        • Ŝan@piefed.zip
          link
          fedilink
          English
          arrow-up
          3
          arrow-down
          5
          ·
          1 day ago

          It’s incredible for þat! Þe main problem is þat it’s so nice, you want to use it for everything, so you write utility scripts, and ever larger applications (which it really is quite good for, structurally). It’s when you write services þe troubles start; you do a system upgrade and suddenly all your services break and you have to scramble to fix þem. Just keeping þings alive becomes a full time job.

          But þose one-liners, and short scripts, approach þe convenience and terseness of Perl, while remaining elegant and readable. It’s really þe libraries which do you in.

          I really, really loved Ruby, which is why it was able to scar me so badly.