Bonum Certa Men Certa

Microsoft GNU-Hub (Part 4)

Article by figosdev

Catch me if you can



Summary: Following the first 3 parts [1, 2, 3] we look more closely at individual GNU projects and their Microsoft-hosted dependencies

In the previous article, the overall methodology for this series was discussed, and Tom has since written this article outlining some of the reasons these things are problems, and what can and probably ought to be done about them.



He also mentioned that the "gnu.org/software" url for Fribidi immediately redirects to the Microsoft-controlled GitHub repo. Let me tell you what I think of this fact.

The processes and policies of the GNU Project are certainly not up to me, though if I (or anybody in charge of policies for the GNU Project) were a lawyer, there would be some sane, ethical limits on what I can support simultaneously.

I couldn't represent people on opposite sides of a court case, because I would basically be taking their money for performing the service of fighting against myself. No matter who wins that one, I've taken their money and thrown the fight for one side or the other!

"Microsoft doesn't say they love your freedom, because their model isn't based on freedom."Microsoft claims to "Love Linux", but lots of very bad people claim to love their victims. Microsoft doesn't say they love your freedom, because their model isn't based on freedom.

They don't say "free software" because they aren't trying to make you free. In fact Techrights has covered the money they paid to politicians to get the City of Munich to ditch free software -- and go back to Microsoft instead! Then there are the bogus patents and royalty-seeking attacks on free software, which both FSF-sponsor IBM and Microsoft have continued to support.

More than a year before Microsoft purchased it, the FSF gave GitHub an "F" in its evaluation of code repo criteria: https://www.gnu.org/software/repo-criteria-evaluation.en.html. They cited:

* Important site functionality does not work without running nonfree JavaScript. * Specific information may not be available in all countries * The worst thing that GitHub does is to encourage bad licensing practice

The FSF also links to other reasons for avoiding GitHub, which were valid before the acquisition but are all the more relevant now.

