[-] lambdabeta@lemmy.ca 25 points 1 month ago

Sadly front end, like "High Level" is a very relative term. For example, in compiler design, the bit that parses code is called the "front end" since the "back end" is what emits machine code. I think that's what they mean here, the "front end" that understands D3D8 code has been added, presumably there is also a "back end" that converts the parsed/analyzed D3D8 code into valid opcodes for consumption by GPU/CPUs.

In the other direction, a UI/UX is sometimes called a "back end" when it is part of a more complex embedded project where physical controls are the "front end".

[-] lambdabeta@lemmy.ca 13 points 2 months ago

I still use Ada daily for my personal projects after having used it at work. I find it compliments my thinking patterns well. My only gripe with it is that they ate too much of their own dog food at AdaCore and now it can be hard to install Ada and gprbuild (due to a circular dependency). Plus gprc stole libgpr and broke some stuff too.

[-] lambdabeta@lemmy.ca 15 points 6 months ago

That would be an excellent idea. But I feel like an even broader community should be created. Like a generic book club, but for code bases! Could even have a small handful of different code bases on the go at a time. I'd love to get to know lemmy's, but also e.g. neovim, or even unciv :)

Maybe one day it could even start tackling Moby Dick!

[-] lambdabeta@lemmy.ca 16 points 6 months ago

I'm also wondering what's in the top-left. Is it a bowl of stones?

Wait! I figured it out.

You were close with C-section, but got the direction wrong. Clearly this is getting ready for urgent replacement of gizzard stones! :)

[-] lambdabeta@lemmy.ca 21 points 7 months ago* (last edited 7 months ago)

All praise our lord and saviour git rebase -i!

[-] lambdabeta@lemmy.ca 34 points 7 months ago

In case anyone wants the real meanings: I am not a lawyer, read the f***ing manual, bank of america.

[-] lambdabeta@lemmy.ca 10 points 11 months ago

I definitely have the soapy gene, but don't mind the taste. I blame thrills soap gum, I occasionally enjoyed that as a kid. My sister also has the gene and can’t stand the taste.

40
submitted 1 year ago by lambdabeta@lemmy.ca to c/canada@lemmy.ca

Maybe here we can draw the leaf without corrupting it. For reference I scaled the wikipedia picture to 100 pixels wide and anchored the 8 corners of the side borders. Hopefully we can make it look good!

[-] lambdabeta@lemmy.ca 46 points 1 year ago

After years, and many languages, I still have to say Ada. Kotlin, Rust, Julia, and Nim are my current contenders to overtake, but here's what Ada does well enough to still be my preferred tool when appropriate:

  • strictness: typically my code works the first time it successfully compiles with few or no bugs. Rust is almost on par in this respect.
  • structure: a corollary of the above is that it forces me to "plan ahead" more than just "start coding" which I find fits my programming style better, and leads to better "Unix Philosophy" product designs. I haven't found any other language that has the same effect other than maybe Haskell.
  • speed: I honestly find that Ada code outperforms C/C++ code most of the time. The only times C/C++ outperform Ada is after optimizations that come at the cost of readability.
  • multitasking: Ada's first-class tasks and protected objects are the only way I've ever been able to write bug-free concurrent programs that are more complex than async/await and/or producer/consumer structures (and I took a dedicated elective on concurrency at university!). Kotlin is almost on par in this respect with its coroutines.
  • hardware: The fact that Ada basically ships with a hard real-time OS built-in and can compile to e.g. AVR means that all my fancy libraries I've written or saved work just as well for a desktop game, a website backend, or an embedded microprocessor. Just look into representation clauses and interrupt pragmas to see its unique powers.
  • design: The whole design of the language has lead it to be the only language where I can consistently return to a multiple year old passion project with no attempt to write maintainable code, and fully understand what its doing and modify it with little effort.
  • tooling: While this is the biggest downside of Ada (see below) gprbuild is still my favourite build tool. I have no idea why strongly-typed build systems aren't more common. Its always a joy to work in gprbuild, once you get gprbuild working of course.
  • static polymorphism: Ada's generics are some of the best I've found. But they have some limitations that leads us into...

