| Yazar | Roland McGrath |
|---|---|
| İlk yayınlanma | 1987 (39 yıl önce) (1987)[1] |
| Güncel sürüm | 2.43[2] |
| Kod deposu | |
| Programlama dili | C |
| İşletim sistemi | Unix benzeri |
| Tür | Çalışma zamanı kütüphanesi |
| Lisans | GNU Kısıtlı Genel Kamu Lisansı |
| Resmî sitesi | gnu.org/software/libc/ |



GNU C Library (Türkçe: GNU C Kütüphanesi), bilinen adıylaglibc,GNU Tasarısı'nınC standart kütüphanesi uyarlamasıdır. Adına rağmen artık doğrudan C++ (ve dolaylı olarak diğerprogramlama dilleri) desteği bulunur. 1990'ların başındaÖzgür Yazılım Vakfı tarafındanGNUişletim sistemi için geliştirilmeye başlanmıştır.
GNU Kısıtlı Genel Kamu Lisansı altında dağıtılmıştır, glibc birözgür yazılımdır.
Glibc tasarısı ilkin daha çok Roland McGrath tarafından yazıldı, 1980'lerdeÖzgür Yazılım Vakfı için çalışmaktaydı.
Şubat 1988'de Özgür Yazılım VakfıANSI C'nin gereksindiği işlevselliğe neredeyse ulaştığını açıklamıştır.[3] 1992'de ANSI C-1989 ve POSIX.1-1990 işlevleri yerine getirilmiş, çalışma POSIX.2 yoluna girmiştir.[4]
Eylül 1995'te Ulrich Drepper glibc tasarısına ilk katkısını yaptı ve gitgide glibc'nin 1990'lardaki ana katkıcısı ve bakımcısı oldu.[5] Drepper uzun yıllar bakımcılık mevkiinde tutuldu ve 2012'ye kadar tasarıya yapılan katkıların toplam %63'ünü kendisine aittir.[6]
1990 başlarındaLinux çekirdeği geliştiricileri glibc'yiçatalladılar. Çatallamalarını "Linux libc" olarak adlandırdılar, yıllarca ayrı olarak geliştirildi ve sürüm 2'den 5'e kadar dağıtıldı.
Özgür Yazılım Vakfı Ocak 1997'de glibc 2.0'ı dağıttığında POSIX ölçünlerine uygunluğu daha fazlaydı, daha iyiyerelleştirmeye ve çoklu dil işlevine,IPv6 yeterliliğine, 64-bit veri erişimine, çok iş parçacıklı uygulamalar için olanaklara, gelecek sürüm uyumluluğuna ve kodun daha fazla taşınabilirliğine sahipti.[7] Bu noktada, Linux çekirdeği geliştiricileri çatallamalarını durdurdular ve Özgür Yazılım Vakfı'nın glibc'sine döndüler.[8]
Linux libc'nin kullanılan son sürümülibc.so.5 iç adını (soname) kullanmıştır. Bundan hareketle Linux üzerinde glibc 2.x sürümlerilibc.so.6[9] iç adını kullanmıştır (Alfa veIA-64 mimarileri şimdilibc.so.6.1 adını kullanmaktadır). Kütüphaneler için sıradan teammülleri takiben *.so dosya ismi bazen libc6 olarak kısaltılmıştır (örneğinDebian'daki paket ismi).
Richard Stallman'a göre Linux libc'de yapılan değişiklikler glibc'yle birleştirilemezdi çünkü kodun yazarlık durumu açık değildi ve GNU tasarısı telif ve yazarların kaydedilmesi hakkında katı davranışlıdır.[10]
2001'den başlayarak kütüphanenin gelişimi bir kurul tarafından denetlenmiştir,[11] Ulrich Drepper ana katkıcı ve bakımcı olarak kaldı.[12] Ulrich Drepper'in açıkça belirttiği gibi yönlendirme kurulu kurulması toplum karşıtlığıyla çevrilmiştir, ona göre bu kurulRMS'nin başarısız yönetimi devralma girişimidir.[13][14][15]
ÖnceleriCVS deposunda olan glibc 2009'da Sourceware'dekiGit deposuna geçirilmiştir.[16]
Drepper'in liderlik şekli ve dış katkı kabulu üzerinde süren uzun tartışmalar etrafında[17][18][19]Debian 2009'da resmen glibc'nin çatalı EGLIBC'ye geçmiştir.[20] Nisan 2015'te Debian 8.0 (Jessie) ile birlikte geri dönmüştür.[21]
Mart 2012'de yönlendirme kurulu oylamayla kendini dağıtmış ve topluluk odaklı geliştirme süreci adına Drepper'i görevden almış, Ryan Arnold, Maxim Kuvyrkov, Joseph Myers, Carlos O'Donnel veAlexandre Oliva GNU bakımcılığıyla görevlendirilmiştir (ama ilave karar alıcı güçleri olmadan).[22][23]
glibc bakımcılığında yaşanan değişikliklerden sonra Debian ve diğer tasarılar glibc'ye geri döndüler.[24] Ayrıca, 2014 başından beri glibc çatalı EGLIBC artık geliştirilmemektedir, bunun sebebi "hedeflere artık doğrudan GLIBC'nin içinde ulaşılmış" olmasıdır.
glibcSingle UNIX Specification (Türkçe: Tek UNIX Tarifnamesi) vePOSIX'in (1c, 1d ve 1j) gerektirdiği işlevselliği karşılamaktadır.ISO C11,ISO C99,Berkeley Unix (BSD) arayüzlerinin, System V Interface Definition'un (Türkçe: System V Arayüz Tanımı) ve X/Open System Interface (Türkçe: X/Open Düzen Arayüzü) uyumlu düzenlerin yanında tüm X/Open UNIX eklentilerine ortak tüm eklentilerle X/Open Portability Guide Issue 4.2'nin (Türkçe: X/Open Taşınabilirlik Kılavuzu Sayı 4.2) gerektirdiği bazı işlevsellikleri karşılamaktadır.
Ek olarak, glibc ayrıca GNU ile geliştirme yapılırken kullanışlı ya da gerekli addedilmiş eklentileri de karşılamaktadır.
Glibc değişikçekirdeklerin ve değişikdonanım mimarilerin çalıştırdığı birçok düzende kullanılmıştır. En yaygın kullanımı x86 donanım üzerindeLinux çekirdeğiyle birliktedir, yine de resmi olarak desteklenen donanımlar[25] şunlardır:32-bit ARM ve yeni 64-bit ISA (AArch64),DEC Alpha,PA-RISC,IA-64,Motorola m68k,MicroBlaze,MIPS,Nios II,PowerPC,s390,SPARC,TILE,x86. Resmi olarakHurd veLinux çekirdeklerini destekler. Ek olarakFreeBSD veNetBSD (Debian GNU/kFreeBSD veDebian GNU/NetBSD düzenlerinin kurulu olduğu) çekirdeklerde,OpenSolaris'in çatal sürümünde çalışan yüksek miktarda yama içeren sürümleri de vardır.[26] AyrıcaBeOS veHaiku'dalibroot.so olarak adlandırılmış ve (düzenlenmiş biçimde) kullanılmıştır.[27]
GeçmişteLinus Torvalds[28] vegömülü Linux yazılımcıları glibc'nin diğer kütüphanelerden yavaş ve "şişirilmiş" olduğu yönünde eleştirmiştir. Bu sebeple çeşitli farklı, daha küçük izdüşüme sahip C standart kütüphaneleri oluşturuldu. Farklı libc'ler şunlardır:Bionic (çoğunluklaBSD'deki libc'yi taban aldı ve Android'de kullanıldı[29]),dietlibc,uClibc,Newlib,Klibc vemusl.
Yine de çoğu küçük aygıt tasarısı diğerlerine karşılık GNU libc'yi kullandı. Bunun sebebi uygulama desteği, standartlara uyumu ve eksiksiz olduğu içindir. Bu küçük aygıt tasarılarına örnek olarakOpenmoko[30] ve (GPE görüntü yazılımı kullanılırken) iPaqel bilgisayarı içinFamiliar Linux verilebilir.[31]
GNU C Library'den farklı diğerC standart kütüphaneler şunlardır:Bionic libc,dietlibc,EGLIBC,klibc,musl,Newlib veuClibc.
Google'ınAndroid'i ve Microsoft'un Windows'u gibi diğer çevre-dizgeler için yazılacak programların glibc üzerinde çalışmalarını sağlayanuyumluluk katmanları ("shim'ler") vardır.libhybris Android'in Bionic'i için bir uyumluluk katmanıdır. Wine daWin32 API/ABI'den glibc'ye uyumluluk katmanı olarak görülebilir.
Çoğu kütüphane tamamlandı. Roland McGrath […] ANSI C kütüphane işlevler setini neredeyse tamamladı. Umuyoruz ki bu baharda hazır olur.
Artık tüm ANSI C-1989 ve POSIX.1-1990 işlevlerini içeriyor, POSIX.2 ve Unix işlevleri (BSD ve System V) üzerindeki çalışma devam ediyor
Tasarının git deposunda 19,000'e yakın katkı bulunuyor (bu katkılar 1995'e kadar gidebiliyor), 12,000'den fazlası Ulrich tarafından yapılmış
GNU LIBC ve Linux LIBC arasındaki ayrım -- Linux kararlı olana dek yıllarca devam etti ve sonra çatallamalar tek bir tasarıda birleştirildi
2001'de GNU C Kütüphanesi Yönlendirme Kurulu …, kuruldu ve şu an Mark Brown, Paul Eggery, Andreas Jaeger, Jakub Jelinek, Ronald McGrath ve Andreas Schwab'dan oluşuyor.
Birkaç hafta önce RMS bana saldırmaya başladı (bir tek posta, bunu nüfuzu almaya çaşılan doğrudan olmayan çaba takip etti, bunu bugün bir başka postayı takip etti). Esas şu ki o benim "GNU ilkelerini" takip etmediğimden yakınıyor ve bu nedenle benim de bir parçası olabileceğim yönlendirme kuruluyla değiştirilmesini söylüyor. Bazılarınız (ismen Roland ve Andreas S.) muhtemelen bunu diğer kurul üyeleri gibi bizi de önerdiğinden beri biliyorsunuz. Ek olarak Mark Brown da listede (Bu ismi, IBM'den bu kümeye uyacak bir kişiyi tanıyorum ama gerçekten o olup olmadığından emin değilim.) Her nasılsa, bunu tamamıyla reddediyorum. Bu tamamıyla yardımcı olmuyor, zıt olan doğrudur. İlk olarak, (herhangi) ana ilkeleri ihlal ettiğimin farkında değilim. Sadece açıkça politik hedefler (tabii ki bir küfür olan) RMS'nin emirlerini takip etmiyorum ve muhtemelen Winblowz'u umursamıyorum […] Bunların hiçbiri herhangi bir şekilde değişiklik yaratmayacak.
Ve şimdi güzel olmayan şeyler için. Stallman son olarak benim glibc gelişimini dışarıdan yönetme olarak adlandırdığım şeyi denedi. Arkamdan komplo kurdu ve diğer ana geliştiricileri denetimi ele almaları için ikna etti sonunda o artık denetimde ve ne ona ne keyif verirse onu dikte edebilecek. Bu girişim başarısız ama her yerdeki insanları baskı altında tuttu ve bu gerçekten çirkin. Sonunda ben "yönlendirme kurulu" olarak adlandıran şeyin oluşturulmasını kabul ettim.
More friendly upstream (especially with regard to embedded architectures): “Daha dostane üst akım (özellikle gömülü mimariler gözetilerek): "İşbirliğini, iletişimi, inceliği ve diğer geliştiricilere saygınlığı özendirerek" (buna zıt olarak)
libroot.so GNU tasarısının parçası değildir ve Haiku'nun kaynak koduna dahil edilmiştir.
Biz glibc kullanacağız (uClibC değil) … Farklı seçenekler yerden tasarruf sağlıyor ve daha çok iyileştirilmiş fakat bize daha çok birleştirmek için baş ağrısı verecek gibi
Soru: Familiar 0.8.4'ü inşa etmek için hangi GLIBC sürümü kullanıldı? Cevap: 2.3.3