<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Literate_Programming</id>
	<title>Literate Programming - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Literate_Programming"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Literate_Programming&amp;action=history"/>
	<updated>2026-05-18T21:57:01Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikipedia (Deutsch) – Lokale Kopie</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki-de.moshellshocker.dns64.de/index.php?title=Literate_Programming&amp;diff=646080&amp;oldid=prev</id>
		<title>imported&gt;Mosmas: /* Eigenschaften eines Literate-Programming-Systems */Satzbau</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Literate_Programming&amp;diff=646080&amp;oldid=prev"/>
		<updated>2023-12-13T16:08:31Z</updated>

		<summary type="html">&lt;p&gt;&lt;span class=&quot;autocomment&quot;&gt;Eigenschaften eines Literate-Programming-Systems: &lt;/span&gt;Satzbau&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Mit {{lang|en|&amp;#039;&amp;#039;&amp;#039;literate programming&amp;#039;&amp;#039;&amp;#039;}} (engl., näherungsweise mit &amp;#039;&amp;#039;literarisches Programmieren&amp;#039;&amp;#039; übersetzbar) bezeichnet man das Schreiben von [[Computerprogramm]]en in einer Form, so dass sie vor allem für Menschen lesbar sind.&lt;br /&gt;
&lt;br /&gt;
Literate programming bedeutet technisch gesehen, dass sowohl die [[Dokumentation]] als auch der [[Quelltext]] des Programms in einer gemeinsamen [[Datei]] vorhanden sind. Spezielle Werkzeuge sorgen dafür, dass sowohl der Quelltext als auch die Dokumentation aus dieser Datei extrahiert werden können. Da die für den Menschen geschriebene Dokumentation im Vordergrund steht, ist die Reihenfolge der Programmausdrücke so ausgelegt, dass diese verständlich dokumentiert werden können.&lt;br /&gt;
&lt;br /&gt;
== Motivation ==&lt;br /&gt;
In &amp;#039;&amp;#039;Communications of the ACM&amp;#039;&amp;#039; fragt 1986 Jon Bentley: {{lang|en|When was the last time you spent a pleasant evening in a comfortable chair, reading a good program?}} (deutsch:  „Wann war das letzte Mal, dass Sie einen angenehmen Abend in einem bequemen Sessel verbracht haben und dabei ein gutes Programm gelesen haben?“) Der Hintergrund dieser Frage beruht auf der Tatsache, dass zwar so mancher Programmierer hervorragende Arbeit leistet und dementsprechend gute Programme erstellt, dass aber kaum ein Programmierer seine Programme ausreichend dokumentiert.&lt;br /&gt;
&lt;br /&gt;
== Geschichte ==&lt;br /&gt;
Die angesprochene Problematik wurde jedoch schon früher erkannt: Die erste Programmierumgebung, die literate programming unterstützte, war das von [[Donald Knuth]] entwickelte [[WEB (Programmiersprache)|WEB]]. 1981 für die Implementierung des [[TeX]]-Systems entwickelt, benutzte es [[Pascal (Programmiersprache)|Pascal]] als Programmiersprache und TeX als Dokumentationsgenerator.&amp;lt;ref&amp;gt;Der Quellcode von TeX wurde in &amp;#039;&amp;#039;TeX: The program&amp;#039;&amp;#039; von Donald Knuth veröffentlicht&amp;lt;/ref&amp;gt; Nachfolger von WEB war [[CWEB]], welches [[C (Programmiersprache)|C]] als Grundlage benutzte.&lt;br /&gt;
&lt;br /&gt;
== Eigenschaften eines Literate-Programming-Systems ==&lt;br /&gt;
Ein Literate-Programming-System ermöglicht Folgendes:&lt;br /&gt;
&lt;br /&gt;
# Quellcode und Kommentare können miteinander gemischt werden.&lt;br /&gt;
# Die Quellcode-Abschnitte können in beliebiger Reihenfolge angeordnet werden. Das Literate-Programming-System setzt sie automatisch in der richtigen Reihenfolge zusammen, so dass sie ausgeführt werden können (&amp;#039;&amp;#039;tangle&amp;#039;&amp;#039;).&lt;br /&gt;
# Aus Programm und Beschreibung kann automatisch eine lesbare Dokumentation mit Inhaltsverzeichnis, Verweisen, Registern etc. erstellt werden (&amp;#039;&amp;#039;weave&amp;#039;&amp;#039;).&lt;br /&gt;
&lt;br /&gt;
== Verwandte Konzepte und Programme ==&lt;br /&gt;
Das ursprüngliche Konzept wurde schließlich von anderen Entwicklern übernommen und fand ebenfalls in anderen Programmiersprachen teilweise seinen Niederschlag.&lt;br /&gt;
&lt;br /&gt;
=== Dokumentationsgeneratoren ===&lt;br /&gt;
Der Dokumentationsgenerator [[Doxygen]] (ähnlich wie [[Java (Programmiersprache)|Java]] mit [[Javadoc]]) setzt das Konzept teilweise um: Speziell formatierte Kommentare im Quelltext (in einer der unterstützten Programmiersprachen) können extrahiert und in eine Dokumentation einbezogen werden. Im Unterschied zum ursprünglichen Gedanken wird durch dieses Konzept nur eine detailgetreue Spezifikation des Quelltextes und seiner Struktur ermöglicht ([[Funktionsparameter]] können genau spezifiziert werden). Eine vollständige Dokumentation des Quelltextes hingegen ist mit diesen Programmen nicht möglich, auch gerade weil eine Umordnung des Programms nicht möglich ist.&lt;br /&gt;
&lt;br /&gt;
=== Spezielle Programmiersprachen ===&lt;br /&gt;
Die Programmiersprache [[Haskell (Programmiersprache)|Haskell]] erlaubt Literate Programming bereits auf Quelltextebene: Kommentare und Programmanweisungen können beliebig gemischt werden. Im Gegensatz zu anderen Programmiersprachen wird bei dieser Strategie der Quelltext speziell markiert – und nicht die dazugehörigen Kommentare. Eine Umordnung ist jedoch auch hier nicht möglich.&lt;br /&gt;
&lt;br /&gt;
=== Generelle Textsatzsysteme ===&lt;br /&gt;
Durch geeignetes Verschränken von Quellcode und Kommentar kann man bei Einsatz geeigneter [[Textsatzsystem]]e Literate Programming erreichen. So kann man zum Beispiel C-Quellcode so schreiben, dass er mit dem C-Compiler zu einem Programm kompiliert werden kann, aber mit [[troff]]/[[groff]] daraus auch ein Postscript-Dokument mit Grafiken erzeugt werden kann. Dabei sind gegenüber „echten“ Literate-Programming-Tools einige Einschränkungen in der Funktionalität in Kauf zu nehmen, da eine spezielle Software mehr Möglichkeiten anbieten kann als generelle Textsatzsysteme.&amp;lt;ref&amp;gt;[http://www.first.in-berlin.de/software/tools/multiple/ Beispiel für Einsatz von troff/groff für Literate Programming]&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Programming by Intention ===&lt;br /&gt;
Programming by Intention (nicht zu verwechseln mit [[Intentionale Programmierung|Intentionaler Programmierung]]) ist ein Konzept der [[Agile Softwareentwicklung|Agilen Softwareentwicklung]], welches besagt, dass bei der Implementierung von Methoden nicht wie üblich Algorithmen implementiert werden, sondern „nur“ Intentionen niedergeschrieben werden. Diese Intentionen entsprechen dann üblicherweise weiteren Hilfsmethoden oder einzeiligen Algorithmen. Damit wird sichergestellt, dass das Programm auch ohne Programmierkenntnisse äußerst einfach zu lesen ist.&amp;lt;ref&amp;gt;[http://www.netobjectives.net/files/books/esad/essential-skills-programming-by-intention.pdf Programming by Intention, Essential Skills for the Agile Developer] (PDF; 731&amp;amp;nbsp;kB)&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Software ==&lt;br /&gt;
* [[WEB_(Programmiersprache)|WEB]] (das Original)&lt;br /&gt;
* [[Noweb]]&lt;br /&gt;
* [[CWEB]] von Marc van Leeuwen&lt;br /&gt;
* [[funnelweb]] (basiert nicht auf WEB/CWEB)&lt;br /&gt;
* [[fweb]] (Weiterentwicklung von CWEB)&lt;br /&gt;
* [[LEO (Software)|LEO]], „Literate Editor with Outlines“&lt;br /&gt;
&lt;br /&gt;
== Literatur ==&lt;br /&gt;
* {{Literatur | Autor=Donald E. Knuth | Titel=Literate Programming | Sammelwerk=The Computer Journal | Jahr=1984 | Band=27 | Nummer=2 | Seiten=97–111 | DOI=10.1093/comjnl/27.2.97 | Online=[http://www.literateprogramming.com/knuthweb.pdf Online] PDF}}&lt;br /&gt;
* {{Literatur | Autor=Stefan Mintert | Titel=Nicht ohne einen Namen. Literate Programming mit XSLT | Sammelwerk=[[iX – Magazin für professionelle Informationstechnik|iX]] | Jahr=2005 | Nummer=4 | Seiten=135–137}}&lt;br /&gt;
* {{Literatur | Autor=Stefan Lindner | Titel=Literarisches Programmieren | TitelErg=Donald E. Knuths WEB-System | Sammelwerk=[[c’t]] | Jahr=1990 | Nummer=10 | Seiten=340}}&lt;br /&gt;
&lt;br /&gt;
== Weblinks ==&lt;br /&gt;
* [http://www.literateprogramming.com/ Literate Programming]&lt;br /&gt;
&lt;br /&gt;
== Einzelnachweise ==&lt;br /&gt;
&amp;lt;references /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Programmierparadigma]]&lt;/div&gt;</summary>
		<author><name>imported&gt;Mosmas</name></author>
	</entry>
</feed>