• Diplomjodler@lemmy.world
    link
    fedilink
    arrow-up
    45
    arrow-down
    2
    ·
    2 months ago

    The Python won’t give an accurate date here because it doesn’t take into account leap years.

    • rtxn@lemmy.world
      link
      fedilink
      arrow-up
      25
      arrow-down
      1
      ·
      2 months ago

      timedelta marks time in days, seconds, and microseconds. It doesn’t take leap years into account because the concept of years is irrelevant to timedelta. If you need to account for leap years, you need a different API.

    • wols@lemmy.zip
      link
      fedilink
      arrow-up
      12
      arrow-down
      1
      ·
      2 months ago

      The comparison is somewhat awkward, because the rails example presumably produces a date, while the python one is referring to an interval of time.
      Just from the meme it’s not obvious which was the actual intended use, so labeling either as inaccurate requires us to make assumptions.

      Personally, the concept of “10 years ago” is a bit nebulous to me. If today is February 29th, is ten years ago March 1st? Doesn’t seem right. Or particularly useful.

    • Eager Eagle@lemmy.world
      link
      fedilink
      English
      arrow-up
      8
      ·
      edit-2
      2 months ago

      Because what’s accurate here depends on the context, and the Python example doesn’t hide that from the programmer.

      The same dilemma goes for month calculations: does “3 months ago” mean 90 days ago, 91.3 days ago, this many days into the target month, or this many days from the target month’s end (e.g. to account for 28, 29, 30, and 31-day months)?

  • _stranger_@lemmy.world
    link
    fedilink
    arrow-up
    29
    arrow-down
    1
    ·
    edit-2
    2 months ago

    Ok, everyone who’s ever had to use datetime hates it, but not because it’s insufficient, but because international date/time is such a nightmare that the library must be complicated enough to support all the edge cases I’m convinced that library has a function for traveling trough time.

    For years I’ve wrapped datetime with custom functions that do exactly and only what I want to mitigate its all-plumbing-zero-porcelain approach to the problem.

  • etchinghillside@reddthat.com
    link
    fedilink
    arrow-up
    27
    arrow-down
    8
    ·
    edit-2
    2 months ago

    LLM is saying this is a feature of Rails and not particularly Ruby.

    I was surprised Python didn’t have a years parameter but learned about

    relativedelta(years=10)

    • mesa@piefed.social
      link
      fedilink
      English
      arrow-up
      26
      ·
      2 months ago

      Yeah its a rails only thing. Rubys biggest issue is its much too intelligent for its own good. Its implicit rather than pythons explicit. Most of the time. That and it’s hard to find out where Ruby starts and rails ends.

      That being said I made a ton of good money on rails back about 15 or so years ago. Still excellent for starting out.

      • tyler@programming.dev
        link
        fedilink
        arrow-up
        1
        ·
        2 months ago

        Ruby’s biggest issue is rails. Ruby is such a beautiful and highly functional language and yet everyone’s experience with it is rails’ horrific metaprogramming magic. I’ve had numerous people tell me they hate Ruby, and yet when I dig deeper I find out that they don’t actually understand where Ruby ends and rails starts and all of their problems lies on rails side. The majority of people I’ve shown that have come to actually like Ruby where they hated it before.

    • immutable@lemmy.zip
      link
      fedilink
      arrow-up
      2
      ·
      edit-2
      2 months ago

      Rails, ActiveSupport I believe, adds this to integers.

      But I think one of the interesting things about it is the open nature of classes in ruby.

      The thing that makes it possible is that you can open classes in user space and just add stuff to them. It’s a neat feature that few languages have.

      The feature, like most features, has pros and cons. On the pro side it makes making DSLs and helpers like this pretty trivial. You can make really expressive ideas and apis because you can change how things you didn’t write work.

      On the con side, it’s harder to discover and the methods of an object being the result of runtime mixins can make things hard to reason about.

      Having worked in both python and ruby and now elixir for the past couple of years, it’s interesting to see how the languages are similar and different.

      There’s an elegant beauty to ruby’s everything is an object and all method calls are messages concept. Python has always struck me as less elegant but the upside is that it can model different ideas in different ways and doesn’t have to try to make them all look like the one central idea.

      Even though I find the model behind ruby more pleasing to think about, I tend to enjoy python more due to it being more explicit and easier to reason about. Although that’s pretty subjective.

      In any case I think the language feature of open classes is a fascinating one and one of the really different parts of ruby that really distinguishes it from python, for better or worse.

  • bleistift2@sopuli.xyz
    link
    fedilink
    English
    arrow-up
    15
    ·
    2 months ago

    Fuck that. I once used a constraint solver in python where you could += a constraint to a problem. This is completely un-discoverable. In any sane language you can use IntelliSense to find that you can problem.add(constraint) and be done with it without ever touching a manual. Overloaded operators are cool, but a menace.

    And while I’m ranting: Angular’s new addRouting(), withThingA(), withThingB() is complete horseshit, too. The old way of doing addRouter({ and letting the IDE tell you what you could to with the router was so much clearer!

    • _stranger_@lemmy.world
      link
      fedilink
      arrow-up
      3
      ·
      edit-2
      2 months ago

      I’ll take overloaded operators over overloaded functions any day of the week, and I also hate overloaded operators.

      Python’s optional typing has come a very long way in the past few years, you might be able to mitigate this with some creative application of typing.

      Edit: I read your post closer, I’m not sure typing would help with the overloaded operator issue and now I have something fun to try out later 😁

    • marcos@lemmy.world
      link
      fedilink
      arrow-up
      1
      arrow-down
      1
      ·
      2 months ago

      Any good inline help would run dir into your variable and discover it overloads that operator. It’s a fault of your tools.

  • friend_of_satan@lemmy.world
    link
    fedilink
    English
    arrow-up
    15
    ·
    edit-2
    2 months ago

    This implies that integers in ROR are complex objects with properties that would be unhelpful in the majority of scenarios. Is that right?

    • myotheraccount@lemmy.world
      link
      fedilink
      arrow-up
      16
      ·
      2 months ago

      Integers are just integers in ruby, with no structure backing them. They behave like objects, but only in some respects. You can call methods on them, but you can’t extend individual numbers with properties for example (which would require them to have structure).

  • Victor@lemmy.world
    link
    fedilink
    arrow-up
    8
    arrow-down
    1
    ·
    edit-2
    2 months ago

    I’m gonna be honest, I never was drawn to python. I’ve been a professional developer for about a decade, and I’ve written all of one (1) python programs that I can remember (for my own personal use, mind).

    • addie@feddit.uk
      link
      fedilink
      arrow-up
      8
      ·
      2 months ago

      What you can achieve in a couple of pages of Python can be pretty spectacular. It’s also mostly very easy-to-read, with the possible exception of class inheritance, which is confusing mess.

      If you need to write more than a couple of pages, then its lack of types becomes a hindrance to me - doing refactors when functions can take basically any arguments is quite painful, for instance. Not requiring any particular structure is great, up until you start to struggle with lack of structure.

      Ideal programming language for when you’re wanting to do something that would be a bit too unwieldy for a shell script. It also makes network requests and json parsing very straightforward, so it’s great for interacting with REST APIs and writing simple microservices. Fast to write and runs quite quickly, so a good choice for Advent Of Code-like tasks. Would probably choose a different language for larger projects or when working in a team, though.

  • Unpigged@lemmy.dbzer0.com
    link
    fedilink
    arrow-up
    5
    ·
    2 months ago

    I miss Ruby DSLs so much. Python is bland. It’s on purpose, I know and even appreciate it.

    Yet I feel like Ruby syntax magic compared to Python blandness is like comparing a steaming plate of beautiful aromatic curry to plain rice.

  • ArcaneSlime@lemmy.dbzer0.com
    link
    fedilink
    arrow-up
    2
    ·
    edit-2
    2 months ago

    There’s two of these threads?! Well ok here’s the same comment.

    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