"In fact Techrights has covered the money they paid to politicians to get the City of Munich to ditch free software -- and go back to Microsoft instead!"The lock-in for some users (or perhaps we should consider a different term for people stuck with GitHub -- useds, because Microsoft is using them more than they're using Microsoft) could be enough to create tension between developers and GNU leadership, as of the 33 people on this anti-rms petition nearly 2/3 of them have remained active on GitHub since they were purchased by Microsoft.

We are going to avoid using the names of individuals (though they already name themselves) but some of the people on the list have even contributed to the connections between GitHub and the GNU project. What isn't being said here is that this is definitely the reason for the petition. While the timing "seizes the day" in terms of trying to kick out rms while he was already stepping down from FSF leadership, the real motivations of the signed are unknown unless we take them at their word.

When no fewer than 20 of them have written or forked code on Microsoft GitHub in the past year, in some instances even for the GNU Project -- (at least 7 of them appear to work for Red Hat, which develops on GitHub and is now owned by the FSF's largest sponsor) we have to point out the possibility that opportunism was a factor.

Either way, trusting one of the most infamous opponents of software freedom with moderation of projects like GNU Bison, GNU Fribidi and other projects key to the GNU project seems like either hiring or working for your own client's opponent -- this sounds like textbook conflict of interest to me, though Tom is the person I would go to for his greater experience with organisational process. Perhaps instead of formally being a conflict of interest, crossing the GNU project with GitHub is merely a really terrible idea -- one of those instances where "compromise" isn't a word denoting reason and cooperation as much as failure.

A bit outside the reach of GNU developers to be certain, GNUzilla is built with rust, which is developed on GitHub.

I'm now trying to catch projects that include jpeg, pdf and postscript files. Why? Because pdf and postscript files use ghostscript, which is typically compiled with png support and brings in zlib1g from GitHub. Help me find a way that's not so.

"...of the 33 people on this anti-rms petition nearly 2/3 of them have remained active on GitHub since they were purchased by Microsoft."For a week or two I was saving screencaps as jpeg instead of png, but it looks like OpenJPEG is GitHub-based as well. Does anybody still use libj2k?

Packages that include one or more png files include gnuschool, GNUjump, GNUbik, GNU remotecontrol, GNU Optical design and simulation library, GNU mifluz, GNU Chess and GNU libmicrohttpd.

GNU Crypto, GNU Astronomy Utilities and Gnu Circuit Analysis Package have png and pdf in docs. GNU Generic Security Service Library has png, pdf and postscript.

GnuTLS has Perl and png in the docs, GNUtrition has Python, png, and pdf.

GNUspool and GNUbatch have Perl, Python and png.

GNUsound has png files, as well as modules for ALSA and Jack, both of which are GitHub based -- though I still don't believe that and will have to check it a few more times before I do.

GNUpod is Perl based.

GNUnet uses Perl, and wolfssl from GitHub.

GNUlib uses https://github.com/gnulib-modules/bootstrap which I found because gnu-pw-mgr uses bootstrap.

GnuCOBOL has a scanner generated by flex, and Perl in tests and docs.

With gnubg, I'm hoping someone can explain this one. It contains Python scripts, there's code written in C which is alright (I'm not going to check how these are related) and someone who appears unrelated to the project is working on something on GitHub which is also called "GNU Backgammon" at ytani01/ytBackgammon--

This is free software, so it's certainly alright if someone forks it or creates what appears to be a Javascript project (if it is indeed a fork). It's unfortunate that they've chosen GitHub for this, but if it's not one of the actual GNU maintainers, we can't blame the GNU Project for this. We can only hope that ytani01 decides to DeleteGithub and move their project somewhere else.

"GNU Smalltalk really shouldn't be developed on Microsoft Github."GNU Zile has Perl in tests and build.

GNU Wget has png in docs and could be compiled with support for brotli (from Google's GitHub) or zstd (Facebook's GitHub) or libpsl for cookie domain checking, which appears to be from GitHub.

GNU VCDImager is being developed on GitHub.

GNU Typist has Perl and Perl modules in tools.

GNU troff and GNU Stow use Perl.

GNU tar calls GNU bison, which is GitHub-based.

GNU SpaceChart uses Perl and contains a parser made for or with bison.

GNU source-highlight has Python and Perl in tests.

GNU Source Release Collection will depend on GitHub as long as any official GNU software does, as its purpose is to "maintain a rolling release of the latest version" of GNU projects.

I would be more comfortable with someone trying to make an official distro-like collection of all GNU projects if the project admin wasn't someone who has continued to develop on Microsoft GitHub for the past year. Why not just bring the entire GNU project into a GitHub staging area?

What is this, anyway? https://github.com/gitGNU

"gnu_bash C GPL-3.0 37 61 0 2 Updated 5 days ago"

"I stopped counting things that use flex or bison for building because there are so many."GNU Solfege uses Python and png.

GNU social uses HTTP_Request2, from GitHub.

GNU Smalltalk has a story, of sorts. It was being developed on GitHub as far back as 7 years ago, well before the Microsoft purchase but by now-inactive contributor bonzini/smalltalk. I only noticed this because of a dead link to MrGwen/gst-visualgst in the /packages folder of the GNU Smalltalk sources.

The current GNU maintainer is also active on GitHub, though it does not seem to be where the most recent Smalltalk development has taken place. For clarity, here is a quick timeline...

* The most recent commit from the actual GNU Smalltalk maintainer on GitHub appears to be from 2015 on janvrany/gst, except for the following fork:

* The most recent commit on GitHub related to GNU Smalltalk appears to be on a fork of Smalltalk at Synss/smalltalk (it also includes a more recent commit from the current GNU maintainer) in 2017 -- this is before the GitHub purchase.

* After the 2018 acquisition, the most recent commit to GNU Smalltalk (typo fixes in the tutorial) appears to be on the GNU git -- this is ideal if it's accurate. GNU Smalltalk really shouldn't be developed on Microsoft Github. http://git.savannah.gnu.org/cgit/smalltalk.git/commit/

So there's probably nothing sinister there, but it's worth watching. The /examples include Gtk, cairo (either gtk1/github or cairo2 < zlib1g) and it uses png.

Gnu Slip uses or used bison, uses or used flex, includes a pdf user manual.

GNU Shishi is a Kerberos 5 implementation with pdf, png and postscript in the docs.

GNU sed uses Perl in tests.

"Even without being based on nixos, the fact that Guix is/has a package manager with package data means that its going to pull in applications from GitHub."GNU Screen includes postscript in docs, while GNU Scientific Library includes Python and png in the docs.

GNU Rush includes cflex.c which is generated by flex, which is from GitHub.

I suppose there are two ways you can treat a parser or lexer created with bison or flex. You can treat them as compiled output of bison or flex, or as a program or fork in their own right. How you decide to think of them determines how vital bison or flex is to changing that project.

You can certainly change the output of bison or flex without running bison or flex again. Anybody who has written their own parsers understands this. But if the source includes the input for bison and flex or calls it from a script, then it's difficult to say they aren't required as well.

I stopped counting things that use flex or bison for building because there are so many.

GNU Robots uses Gtk. When you see Gtk, it pretty much means glib2 or gtk1 -- one of which needs libffi, the other of which is on GitHub. This is irritating -- somebody show the way out of this. I don't love GNOME at all, but I do like Gtk.

GNU radius has a scanner written by flex, it also uses Perl. GNU Pth uses Perl and includes postscript documents.

GNU Prolog has Perl in examples, pdf and png in docs. GNU Pem uses Perl.

GNU patch appears to use bison. GNU Parted uses Perl and Python in tests.

"As to whether Guix depends on GitHub, I would say so."GNU Parallel is based on Perl, and has pdf in /src.

GNU Paint is written in Vala, and uses glib, cairo and Gtk.

GNU Octave uses Perl and png, GNU Networking Utilities use Perl.

GNU nano has OS/2 support which comes from GitHub, and seems to need flex. The Debian package inexplicably requires zlib1g, I was unable to determine why (it's not mentioned in the source) https://packages.debian.org/buster/nano

GNU MIX Development Kit has png in the docs, a scanner generated by flex, and uses Gtk.

GNU Midnight Commander uses Perl and optionally builds with glib2 (which needs libffi which is from Github).

The NEWS file in GNU Mes says: "Mescc now depends on M1" from mescc-tools on GitHub, and "Mescc now depends on the hex2 linker" from mescc-tools on GitHub.

GNU MediaGoblin uses Python, as well as Docker (Docker is based on GitHub).

GNU Mailutils uses lots of Python and may need bison or flex.

GNU Mailman uses Python and png.

GNU Linear Programming Kit has pdf in examples, /doc.

GNU LilyPond Music Typesetter uses Python, postscript, has png in docs.

GNU Libtasn1 may need bison, has postscript, png and pdf in docs.

"First, I use basic automation and string matching to isolate relevant data, then to present it to me one project at a time so I can process hundreds of projects."GNU Internationalized Domain Names Library has Perl in tests, pdf and png in docs and may have other components from GitHub.

GNU Hyperbole uses Python, png -- this one is worth watching with regards to GitHub.

GNU Health is largely Python-based.

GNU HaliFAX uses Gtk. GNU gzip uses Perl. GNU gv has a parser generated with bison and uses Perl.

GNU Guix has png in docs, pdf in docs and probably needs libffi from GitHub.

NixOS being Github-based means GitHub is probably impossible to avoid for Guix -- though that wouldn't mean Guix had no potential as a fork.

Even without being based on nixos, the fact that Guix is/has a package manager with package data means that its going to pull in applications from GitHub. No effort is being made to make that more than it is, because practically every known distro pulls in packages that are GitHub-based -- like Python, for example. Also libgd (GitHub) which the changelog says was added then removed. Very relevant to Guix? Perhaps not, but due to looking it up I know libgd is GitHub-based.

As to whether Guix depends on GitHub, I would say so. Elogind is forked on GitHub for guixSD: https://github.com/elogind/elogind The fork is for a good cause, but why use GitHub for this?

From README.md: "All of the credit for elogind should go to the systemd developers." "All of the blame should go to Andy Wingo, who extracted elogind from systemd." "All complaints should go to Sven Eden, who is maintaining elogind."

The readme for GNU Guile-CV says Guile-CV is based on vigra (which is based on GitHub).

GNU GRUB uses Python, png, jpeg. Riscv-isa-manual is GitHub-based. The changelog implies that zstd from Facebook's GitHub is supported, which possibly means it's included. And m4/intl.m4 says "dnl because plural.y uses bison specific features".

"As to how to devote hours at a time to this, it really takes a soundtrack. Half of this research was not possible without Green Velvet and Tiësto sets on loop -- I would have gotten really bored."GNU gradebook uses png and Gtk. GNU Go uses Perl, Python and has png in docs and pdf in docs.

GNU GLOBAL uses Python and Perl. It also appears to include jQuery, which is GitHub-based.

GNU Enterprise and GNU EDMA use Python.

GNU C Library uses Perl and Python. Serious question -- what is it like if you remove them? I'm glossing over a lot of details there, sorry about that.

This was incredibly tedious work to research and put together, how did I sit through this?

"With a soundtrack, it's also quite interesting to discover all these Lilliputian strings linking the GNU project with stuff developed increasingly on GitHub -- Microsoft tries, as it always has year after year -- to take all the marbles and win."First, I use basic automation and string matching to isolate relevant data, then to present it to me one project at a time so I can process hundreds of projects. The automation and results prove nothing -- they only show where to pay more attention. I take the data and go from there.

As to how to devote hours at a time to this, it really takes a soundtrack. Half of this research was not possible without Green Velvet and Tiësto sets on loop -- I would have gotten really bored. With a soundtrack, it's also quite interesting to discover all these Lilliputian strings linking the GNU project with stuff developed increasingly on GitHub -- Microsoft tries, as it always has year after year -- to take all the marbles and win.

Will Part 5 have some good news? You tell me.

Long live rms, and happy hacking.

Licence: Creative Commons CC0 1.0 (public domain)

Recent Techrights' Posts

Official SUSE Blog Still Uses LLM Slop (Bots) to Make Fake Articles (Marketing)
The company is all about sound bites
Companies Realise That Slop Doesn't Work as Advertised, Accordingly Dump It
"Hype dims as a country-wide survey of US corporations shows a sudden drop-off in AI use among firms with more than 250 employees."
Microsoft-Funded Lawsuits Against Critics of UEFI 'Secure Boot'
Remember that no company (or law firm) ever survives collaborations with Microsoft
It's Only the Second Week of September and Already Two Waves of Layoffs at Microsoft, Slopfarms and Microsoft-Funded Sites Spin It as "AI Investments" Rather Than Commercial Failure
A very large third one expected next week
If Your Machine Still Has "Secure Boot" Enabled, Then Microsoft Has a de Facto Kill Switch (Even If Your Machine Doesn't Have Windows and Never Had Windows)
It is not incorrect to call UEFI 'secure boot' a "kill switch"
Reddit is Corporate Propaganda
To make matters worse, Reddit ousted many original moderators
Jeff Geerling Shocked to Discover Many Metrics in YouTube Are Fake (His Audience Turns Out to be Much Smaller)
Maybe self-host all videos, don't rely on Google's "FOMO" cheating (addiction based on false assumptions)
EPO Workers Point Out that the EPO is Destroying the Planet Under the Guise of "Hey Hi" (It Also Grants Many Invalid Patents Illegally
On 12 March and 16 June 2025, staff representation met with the administration in the Local Occupational Health, Safety and Ergonomics Committee (LOHSEC) in Munich
 
Bill Gates-Funded Media Inadvertently Refutes the Microsoft Lie That in 2025 Microsoft Had Just Two Waves of Layoffs
There were about 12 rounds of layoffs so far in 2025
From theregister.co.uk to theregister.com (US) to The Register MS (Run by Microsoft Operatives) and theregister.ai
The best way to break this racket (or cycle of hype and harm) is to break the chains of funding
Open Source Initiative (OSI) Culture of Censorship Necessitates More Speech
The OSI bans dissent or people who merely point out that the OSI is abusive
How to Reach Us Discreetly (Other Than Encrypted E-mail)
We're still managing to maintain a 100% source protection record. We soon turn 19.
LLMs Are Vastly Worse Than a Waste of Energy and the Externalities Are Huge
Worse than just higher power bills for everybody
LLMs Versus Search (Not Replacing Search But Engaging in DDoS Attacks Against Web Sites That Permit Searching)
The state of the Web isn't just bad; it's utterly terrible
Over at Tux Machines...
GNU/Linux news for the past day
IRC Proceedings: Monday, September 08, 2025
IRC logs for Monday, September 08, 2025
The UEFI 9/11 - Part IX - Shunning Old Computers (in 2023 the Certificate Was Updated/Overridden, Underlying Aim May Be Herding/Forcing People to Get TPM and Other 'Novel' Restrictions)
the "upgrade treadmill"
Rumour: Second Wave of Microsoft Mass Layoffs in September to Commence Third Week of September
That basically answers questions like, "Any specific date or time of the month?"
Gemini Links 08/09/2025: Reality, ROOPHLOCH 2025, and Writing Another Gemini Client
Links for the day
Updating Firmware is Not the Solution But Only Additional Risk, Disable "Secure Boot" Today
firmware blobs are buggy, secret, impossible to audit, and barely tested
Microsoft Tim's DevClass (Part of The Register MS/Situation Publishing) is Full of Slop
Looking at many sites that are full of slop images is becoming an eye sore and hallmark of text too likely generated by LLMs or 'assisted' (tainted) by them
Microsoft Trying to Fake Demand for Slop. At What Cost?
That's a giant demotion and broken promises
Sunlight is the Best Disinfectant and Kryptonite/Garlic to Vampires
Transparency (sometimes described by words like "Sunlight" or "Truth") is paramount
The Register MS Uses Slop in Articles About Slop
we are fairly certain it's slop or CG based on other people's work
Visiting a Web Page or a Public URL Should be Safe, Predictable, and Benign
It's probably too late to "fix" the Web
The Register MS (Situation Publishing) is Paid to Spread Mindless Hype for the "Hey Hi" Ponzi Scheme and That's a Serious Problem
"Sponsored by Zoom."
Links 08/09/2025: Burger King Cracked, Cox v. Sony Analysed
Links for the day
Gemini Links 08/09/2025: Socialist Computer Museum and GAFAM/ByteDance/TikTok-Dominated Net
Links for the day
Links 08/09/2025: Tim Crook Disappoints Apple Faithfuls and Zuckerberg Lies (Financial Fraud) for Cheeto King
Links for the day
Turn Off Microsoft's Restricted Boot ("Secure Boot")
We're still running a series on this issue
Social Control Media Sites Have Become Bot Farms (Not Limited to LLMs and Automation)
linkedin.com was nothing but trouble and losses for Microsoft
Deep in Debt With the Magnitude of Losses Quickly Growing, Microsoft "Open" "Hey Hi" Now Uses Broadcom for Vapourware, Pretending It'll Do OK Next Year
At some stage it'll collapse
You Can Tell Microsoft is in Trouble When Its Own Fans and Staff Blast it
"Microsoft sinks billions into chasing artificial intelligence fads to hype up its share price."
Multiple Undersea Cable Cuts and We're Still OK
Microsoft customers experience problems
Lawyers Who Think They Are Online Assassins Don't Deserve a Licence to Operate
they've become a laughing stock in their "sector"
Microsoft Windows Fell to 3.9% "Market Share" in Bahamas
Based on statCounter
How the European Union (EU) Fell Out of Love With Free/Libre Software
Lots of bribery
Over at Tux Machines...
GNU/Linux news for the past day
IRC Proceedings: Sunday, September 07, 2025
IRC logs for Sunday, September 07, 2025
Gemini Links 07/09/2025: Scanner, Slop, and Chadobear
Links for the day
The UEFI 9/11 is 3 Days Away
Nobody denies that bad things will happen
Google Versus Journalism
Google played a big role in the demise of news sites
Gemini Links 07/09/2025: Advertising, Decentralized Archival, and Outsourcing to Bezos
Links for the day
Certificate Authority Let's Encrypt Has Almost Gone Down to Zero, Nearly Totally Extinct in Geminispace, the Few Capsules Still Using It Are Spam/Dead/Stagnant
This represents another decrease for Let's Encrypt; the last decrease was last week
Not Much Left in News Cycles
To be very clear, this does not describe "Linux" anything; it's true in just about every facet of news, except the paid-for fake "journalism" about "hey hi" (sites getting paid explicitly to maintain or rekindle hype)
Trying to Silence Techrights Was a Huge Mistake
Peter Thiel attacked a publisher for asserting, correctly, that he was gay. Now everyone knows it.
Throwing Away "Old" Computers (Mozilla and Other Climate Deniers)
Mozilla is not leftist
The UEFI 9/11 - Part VIII - Denial of Service and Selling Us WSL (Windows) Instead of "Risky" (Prone by Breakage by Microsoft) GNU/Linux
Restricted Boot (so-called 'SecureBoot') does not improve security. It is nothing but trouble. It's meant to trouble non-Windows users. In dual-boot setups, SecureBoot is a recipe for disaster because Microsoft keeps erasing or tampering with the boot sector, to paraphrase an associate
Slop is Extremely Rare in Geminispace, Slop Images Are Unheard Of (Despite Images Being Supported)
As long as Geminispace grows in terms of domains it's safe to predict the protocol will still be used in 2029 and hence Geminispace will turn 10
Links 07/09/2025: Robodebt Class Action, Fines, and Copyright Settlement
Links for the day
Links 07/09/2025: Yle Impersonated in Social Control Media, Boat-Attacking Orcas, Midjourney Sued Again
Links for the day
Slopwatch: LinuxSecurity, Linux Journal, and the Serial Slopper
Google won't tackle the issue because Google participates not only in relaying slop but also in generating lots of it
Links 07/09/2025: Google Fines in EU and "Your Internet Access Is at Risk"
Links for the day
Gemini Links 07/09/2025: Little Brother and Corporate Theatre
Links for the day
Links 07/09/2025: More Harms of Slop and Anthropic's Nightmare Scenario (Huge Legal Liabilities for Slop)
Links for the day
Over at Tux Machines...
GNU/Linux news for the past day
IRC Proceedings: Saturday, September 06, 2025
IRC logs for Saturday, September 06, 2025