Hey buddy some of us jork it to the mDNS RFC every single day
I’m not entirely sure what you mean tbh. Like if something changes in a library you linked against? I guess you would have to rebuild it but you would have to rebuild a shared library too and place it into the system. Actually, you don’t necessarily have to rebuild anything, you can actually just relink it if you still have object files around (like OpenBSD does this to relink the kernel into a random order on every boot), just swap in a different object file for what you changed
Okay let’s say I am writing MyReallyCoolLibrary V1. I have a myReallyCoolFunction()
. You want to use myReallyCoolFunction
in your code. Regardless if your system works on API or ABI symbols, what a symbol is is a universal address for a specific functionality. So when my library is compiled it makes a S_myReallyCoolFunction
, and when your app is compiled it makes a call S_myReallyCoolFunction
and this symbol needs to be resolved from somewhere.
So static linking is when you compile the app with S_myReallyCoolFunction
inside of it so when it sees call S_myReallyCoolFunction
it finds the S_myReallyCoolFunction
in the app data. Dynamic linking is when it finds call S_myReallyCoolFunction
in a library that’s a file on your machine. Plan9 uses static linking.
So let’s talk about this what it means for “code portability”. Let’s say I make an MyReallyCoolLibrary V1 and I have to change a few things, here are alternate universes that can happen:
myReallyCoolFunction
myReallyCoolFunction
but I do not change its behavior, I simply refactor the code to be more readable.myReallyCoolFunction
and I change its behavior.myReallyCoolFunction
and change it’s interface.myReallyCoolFunction
.So let’s compute what this should mean for encoding a Symbol in this case.
myReallyCoolFunction
from V2 can stay declared as S_myReallyCoolFunction
myReallyCoolFunction
from V2 can stay declared as S_myReallyCoolFunction
myReallyCoolFunction
from V2 has to be declared as S_myReallyCoolFunctionNew
myReallyCoolFunction
from V2 has to be declared as S_myReallyCoolFunctionNew
S_myReallyCoolFunction
Now these are the practical consequences for your code:
So now to make code truly portable I must now remove the app refactor pieces. I have 2 ways of doing that.
With #1 you have the problem everyone complains about today.
With #2 you essentially carry forward all work ever done. Every mistake, every refactor, every public API that’s ever been written and it’s behaviors must be frozen in amber and reshipped in the next version.
There is no magic here, it’s a simple but difficult to manage diagram.
Plan 9 is a carefully tuned system ofc and I obviously have the Plan 9 brainworms but like…
I agree that Plan 9 is really cool, but in practice Linux is the height of active development OS complexity that our society is able to build right now. Windows in comparison is ossifying, and OSX is much simpler.
I’ve never written any programs that were subject to such strict verification tbh. I had to look up what “DSL” means lol, Wikipedia says “definitive software library”.
DSL in this case means Domain Specific Language
I rly think it’s not such a problem most of the time, code changes all the time and people update it, as they should imo,
But here’s the problem with this statement, it unravels your definition of “code portability”. The whole point of “code portability” is that I don’t have to update my code. So I’m kind-of confused about what we’re arguing if it’s not Flatpak style portability, it’s not code portability, what are we specifically talking about?
And that formal verification can only get you as far as verifying there are no bugs but it can’t force you to write good systems or specifications and can’t help you if there are things like cosmic rays striking your processor ofc hehe
The formal verification can only reify the fact that you need something called Foo and I can provide it. The more formal it is the more accurate we can make the description of what Foo is and the more accurately I can provide something that matches that. But I can’t make it so that your Foo is actually a Bar because you meant a Bar but you didn’t know you needed a Bar. We can match shapes to holes but we cannot imbue the shapes or the holes with meaning and match on that. We can only match geometrically, that is to say (discrete) mathematically.
I agreee, this isn’t just a technological problem to me but also a social one. Like ideally I would love to see way more money or resources for computer systems research and state-sponsored computer systems. Tbh I feel like most of the reason ppl focus so much on unchanging software, ABIs, APIs, instruction sets, operating systems, etc is cuz capitalists use them to make products and them never changing and just being updated forever is labor reducing lol. When software is designed badly or the world has changed and software no longer suits the world we live in (many such cases), we (the community of computer-touchers lol) should be able to change it. Ofc there will be a transition process for anything and this is quite vague but yeh
I generally agree with this sentiment but I think the capitalist thing defeating better computing standards, tooling, and functionality is the commodity form. The commodity form and its practical uses don’t care about our nerd shit. The commodity form barely cares to fulfill the functional need it’s reified form (e.g. an apple) provides. That is to say, the commodity form doesn’t care if you make Shitty Apples or Good Apples as long as you can sell Apples. That applies to software, and as software grows more complex, capitalism tends to produce shitty software simply because the purpose of the commodity form is to facilitate trade not to be correct/reliable/be of any quality.
You just link against the symbols you use though :/ Lemme go statically link some GTK thing I have lying around and see what the binary size is cuz the entire GTK/GLib/GNOME thing is one of the worst examples of massive overcomplication on modern Unix lol
If you link against symbols you are not creating something portable. In order for it to be portable the lib cannot ever change symbols. That’s a constraint you can practically only work with if you have low code movement and you control the whole system. (see below for another way but it’s more complex rather than less complex).
Also I’m not a brother :|
My bad. I apologize. I am being inconsiderate in my haste to reply.
It was less complex cuz they made it that way though, we can too. FlatPaks are like the worst example too cuz they’re like dynamically linked things that bring along all the libraries they need to use anyway (unless they started keeping track of those?) so you get the worst of both static and dynamic linking. I just don’t use them lol
But there’s no other realistic way.
You mean portable like being able to copy binaries between systems? Cuz back in the 90s you would usually just build whatever it was from source if it wasn’t in your OS or buy a CD or smth from a vendor for your specific setup. Portable to me just means like that programs can be be built from source and run on other operating systems and isn’t too closely attached to wherever it was first created. Being able to copy binaries between systems isn’t something worth pursuing imo (breaking userspace is actually cool and good :3, that stable ABI shit has meant Linux keeps around so much ancient legacy code or gets stuck with badddd APIs for the rest of time or until someone writes some awful emulation layer lol)
That’s a completely different usage of “portable” and is basically a non-problem in the modern era, as long as and see my response to the symbols point, you are within the same-ish compatibility time frame.
It’s entirely impossible to do this over a distributed ecosystem over the long term. You need symbol migrations so that if I compile code from 1995 it can upgrade to the correct representation in modern symbols. I’ve built such dependency management systems for making evergreen data in DSLs. Mistakes, deprecation, and essentially everything you have ever written has to be permanent, it’s not a simple way to program. It can only be realized in tightly and directly controlled environments like Plan 9 or if you’re the architect of an org.
Dependency management is an organization problem that is complex, temporal, and intricate. You cannot “technology” your way out of the need to manage the essential complexity here.
I agree about static linking but… 100mb of code is absolutely massive, do Rust binaries actually get that large?? Idk how you do that even, must be wild amounts of automatically generated object oriented shit lol
My brother in Christ if you have to put every lib in the stack into a GUI executable you’re gonna have 100mb of libs regardless of what system you’re using.
Also Plan 9 did without dynamic linking in the 90s. They actually found their approach was smaller in a lot of cases over having dynamic libraries around: https://groups.google.com/g/comp.os.plan9/c/0H3pPRIgw58/m/J3NhLtgRRsYJ
Plan 9 was a centrally managed system without the speed of development of a modern OS. Yes they did it better because it was less complex to manage. Plan 9 doesn’t have to cope with the fact that the FlatPak for your app needs lib features that don’t come with your distro.
Also wdym by this? Ppl have been writing portable programs for Unix since before we even had POSIX
It was literally not practical to have every app be portable because of space constraints.
You mean the William S Burroughs apple shot?
Nobody at google knows the ics format anymore they’re all setting this up thru gcal LMAO
Because portability has only been practical for the majority of applications since 2005ish.
You’re not having a system where every executable has 100mb of OS libs statically linked to them in the 90’s be fuckin for real.
You complain a lot about static linking in rust and it’s the only way to actually achieve portability.
deleted by creator
Have you been getting interviews at least?
What’s funny is that World is defederated from Beehaw which is just a center-left lib server with actual moderation where you can’t slur BIPOC / GSM.
Which is ironic cause you will catch a ban from world for Dugin posting.
I have already depicted you as the soyjack and me as the chat but with political compass memes. Ironically world has made an “enlightened centrism” meme with how laughable the actual characterization of these instances is.
Ironically they don’t understand that shitjustworks is literally channer-lite, and that db0 isn’t filled with anarchists but anarkiddie cosplayers whose only understanding of anarchism is based on the struggles of being a child and being forced to get a public education.
Anarchists literally are more “read theory” guys than ML’s are, and yet their anarchism comm is dead and attempts to do silly shit like join up with #50501 which is a movement of about 100 people per state who think holding signs at their state capitol is going to do anything.
Finally they post shit like this which is hilarious because it’s so misleading. It’s a history of a specific Platformist movement (the one that created Platformism) and not an introduction to Platformism itself which is a party and inter-party organizational strategy, it’s like Democratic Centralism than Marxist Leninism.
Anarchism in theory and practice is about building resilient societies which are free at the communal and individual levels, which is building in hard mode. It’s not complaining about mommy giving you rules, which is what most dbzero posters do.
I live in the north east 70 is luxury here, and 68 is starting to be less common as energy prices increase.
Parts of my house are somewhere between 55 and 80 because I heat with wood. I average out between 60 and 68. Anything above 55 is fine, just wear a sweater. Lower than 55 is only a problem if it’s for an extended period of time because it’s a higher risk for respiratory viruses.
As many have said lathe is like 9 ish year old meme at this point.
Also if she posted on here Alice would have been banned for one of her many poster moments, between necrophilia and the I’m gonna become a cop shit.
Also I have experience with the fact that TF production is a huge shit show. They put out a call several times on a company I’ve literally worked for and never followed up. At least when True Anon scraps an idea they put out a call for they don’t just ignore you.
This is called social avoidance. It’s a maladaption.
The underlying causes can vary and you’d need a health professional to diagnose. This is an extremely common reaction for:
First off
for being a true poster.
If I knew this was going to lead to a “I got rejected for Berghain” style reply, I wouldn’t have asked. I’m gonna reply to the substance, but god damn this is an epic post.
You’re gonna have a hard time convincing me (also queer) that American gay men are more inclusive in their sex parties compared to Euros. Sure you might make it past the door in SF vs Berlin, but that doesn’t mean you’re gonna get what you want. American horsemarket literally has a FAQ about “will I get any action if I’m not a twink or a muscle bod” (damn wonder why that’s a FAQ huh?) The answer is basically “I can’t make people fuck you”. After all America has those 6 magic words on Grindr.
I’m also autistic and there’s no real difference here. NT’s also have to fake being “cool” to get into German clubs. You can fake being NT cool for 5 minutes to get past the bouncer. Nobody’s gonna care if you can’t make eye contact when you have a hood on dude.
Lastly American horsemarket doesn’t enforce condoms compared to Germany, which is crazy.
But honestly 5 star out of left field post that explains the Rosebud of your political view.
The problem is it boils down to there’s less posts on German sniffies that say “absolutely no loads refused”.
Same problem exists in the self driving space.
Level 2 partial automation is ADAS or Advanced Driver Assistance Systems. Some Level 2 features actually harm driver attention like:
I think at this point you need to give concrete examples rather than descriptions because the difference is rather nebulous if we’re talking about anything realistically mainstream which you would find in a Western global city.
The idea that queer spaces are a uniquely American trait is also horse shit.
Yeah too bad gns implements rate limiting and bad actor protection by essentially mimicking butt coin and requiring proof of work.
Trust is not a technologically solvable problem. This includes current DNS systems because ownership is effectively a proof of stake.