Mit eXtension of baSH erstellen, verwalten und publizieren Sie eigene Libraries für Scripting-Projekte via Git-Repository.
Auf der Projektseite https://github.com/xsh-lib sind bereits einige nützliche Bibliotheken in Form von Repositories angepinnt.
(Bild: alexzhangs / GitHub)
Aliasse und lose Funktionssammlungen helfen eine Weile, werden aber irgendwann unübersichtlich, sind schwierig zu verwalten und lassen sich nicht wirklich gut mit anderen teilen. Dann bieten sich Bibliotheken an, die die Bash und andere Shells mit etlichen Standardwerkzeugen aufwerten.
Einige der spannendsten Bash-Library-Projekte haben wir bereits beleuchtet. Natürlich fehlt solchen vorgefertigten Bibliotheken die persönliche Note von über Jahre aufgelaufenen Aliassen. Und da kommt das FrameworkeXtension of baSH, kurz xsh, ins Spiel.
Xsh ist primär ein Framework zum Nutzen, Erstellen, Verwalten und Veröffentlichen eigener Bibliotheken. Es gibt aber auch einige Standardbibliotheken, so dass xsh auch Out-of-the-Box nützliche Funktionen bereitstellt, beispielsweise für eine strukturierte Verwaltung: Einfacher Umgang mit Hilfe-/Usage-Texten für Funktionen, Basis-Logging, Debugging, Versionierung und natürlich das Laden, Deinstallieren und Updaten von Bibliotheken.
Die Bibliotheken selbst bestehen lediglich aus Skript-Dateien in einer simplen Ordnerstruktur in Form eines Git-Repositories, welches direkt über den xsh-Befehl geladen werden kann. Die eigentlichen Funktionen sind dann in zwei Ausführungen realisierbar: Standardmäßig beinhaltet etwa eine Datei „foobar.sh“ genau eine Funktion plus Usage-Informationen in vorgegebener Formatierung.
Alternativ lassen sich auch komplette Skripte über die Bibliothek nutzen, die in einem eigenen Unterordner liegen und keine Funktion (im Sinne von „function“ natürlich) beinhalten müssen. Soweit die Theorie. Wie einfach xsh in der Praxis ist, und zwar sowohl bezüglich der Nutzung existierender als auch der Entwicklung eigener Bibliotheken, sehen Sie im Folgenden Schritt für Schritt.
Xsh und Core-Bibliothek aufsetzen
Die Installation von xsh ist trivial: Klonen Sie das Repository, führen Sie das Installationsskript aus, das xsh an Ihr Umgebung anpasst, und starten Sie xsh:
Welche Bibliotheken geladen sind, erfahren Sie über „xsh list“, was etwa folgende Ausgabe produziert:
x (0.3.5) => xsh-lib/core
Wichtig ist hier das vorangestellte „x“: Das ist der intern genuzte Name der Bibliothek, über den Sie zum Beispiel alle Funktionen/Tools dieser Core-Bibliothek auflisten können:
xsh list x
… produziert eine Liste mit Einträgen wie:
[functions] x/json/parser
Es handelt sich hier um eine Funktion (bei Skripten wäre [script] vorangestellt) namens „parser“ in der Bibliothek „x“ im Package/Unterordner „json“. Wenn Sie die oben erwähnten standardisierten Usage-Informationen sehen wollen:
xsh help x/json/parser
Fehlt noch ein letzter Schritt, nämlich die Nutzung dieses Tools. Dafür gibt es zwei Optionen – zunächst der Aufruf via xsh-Befehl:
xsh x/json/parser
Oder Sie importieren das gesamte Package und verzichten auf xsh:
xsh imports x/json x-json-parser
Es werden hier also alle Tools (aka sh-Dateien) im Package (aka Unterordner) „jason“ aus der Bibliothek „x“ geladen – darunter eben auch „parser“. Über die Syntax „Bibliothek-Package-Tool“ kann der JSON-Parser dann direkt aufgerufen werden.
Eigene Bibliothek realisieren
Die erste eigene Bibliothek ist nun nur noch ein paar Schritte entfernt. Sie benötigen Zugriff auf einen Git-Server, hier im Beispiel soll es GitHub sein.
Die Beispiel-Bibliothek „mylib“ soll hier nur aus einer Funktion in einer Datei bestehen: „XforU“ tauscht schlicht X gegen U in einem gegebenen String – sinnvoller Weise landet diese Funktion in einem Package namens „testing“.
In der Datei „xsh.lib“ wird lediglich der interne Name der Bibliothek konfiguriert:
name=mylib
Spannend wird es nun in der Datei „xforu.sh“:
#? Usage: #? @xforu STRING ... #? #? Output: #? Swaps the letters X and U in STRING. #? #? Example: #? @xforu Buxtehude #? # Buutehude #? function xforu () { echo "$@" | tr [Xx] [Uu] }
Die #-Zeilen liefern die Usage-Informationen – den Kommentarstil müssen Sie exakt so umsetzen, damit später Aufrufe wie „xsh help mylib/testing/xforu“ funktionieren. Die Funktion selbst ist dann einfach Standard-Bash-Skript, hier wird also der als Argument übergebene String via „echo“ ausgegeben und via „tr“ manipuliert, um große und kleine Xe gegen entsprechende Us zu tauschen.
Nun können Sie ein Repo anlegen, etwa „meine-xsh-lib“, die Ordnerstruktur committen und pushen, und anschließend mit xsh laden:
Stand: 08.12.2025
Es ist für uns eine Selbstverständlichkeit, dass wir verantwortungsvoll mit Ihren personenbezogenen Daten umgehen. Sofern wir personenbezogene Daten von Ihnen erheben, verarbeiten wir diese unter Beachtung der geltenden Datenschutzvorschriften. Detaillierte Informationen finden Sie in unserer Datenschutzerklärung.
Einwilligung in die Verwendung von Daten zu Werbezwecken
Ich bin damit einverstanden, dass die Vogel IT-Medien GmbH, Max-Josef-Metzger-Straße 21, 86157 Augsburg, einschließlich aller mit ihr im Sinne der §§ 15 ff. AktG verbundenen Unternehmen (im weiteren: Vogel Communications Group) meine E-Mail-Adresse für die Zusendung von Newslettern und Werbung nutzt. Auflistungen der jeweils zugehörigen Unternehmen können hier abgerufen werden.
Der Newsletterinhalt erstreckt sich dabei auf Produkte und Dienstleistungen aller zuvor genannten Unternehmen, darunter beispielsweise Fachzeitschriften und Fachbücher, Veranstaltungen und Messen sowie veranstaltungsbezogene Produkte und Dienstleistungen, Print- und Digital-Mediaangebote und Services wie weitere (redaktionelle) Newsletter, Gewinnspiele, Lead-Kampagnen, Marktforschung im Online- und Offline-Bereich, fachspezifische Webportale und E-Learning-Angebote. Wenn auch meine persönliche Telefonnummer erhoben wurde, darf diese für die Unterbreitung von Angeboten der vorgenannten Produkte und Dienstleistungen der vorgenannten Unternehmen und Marktforschung genutzt werden.
Meine Einwilligung umfasst zudem die Verarbeitung meiner E-Mail-Adresse und Telefonnummer für den Datenabgleich zu Marketingzwecken mit ausgewählten Werbepartnern wie z.B. LinkedIN, Google und Meta. Hierfür darf die Vogel Communications Group die genannten Daten gehasht an Werbepartner übermitteln, die diese Daten dann nutzen, um feststellen zu können, ob ich ebenfalls Mitglied auf den besagten Werbepartnerportalen bin. Die Vogel Communications Group nutzt diese Funktion zu Zwecken des Retargeting (Upselling, Crossselling und Kundenbindung), der Generierung von sog. Lookalike Audiences zur Neukundengewinnung und als Ausschlussgrundlage für laufende Werbekampagnen. Weitere Informationen kann ich dem Abschnitt „Datenabgleich zu Marketingzwecken“ in der Datenschutzerklärung entnehmen.
Falls ich im Internet auf Portalen der Vogel Communications Group einschließlich deren mit ihr im Sinne der §§ 15 ff. AktG verbundenen Unternehmen geschützte Inhalte abrufe, muss ich mich mit weiteren Daten für den Zugang zu diesen Inhalten registrieren. Im Gegenzug für diesen gebührenlosen Zugang zu redaktionellen Inhalten dürfen meine Daten im Sinne dieser Einwilligung für die hier genannten Zwecke verwendet werden. Dies gilt nicht für den Datenabgleich zu Marketingzwecken.
Recht auf Widerruf
Mir ist bewusst, dass ich diese Einwilligung jederzeit für die Zukunft widerrufen kann. Durch meinen Widerruf wird die Rechtmäßigkeit der aufgrund meiner Einwilligung bis zum Widerruf erfolgten Verarbeitung nicht berührt. Um meinen Widerruf zu erklären, kann ich als eine Möglichkeit das unter https://contact.vogel.de abrufbare Kontaktformular nutzen. Sofern ich einzelne von mir abonnierte Newsletter nicht mehr erhalten möchte, kann ich darüber hinaus auch den am Ende eines Newsletters eingebundenen Abmeldelink anklicken. Weitere Informationen zu meinem Widerrufsrecht und dessen Ausübung sowie zu den Folgen meines Widerrufs finde ich in der Datenschutzerklärung.
xsh load -b master mein-nutzername/meine-xsh-lib
Nun sollten folgende Befehle funktionieren:
xsh list mylib xsh mylib/testing/xforu „Buxtehude“
Die Option „-b master“ dient dazu, xsh mitzuteilen, dass die letzte, ungetaggte Version zu Testzwecken geladen wird. Heißt: Es fehlt noch das Publizieren.
Erstellen Sie dazu einfach ein Release mit einem Versions-Tag, also etwa „1.0.0“ – am besten geht das direkt über die GitHub-Weboberfläche über „Releases/Draft a new release“, wo Sie zum Release direkt einen Tag anlegen lassen können.
Anschließend lässt sich die Bibliothek ohne explizite Testing-Hinweise in xsh laden:
xsh load mein-nutzername/meine-xsh-lib
Über „xsh list“ sehen Sie dann Ihre versionierte Bibliothek:
mylib (1.0.0) => mein-nutzername/meine-xsh-lib
Wenn Sie später Änderungen durchführen, erstellen Sie einfach einen neuen Release „2.0.0“ und schon können Sie mit …
xsh update mein-nutzername/meine-xsh-lib
… auf die neue Version aktualisieren.
Wenn Sie xsh antesten wollen, können Sie auch auf ein xsh-Template bei GitHub zurückgreifen, das ein Repository mit dem korrekten Layout erzeugt.
Man muss sich bei xsh vielleicht kurz daran gewöhnen, dass mal die Ordnernamen und mal der intern konfigurierte Name für die Bibliothek zum Einsatz kommt und auch ein paar intern genutzte Begrifflichkeiten sind nicht wirklich intuitiv verständlich. Aber grundsätzlich ist xsh ein extrem einsteigerfreundliches, schlankes Framework, das dennoch alles Wichtige abdeckt.
Sicherlich dürfte es ein paar Stündchen dauern, ein paar Dutzend Aliasse und Mini-Skripte in die xsh-Struktur zu überführen – es lohnt sich! Die Verwaltung ist wesentlich einfacher als bei der üblichen Loseblattsammlung, dank Git-Hosting stehen Funktionen auf beliebigen Rechnern binnen Sekunden zur Verfügung und letztlich können natürlich auch Kollegen mit den nützlichen Helferlein versorgt werden – die dann vielleicht ihrerseits ein paar Zeilen Code spendieren.
Ein Tipp noch zu privaten GitHub-Repos: Laut offizieller Dokumentation funktioniert xsh auch damit, hier führte der Versuch jedoch zu einer Login-Credentials-Schleife und Fehlermeldungen. Nach dem Umstellen auf öffentliche Sichtbarkeit lief alles problemlos.