\section{Informatik}
\label{fach:informatik}
Das Fachmodul \module{Informatik} bindet Pakete ein, um Klassen- sowie Objektdiagramme (\texttt{pgf-umlcd}), Syntaxdiagramme (\pkg{syntaxdi}), Struktogramme (\pkg{struktex}) und Sequenzdiagramme (\texttt{pgf-umlsd}) setzen zu können. Die entsprechenden Dokumentationen sind bei den jeweiligen Paketen zu finden. Hier sind lediglich Abweichungen und Erweiterungen vom Standardumfang der Pakete dokumentiert.

\subsection{Objektdiagramme}
\begin{commands}
    \command{anchormark}[\oarg{Horizontale Verschiebung} \marg{Nodename}\oarg{Skalierung}] Durch den Befehl \cs{anchormark} können Objektdiagramme mit Beziehungsattributen ausgestattet werden, die an der korrekten Stelle hinter dem Attributbezeichner beginnen.

    \achtung{Dieser Befehl ist nicht skalierungssicher!}

    % % Der folgende kenntlich gemachte Abschnitt ist in der Zusammenarbeit
    % % von Informatikreferendaren und ehemaligen Informatikreferendaren
    % % der Studienseminare (heute ZfsL) Arnsberg, Hamm und Solingen
    % % entstanden.
    % %
    % % Der Abschnitt steht unter der Lizenz: Creative Commons by-nc-sa
    % % Version 4.0
    % % http://creativecommons.org/licenses/by-nc-sa/4.0/deed.de
    % %
    % % Nach dieser Lizenz darf der Abschnitt beliebig kopiert und
    % % bearbeitet werden, sofern das Folgeprodukt wiederum unter
    % % gleichen Lizenzbedingungen vertrieben und auf die ursprünglichen
    % % Urheber verwiesen wird.  Eine kommerzielle Nutzung ist
    % % ausdrücklich ausgeschlossen.
    % %
    % % Die Namensnennung durch einen Verweis und die Lizenzangabe der
    % % ursprünglichen Urheber auf den Materialien für Schülerinnen und
    % % Schüler ist erforderlich.
    % %
    % % Die vollständige Sammlung der Dokumente steht unter
    % % http://ddi.uni-wuppertal.de/material/materialsammlung/ zur
    % % Verfügung.
    % %
    % % Das LaTeX-Paket zum Setzen der Dokumente der Sammlung steht unter
    % % http://www.ctan.org/pkg/ zur Verfügung.
    % %
    % % ----- BEGIN ------------------------------------------------------
        \begin{example}[gobble=12]
            \begin{tikzpicture}[remember picture]
                \begin{object}[text width=5.5cm]{gustavsRadiowecker}{-3,0}
                    \attribute{standort = \diastring{Gustavs Zimmer}}
                    \attribute{weckzeit = \diastring{6:30}}
                    \attribute{weckmodusAktiv = \diastring{Wahr}}
                    \attribute{hatLautsprecher = \anchormark{hatLautsprecher}[0.025]}
                    \operation{einschalten()}
                    \operation{ausschalten()}
                    \operation{alarmAusloesen()}
                \end{object}
                \begin{object}[text width=4.5cm]{gustav}{-10,0}
                    \attribute{name = \diastring{Gustav Grabert}}
                    \attribute{geburtstag = \diastring{3.10.1998}}
                    \attribute{besitzt =\anchormark{besitzt}[0.025]}
                    \attribute{kennt =\anchormark{gKennt}[0.025]}
                \end{object}
                \begin{object}[text width=4.5cm]{fridolin}{-10,-4}
                    \attribute{name = \diastring{Fridolin Wagner}}
                    \attribute{geburtstag = \diastring{1.4.1999}}
                    \attribute{kennt =\anchormark{fKennt}[0.025]}
                \end{object}
                \begin{object}[text width=5.2cm]{lautsprecher}{-3,-5}
                    \attribute{untereFrequenzInHertz = 100}
                    \attribute{obereFrequenzInHertz = 18000}
                \end{object}

                \draw (hatLautsprecher) -- (lautsprecher.north);
                \draw (gKennt.south east) -- (fridolin.north);
                \draw (besitzt.east) -- (gustavsRadiowecker.west);
                \draw (fKennt.east) -- ($(fKennt.east)+(3.5,0)$)
                    -| ($(gustav.south)+(3,0.2)$) -- ($(gustav.south east)
                    +(-0.01,0.2)$);
            \end{tikzpicture}
        \end{example}
        % % ----- END ------------------------------------------------------
\end{commands}

