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
Welcome to Programmer Humor!
This is a place where you can post jokes, memes, humor, etc. related to programming!
For sharing awful code theres also Programming Horror.
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
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.
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.
This is exactly why I love PowerShell.
Need the [DateTime] object from 10 years ago? No biggie, just chuck (Get-Date).AddYears(-10)
down your console.
Need it in a specific timezone? That one's trickier, but since PowerShell can do .Net, run this:
$TargetDateTime = (Get-Date).AddYears(-10)
$TargetTimeZone = "India Standard Time"
$tz = [TimeZoneInfo]::FindSystemTimeZoneById($TargetTimeZone)
$utcOffset = $tz.GetUtcOffset($TargetDateTime)
[DateTimeOffset]::new($TargetDateTime.Ticks, $utcOffset)
And you get a DateTimeOffset object, which is this beauty:
DateTime : 25/08/2015 23:15:14
UtcDateTime : 25/08/2015 17:45:14
LocalDateTime : 25/08/2015 19:45:14
Date : 25/08/2015 00:00:00
Day : 25
DayOfWeek : Tuesday
DayOfYear : 237
Hour : 23
Millisecond : 421
Microsecond : 428
Nanosecond : 600
Minute : 15
Month : 8
Offset : 05:30:00
TotalOffsetMinutes : 330
Second : 14
Ticks : 635761413144214286
UtcTicks : 635761215144214286
TimeOfDay : 23:15:14.4214286
Year : 2015
DateTime
is the time in your target timezone, UtcDateTime
is, well, the UTC time, and LocalDateTime
is the time on host you ran the commands on.
Complicated or not, the interfaces suck. And dont have to. And that's the problem.
exactly why I wrap the parts I need, it's like git, tons of power, zero help.
Using ruby felt weird, it felt like it shouldn't work but it does.
The Python won't give an accurate date here because it doesn't take into account leap years.
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.
365.25*10 would at least get you closer.
You can subtract two dates and get the exact time difference.
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.
Ruby should add 10.years.ago.today
yeah, that's pretty much why timedelta doesn't have the concept of months or years, just days and smaller units. I like it better this way.
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)?
Does the Ruby version do that though?
I haven't got it installed to check, but seeing constants like SECONDS_PER_YEAR in the documentation makes me think it's just as bad if not worse.
https://api.rubyonrails.org/classes/ActiveSupport/Duration.html
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!
365.25, surely
Never use numbers when calculating dates. Use the data formats and constants the calendar library provides.
Yukihiro “Matz” Matsumoto has often said that he is “trying to make Ruby natural, not simple,” in a way that mirrors life.
People still use ruby?
You probably use it everyday and didn't know it https://github.blog/engineering/architecture-optimization/building-github-with-ruby-and-rails/
I just started a new php gig
I work with Delphi.
I fucking love PHP. I know I probably sound crazy to most developers, but PHP 8+ is freaking dope.
I had a coworker choose RoR for a major project despite the fact that he didn't know it, nobody on his team knew it, nobody at our company knew it, and nobody in the entire state knew it. It ended as one would expect, after three years and millions of dollars spent, with the only revenue it generated being $50K from the original client that had to be refunded to avoid a lawsuit.
The handful of us have moved onto Crystal Lang. It's a statically type checked and compiled dialect of Ruby. Crystal is fun to write code, but the compiler is slower (compared to go-lang/rust)... because... well it's a ruby dialect (with DSL's)... and the 3rd party libraries are limited.
This implies that integers in ROR are complex objects with properties that would be unhelpful in the majority of scenarios. Is that right?
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).
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)
LLM is saying...
Stop. Nothing at all past those three words is worth a damn.
What is the purpose of this comment.
You didn't seem to be ashamed of admitting to asking an LLM a question as if it was helpful, wise, or respectable for you to have done. You should be.
This is a poor perspective to have on things towards a stranger on the internet. I hope you’re just having a bad day and that things get better.
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.
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.
Fuck Rails sideways
Why?
I'm surprised this post hasn't summoned perl devs yet... 🤨