

No, I don’t want to “turn children on”.


No, I don’t want to “turn children on”.


If it were a magic lang item, you could treat the resulting value in a special way. Then, you could create an optimization pass for this situation: if a variable is assigned random in a loop and the loop can only be exited with a certain value, the compiler can coerce the magic rand value to it.


You could do a lot worse. If the type of i was an object, you could overload the negation operation to have side-effects for the third snippet, for example.


I don’t know what I was thinking.
But, if you borrow C’s semantics, you are allowed to “optimize” away side-effect-less loops, even if they would never terminate. But that would require the random method to be pure.


I feel like an idiot. Also, in the “Good” example, no underflow occurs. i goes from 0 to -10, and x is assigned to -i every loop.
It might still be possible to optimize away the random number example, if the random function were made a magic language item, but it would not be even remotely close to being worth the effort.


The compiler should be able to optimize all of them to the same machine code.
x==10, so as long as the nextInt() method doesn’t have side effects, the loop should be eliminated. But, again, language semantics can affect this.Edit: Very wrong for 3 & 4, see replies.


Depends on your religion, I guess. The Flying Spaghetti Monster seems pretty edible.


If you make it amphibious and go fast enough, it will plane.


- do not use ANY company resources. This could put you at risk of theft.
- do not do it on company time or make it look like it’s on company time. See point 2.
Did you mean “See point 1.”?


I mostly agree with you, but this is not quite true:
XDG implementation (which is also only used as a fallback when the three DE-specific implementations fail, even though all of them actually support XDG so having separate implementations is pointless)
Yes, the DE-specific implementations is pointless (as far as I know, I use a WM), but the XDG implementation is actually used first, and the function returns true if any impl returns true, like xdg() || gnome() || gnome_old() || kde().
rework the code so that there is a difference between “this DE wants light mode” and “couldn’t figure out of this DE is in light or dark mode” - both of these are now represented by the “false” return value.
This isn’t that bad? Yes, having an enum with three variants would be better and more readable, but the code just defaults to light mode if nothing wants dark mode, and prefers dark mode even if separate impls want both light and dark mode.
With multiple impls, you have to resolve conflicts somehow. You could, for example, match on current DE/WM name, only using the current DE’s impl, defaulting to XDG, avoiding the problem entirely or just use first impl that doesn’t return “default” or “error”.
I don’t like AI generated code, having reviewed some disgusting slop before. But it’s better to criticize the code’s actual faults, like the incorrect impls (which you listed) or failing the Linux CI.


What about “I’ll accept your pull request if you accept my merge request”?


Not quite sure if this answers your question, but at least on Linux, there is the x32 ABI, which uses most of the changes of x64 over x86, except that pointers are 32-bit. This allows programs to use more registers & other goodies from x64, while keeping pointers small.
If your program doesn’t use over 4GiBs of memory, it can result in a smaller memory footprint (less space used for pointers) and better performance (smaller structs fit better in CPU cache).
Also, there are people who run a 32-bit OS on a 64-bit CPU and don’t know better.


The theory of everything?


I meant the following:
The bootloader installer package is distro dependent, the bootloader the package installs isn’t. You can boot Debian no matter if the GRUB is installed from Debian stable, Debian Sid, Arch, Fedora or even FreeBSD. Otherwise, dual booting wouldn’t work.
Like I said, I’ve done that before, though with SystemD Boot instead of GRUB, which was a bit simpler due to how the bootloader is configured.
emerge --ask cake
...
[ebuild N ] dev-dotnet/cake-5.0.0 USE="-debug"
Huh. Seems like Gentoo really has a cake recipe.


As it’s a bootloader, it should make almost no difference which distribution was used to install it. (I’m not sure if Debian patches their GRUB.) I just used Arch as an example, as it is famous for being up to date. And, no matter where it’s installed from, if you’ve made changes to GRUB’s configuration, you’ll have to copy it over to the live distribution to keep your changes.
Yes, Debian Sid might be more familiar for Debian users, but that’s it.
Edit: You said “get the grub debs from Debian sid”, but installing Sid packages on non-Sid systems isn’t something that you should do.


But bootloaders are distro/OS agnostic. Why wait for Debian, when you could, for example, boot an Arch live ISO to install a newer GRUB?
I don’t use GRUB, but have done the same thing with SystemD Boot before. As GRUB’s configuration system is a bit more complex, you might have to mount your main install to get the correct config file.


Unlike Windows, on Linux you need to run ./<command> instead of just <command> for executables in you current directory.
That’s quite fast, do they cause many accidents?
Where did you find a laptop with a 27.2" or larger screen?