There are some situation where Ada shows its age:

  • static calculation: I love Nim (and Zig, etc) for the ability to run arbitrary code at compile time. It allows me to describe what would normally be an opaquely initialized data structure or code path in a clear and descriptive manner.
  • terseness: Ada is verbose, that's not such a big deal, but I find its just a tad too verbose which can lead to some slight difficulty when parsing code. func/proc (Nim) vs fun (Kotlin) vs fn (Rust) doesn't make much difference to me, but function X returns Y/procedure X starts to add a lot of visual noise to a file.
  • web compilation: The ability for both Kotlin and Nim to compile to either ASM or JS is AWESOME. If I have to write a "full stack" application, Kotlin multiplatform with ktor every day.
  • operator overloading: Only the built-in operators can be overloaded in Ada. It always makes me wish I could overload arbitrary operators. A small thing, but a symptom of...
  • TOOLING: Ada's tooling is BY FAR the hardest I have ever seen to get working. It takes the "eat your own dog food" too far. The fact that even in Arch Linux you have to install a bootstrap package, then the real package shows how hard it is to get a consistent build environment. ALR is helping in this respect, but is still not quite mature in my opinion.

Here's when I use the alternatives, and their biggest weaknesses:

  • Kotlin: anything where I want both one or more JS artifacts and one or more JVM/native artifacts. Weaknesses: performance, static analysis, on the fence about tooling (gradle is cool, but sometimes seems too over-engineered), Biggest weakness: IDE dependency, writing Kotlin outside of IntelliJ is a pain, which is somewhat fair given who maintains it!
  • Rust: so close to beating Ada, if not for two things: ugly code - so many operators and glyphs that pollute the reading experience, maybe I'll get used to it eventually, but for now I can't scan Rust code, nor pick up and revisit it nearly as easily as Ada; language scale - I find Rust suffers from the C++ design attitude of "we can add this as a language feature" it takes too much mental effort to hold the entire design of the language in your head, which you sort-of have to do to develop software. Java and C are IMHO the undisputed kings in this respect. After reading through the specifications of both languages, neither will ever have any surprises in store for you. There's no magic under the hood or special case. All the cool features are done by libraries and rely on the same simple syntax. Every time I learn a new cool thing Rust can do, its at the expense of another edge case in the compiler that modifies my conceptual model of the code.
  • Julia: multiple dispatch and mathematics plus clean module design and easy unicode incorporation leads to clean code for math-y/science-y code.
  • Nim: templates and macros are excellent, concept system gives access to Rust-style traits without all of the additional "ugliness" of Rust, excellent performance, tiny executables. I just find that the syntax can get clunky. The UFCS easily cleans up a lot of the mess that Rust creates with its added features, since it keeps the parsing the same even when using some fancy language feature.

Thank you for attending my TED talk :P. Any questions?

[-] lambdabeta@lemmy.ca 88 points 1 year ago

Not false at all: https://en.m.wikipedia.org/wiki/Capital_punishment_in_the_United_States

11 solid yes states. Of course Florida is one too.

(obligatory this is satire)

[-] lambdabeta@lemmy.ca 18 points 1 year ago

If you read the linked document, it outlines how reverse engineering may fall under a certain level of fair use, e.g. for reasearch and/or backup/archival purposes.

It really isn't as clear-cut as it seems at first.

[-] lambdabeta@lemmy.ca 12 points 1 year ago

More specifically look up the term "ablaut reduplication". There's lots of great articles and honestly some pretty good YouTube videos on the subject. I'm honestly surprised how great the YouTube linguistics scene is, from Tom Scott's language files to rob words and name explain (plus nativlang). Hours of infotainment on linguistics for those interested!

3

I've sunk many hours into the which species is closer related to X, A or B?

[-] lambdabeta@lemmy.ca 17 points 1 year ago

Wait until you learn about the shell specific /dev "files" like /dev/udp and /dev/tcp (which can send/recv IP traffic as if from a file)!

1

Hopefully this post works, first time posting on jerboa.

1
submitted 1 year ago by lambdabeta@lemmy.ca to c/poodles@lemmy.ca

She's our brown miniature poodle, about a year and a half old.

view more: next ›

lambdabeta

joined 1 year ago
MODERATOR OF