\subsection{Sequenzdiagramme}
\label{fach:informatik:sequenz}
\begin{commands}
    \command{skaliereSequenzdiagramm}[\marg{Faktor}]
        \achtung{Sollte nicht mehr verwendet werden: Besser resizebox oder scalebox}

        Da es vorkommen kann, dass Sequenzdiagramme zu breit für eine Seite sind, kann mit dem Befehl \cs{skaliereSequenzdiagramm}\marg{Faktor} die Größe des Sequenzdiagramms angepasst werden, wenn er innerhalb der Umgebung \env{sequencediagram} ausgeführt wird.

    \command{newthreadtwo}[\oarg{Farbe}\marg{Bezeichnung}\marg{Name}\marg{Abstand}]
        Threads haben im Gegensatz zu Instanzen im Paket \pkg{pgf-umlsd} immer einen festen Abstand zu den Nachbarn. Durch den neuen Befehl \cs{newthreadtwo} ist es über den dritten Parameter möglich, diesen Abstand zu verändern. Dabei verhält sich der neue Parameter für den Abstand genauso wie der zugehörige optionale Parameter bei Instanzen.

        \begin{example}[gobble=12]
            \begin{sequencediagram}
                \newthread{fritz}{fritz}
                \newthreadtwo{mutter}{mutter}{3cm}
                \newinst[2]{wecker}{wecker}
                \newinst[2]{lampe}{lampe}

                \begin{callself}[2]{fritz}{schlafe()}{}
                \end{callself}
                \begin{call}{fritz}{gibUhrzeit()}{wecker}{\diastring{5:30}}
                \end{call}
                \begin{callself}[2]{fritz}{schlafe()}{}
                    \begin{call}{mutter}{gibUhrzeit()}{wecker}{\diastring{6:30}}
                    \end{call}
                \begin{call}{mutter}{schalteAn()}{lampe}{}
                    \end{call}
                    \begin{call}{mutter}{weckeAuf()}{fritz}{}
                    \end{call}
                \end{callself}
            \end{sequencediagram}
        \end{example}

    \command{nextlevel} Im Paket für Sequenzdiagramme ist vorgesehen, dass man mit \cs{prevlevel} wieder einen Schritt nach oben gehen kann. Zusätzlich wird ein Befehl \cs{nextlevel} bereitgestellt, mit dem man auch einen zusätzlichen Schritt nach unten gehen kann, um ggf. etwas mehr Platz und Abstand zu schaffen.

\end{commands}

\subsection{Struktogramme}
Mit dem Paket \pkg{struktex} lassen sich sehr einfach Struktogramme setzen:

\begin{example}[gobble=4]
    \begin{struktogramm}(130,60)[koche Kaffee]
    \assign{F"ulle 1 Liter Wasser in die Kaffekanne}
    \assign{Gie"se das Wasser in den Wasserbeh"alter}
    \assign{Lege eine Filtert"ute in den Filter}
    \ifthenelse{5}{5}{Sind die Kaffeetrinker m"ude?}{Ja}{Nein}
        \assign{Gib 6 L"offel Pulver hinein}
    \change
        \assign{Gib 5 L"offel Pulver hinein}
    \ifend
    \assign{Dr"ucke auf den Start-Knopf}
    \while{Solange der Kaffee noch nicht durchgelaufen ist}
        \assign{Warte ungeduldig}
    \whileend
    \assign{Gie"se den Kaffee in die Tasse}
    \assign{Trinke den Kaffee aus der Tasse}
    \end{struktogramm}
\end{example}

\subsection{Syntaxdiagramme}
Beispiele sind dem Paket \pkg{syntaxdi} zu entnehmen.

\subsection{Flussdiagramme}
Für Flussdiagramme, bzw. Programmablaufpläne steht der Style \verbcode|pap| bereit, der in \env{tikzpicture} genutzt werden kann. Damit werden \cs{node} ein entsprechendes Aussehen gegeben. Es stehen zur Verfügung:
\begin{description}
    \item[startstop] Für den Beginn bzw. das Ende eines Ablaufs, als Rechteck mit runden Ecken.
    \item[verzweigung] Für Abfragen und Wiederholungen als Diamant.
    \item[aktion] Einfache Aktionen in einem Rechteck.
    \item[einausgabe] Ein Rhomboid wird für Ein- oder Ausgaben genutzt.
    \item[unterprogramm] Ein Rechteck ergänzt um freie Flächen auf der linken und rechten Seite stellt den Aufruf eines Unterprogramms dar.
\end{description}

Weiterhin können Linien mit dem Style \verbcode|linie| versehen werden, um diese deutlicher darzustellen.

\begin{example}[gobble=4]
    \begin{tikzpicture}[pap]
        \node[startstop] (s1){Los!};
        \node[verzweigung, below = of s1] (v1) {Lieblingsfach Informatik?};
        \node[unterprogramm, right = of v1] (up1) {\nodepart[text width=7em]{two} Pro\-gram\-mie\-re ein Spiel};
        \node[aktion, below = of up1] (a1) {fuehre es aus!};
        \node[einausgabe, below = of v1] (ea1) {ERROR 1337};
        \node[startstop, below = of ea1] (e1){Ende};

        \draw[linie] (s1)--(v1);
        \draw[linie] (v1)--(up1) node[near start, above] {ja};
        \draw[linie] (v1)--(ea1) node[near start, right] {nein};
        \draw[linie] (up1)--(a1);

        \draw[linie] (a1) |- ($(e1.north) + (0,0.5)$);
        \draw[linie] (ea1)--(e1);
    \end{tikzpicture}
\end{example}
