texlive[46035] Master/texmf-dist: tikz-timing (11dec17)

commits+karl at tug.org commits+karl at tug.org
Mon Dec 11 23:21:39 CET 2017


Revision: 46035
          http://tug.org/svn/texlive?view=revision&revision=46035
Author:   karl
Date:     2017-12-11 23:21:38 +0100 (Mon, 11 Dec 2017)
Log Message:
-----------
tikz-timing (11dec17)

Modified Paths:
--------------
    trunk/Master/texmf-dist/doc/latex/tikz-timing/README
    trunk/Master/texmf-dist/doc/latex/tikz-timing/tikz-timing.pdf
    trunk/Master/texmf-dist/source/latex/tikz-timing/tikz-timing.dtx
    trunk/Master/texmf-dist/source/latex/tikz-timing/tikz-timing.ins
    trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing.sty

Removed Paths:
-------------
    trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-advnodes.sty
    trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-arrows.sty
    trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-beamer.sty
    trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-clockarrows.sty
    trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-columntype.sty
    trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-counters.sty
    trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-either.sty
    trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-ifsym.sty
    trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-interval.sty
    trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-nicetabs.sty
    trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-overlays.sty

Modified: trunk/Master/texmf-dist/doc/latex/tikz-timing/README
===================================================================
--- trunk/Master/texmf-dist/doc/latex/tikz-timing/README	2017-12-11 01:54:21 UTC (rev 46034)
+++ trunk/Master/texmf-dist/doc/latex/tikz-timing/README	2017-12-11 22:21:38 UTC (rev 46035)
@@ -8,7 +8,7 @@
 \hbox, etc.) and into tikzpictures.  A tabular-like environment is provided to
 produce larger timing diagrams.
 
-Copyright (C) 2009 Martin Scharrer
+Copyright (C) 2009-2016 Martin Scharrer
 E-mail: martin at scharrer-online.de
 WWW: http://latex.scharrer-online.de/tikz-timing/
 

Modified: trunk/Master/texmf-dist/doc/latex/tikz-timing/tikz-timing.pdf
===================================================================
(Binary files differ)

Modified: trunk/Master/texmf-dist/source/latex/tikz-timing/tikz-timing.dtx
===================================================================
--- trunk/Master/texmf-dist/source/latex/tikz-timing/tikz-timing.dtx	2017-12-11 01:54:21 UTC (rev 46034)
+++ trunk/Master/texmf-dist/source/latex/tikz-timing/tikz-timing.dtx	2017-12-11 22:21:38 UTC (rev 46035)
@@ -1,85 +1,45 @@
-% \iffalse
-%<*copyright>
-%
-% Copyright (C) 2009 by Martin Scharrer <martin at scharrer-online.de>
-% -----------------------------------------------------------------
-%
-% This work may be distributed and/or modified under the
-% conditions of the LaTeX Project Public License, either version 1.3c
-% of this license or (at your option) any later version.
-% The latest version of this license is in
-%
-%   http://www.latex-project.org/lppl.txt
-%
-% and version 1.3c or later is part of all distributions of LaTeX
-% version 2008/05/04 or later.
-%
-% This work has the LPPL maintenance status `maintained'.
-%
-% The Current Maintainer of this work is Martin Scharrer.
-%
-% This work consists of the files tikz-timing.dtx, tikz-timing.ins
-% and the derived file tikz-timing.sty.
-%
-% $Id: tikz-timing.dtx 2038 2011-01-09 20:44:26Z martin $
-%</copyright>
+% \iffalse meta-comment
+%<=*COPYRIGHT>
+%% Copyright (C) 2009-2012 by Martin Scharrer <martin at scharrer-online.de>
+%% ----------------------------------------------------------------------
+%% This work may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either version 1.3
+%% of this license or (at your option) any later version.
+%% The latest version of this license is in
+%%   http://www.latex-project.org/lppl.txt
+%% and version 1.3 or later is part of all distributions of LaTeX
+%% version 2005/12/01 or later.
+%%
+%% This work has the LPPL maintenance status `maintained'.
+%%
+%% The Current Maintainer of this work is Martin Scharrer.
+%%
+%% This work consists of the files tikz-timing.dtx and tikz-timing.ins
+%% and the derived filebase tikz-timing*.sty.
+%%
+%<=/COPYRIGHT>
 % \fi
 %
 % \iffalse
 %<*driver>
-\makeatletter
-%</driver>
-\RequirePackage{svn-prov}[2009/05/03]
-%<package>\ProvidesPackageSVN
-%<examplecode>\ProvidesPackageSVN[tikz-timing-examplecode]
-%<ydoc>\ProvidesPackageSVN[ydoc]
-%<lib-arrows>\ProvidesPackageSVN[tikz-timing-arrows]
-%<lib-either>\ProvidesPackageSVN[tikz-timing-either]
-%<lib-overlays>\ProvidesPackageSVN[tikz-timing-overlays]
-%<lib-clockarrows>\ProvidesPackageSVN[tikz-timing-clockarrows]
-%<lib-columntype>\ProvidesPackageSVN[tikz-timing-columntype]
-%<lib-nicetabs>\ProvidesPackageSVN[tikz-timing-nicetabs]
-%<lib-counters>\ProvidesPackageSVN[tikz-timing-counters]
-%<lib-advnodes>\ProvidesPackageSVN[tikz-timing-advnodes]
-%<lib-interval>\ProvidesPackageSVN[tikz-timing-interval]
-%<lib-beamer>\ProvidesPackageSVN[tikz-timing-beamer]
-%<lib-ifsym>\ProvidesPackageSVN[tikz-timing-ifsym]
-%<*driver>
-\ProvidesFileSVN
-%</driver>
-  {$Id: tikz-timing.dtx 2038 2011-01-09 20:44:26Z martin $}
-  [v0.7d
-%<package>   Digital Timing Diagrams using TikZ]
-%<examplecode>   Macros to produce examples for the tikz-timing package]
-%<ydoc>   Documentation Macros for tikz-timing package]
-%<lib>   TikZ-Timing Library for
-%<lib-arrows|      >   timing arrows]
-%<lib-either|      >   uncertain transitions]
-%<lib-overlays|    >   timing overlays]
-%<lib-clockarrows| >   timing clock arrows]
-%<lib-columntype|  >   timing cell types]
-%<lib-nicetabs|    >   nice timing tables]
-%<lib-counters|    >   counter values]
-%<lib-advnodes|    >   advanced nodes]
-%<lib-interval|    >   alternative Z transitions]
-%<lib-beamer|      >   beamer overlay support]
-%<lib-ifsym|       >   ifsym compatible macros]
-%<*driver>
-  DTX-File of 'tikz-timing' package.]
-%</driver>
-%<lib>\GetFileInfoSVN*%
-%<lib>\RequirePackage{tikz-timing}[\filedate]%
-%<*package|driver>
-\DefineFileInfoSVN[tikztiming]
-%</package|driver>
-%<!package>\DefineFileInfoSVN
-%<*driver>
+\ProvidesFile{tikz-timing.dtx}[%
+%<=*DATE>
+    2017/12/10
+%<=/DATE>
+%<=*VERSION>
+    v0.7e
+%<=/VERSION>
+    DTX-File of 'tikz-timing' package.]
 \newif\ifprintversion % \fi
-\ifx\printversion\@undefined
-\else
+\ifdefined\printversion
   \printversiontrue
 \fi
 
+\RequirePackage{filecontents}
+\begin{filecontents}{ydoc.cfg}
+  % Intensionally empty
+\end{filecontents}
+
 \ifprintversion
   \documentclass{ltxdoc}
   \let\chapter\section
@@ -89,11 +49,11 @@
   \documentclass[landscape,12pt]{scrreprt}
   \usepackage{ydoc}
 \fi
+\GetFileInfo{tikz-timing.dtx}
+\usepackage{tikz-timing}[\filedate]
 
 \usepackage{hyperref}
 \usepackage{atbegshi}
-\GetFileInfoSVN{tikz-timing.dtx}
-\usepackage{tikz-timing}[\tikztiming at date]
 \usetikztiminglibrary{arrows,either,overlays,clockarrows,columntype}
 \usetikztiminglibrary{nicetabs,counters,advnodes,interval,ifsym}
 \tikzset{timing/no nice tabs}
@@ -128,6 +88,7 @@
 \def\textfraction{0.05}
 \setcounter{bottomnumber}{2}
 
+\usepackage{listings}
 \lstset{basicstyle=\ttfamily}
 
 \usepackage{shortvrb}
@@ -171,7 +132,7 @@
 \let\envv\env
 \let\css\cs
 \def\lib{\texttt}
-\def\library{\section}
+\def\library#1#2{\section{#2}\label{lib:#1}}
 
 \usepackage{xspace}
 \def\ie{i.e.\xspace}
@@ -178,13 +139,13 @@
 \def\eg{e.g.\xspace}
 
 \makeatletter
-% The following code is only needed to produce package examples and therefor not 
+% The following code is only needed to produce package examples and therefor not
 % included in the style file but might be written to an additional file.
 % \iffalse
 %</driver>
 %<*examplecode>
 % \fi
-
+%
 % \begin{environment}{tikztimingexampletable}
 %    \begin{macrocode}
 \newenvironment{tikztimingexampletable}{%
@@ -233,9 +194,9 @@
     }%
     \draw [line width=\heavyrulewidth] (charnodex) +(+1,+1) -- (-1,+1);
     \draw [line width=\lightrulewidth]  (charnodex) +(+1,-1) -- (-1,-1);
-    \draw [line width=\lightrulewidth]  (charnodey) +(+1,-0.6) -- (+1,-1.4) 
+    \draw [line width=\lightrulewidth]  (charnodey) +(+1,-0.6) -- (+1,-1.4)
     (+1,-0.6) -- (+1,+0.6);
-    \draw [line width=\heavyrulewidth] (charnodey) ++(-1,-1) -- +($ (2,0) + 
+    \draw [line width=\heavyrulewidth] (charnodey) ++(-1,-1) -- +($ (2,0) +
     (charnodex) $);
     %
     \path (1.5,-2) node (charnodex) {\strut};
@@ -322,7 +283,7 @@
 % \hypersetup{%
 %   pdfauthor   = {Martin Scharrer <martin at scharrer-online.de>},
 %   pdftitle    = {The tikz-timing package, \fileversion\ from \filedate},
-%   pdfsubject  = {Documentation of LaTeX package tikz-timing which allows the 
+%   pdfsubject  = {Documentation of LaTeX package tikz-timing which allows the
 %   easy creation of timing diagrams inside tikz pictures or text.},
 %   pdfkeywords = {tikz-timing, timing diagram, LaTeX}
 % }%
@@ -371,7 +332,7 @@
 %   {\LARGE\sffamily The \raisebox{-0.66ex}{\Huge\textsf
 %   {\texttiming[z]{3d{\strut tikz}z5d{\strut timing}0.2z}}} package}\\[3ex]
 %   {\large Version \fileversion\ -- \filedate}\\[2ex]
-%   {\large Martin Scharrer \\\normalsize 
+%   {\large Martin Scharrer \\\normalsize
 %   \url{martin at scharrer-online.de}\\[.8ex]
 %   WWW: \url{http://latex.scharrer-online.de/tikz-timing}\\[.5ex]
 %   CTAN: \url{http://www.ctan.org/pkg/tikz-timing}\\[1.2ex]}
@@ -392,14 +353,14 @@
 % \addtocontents{toc}{\vspace*{-1.5em}}
 %
 % \chapter{Introduction}
-% This package uses the \pkg[pgf]{tikz} package to produce timing diagrams 
-% inside text or \envv{tikzpicture} environments.  Also a tabular-like 
-% environment is provided to produce a larger timing diagram with multiple 
+% This package uses the \pkg[pgf]{tikz} package to produce timing diagrams
+% inside text or \envv{tikzpicture} environments.  Also a tabular-like
+% environment is provided to produce a larger timing diagram with multiple
 % labeled signals and the possibility to add own drawing material.
 % Additional optional functionality is provided by libraries.
 %
-% The signal levels of the timing diagram can be given by corresponding 
-% characters/letters like "H" for \emph{Logical High} or "L" for 
+% The signal levels of the timing diagram can be given by corresponding
+% characters/letters like "H" for \emph{Logical High} or "L" for
 % \emph{Logical Low}. So e.g.\ "{HLZXD}" gives `\texttiming{HLZXD}'.
 % In order to fit (in)to normal text the diagram size (\ie its height, width and line width)
 % is defined relatively to the currently active font size. The diagram height is about the height of an
@@ -419,7 +380,7 @@
 %  `\texttt{\@tempa}'~$\rightarrow$~`\texttiming{#1}'}
 % \makeatother
 % A single timing character produces a diagram with a width identical to its height
-% (\iex{H}). Longer diagrams can be produces by either 
+% (\iex{H}). Longer diagrams can be produces by either
 % using the same character multiple times (\iex{HHH})
 % or writing the width as number in front of the character (\iex{3.2H}).
 % For (partial) compatibility with similar packages lowercase characters only produce
@@ -449,42 +410,42 @@
 % \fi
 %
 % \iffalse
-% The package is build to make it possible to define new characters from scratch 
-% or as modified copy of other characters. However, no user macros nor 
-% documentation for this are provided at the moment. Interested \LaTeX\ users 
+% The package is build to make it possible to define new characters from scratch
+% or as modified copy of other characters. However, no user macros nor
+% documentation for this are provided at the moment. Interested \LaTeX\ users
 % should look at the default definitions at the end of the source code.
 % \fi
 %
 % \iffalse
 % \section{Similar Packages}
-% There a some packages which target the same application like the package 
+% There a some packages which target the same application like the package
 % presented by this document.
 %
 % \begin{description}
-%   \itempkg{ifsym} This package (using the |electronic| option) provides a 
-%   special font which contains graphical representation of the logical levels 
-%   high and low at the corresponding letter "H" and "L".  The lower case 
-%   versions have only half the width of the uppercase ones. Also a transition 
-%   can be added using the "|" character which will (sometimes) be added 
+%   \itempkg{ifsym} This package (using the |electronic| option) provides a
+%   special font which contains graphical representation of the logical levels
+%   high and low at the corresponding letter "H" and "L".  The lower case
+%   versions have only half the width of the uppercase ones. Also a transition
+%   can be added using the "|" character which will (sometimes) be added
 %   automatically between |HL| and |LH|.
-%   The diagrams are created using the command |\textifsym|\marg{characters}, 
+%   The diagrams are created using the command |\textifsym|\marg{characters},
 %   e.g.\ \verb+\textifsym{H|L|h|l|H|L}+ results in
 %   \DeleteShortVerb{\|} `\textifsym{H|L|h|l|H|L}'.
 %   \MakeShortVerb{\|}
 %
-%   There is no support for transition slopes and no support for new 
+%   There is no support for transition slopes and no support for new
 %   user-defined logical levels.
 %
-%   \itempkg[(CTAN)]{timing} This package also provides a font for the logical 
-%   levels but supports transition slopes and larger timing diagrams.  This 
+%   \itempkg[(CTAN)]{timing} This package also provides a font for the logical
+%   levels but supports transition slopes and larger timing diagrams.  This
 %   package seems not been updated for a while.
 %
 %   \itempkgnoctan[(TikZ Example Page)]{timing}%
-%   {http://www.texample.net/tikz/examples/timing-diagram/} This package is 
-%   accidentally also called "timing.sty" and is not published on CTAN but on 
-%   the TikZ example website.  It is a small package which is meant as an 
-%   example for the graphics package \texttt{tikz} which is used to draw the 
-%   diagram.  The logical levels must be provided using macros like 
+%   {http://www.texample.net/tikz/examples/timing-diagram/} This package is
+%   accidentally also called "timing.sty" and is not published on CTAN but on
+%   the TikZ example website.  It is a small package which is meant as an
+%   example for the graphics package \texttt{tikz} which is used to draw the
+%   diagram.  The logical levels must be provided using macros like
 %   `|\bit|\marg{0 or 1}\marg{length}'.
 % \end{description}
 % \fi
@@ -496,29 +457,29 @@
 % \newenvironment{Changes}[2]{\paragraph{#1 from #2}\begin{itemize}\let\change\item}{\end{itemize}}
 %
 % \changes{v0.3}{2009/04/24}{First released version}
-% \changes{v0.4}{2009/05/03}{Added output routine which combines successive 
-% occurrences of the same character. This improves screen display quality and 
+% \changes{v0.4}{2009/05/03}{Added output routine which combines successive
+% occurrences of the same character. This improves screen display quality and
 % reduces rendering time and file size.
-% \item Removed own macros for lowercase characters. They 
-% are now handled by the uppercase macros which receive half of the width. 
+% \item Removed own macros for lowercase characters. They
+% are now handled by the uppercase macros which receive half of the width.
 % Exceptions are possible like for the `m' character.
-% \item Added parser for rows in \env{tikztimingtable}. 
-% This makes the syntax much more stable. Also replaced row counter with TikZ 
+% \item Added parser for rows in \env{tikztimingtable}.
+% This makes the syntax much more stable. Also replaced row counter with TikZ
 % coordinates which is more user-friendly.
 % \item User macros to draw grids and lines inside table.
 % \item In-line Nodes, \eg to mark positions inside the diagram.}
-% \changes{v0.4a}{2009/05/05}{Added \cs{tablerules} macro. Changed default style 
+% \changes{v0.4a}{2009/05/05}{Added \cs{tablerules} macro. Changed default style
 % of inline nodes to \texttt{coordinate}.}
-% \changes{v0.5}{2009/05/15}{Added PGF shape for timing diagrams. Added 
-% meta-characters. Changed `M' character to use PGF decorations. Added special 
-% `B' character to reduce width of next character. Changed \cs{timing} syntax to 
-% include an `at' before the coordinate. Bug fix for use with the `calc' 
+% \changes{v0.5}{2009/05/15}{Added PGF shape for timing diagrams. Added
+% meta-characters. Changed `M' character to use PGF decorations. Added special
+% `B' character to reduce width of next character. Changed \cs{timing} syntax to
+% include an `at' before the coordinate. Bug fix for use with the `calc'
 % package.}
-% \changes{v0.6}{2009/07/27}{Added ``forward'' modifier `\texttt{F}' as reverse 
+% \changes{v0.6}{2009/07/27}{Added ``forward'' modifier `\texttt{F}' as reverse
 % version of the ``backward'' modifier `\texttt{B}'.
-% \item Added support for 
+% \item Added support for
 % lower-case modifiers ``\texttt{b}', `\texttt{f}' and \texttt{n}'.
-% \item Added libaries for characters `\texttt{A}'/`\texttt{W}' for arrows and 
+% \item Added libaries for characters `\texttt{A}'/`\texttt{W}' for arrows and
 % '\texttt{E}' for uncertain low-to-high and high-to-low transitions.}
 % \changes{v0.6a}{2009/07/28}{Added library for overlay modifier `\texttt{O}'.}
 %
@@ -528,7 +489,7 @@
 %       \item[\lib{clockarrows}]  Library for clock arrows.
 %       \item[\lib{columntype}]   Library providing a timing column type for |tabular|.
 %       \item[\lib{nicetabs}]     Library to format \cs{tikztimingtable} like a |booktab| |tabular|.
-%       \item[\lib{counters}]     Library to defined counter characters which display an incrementing 
+%       \item[\lib{counters}]     Library to defined counter characters which display an incrementing
 %                             counter value every time there are used.
 %       \item[\lib{advnodes}]     Library for advanced nodes with multiple anchor points.
 %       \item[\lib{ifsym}]        Library providing the same timing symbols and characters as the |ifsym| package
@@ -536,7 +497,7 @@
 %     \end{description}
 %   \change Additional experimental libraries:
 %     \begin{description}
-%       \item[\lib{interval}]     Library to change color of "ZL", "ZH" etc. transitions to 
+%       \item[\lib{interval}]     Library to change color of "ZL", "ZH" etc. transitions to
 %                             indicate borders of an interval.
 %       \item[\lib{beamer}]       Library providing some marginal beamer overlay support.
 %     \end{description}
@@ -548,8 +509,8 @@
 %     \end{itemize}
 %   \change Meta-characters can now have arguments.
 %   \change Added more variety for in-line options: "[[ ]]", "[+ +]" and "[| |]".
-%   \change Handling of in-line options and nodes got modified. Options are now placed directly 
-%     where placed and are valid until the next ";". Please note that |[/utils/exec={..}]| now 
+%   \change Handling of in-line options and nodes got modified. Options are now placed directly
+%     where placed and are valid until the next ";". Please note that |[/utils/exec={..}]| now
 %     needs to be written as \verb+[|/utils/exec={..}|]+. Otherwise it is re-executed every time
 %     the drawing path is renewed.
 %   \change Added star version of \cs{tablegrid}.
@@ -562,7 +523,7 @@
 %   \change The \cs{timing} macro is now only defined inside |tikzpictures|.
 %           This includes |tikztimingtable|.
 %   \change Added TikZ style |timing/draw grid| for grids behind \cs{timing} macros.
-%   \change Replaced macros \cs{texttimingbefore}, \cs{texttimingafter} and \cs{texttiminggrid} with 
+%   \change Replaced macros \cs{texttimingbefore}, \cs{texttimingafter} and \cs{texttiminggrid} with
 %           TikZ settings "timing/before text", "timing/after text" and "timing/draw grid".
 %   \change Added separators "timing/outer sep" around \cs{texttiming}.
 %   \change Graphical improvements for `double line' characters like "D", "U" and "E".
@@ -573,9 +534,9 @@
 %   \change The \env{tikztimingtable} environment and associated macros got enhanced:
 %     \begin{itemize}
 %       \item The content is no longer read as macro argument and can now include paragraphs.
-%       \item Multiple |extracode| sections can be now included between rows, not only a single 
+%       \item Multiple |extracode| sections can be now included between rows, not only a single
 %             section at the very end.
-%       \item A \env{extracode} environment has been added. Both macro and environment have now 
+%       \item A \env{extracode} environment has been added. Both macro and environment have now
 %             an optional argument for TikZ settings.
 %       \item Added \cs{tableheader} macro to label both columns. The \cs{tablerules} macro got
 %             adjusted to detect the header line and draw also a middle line.
@@ -586,6 +547,7 @@
 %     \end{itemize}
 % \end{Changes}
 % \changes{v0.7d}{2011/01/09}{Fix for end macro of extracode environment to support etoolbox's environment hooks.}
+% \changes{v0.7e}{2017/12/10}{Documentation update: added usage as float with caption due to user request.}
 %
 %
 % \endgroup
@@ -715,58 +677,58 @@
 % \hbox{\emph{E.g.:} `\hbox{\texttt{\@tempa}}' $\to$ \texttiming{#1}}}
 %   \begin{supertabular}{>{\ttfamily}l>{\raggedright\arraybackslash}p{.85\textwidth}}
 % D\{\}D & Produces transition between two data values. \Example{D{}D} \\
-% D\{\meta{Text}\} & Adds \meta{text} into a data signal using a node.  
+% D\{\meta{Text}\} & Adds \meta{text} into a data signal using a node.
 % \Example{D{A}D{B}} \\
-% D\{[\meta{\scriptsize 
-% \raisebox{-1ex}{\shortstack{TikZ\\Settings}}}]\meta{Text}\} & Adds \meta{text} 
+% D\{[\meta{\scriptsize
+% \raisebox{-1ex}{\shortstack{TikZ\\Settings}}}]\meta{Text}\} & Adds \meta{text}
 % using the given node \meta{settings}. \Example{D{[blue]A}} \\
-% \meta{\small number}\meta{\small character} & Sets width of next signal to 
+% \meta{\small number}\meta{\small character} & Sets width of next signal to
 % given number.  Half of it if character is in lower case.
 % \Example{2.6H5.2l}\\
-% \meta{\small integer}\{\meta{\small characters}\} &  Repeats the given 
+% \meta{\small integer}\{\meta{\small characters}\} &  Repeats the given
 % characters \texttt{\meta{int}} times.  \Example{5{hl}}\\
 % \{ \meta{\small characters} \} &  Encloses characters in a local scope. Options inside are only
 % local to the scope. This also applies to the effect of `\texttt{;}' and similar modifiers.
 % \Example{H {[blue] LH} L}\\
 % \midrule
-% \meta{\small number}B & Su\underline{b}tracts the given number from the width 
+% \meta{\small number}B & Su\underline{b}tracts the given number from the width
 % of the next character. ``\textit{\texttt{B}ackwards}''
 % \Example{H.5BL}\\
-% \meta{\small number}F & Adds the given number to the width of the next 
+% \meta{\small number}F & Adds the given number to the width of the next
 % character.  ``\textit{\texttt{F}orwards}'' \Example{H.5FL}\\
-% N\oarg{\tiny Settings}\parg{\tiny Name}\marg{\tiny Content} & Adds node at 
+% N\oarg{\tiny Settings}\parg{\tiny Name}\marg{\tiny Content} & Adds node at
 % current position.  All three arguments are optional.  \Example{H N(a1) L}\\
 %   \midrule
-% {}[\meta{TikZ Keys}]  & Executes given TikZ settings during the drawing 
-% process. This settings will be re-executed when the internal drawing path is renewed which 
+% {}[\meta{TikZ Keys}]  & Executes given TikZ settings during the drawing
+% process. This settings will be re-executed when the internal drawing path is renewed which
 % can cause side-effects. \Example{H[blue]LH} \\
-% {}[|\meta{TikZ Keys}|]  & Executes given TikZ settings during the drawing 
+% {}[|\meta{TikZ Keys}|]  & Executes given TikZ settings during the drawing
 % process like \texttt{[ ]} but does not re-executes them.
 % {\Example{D{.} [|/utils/exec={\def\m{...}}|] D{.} D{.}}} \\
-% {}[!\meta{TikZ Keys}!]  & Executes given TikZ settings during the 
-% \emph{parsing} process. Because this makes only sense for internal settings 
-% the default path is `\texttt{/tikz/timing}', not `\texttt{/tikz}' like in all  
+% {}[!\meta{TikZ Keys}!]  & Executes given TikZ settings during the
+% \emph{parsing} process. Because this makes only sense for internal settings
+% the default path is `\texttt{/tikz/timing}', not `\texttt{/tikz}' like in all
 % other settings macros. \Example{H[!wscale=2.5!]LH} \\
-% {}[[\meta{TikZ Keys}]]  & Executes given TikZ settings first during the 
-% parsing process and again during the drawing process. This is for settings 
-% which are needed for width calculations and again for the drawing code, \eg 
+% {}[[\meta{TikZ Keys}]]  & Executes given TikZ settings first during the
+% parsing process and again during the drawing process. This is for settings
+% which are needed for width calculations and again for the drawing code, \eg
 % the slope values. \Example{H[[timing/slope=.5]]L $\slope$H} \\
 %   \midrule
 % !\{\meta{code}\}  & Places given code into the internal \envv{tikzpicture}.
 % See Example~\ref{exa:adv}. \\
-% @\{\meta{code}\}  & Executes the given code immediately during the parsing 
-% process. This can be used to change parsing parameters. To execute code during 
-% the drawing process use \verb+[|/utils/exec=+\meta{code}\verb+|]+ instead. 
+% @\{\meta{code}\}  & Executes the given code immediately during the parsing
+% process. This can be used to change parsing parameters. To execute code during
+% the drawing process use \verb+[|/utils/exec=+\meta{code}\verb+|]+ instead.
 % \Example{L @{\setwscale{2}} H} \\
-% \texttt{\$}\meta{math expression}\texttt{\$} & Takes a valid \texttt{pgfmath} 
-% expression (See \pkg{pgf} manual), evaluates it and places the result back in 
-% the input string so it can be used as width for the next character. The macros  
-% \cs{slope}=\cs{lslope}, \cs{dslope}, \cs{zslope} and \cs{wscale} can be used 
+% \texttt{\$}\meta{math expression}\texttt{\$} & Takes a valid \texttt{pgfmath}
+% expression (See \pkg{pgf} manual), evaluates it and places the result back in
+% the input string so it can be used as width for the next character. The macros
+% \cs{slope}=\cs{lslope}, \cs{dslope}, \cs{zslope} and \cs{wscale} can be used
 % to access the corresponding values.  \Example{D{} $ \dslope $ D{} D} \\
 %   \midrule
-% ;  & Renews the internal drawing path which ends the scope of all options 
+% ;  & Renews the internal drawing path which ends the scope of all options
 % given by \texttt{[\,]}. \Example{H;[blue]L;H} \\
-% ,  & Same as `\texttt{;}', but timing specific options (atm.: slopes and line 
+% ,  & Same as `\texttt{;}', but timing specific options (atm.: slopes and line
 % width) are restored for the new path. \Example{[line width=1pt]L,H;L} \\
 % \end{supertabular}
 % \endgroup
@@ -776,18 +738,18 @@
 % \section{Macro for use in Text Mode}
 % \vspace{-\bigskipamount}%
 % \DescribeMacro\texttiming[<initial~character/TikZ Settings>]{<characters>}
-% This macro places a single timing diagram line into the current text. The 
-% signals have the same height as a uppercase letter (like `X') of the current 
+% This macro places a single timing diagram line into the current text. The
+% signals have the same height as a uppercase letter (like `X') of the current
 % font, \ie they scale with the font size.
-% The macro argument must contain only valid logic characters and modifiers 
+% The macro argument must contain only valid logic characters and modifiers
 % which define the logical levels of the diagram line.
 %
-% An initial character can be given as an optional argument. No logic level will 
-% be drawn for this character. Instead it will be used to define the initial 
-% position of the signal so that the diagram line will start with a transition 
-% from the initial to the first character. However, if the optional argument 
-% holds more than a single character it is taken as TikZ settings for the 
-% diagram. The initial character can then be given using the key 
+% An initial character can be given as an optional argument. No logic level will
+% be drawn for this character. Instead it will be used to define the initial
+% position of the signal so that the diagram line will start with a transition
+% from the initial to the first character. However, if the optional argument
+% holds more than a single character it is taken as TikZ settings for the
+% diagram. The initial character can then be given using the key
 % `|timing/initchar=|\meta{char}'.
 %
 % \par\medskip\noindent
@@ -795,10 +757,10 @@
 % \textit{Examples:}\\*[\smallskipamount]\hspace*{\parindent}%
 % \begin{minipage}{\textwidth-4\parindent}
 % \small |\texttiming{HLZDZLH}|^^A
-% \phantom{\texttt{[L]}} gives `\texttiming{HLZDZLH}', with grid: 
+% \phantom{\texttt{[L]}} gives `\texttiming{HLZDZLH}', with grid:
 % `{\let\texttimingbefore\texttiminggrid\texttiming{HLZDZLH}}'.\\
 % |\texttiming[L]{HLZDZLH}| ^^A
-% gives `\texttiming[L]{HLZDZLH}', with grid: 
+% gives `\texttiming[L]{HLZDZLH}', with grid:
 % `{\let\texttimingbefore\texttiminggrid\texttiming[L]{HLZDZLH}}'.\\
 % |\texttiming[green]{HLZDZLH}| ^^A
 % gives `\texttiming[green]{HLZDZLH}'\\
@@ -809,25 +771,25 @@
 %
 % \DescribeMacro\texttimingbefore!{\hspace{2em}\textbf{Deprecated!}\hspace{8em}(\emph{defaults to}: \meta{empty})}!
 % \DescribeMacro\texttimingafter!{\hspace{2.5em}\textbf{Deprecated!}\hspace{8em}(\emph{defaults to}: \meta{empty})}!
-% This two macros are executed before and after every timing diagram line 
-% created by \cs{texttiming} macro inside the same \envv{tikzpicture} 
-% environment and can be used to add drawing macros. The argument of the 
-% \cs{texttiming} macro is already processed before any of these macros are 
+% This two macros are executed before and after every timing diagram line
+% created by \cs{texttiming} macro inside the same \envv{tikzpicture}
+% environment and can be used to add drawing macros. The argument of the
+% \cs{texttiming} macro is already processed before any of these macros are
 % expanded, therefore this macros can access the width of the diagram.
 %
-% These macros should not be used directly in newer code but instead the new 
-% TikZ styles "timing/before text" and "timing/after text". For backward 
+% These macros should not be used directly in newer code but instead the new
+% TikZ styles "timing/before text" and "timing/after text". For backward
 % compatibility these styles default to the two macros.
 %
 % {\small
-% (Deprecated) Example: |\let\texttimingbefore\texttiminggrid| adds a grid into the 
+% (Deprecated) Example: |\let\texttimingbefore\texttiminggrid| adds a grid into the
 % background of the \cs{texttiming} diagram.}
 %
 % \DescribeMacro\texttiminggrid!\hspace{2.5em}\textbf{Deprecated!}!
-% This macro should only be used inside \cs{texttimingbefore} or 
+% This macro should only be used inside \cs{texttimingbefore} or
 % \cs{texttimingafter} and draws a grid of the full size of the
 % \cs{texttiming} diagram.
-% For newer code the TikZ styles "timing/draw grid" and "timing/no grid" 
+% For newer code the TikZ styles "timing/draw grid" and "timing/no grid"
 % should be used instead, \eg
 % |\tikzset{timing/intext/.append style={timing/draw grid}}| or simply enable the grid globally
 % for all in-text and other timing diagrams with |\tikzset{timing/draw grid}|.
@@ -837,22 +799,22 @@
 % \section{Macro for use inside TikZ-Pictures}
 %
 % \DescribeMacro\timing[<TikZ Keys>]~'at'~(<TikZ Coordinate>)~{[<initial character>]<characters>}';'
-% This macro does the same as \cs{texttiming} but is designed to be used inside 
-% a \envv{tikzpicture} environment and only there. Like normal TikZ macros 
-% (\css{path}, \css{drawn}, \css{node}) it allows an optional argument with TikZ 
-% settings and an optional TikZ-coordinate.  However, a own argument parser, not 
-% the one used by TikZ, is used to detect and read these optional arguments.  
-% Therefore the order of the arguments is mandatory and must not be reversed.  
+% This macro does the same as \cs{texttiming} but is designed to be used inside
+% a \envv{tikzpicture} environment and only there. Like normal TikZ macros
+% (\css{path}, \css{drawn}, \css{node}) it allows an optional argument with TikZ
+% settings and an optional TikZ-coordinate.  However, a own argument parser, not
+% the one used by TikZ, is used to detect and read these optional arguments.
+% Therefore the order of the arguments is mandatory and must not be reversed.
 % This small limitation might be overcome in future versions of this package.
 %
-% Please note that the optional initial character may be given \emph{inside} and 
-% at the very start of the mandatory argument, not before it. This is necessary 
+% Please note that the optional initial character may be given \emph{inside} and
+% at the very start of the mandatory argument, not before it. This is necessary
 % because of several technical reasons.
 %
-% Example: |\tikz \timing [green] at (1,2) {HLZDZLH};|\phantom{\texttt{[L]}} 
+% Example: |\tikz \timing [green] at (1,2) {HLZDZLH};|\phantom{\texttt{[L]}}
 % gives `\tikz \timing [green] at (1,2) {HLZDZLH};'.
-% 
-% Example: |\tikz \timing [green] at (1,2) {[L]HLZDZLH};| gives `\tikz \timing 
+%
+% Example: |\tikz \timing [green] at (1,2) {[L]HLZDZLH};| gives `\tikz \timing
 % [green] at (1,2) {[L]HLZDZLH};'.
 %
 % \ifprintversion\else
@@ -859,25 +821,25 @@
 %   \clearpage
 % \fi
 % \subsection*{Timing Shape Anchors}\label{sec:timingshape}
-% Every timing diagram line produced by \cs{timing}, which includes the rows in 
-% \env{tikztimingtable}, is also a PGF shape (node) with several anchors. These 
+% Every timing diagram line produced by \cs{timing}, which includes the rows in
+% \env{tikztimingtable}, is also a PGF shape (node) with several anchors. These
 % are shown in Figure~\ref{fig:shape}.
-% The shape is very similar to the standard |rectangle| shape but does not 
-% provide a |text| anchor. In addition to the standard points of the compass 
-% anchors of TikZ the three logic levels |low|, |mid| and |high| can be used in 
-% combination with |start|, |mid| and |end|.  An extra |origin| anchor is 
-% located at the lower left, also called |south west| corner where the diagram 
-% originates.  The two anchors called |start| and |end| are provided to mark the 
-% start and end of the timing signal.  There are either located at the low, 
-% middle or high logic level dependent on the used first (or initial) and last 
+% The shape is very similar to the standard |rectangle| shape but does not
+% provide a |text| anchor. In addition to the standard points of the compass
+% anchors of TikZ the three logic levels |low|, |mid| and |high| can be used in
+% combination with |start|, |mid| and |end|.  An extra |origin| anchor is
+% located at the lower left, also called |south west| corner where the diagram
+% originates.  The two anchors called |start| and |end| are provided to mark the
+% start and end of the timing signal.  There are either located at the low,
+% middle or high logic level dependent on the used first (or initial) and last
 % timing character.
-% 
-% In order to use the timing node it has to be named which can be done using the 
-% `\texttt{name=\meta{name}}' option inside the optional argument. The rows of a 
-% \env{tikztimingtable} are automatically named as `|row|\meta{row number}' 
+%
+% In order to use the timing node it has to be named which can be done using the
+% `\texttt{name=\meta{name}}' option inside the optional argument. The rows of a
+% \env{tikztimingtable} are automatically named as `|row|\meta{row number}'
 % where the first row has the number 1.
 %
-% ^^AFurther details how to use a shape inside a TikZ or PGF picture can be 
+% ^^AFurther details how to use a shape inside a TikZ or PGF picture can be
 % ^^Afound in the PGF manual Section~15 and~59, respectively.
 %
 % \begin{figure}
@@ -900,8 +862,8 @@
 %     node[\placement] {\tiny\texttt{(s.\anchor)}};
 % \end{tikzpicture}%^^A
 % }
-% \caption[Timing Shape Anchors]{Timing Shape Anchors. The \texttt{start} and 
-% \texttt{end} anchors mark the start and end of the timing 
+% \caption[Timing Shape Anchors]{Timing Shape Anchors. The \texttt{start} and
+% \texttt{end} anchors mark the start and end of the timing
 % signal.}\label{fig:shape}
 % \end{figure}
 %
@@ -914,28 +876,28 @@
 %   \hspace*{-1em}\Macro\extracode~~'% Optional' \\
 %   <additional code>
 % \end{DescribeEnv}
-% This environment can be used to typeset multi-line timing diagrams.  The 
-% syntax is like the one for a \envv{tabular} environment with two columns.  The 
-% first column is for the signal name and the second one are the logic 
-% characters which would be placed inside the argument of a \cs{texttiming} or 
+% This environment can be used to typeset multi-line timing diagrams.  The
+% syntax is like the one for a \envv{tabular} environment with two columns.  The
+% first column is for the signal name and the second one are the logic
+% characters which would be placed inside the argument of a \cs{texttiming} or
 % \cs{timing} macro.
-% If the second column starts with an optional argument it is either taken as 
-% initial character if it holds only a single character or as row wide settings 
+% If the second column starts with an optional argument it is either taken as
+% initial character if it holds only a single character or as row wide settings
 % otherwise.
-% The whole table will be drawn inside a \envv{tikzpicture} environment using 
-% multiple \cs{timing} and \cs{node} macros for the timing signals and their 
-% names, respectively.  Additional \pkg{tikz} drawing code can be insert at the 
+% The whole table will be drawn inside a \envv{tikzpicture} environment using
+% multiple \cs{timing} and \cs{node} macros for the timing signals and their
+% names, respectively.  Additional \pkg{tikz} drawing code can be insert at the
 % end of the table using \cs{extracode}.
 %
 % \DescribeMacro\extracode[TikZ Keys]
 % This macro is only defined inside a \env{tikztimingtable} environment. In earlier
 % versions of this package it could only be used after the last table line (\ie after a |\\|).
-% If used there all code between it and the |\end{tikztimingtable}| will be placed inside the same 
-% \envv{tikzpicture}. This allows to add some drawing lines or a grid to the 
+% If used there all code between it and the |\end{tikztimingtable}| will be placed inside the same
+% \envv{tikzpicture}. This allows to add some drawing lines or a grid to the
 % picture. The macro does \emph{not} start a TikZ |scope| or a \TeX\ group by itself.
 % The optional \meta{settings} therefore affect all following code until the end of the picture.
 %
-% It is also possible to draw something behind the timing diagram by 
+% It is also possible to draw something behind the timing diagram by
 % using using the \env{background} environment or the PGF background layer:\\[\smallskipamount]
 % |\begin{pgfonlayer}{background}|\ldots|\end{pgfonlayer}|
 %
@@ -942,13 +904,13 @@
 % \DescribeMacro\endextracode
 % From\NewIn{v0.7} version 0.7 on it is possible to add further timing rows after an |extracode| section by using
 % \cs{endextracode}. Everything after this macro is taken as part of a new row. It is allowed to use
-% this macro direct before \cs{end}\env{tikztimingtable}. This makes it possible to use \cs{extracode} 
+% this macro direct before \cs{end}\env{tikztimingtable}. This makes it possible to use \cs{extracode}
 % anywhere inside the table, including at the very start before any rows are processed. Early
 % insertion of extra code is necessary for \eg limiting the bounding box or setting up a clipping path.
 %
 % \DescribeEnv[<extra drawing code>]{extracode}[<TikZ settings>]
-% Instead\NewIn{v0.7} of using \cs{extracode} \dots \cs{endextracode}, which is actual plain\TeX\ syntax, this 
-% \LaTeX\ style environment can be used. Like any environment it creates a \TeX\ group around its 
+% Instead\NewIn{v0.7} of using \cs{extracode} \dots \cs{endextracode}, which is actual plain\TeX\ syntax, this
+% \LaTeX\ style environment can be used. Like any environment it creates a \TeX\ group around its
 % content, but no TikZ |scope| is created to allow drawing code (\eg clipping paths) to affect the
 % rest of the table. The optional \meta{settings}, however, only affect the environment content.
 %
@@ -956,69 +918,69 @@
 % a \Macro\begin{extracode} must always be closed by \Macro\end{extracode}.
 %
 % \subsection*{Macros for \cs{extracode} Section}
-% The following macros are only defined inside a \env{tikztimingtable} after the 
+% The following macros are only defined inside a \env{tikztimingtable} after the
 % macro \cs{extracode}. They are useful for drawing additional material.
 %
 % \DescribeMacro\tablegrid*[<TikZ Keys>]
 % After \css{extracode} this macro draws a grid in the background of the table.
-% A separate grid is drawn for each row. The normal version draws all grids with 
-% the width of the widest row while the star version draws them with the width 
+% A separate grid is drawn for each row. The normal version draws all grids with
+% the width of the widest row while the star version draws them with the width
 % of the corresponding row. Because this macro draws material into the |background|
 % layer it must not be placed inside a |pgfonlayer| environment itself.
 %
 % \DescribeMacro\fulltablegrid[<TikZ Keys>]
-% After \css{extracode} this macro draws a big grid over all rows in the 
+% After \css{extracode} this macro draws a big grid over all rows in the
 % background of the table.
 %
 % \DescribeMacro\nrows
-% Returns the number of rows in the current table. Useful for use in 
+% Returns the number of rows in the current table. Useful for use in
 % \cs{horlines}.
 %
 % \DescribeMacro\rowdist
 % \DescribeMacro\coldist
-% This macros return the row and column distance.  There are useful for drawing 
-% additional material relative to the rows and columns.  This values can be set 
-% (\eg in the optional argument of the table) using the \texttt{timing/rowdist} 
-% and \texttt{timing/coldist} settings which are explained in 
+% This macros return the row and column distance.  There are useful for drawing
+% additional material relative to the rows and columns.  This values can be set
+% (\eg in the optional argument of the table) using the \texttt{timing/rowdist}
+% and \texttt{timing/coldist} settings which are explained in
 % Section~\ref{sec:styles}.
 %
 % \DescribeMacro\twidth
-% Returns the width (as multiple of the `period width') of the longest timing 
+% Returns the width (as multiple of the `period width') of the longest timing
 % diagram line in the table. Example: If the longest line would be
 % "H 2.3L z" than \cs{twidth} would be $1+2.3+0.5=3.8$.
 %
 % \DescribeMacro\horlines[<TikZ Keys>]{<list>}
-% Draws horizontal lines, optionally with the given \meta{Settings}, at the base 
-% line of the rows given by \meta{list}. The PGF macro 
-% \css{foreach}\footnote{See the \texttt{pgf} manual for more details.} is 
-% internally used so the list can include not only row numbers as integer but 
-% also fractional numbers and the "..." operator to auto-increment the 
-% numbers. Please note that all numbers in the list are multiplied by 
+% Draws horizontal lines, optionally with the given \meta{Settings}, at the base
+% line of the rows given by \meta{list}. The PGF macro
+% \css{foreach}\footnote{See the \texttt{pgf} manual for more details.} is
+% internally used so the list can include not only row numbers as integer but
+% also fractional numbers and the "..." operator to auto-increment the
+% numbers. Please note that all numbers in the list are multiplied by
 % \cs{rowdist}.
-% If the list is empty the default "1,2,...,\nrows" is used which draws lines 
+% If the list is empty the default "1,2,...,\nrows" is used which draws lines
 % for all rows.
 %
 % \DescribeMacro\vertlines[<TikZ Keys>]{<list>}
-% Like \cs{horlines} but draws vertical lines and the listed numbers a relative 
+% Like \cs{horlines} but draws vertical lines and the listed numbers a relative
 % to the basic width.
-% If the list is empty the default "0,1,...,\twidth" is used which draws lines 
+% If the list is empty the default "0,1,...,\twidth" is used which draws lines
 % after every period width.
 %
 % \DescribeMacro\tableheader[<TikZ Keys>]{<Description Title>}{<Signal Title>}
-% This macro adds a table head row on top of the table. The two mandatory 
+% This macro adds a table head row on top of the table. The two mandatory
 % arguments provide the header text for the description and signal columns.
 %
 % \DescribeMacro\tablerules[<TikZ Keys>]
-% This macro adds top and bottom rules to the table in the same (or at least 
-% very similar) way as the \texttt{booktabs} package is doing it for normal 
-% \texttt{tabular}s. The current bounding box is used to calculate the needed 
+% This macro adds top and bottom rules to the table in the same (or at least
+% very similar) way as the \texttt{booktabs} package is doing it for normal
+% \texttt{tabular}s. The current bounding box is used to calculate the needed
 % rule length, which makes this macro position dependent if further code
-% changes the bounding box. If the \cs{tableheader} macro was used beforehand it 
-% also draws a thinner horizontal line (like \texttt{booktabs} \cs{midrule}) 
+% changes the bounding box. If the \cs{tableheader} macro was used beforehand it
+% also draws a thinner horizontal line (like \texttt{booktabs} \cs{midrule})
 % between the table head and body.
 %
 % \DescribeEnv[<drawing commands>]{background}[<TikZ Keys>]
-% This environment can be used to draw material on the |background| layer and is 
+% This environment can be used to draw material on the |background| layer and is
 % an abbreviation for:\\[\medskipamount]
 % |    \begin{pgfonlayer}{background}|\\
 % |      \begin{scope}|\oarg{TikZ Keys}\\
@@ -1030,7 +992,7 @@
 % The standard "scale" setting of TikZ will not scale all parts of the table correctly,
 % \eg the line width and nodes will keep their original size. However there are scaled
 % relative to the font size. Alternatively the table can be scaled using the
-% \cs{scalebox}\marg{factor}\marg{content} macro from the \pkg{graphicx} package or 
+% \cs{scalebox}\marg{factor}\marg{content} macro from the \pkg{graphicx} package or
 % be placed inside a scaled \cs{node} inside another \env{tikzpicture} environment.
 %
 % \subsection*{Positions \& Nodes inside the Table}
@@ -1038,23 +1000,23 @@
 % \subsubsection*{Coordinates}
 % The first row starts at $y=0$ and the next rows are each
 % |-1*\rowdist| lower than the previous one.
-% The vertical unit is 1 \textsf{signal height} and the default row distance is 
-% `2' (=$2\times$\textsf{signal height}).  This means that a normal table with 
-% three rows goes from $y=+1$ (base line at 0 + 1 \textsf{signal height}) to 
-% $y=-4$ (first row:~+0, second row:~-2, third row:~-4).  This are relative to 
-% the middle of the drawn lines, \ie the bounding box is 
-% $2\times\frac{\text{\textsf{line width}}}{2}=1\times $\textsf{line width} 
+% The vertical unit is 1 \textsf{signal height} and the default row distance is
+% `2' (=$2\times$\textsf{signal height}).  This means that a normal table with
+% three rows goes from $y=+1$ (base line at 0 + 1 \textsf{signal height}) to
+% $y=-4$ (first row:~+0, second row:~-2, third row:~-4).  This are relative to
+% the middle of the drawn lines, \ie the bounding box is
+% $2\times\frac{\text{\textsf{line width}}}{2}=1\times $\textsf{line width}
 % higher.
 %
-% The timing column starts at $x=0$ and goes into the positive range while 
+% The timing column starts at $x=0$ and goes into the positive range while
 % scaled using the period width. Example: |HHHh| has a width of 3.5.
-% The label column starts at $x=-$|\coldist| and the text is right align with 
+% The label column starts at $x=-$|\coldist| and the text is right align with
 % the right border at this position.
 % See Figure~\ref{fig:distnodestable} for an illustration.
 %
 % \subsubsection*{Nodes}
-% Each timing line is a timing node (see section~\ref{sec:timingshape}) 
-% labeled (not fully correctly) as `|row|\meta{number}', where the first row has the number 1 and the last 
+% Each timing line is a timing node (see section~\ref{sec:timingshape})
+% labeled (not fully correctly) as `|row|\meta{number}', where the first row has the number 1 and the last
 % one the number provided in \cs{nrows}, but can also accessed using the alias "last row".
 % The corresponding labels are normal rectangle nodes named "label0", "label1", \dots,
 % `|label|\cs{nrows}'/"last label".
@@ -1165,10 +1127,10 @@
 %
 % \clearpage
 % \section{Macros for use inside the Character String}
-% The modifiers "@" and `\texttt{\$}' allow the user to include macros.  These 
-% macros are evaluated when the |tikz-timing| parser encounters them in the 
-% input character string, \ie before any diagram element is drawn or any single 
-% bracket "[ ]" options are processed. Therefore their values should be set 
+% The modifiers "@" and `\texttt{\$}' allow the user to include macros.  These
+% macros are evaluated when the |tikz-timing| parser encounters them in the
+% input character string, \ie before any diagram element is drawn or any single
+% bracket "[ ]" options are processed. Therefore their values should be set
 % either outside the |tikz-timing| diagram or with the "[! .. !]" or
 % "[[ .. ]]" option blocks.
 %
@@ -1176,15 +1138,15 @@
 %
 % \DescribeMacro\tikztimingsetwscale{<math expression>}
 % \DescribeMacro\setwscale{<math expression>}
-% This macro\NewIn{v0.7}, which can be called |\setwscale| for short inside modifier code, 
-% sets the |wscale| value. This value is used during the parsing process to 
-% scale the width of the characters, \eg |wscale=3.2| makes |1H| as long as 
-% |3.2H| normally would be. Slopes are not affected, but the `width' values of 
-% meta-characters are. It can also be set with the |timing/wscale| TikZ setting.  
+% This macro\NewIn{v0.7}, which can be called |\setwscale| for short inside modifier code,
+% sets the |wscale| value. This value is used during the parsing process to
+% scale the width of the characters, \eg |wscale=3.2| makes |1H| as long as
+% |3.2H| normally would be. Slopes are not affected, but the `width' values of
+% meta-characters are. It can also be set with the |timing/wscale| TikZ setting.
 % The current value can be accessed using \cs{wscale}.
 %
 % \DescribeMacro\wscale
-% Returns the current width scaling "wscale" value. 
+% Returns the current width scaling "wscale" value.
 %
 % \DescribeMacro\xunit
 % \DescribeMacro\yunit
@@ -1193,21 +1155,21 @@
 %
 % \DescribeMacro\slope
 % \DescribeMacro\lslope!\hspace{.6em}\small(alias)!
-% Returns the current logic slope, \ie the slope between |L| and |H| 
+% Returns the current logic slope, \ie the slope between |L| and |H|
 % levels.
-% Set by the |timing/lslope| or indirectly by the |timing/slope| TikZ setting.  
+% Set by the |timing/lslope| or indirectly by the |timing/slope| TikZ setting.
 % See Table~\ref{tab:styles} for more information.
 %
 % \DescribeMacro\zslope
-% Returns the current Z slope. Set by the |timing/zslope| or indirectly by the 
+% Returns the current Z slope. Set by the |timing/zslope| or indirectly by the
 % |timing/slope| TikZ setting.
 %
 % \DescribeMacro\dslope
-% Returns the current Z slope. Set by the |timing/dslope| or indirectly by the 
+% Returns the current Z slope. Set by the |timing/dslope| or indirectly by the
 % |timing/slope| TikZ setting.
 %
 % \subsection*{Examples:}
-% Changing the slope and using its value to calculate the width of a 
+% Changing the slope and using its value to calculate the width of a
 % character:\\
 % |\texttiming{ HLHLHL [[timing/slope=.5]] H $\slope$L }|\\
 % gives:
@@ -1221,56 +1183,62 @@
 %
 % \clearpage
 % \section{Meta-Characters}
-% It is possible to define recurring groups of characters and modifiers as so 
-% called meta-characters. These characters are than expanded to the group 
-% whenever they appear inside the character list. Please note that like for 
-% groups a numeric factor before such a meta-character is taken as a repetition 
-% factor not as a width. The meta-character is case sensitive and the other case 
-% is not affected by the definition, \ie the lower- and uppercase versions of 
-% one character can have complete different meanings. It is possible to redefine 
-% normal characters (only one or both cases) as meta-characters, which 
-% suppresses its normal meaning. Using the meta-character in its own definition 
+% It is possible to define recurring groups of characters and modifiers as so
+% called \emph{meta-characters}. These characters are than expanded to the group
+% whenever they appear inside the character list. Please note that like for
+% groups a numeric factor before such a meta-character is taken as a repetition
+% factor not as a width. The meta-character is case sensitive and the other case
+% is not affected by the definition, \ie the lower- and uppercase versions of
+% one character can have complete different meanings. It is possible to redefine
+% normal characters (only one or both cases) as meta-characters, which
+% suppresses its normal meaning. Using the meta-character in its own definition
 % group causes a infinite loop which will lead to an \TeX\ error.
-% 
+%
 % \DescribeMacro\tikztimingmetachar{<Meta-Character>}[<Number of arguments>]{<Character Group>}
-% This macro defines the given \meta{meta-character} to be identical to the 
-% given \meta{character group}. Alternatively this can also be done using the 
-% TikZ style `|timing/metachar=|\marg{Meta-Character}\oarg{Number of 
-% arguments}\marg{Character~Group}'. 
+% This macro defines the given \meta{meta-character} to be identical to the
+% given \meta{character group}. Alternatively this can also be done using the
+% TikZ style `|timing/metachar=|\marg{Meta-Character}\oarg{Number of
+% arguments}\marg{Character~Group}'.
 %
-% An empty group deletes the meta-character, which  might be necessary in cases 
-% when normal characters are temporary redefined as meta-characters. However, if 
+% An empty group deletes the meta-character, which  might be necessary in cases
+% when normal characters are temporary redefined as meta-characters. However, if
 % the group only contains spaces the meta-character is practically ignored.
 %
+% Because the meta-character is simply expanded to its character list, the first
+% character of this list might be combined with identical characters placed before the meta-character.
+% For example, after a meta-character "Y" got defined as "2D{A} 2D{B}" the characters "DY" will first be expanded to
+% "D2D{A} 2D{B}" and then combined to "3D{A} 2D{B}". This might not be the wanted behaviour and can be avoided by terminating the leading "D" with
+% its own braces: "D{}Y".
+%
 % \subsection*{Meta-Characters with Arguments}
 % The\NewIn{v0.7}
 % replacement text of meta-character can now include macro arguments.
-% This allows the creation of more complex and flexible meta-characters.  The 
-% optional argument \meta{Number of arguments} selects the number of macro 
-% arguments in the same way it does for \cs{newcommand}. However, the first 
-% argument |#1| is always set to the given `width' of the meta-character, \ie 
-% the number value preceding it. All further arguments are read as normal for 
-% macros from the text after the meta-character. It is recommended to enclose 
+% This allows the creation of more complex and flexible meta-characters.  The
+% optional argument \meta{Number of arguments} selects the number of macro
+% arguments in the same way it does for \cs{newcommand}. However, the first
+% argument |#1| is always set to the given `width' of the meta-character, \ie
+% the number value preceding it. All further arguments are read as normal for
+% macros from the text after the meta-character. It is recommended to enclose
 % them in braces.
 %
-% The default behaviour of meta-character without arguments is, as mentioned 
-% above, to repeat the replacement group by the preceding number (`width'). This 
+% The default behaviour of meta-character without arguments is, as mentioned
+% above, to repeat the replacement group by the preceding number (`width'). This
 % is now archived by defining them internally as `|#1|\marg{Character Group}',
-% which creates a repetition group. Users which want to include an own argument 
-% but still want to repeat the group need to define a meta-character with at 
-% least two arguments and define it as "#1{ .. #2 .. }". If the repetition is 
-% not wanted the |#1| argument can be used as a real width for one or more group 
-% internal characters: "{Y}[1]{Z #1D Z}", so "4Y" will give "Z 4D Z" 
+% which creates a repetition group. Users which want to include an own argument
+% but still want to repeat the group need to define a meta-character with at
+% least two arguments and define it as "#1{ .. #2 .. }". If the repetition is
+% not wanted the |#1| argument can be used as a real width for one or more group
+% internal characters: "{Y}[1]{Z #1D Z}", so "4Y" will give "Z 4D Z"
 % instead of "4{Z D Z}".
-% 
-% Also the modifier "@" (see Table~\ref{tab:modifiers}) together with the 
-% \cs{setwscale} macro can be used to scale the whole group dependent on the 
+%
+% Also the modifier "@" (see Table~\ref{tab:modifiers}) together with the
+% \cs{setwscale} macro can be used to scale the whole group dependent on the
 % first argument:\\
 % "{Y}[1]{ @{\setwscale{#1*\wscale}} Z 2D Z @{\setwscale{\wscale/#1}} }", so
 % "4Y" is equivalent to "4Z 8D 4Z".
 %
-% The new `\texttt{\$}' modifier can be used to calculate the width of the group 
-% characters: |{Y}[1]{$#1/3$D{A} $#1/3D${B} $#1/3$D{C}}|, so "4Y" results in 
+% The new `\texttt{\$}' modifier can be used to calculate the width of the group
+% characters: |{Y}[1]{$#1/3$D{A} $#1/3$D{B} $#1/3$D{C}}|, so "4Y" results in
 % "1.333D{A} 1.333D{B} 1.333D{C}".
 %
 %
@@ -1331,8 +1299,8 @@
 % {\tikztimingmetachar{Y}[3]{ .2D .2B #1d{\strut #2} .2D .2B #1d{\strut #3} }%
 %  \texttiming{ Z 2Y{a}{b} Z 4Y{1}{2} Z}}
 % \\[\bigskipamount]
-% Mata-chars to set the width scaling. Because the scaling also affects the 
-% meta-char width (|#1|) argument a compensation is needed to achieve absolute 
+% Mata-chars to set the width scaling. Because the scaling also affects the
+% meta-char width (|#1|) argument a compensation is needed to achieve absolute
 % values (|W|) instead of relative ones (|w|).\\
 % |\tikztimingmetachar{w}[1]{ [! wscale=#1 !] }         % relative|\\
 % |\tikztimingmetachar{W}[1]{ [! wscale=#1/\wscale !] } % absolute|\\
@@ -1343,20 +1311,47 @@
 %  \texttiming{ HL .2w HLHLH 3w LH 1W LH }}
 %
 % \clearpage
+% \section{Floating timing diagrams with captions}
+% The timing diagrams can also be typeset as floats with (or without) a caption like a |figure|.
+% This can be easily achieved by using the \pkg{caption} package as shown in the following example document.
+%
+% \par\vspace{3\baselineskip}\par
+%
+% \begin{lstlisting}[gobble=4,language={[latex]tex},frame=single]
+%   \documentclass{article}
+%   \usepackage{tikz-timing}
+%   \usepackage{caption}
+%
+%   \DeclareCaptionType{timingdiag}[Timing diagram][List of Timing Diagrams]
+%
+%   \begin{document}
+%   \listoftimingdiags
+%
+%   \begin{timingdiag}[!ht]
+%     \centering
+%     (timing code)
+%     \caption{Some timing diagram caption}
+%     \label{tim:foobar}
+%   \end{timingdiag}
+%
+%   \end{document}
+% \end{lstlisting}
+%
+%
 % \chapter{TikZ Keys for Styles, Settings and Actions}\label{sec:styles}
 % TikZ itself uses the |pgfkeys| package to define and apply drawing styles and settings.
-% The same method is also used for |tikz-timing| which 
-% places all of the keys under the ``subdirectory'' "timing" in 
-% the main ``directory'' `tikz', which is the default when \css{tikzset} is 
+% The same method is also used for |tikz-timing| which
+% places all of the keys under the ``subdirectory'' "timing" in
+% the main ``directory'' `tikz', which is the default when \css{tikzset} is
 % used.
 % This keys are simply called \emph{TikZ Keys} throughout this manual and
 % can be used in all places where \meta{TikZ Keys} is mentioned, while some only make sense at specific
 % places.
-% Three types of keys 
+% Three types of keys
 % are used by this package: styles, settings and actions.
 %
 % Styles simply define the style in which a certain element is drawn, \eg in which color or line width.
-% This styles are defined and can be redefined using 
+% This styles are defined and can be redefined using
 % \css{tikzset}|{|\meta{style name}|/.style=|\meta{value}|}|. However, while some styles
 % are initial empty, some hold internal settings and therefore user styles should only be added
 % using `|.append style=|\meta{value}'.
@@ -1367,7 +1362,7 @@
 % Action are TikZ keys which perform a drawing or other action on the current element, either directly or
 % by en-/disable an internal setting which then in turn triggers the drawing process. Therefore some
 % actions can be globally and/or locally but others only make sense if used locally on a single |tikz-timing|
-% macro or environment or even a scope inside a \env{tikztimingtable}. 
+% macro or environment or even a scope inside a \env{tikztimingtable}.
 % Action can be very similar to settings but they always execute code instead of only setting/redefining it.
 %
 % \begingroup
@@ -1455,7 +1450,7 @@
 %     timing/\meta{lc char}/background           & \s & Background style for characters `\texttt{D}' and `\texttt{U}'. \\
 %     timing/\meta{lc char}/text                 & \s & Text style for character \meta{char}.  Only defined for `\texttt{D}'. \\
 %     \midrule
-%     timing/text format=\meta{macros}           & \s & Define macros which are placed before the text of `\texttt{D\{text\}}'. The text is enclosed in braces to 
+%     timing/text format=\meta{macros}           & \s & Define macros which are placed before the text of `\texttt{D\{text\}}'. The text is enclosed in braces to
 %                                                    allow the last macro to take it as an argument. A \cs{strut} is a good choice to ensure a common baseline.\\
 %     \bottomrule
 %   \end{tabularx}
@@ -1481,33 +1476,33 @@
 %
 % \clearpage
 % \chapter{Libraries for Further Characters}
-% All default timing characters described in Table~\ref{tab:chars} are always 
-% made available by this package. Further, less-common characters are provided 
-% by libraries which are loaded with the macro 
-% \cs{usetikztiminglibrary}\marg{library}.  This is done to hold the memory 
-% usage of this package small and reduce the risk of collisions with 
+% All default timing characters described in Table~\ref{tab:chars} are always
+% made available by this package. Further, less-common characters are provided
+% by libraries which are loaded with the macro
+% \cs{usetikztiminglibrary}\marg{library}.  This is done to hold the memory
+% usage of this package small and reduce the risk of collisions with
 % user-defined (meta-)characters.
 % The full syntax for the above macro is
-% \cs{usetikztiminglibrary}\oarg{options}\marg{library,\dots}\oarg{date}, like 
-% the one for \cs{usepackage}. 
-% The date is used as a version number like for packages and is identical to the date 
+% \cs{usetikztiminglibrary}\oarg{options}\marg{library,\dots}\oarg{date}, like
+% the one for \cs{usepackage}.
+% The date is used as a version number like for packages and is identical to the date
 % of the |tikztiming| package.
 %
 % \clearpage
 % \library{arrows}{Arrows}
-% The library "arrows" enables two characters "A" and "W" which draw 
-% vertical up and down \textit{A}rro\!\textit{W}s. Such arrows are used in 
-% timing diagrams to mark special polarized events, like clock edges of another 
+% The library "arrows" enables two characters "A" and "W" which draw
+% vertical up and down \textit{A}rro\!\textit{W}s. Such arrows are used in
+% timing diagrams to mark special polarized events, like clock edges of another
 % signal.
 %
-% The width provided with these character is added as whitespace after the 
-% ``zero-width'' arrow: "A2AA" results in `\texttiming{A2AA}'. This space 
-% can be avoided by specifying the width to zero: "0A". Like the "C" and 
+% The width provided with these character is added as whitespace after the
+% ``zero-width'' arrow: "A2AA" results in `\texttiming{A2AA}'. This space
+% can be avoided by specifying the width to zero: "0A". Like the "C" and
 % "T" characters the subsequent arrow characters are not combined into one.
 %
-% The arrow tips can be changed using the TikZ styles for this characters. See 
-% section~\ref{sec:styles} for more information. The "A" and "W" character should 
-% only be used which each each other, but not together with any other characters 
+% The arrow tips can be changed using the TikZ styles for this characters. See
+% section~\ref{sec:styles} for more information. The "A" and "W" character should
+% only be used which each each other, but not together with any other characters
 % except with "S" (space).
 %
 % \begin{table}[H]
@@ -1531,16 +1526,16 @@
 %
 % \clearpage
 % \library{either}{Either High or Low}
-% The library "either" enables the "E" character which stands for 
-% `\textit{either high or low}'. This character is designed to be used with the 
-% "H" and "L" characters to display a uncertainty of a transition.  
-% Sometimes a, e.g.\ low signal can go either to high or stay at low for a 
-% certain time before it definitely goes to high. In this case both (or more) 
+% The library "either" enables the "E" character which stands for
+% `\textit{either high or low}'. This character is designed to be used with the
+% "H" and "L" characters to display a uncertainty of a transition.
+% Sometimes a, e.g.\ low signal can go either to high or stay at low for a
+% certain time before it definitely goes to high. In this case both (or more)
 % possible transitions can be drawn using this character.
-% Like the "C" and "T" characters subsequent "E" characters are not 
+% Like the "C" and "T" characters subsequent "E" characters are not
 % combined into one.
 %
-% The drawing style can be changed using the |timing/e| and 
+% The drawing style can be changed using the |timing/e| and
 % |timing/e/background| TikZ style.
 %
 % \begin{table}[H]
@@ -1578,37 +1573,37 @@
 %
 % \clearpage
 % \library{overlays}{Overlays}
-% The library "overlays" enables the "O" character which allows the 
+% The library "overlays" enables the "O" character which allows the
 % overlaying of timing characters, i.e.~different groups of timing characters
 % are drawn on top of each other. This is not to be confused with `dynamic' overlay
 % provided by the presentation class |beamer|. The |tikz-timing| library \lib{beamer} provides
 % some support for such overlays.
 %
-% The "O" character awaits a set of character 
-% enclosed by braces which are drawn as normal. The position before the "O" 
-% character is then restored and the following characters are drawn over them.  
-% Older versions of this character awaited a second set of characters in braces 
+% The "O" character awaits a set of character
+% enclosed by braces which are drawn as normal. The position before the "O"
+% character is then restored and the following characters are drawn over them.
+% Older versions of this character awaited a second set of characters in braces
 % but this braces are now optional. The exact syntax is:\\[\smallskipamount]
-% \hspace*{2em} \meta{chars before} |O|\marg{background chars} \marg{foreground 
+% \hspace*{2em} \meta{chars before} |O|\marg{background chars} \marg{foreground
 % chars} \meta{chars after}\\[\smallskipamount]
 % or, without second set of braces, but equal:\\[\smallskipamount]
-% \hspace*{2em} \meta{chars before} |O|\marg{background chars} \meta{foreground 
+% \hspace*{2em} \meta{chars before} |O|\marg{background chars} \meta{foreground
 % chars, \dots}\\[\smallskipamount]
 %
-% It is the responsibility of the user to make sure that the lines drawn by the 
-% first set reconnect to the main lines or do something else useful.  The 
-% modifier ";" can be used to restart the drawn line, e.g.\ to change to a 
-% different color. This is not done automatically to give the user the freedom 
-% if and where this should happen. It is recommended to start and end the set 
+% It is the responsibility of the user to make sure that the lines drawn by the
+% first set reconnect to the main lines or do something else useful.  The
+% modifier ";" can be used to restart the drawn line, e.g.\ to change to a
+% different color. This is not done automatically to give the user the freedom
+% if and where this should happen. It is recommended to start and end the set
 % with characters identical with the main line to avoid ugly connection points.
 %
-% Please note that the width of the first argument is ignored and does not count to the 
+% Please note that the width of the first argument is ignored and does not count to the
 % total width of the diagram line. The characters following the overlay should therefore
 % be as wide or wider as the one of the overlay, otherwise the bounding box and background grid
-% will be incorrect. 
+% will be incorrect.
 %
-% Overlays can be cascaded\NewIn{v0.7}, \ie an overlay can be included in the first argument 
-% of another overlay. 
+% Overlays can be cascaded\NewIn{v0.7}, \ie an overlay can be included in the first argument
+% of another overlay.
 %
 % \begin{table}[H]
 % \centering
@@ -1654,15 +1649,15 @@
 %
 % \clearpage
 % \library{clockarrows}{Clock Arrows}
-% The library "clockarrows"\NewIn{v0.7} is changing the "C" clock character to contain 
-% arrows which mark the rising and/or falling clock edge. By default the rising 
-% edges are marked. To simplify the implementation only the transition from a 
-% "C" to another "C" character contains the arrows but not transitions from 
+% The library "clockarrows"\NewIn{v0.7} is changing the "C" clock character to contain
+% arrows which mark the rising and/or falling clock edge. By default the rising
+% edges are marked. To simplify the implementation only the transition from a
+% "C" to another "C" character contains the arrows but not transitions from
 % or to different characters, like "HCH" or "LCL".
 %
-% The arrows can be controlled using the TikZ styles shown in 
-% Table~\ref{tab:clockarrowstyles} below. This styles can also be used as 
-% library options. The key ``directory'' "timing/c" must be dropped for 
+% The arrows can be controlled using the TikZ styles shown in
+% Table~\ref{tab:clockarrowstyles} below. This styles can also be used as
+% library options. The key ``directory'' "timing/c" must be dropped for
 % options, e.g.\\\hspace*{2em}
 % \cs{usetikztiminglibrary}|[rising arrows]{clockarrows}|.
 
@@ -1734,43 +1729,44 @@
 %        \texttt{arrow tip=stealth}       & \texttiming[timing/c/arrow tip=stealth]{10{C}} \\
 %      \bottomrule
 %    \end{tabular}
+%   \fi
 %   \end{minipage}
 % \end{table}
 %
 % \clearpage
 % \library{columntype}{Column Type}
-% The library "columntype"\NewIn{v0.7} uses the \pkg{array} package to define a new 
-% |tabular| column type for timing characters. The tabular column can then hold 
-% timing characters like the \env{tikztimingtable}. An initial option block 
-% "[...]" is taken as initial character or diagram line wide settings. The 
-% main difference between these two table types is that \env{tikztimingtable} 
-% creates a big common |tikzpicture| with one coordinate system with potential 
-% extra drawing code and the column type creates single pictures for each 
+% The library "columntype"\NewIn{v0.7} uses the \pkg{array} package to define a new
+% |tabular| column type for timing characters. The tabular column can then hold
+% timing characters like the \env{tikztimingtable}. An initial option block
+% "[...]" is taken as initial character or diagram line wide settings. The
+% main difference between these two table types is that \env{tikztimingtable}
+% creates a big common |tikzpicture| with one coordinate system with potential
+% extra drawing code and the column type creates single pictures for each
 % diagram line without common coordinate system.
 %
-% By default the letter "T" and left alignment are used for the timing column 
-% type. The TikZ style |timing/columntype=|\marg{letter}\marg{alignment} can be 
-% used to select different column letters and alignments. The \meta{alignment} 
-% represents here the \emph{real} column letter like "l", "c" or "r".  
-% Additional column code can be added using the `|>|\marg{code}' and 
+% By default the letter "T" and left alignment are used for the timing column
+% type. The TikZ style |timing/columntype=|\marg{letter}\marg{alignment} can be
+% used to select different column letters and alignments. The \meta{alignment}
+% represents here the \emph{real} column letter like "l", "c" or "r".
+% Additional column code can be added using the `|>|\marg{code}' and
 % `|<|\marg{code}' argument of the \pkg{array} package.
 % \iffalse
 % \noindent\textbf{Examples:}\\
-% \hspace*{1em}|\tikzset{timing/columntype={T}{r}}| \hspace{2em} Change to right 
+% \hspace*{1em}|\tikzset{timing/columntype={T}{r}}| \hspace{2em} Change to right
 % alignment.\\
-% \hspace*{1em}|\tikzset{timing/columntype={I}{>{code}c<{code}}| \hspace{2em} 
-% Defines letter "I" to create centered timing diagrams with some code before   
+% \hspace*{1em}|\tikzset{timing/columntype={I}{>{code}c<{code}}| \hspace{2em}
+% Defines letter "I" to create centered timing diagrams with some code before
 % and after it.
 % \fi
 %
-% More complex column types (\eg one holding |@{..}| or |!{..}| arguments, 
-% multiple columns, etc.) must be defined manually using \pkg{array}'s 
-% \cs{newcolumntype} macro.  The default definition is equal 
+% More complex column types (\eg one holding |@{..}| or |!{..}| arguments,
+% multiple columns, etc.) must be defined manually using \pkg{array}'s
+% \cs{newcolumntype} macro.  The default definition is equal
 % to\\[\smallskipamount]
 % \hspace*{2em}|\newcolumntype{T}{>{\celltiming}l<{\endcelltiming}}|.
 %
 % \smallskip
-% The default "T" definition can be suppressed by using either the library 
+% The default "T" definition can be suppressed by using either the library
 % option |notype| or a different |type| (equal to |timing/columntype|):
 % \\[\smallskipamount]
 % \hspace*{2em}|\usetikzlibrary[type={U}{l}]{columntype}|\\[\smallskipamount]
@@ -1797,26 +1793,26 @@
 %
 % \clearpage
 % \library{nicetabs}{Nice Timing Tables}
-% The library "nicetabs"\NewIn{v0.7} uses the settings of the \pkg{array} and 
-% \pkg{booktabs} packages to improve the layout of \env{tikztimingtables}. The 
-% resulting table matches a \env{tabular}|{rT}| table which uses the above 
-% packages and the |columntype| library.  The table macros \cs{tabcolsep}, 
+% The library "nicetabs"\NewIn{v0.7} uses the settings of the \pkg{array} and
+% \pkg{booktabs} packages to improve the layout of \env{tikztimingtables}. The
+% resulting table matches a \env{tabular}|{rT}| table which uses the above
+% packages and the |columntype| library.  The table macros \cs{tabcolsep},
 % \cs{arraystretch} and \cs{extrarowheight} are obeyed.
-% 
-% The original table layout is designed to produce integer coordinates between 
-% the rows to simplify the drawing of extra drawings (see \cs{extracode}). The 
-% improved layout will cause non-integer coordinates, but in-line nodes and the 
-% \cs{rowdist} and \cs{coldist} macros can be used to draw extra material 
+%
+% The original table layout is designed to produce integer coordinates between
+% the rows to simplify the drawing of extra drawings (see \cs{extracode}). The
+% improved layout will cause non-integer coordinates, but in-line nodes and the
+% \cs{rowdist} and \cs{coldist} macros can be used to draw extra material
 % relatively to the rows.
-% 
-% The TikZ styles "timing/nice tabs" (default) and "timing/no nice tabs" can 
-% be used to activate and deactivate the layout, \eg for each table. Both 
+%
+% The TikZ styles "timing/nice tabs" (default) and "timing/no nice tabs" can
+% be used to activate and deactivate the layout, \eg for each table. Both
 % settings can be given as a library option, but without the "timing/" path.
-% 
+%
 % \bigskip
 % \begin{table}[H]
-%   \caption{Timing tables using `nice' (left) and normal (right) Layout. For 
-%   comparison a \texttt{\{tabular\}\{rT\}} table is placed in grey below the 
+%   \caption{Timing tables using `nice' (left) and normal (right) Layout. For
+%   comparison a \texttt{\{tabular\}\{rT\}} table is placed in grey below the
 %   left table.}^^A
 %   \hbox{}\hfill
 %   \begin{tikzpicture}
@@ -1856,22 +1852,22 @@
 %
 % \clearpage
 % \library{counters}{Counter Character}
-% The library "counters"\NewIn{v0.7}\ExtIn{v0.7a} allows the easy definition 
-% of meta-characters which 
-% implement up-counters. These characters show the counter value using the 
-% "D{}" character and increment it by one every time they are used. A second 
-% character can be defined to (re-)set the counter to a specific value. The 
-% counter values can be decimal (base-10, default), hexadecimal (base-16) or any 
-% other base from 2 to 36. By default the lower case version of the counter 
+% The library "counters"\NewIn{v0.7}\ExtIn{v0.7a} allows the easy definition
+% of meta-characters which
+% implement up-counters. These characters show the counter value using the
+% "D{}" character and increment it by one every time they are used. A second
+% character can be defined to (re-)set the counter to a specific value. The
+% counter values can be decimal (base-10, default), hexadecimal (base-16) or any
+% other base from 2 to 36. By default the lower case version of the counter
 % character is defined to produce the same output only with half the width.
 %
 % Counter characters are defined using the TikZ key
 % `\texttt{timing/counter/new=}\linebreak[3]\ignorespaces
-% \texttt{\{char=\meta{char},\meta{settings}\}}' which can also be written as 
-% "timing/new counter". The \meta{settings} are TikZ keys themselves and are 
-% shown by Table~\ref{tab:countersettings}.  One or more "new" keys (path 
+% \texttt{\{char=\meta{char},\meta{settings}\}}' which can also be written as
+% "timing/new counter". The \meta{settings} are TikZ keys themselves and are
+% shown by Table~\ref{tab:countersettings}.  One or more "new" keys (path
 % "timing/counter" removed) can be given as library options.
-% The counter values are global like normal \LaTeX\ counters. They should be reset 
+% The counter values are global like normal \LaTeX\ counters. They should be reset
 % in every timing diagram line before they are used.
 %
 % \subsubsection*{Counter Style}
@@ -1903,13 +1899,13 @@
 %  \toprule
 %   \multicolumn{1}{l}{Key name} & Description \\
 %  \midrule
-%   char=\meta{char} & Defines the given \meta{char} to be a counter 
-%     meta-character. If it is a upper case character the lower case character 
-%     will produce the same output but with the half width, as long this is not 
+%   char=\meta{char} & Defines the given \meta{char} to be a counter
+%     meta-character. If it is a upper case character the lower case character
+%     will produce the same output but with the half width, as long this is not
 %     overwritten with the \texttt{half with char} key. \\
-%   half width char=\meta{char} & Defines the given \meta{char} to be the half 
-%     width version of the counter value. By default this is the lower case 
-%     version of the counter character given with \texttt{char}. An empty value 
+%   half width char=\meta{char} & Defines the given \meta{char} to be the half
+%     width version of the counter value. By default this is the lower case
+%     version of the counter character given with \texttt{char}. An empty value
 %     for \meta{char} deactivates the definition of a half width character.\\
 %   reset char=\meta{char}
 %    & Defines the given \meta{char} to (re-)set the counter value to the `width'
@@ -1932,7 +1928,7 @@
 %  \midrule
 %   increment=\small\meta{pgfmath expression} &
 %                              Sets the increment which is added every time the counter
-%                              character is used. This can be a formula which result is truncated 
+%                              character is used. This can be a formula which result is truncated
 %                              to a integer. The current counter value can be referenced as \cs{N}.
 %                              The increment can be negative which causes
 %                              the counter to count down. Default: 1\\
@@ -1956,7 +1952,7 @@
 %
 % \subsubsection*{Examples:}
 % \noindent
-% Counter character "Q" with base 16 (hexadecimal). "R" resets the 
+% Counter character "Q" with base 16 (hexadecimal). "R" resets the
 % counter. The counter value should be in blue text typer font.\\*\noindent
 % |\tikzset{timing/new counter={char=Q,base=16,reset char=R}}|\\*\noindent
 % |\tikzset{timing/counter/Q/text/.style={font=\ttfamily,blue}}|\\*\noindent
@@ -1989,7 +1985,7 @@
 %
 % \clearpage
 % \library{advnodes}{Advanced Nodes}
-% The library "advnodes"\NewIn{v0.7} changes the in-line nodes, \ie the "N" character, to provide multiple 
+% The library "advnodes"\NewIn{v0.7} changes the in-line nodes, \ie the "N" character, to provide multiple
 % transition dependent and independent node anchors shown in Table~\ref{tab:advanchor}.
 %
 % Most transitions provide the three logic level anchors "low", "mid" and "high" which lie
@@ -1997,9 +1993,9 @@
 % two low and/or high level anchors which are called "low2" and "high2".
 %
 % To align marker lines over multiple rows inside a \env{tikztimingtable} a set of transition
-% independent node anchors are provided: "LOW", "MID", "HIGH". This anchors lie all at the begin of the 
+% independent node anchors are provided: "LOW", "MID", "HIGH". This anchors lie all at the begin of the
 % transition at the appropriate logic levels.
-% With the normal coordinate-like in-line nodes the vertical node (center) position has to be taken into 
+% With the normal coordinate-like in-line nodes the vertical node (center) position has to be taken into
 % account, while this advanced anchors do this automatically.
 %
 % Often marker lines should start and end with a little vertical offset from the timing diagram to be more distinguishable.
@@ -2007,10 +2003,10 @@
 % The vertical distance can be set using `|timing/nodes/offset=|\meta{dim.~or number}'.
 %
 % \textbf{Please note} that the node \emph{center} of advanced nodes will be different for some transitions.
-% The "center" anchor (used by default if no node anchor is provided) will be placed at the logical center of the 
-% transition, \ie mostly in the middle of it. In order not to break existing diagrams which use nodes as references 
+% The "center" anchor (used by default if no node anchor is provided) will be placed at the logical center of the
+% transition, \ie mostly in the middle of it. In order not to break existing diagrams which use nodes as references
 % to draw additional material an TikZ styles is provided to select between the old and new node centers. This styles
-% can be used globally or locally as required. The two explicit anchors "new center" and "old center" are also 
+% can be used globally or locally as required. The two explicit anchors "new center" and "old center" are also
 % provided. For existing documents with diagrams using normal nodes it is recommended
 % to switch to simple nodes or to the old node centers globally or select such a style for each old diagram.
 %
@@ -2019,18 +2015,19 @@
 % The settings can be used as library options with the "timing/nodes/" part removed.
 %
 % \vfill\noindent
-% \begin{tabularx}{\textwidth}{lX}
+% \begin{tabularx}{\textwidth}{>{\ttfamily}lX}
 %  \toprule
-%   TikZ Setting              &  Description \\
+%   \normalfont
+%   TikZ Setting            &  Description \\
 %  \midrule
-%   |timing/nodes/advanced|   &  Selects advanced in-line nodes. (library default) \\
-%   |timing/nodes/simple|     &  Selects simple coordinate-style in-line nodes. (package default) \\
+%   timing/nodes/advanced   &  Selects advanced in-line nodes. (library default) \\
+%   timing/nodes/simple     &  Selects simple coordinate-style in-line nodes. (package default) \\
 %  \midrule
-%   |timing/nodes/new center| &  Center of in-line nodes is in the new position. (default for |advanced|) \\
-%   |timing/nodes/old center| &  Center of in-line nodes is in the old position. (always on for |simple|) \\
+%   timing/nodes/new center &  Center of in-line nodes is in the new position. (default for \texttt{advanced}) \\
+%   timing/nodes/old center &  Center of in-line nodes is in the old position. (always on for \texttt{simple}) \\
 %  \midrule
-%   |timing/nodes/offset|     &  Sets offset for |TOP| and |BOTTOM| anchors.
-%                                Can be a dimension with unit or a factor to the current |y| unit. (default: 0.25) \\
+%   timing/nodes/offset     &  Sets offset for \texttt{TOP} and \texttt{BOTTOM} anchors.
+%                                Can be a dimension with unit or a factor to the current \texttt{y} unit. (default: 0.25) \\
 %  \bottomrule
 % \end{tabularx}
 %
@@ -2072,80 +2069,80 @@
 %     new center/.style={marker,mark size=\pgflinewidth,mark=*,fill=blue,draw=blue},
 %   }^^A
 %^^A
-%   \newcommand\namark[2][]{^^A 
+%   \newcommand\namark[2][]{^^A
 %     \draw[mark=o,mark size=3\pgflinewidth,#1] plot coordinates {(#2)}
 %   }^^A
 %^^A
-%   \def\NodeAnchors#1#2{^^A 
+%   \def\NodeAnchors#1#2{^^A
 %     \Huge
-%     {\raisebox{-.5ex}{\scalebox{1}{^^A 
+%     {\raisebox{-.5ex}{\scalebox{1}{^^A
 %     \begin{tikzpicture}[timing/picture,line width=.5\pgflinewidth]
 %       \let\pgf at sh@ma at A\@undefined
 %       \timing [name=T] at (0,0) {#1 N(A) #2};
 %       \useasboundingbox (T.south west) rectangle (T.north east);
-%       ^^A 
+%       ^^A
 %       \pgf at sh@ma at A
 %       \anchorpoints
-%       \foreach \a in {LOW,MID,HIGH,old center,new center} {^^A 
-%         \namark[gray,\a]{A.\a};^^A 
-%       }^^A 
-%       \foreach \a in {low,mid,high,low2,high2} {^^A 
-%         \@ifundefined{\a}{}^^A 
-%           {\namark[semithick,\a]{A.\a};}^^A 
-%       }^^A 
-%       \namark[old center,blue]{A.old center};^^A 
-%     \end{tikzpicture}^^A 
-%     }}}^^A 
+%       \foreach \a in {LOW,MID,HIGH,old center,new center} {^^A
+%         \namark[gray,\a]{A.\a};^^A
+%       }^^A
+%       \foreach \a in {low,mid,high,low2,high2} {^^A
+%         \@ifundefined{\a}{}^^A
+%           {\namark[semithick,\a]{A.\a};}^^A
+%       }^^A
+%       \namark[old center,blue]{A.old center};^^A
+%     \end{tikzpicture}^^A
+%     }}}^^A
 %     \Huge\strut
 %   }^^A
 %^^A
-%   \def\bchars{,L,H,X,D,E}^^A 
-%   \def\achars{,L,H,X,D,D{A},E,0LE,0HE}^^A 
+%   \def\bchars{,L,H,X,D,E}^^A
+%   \def\achars{,L,H,X,D,D{A},E,0LE,0HE}^^A
 %^^A
 %   \def\DA{D{A}}^^A
-%   \def\tablecontent{^^A 
+%   \def\tablecontent{^^A
 %     \begin{tabular}{lrrrrrrrrrrrrrrrrrr}^^A
 %       \toprule
 %         \tikzpicture
 %           \useasboundingbox (-1ex,-.5ex) rectangle (1ex,.5ex);
-%           \node {^^A 
-%         \scalebox{0.4}^^A 
-%           {\rotatebox{-45}{$\frac{\mbox{\rotatebox{45}{to}}}^^A 
-%           {\mbox{\rotatebox{45}{from}}}$}}^^A 
-%         };^^A 
+%           \node {^^A
+%         \scalebox{0.4}^^A
+%           {\rotatebox{-45}{$\frac{\mbox{\rotatebox{45}{to}}}^^A
+%           {\mbox{\rotatebox{45}{from}}}$}}^^A
+%         };^^A
 %       \endtikzpicture
 %   }
 %^^A
-%   \def\atc#1{^^A 
+%   \def\atc#1{^^A
 %     \begingroup
-%       \edef\@tempa{#1}^^A 
+%       \edef\@tempa{#1}^^A
 %       \expandafter\g at addto@macro\expandafter\tablecontent
-%       \expandafter{\@tempa}^^A 
+%       \expandafter{\@tempa}^^A
 %     \endgroup
-%   }^^A 
+%   }^^A
 %^^A
-%   \foreach \b in \bchars {^^A 
-%     \atc{& \noexpand\multicolumn{1}{c}{\b}}^^A 
+%   \foreach \b in \bchars {^^A
+%     \atc{& \noexpand\multicolumn{1}{c}{\b}}^^A
 %   }^^A
 %^^A
 %   \atc{\noexpand\\ \noexpand\midrule}^^A
 %^^A
-%   \foreach \a in \achars {^^A 
+%   \foreach \a in \achars {^^A
 %     \ifx\a\DA
-%       \atc{D\noexpand\{A\noexpand\}}^^A 
+%       \atc{D\noexpand\{A\noexpand\}}^^A
 %     \else
-%       \atc{\a}^^A 
+%       \atc{\a}^^A
 %     \fi
-%     \foreach \b in \bchars {^^A 
-%       \atc{& \noexpand\NodeAnchors{\a}{\b}}^^A 
-%       ^^A \hbox to 5em{\llap{\a\b:} \NodeAnchors{\a}{\b}}^^A 
+%     \foreach \b in \bchars {^^A
+%       \atc{& \noexpand\NodeAnchors{\a}{\b}}^^A
+%       ^^A \hbox to 5em{\llap{\a\b:} \NodeAnchors{\a}{\b}}^^A
 %     }^^A
 %     \atc{\noexpand\\}^^A
 %   }^^A
 %^^A
-%   \atc{^^A 
+%   \atc{^^A
 %     \noexpand\bottomrule
-%     \noexpand\end{tabular}^^A 
+%     \noexpand\end{tabular}^^A
 %   }^^A
 %^^A
 %   \sffamily\centering
@@ -2175,7 +2172,7 @@
 % \library{ifsym}{Compatibility Macros for \texttt{ifsym} package}
 % The library "ifsym"\NewIn{v0.7} provides macros and timing styles to emulate the behaviour of the \pkg{ifsym} package
 % when loaded with the |electronic| option. The \pkg{ifsym} package was an early inspiration to this package
-% and this library allows the usage of |ifsym| style timing symbol macros and characters 
+% and this library allows the usage of |ifsym| style timing symbol macros and characters
 % (`|\textifsym|\marg{characters}' which uses `|\texttiming[timing/ifsym]|\marg{characters}')
 % which are described in Table~\ref{tab:ifsymmacros} and Table~\ref{tab:ifsym}, respectively.
 % This is useful if old |ifsym| timing diagrams should be reused. The |tikz-timing| replacements are a very close match
@@ -2184,8 +2181,8 @@
 % (the one provided by this library, not the one from the \pkg{ifsym} package) is supported but it is not guaranteed to work
 % 100\% properly. Please note that the "M" character is defined to use "X" in black.
 %
-% The library can be loaded with one of the options "provide" (default), "new", "renew" or "off", respectively. 
-% These select if the macros should be defined using \cs{providecommand}, \cs{newcommand}, \cs{renewcommand} 
+% The library can be loaded with one of the options "provide" (default), "new", "renew" or "off", respectively.
+% These select if the macros should be defined using \cs{providecommand}, \cs{newcommand}, \cs{renewcommand}
 % or not at all. This can be useful if the \pkg{ifsym} package is loaded beforehand.
 %
 %
@@ -2222,7 +2219,7 @@
 %       \bottomrule
 %     \end{tabular}
 %   }%^^A
-% 
+%
 % \ifprintversion
 %
 % \begin{table}
@@ -2266,12 +2263,12 @@
 % \textbf{This library is under development and might change in the future.}
 %
 % The library "interval"\NewIn{v0.7} allows the drawing of intervals using the "H", "L", "Z" and "X" logic levels.
-% It provides modified definitions of X and Z transitions (e.g.~"LX", "XH") where the transition edges can 
+% It provides modified definitions of X and Z transitions (e.g.~"LX", "XH") where the transition edges can
 % be coloured either way to indicate interval borders.
 %
-% The interval borders can be set using the `|timing/interval=|\marg{settings}' TikZ style. The 
+% The interval borders can be set using the `|timing/interval=|\marg{settings}' TikZ style. The
 % \meta{settings} are "lo" (left-open), "lc" (left-closed) and "ro" (right-open), "rc" (right-closed), which build the
-% following combinations: "{lo,ro}", "{lc,ro}", "{lo,rc}" and "{lc,rc}". However, every of them can also be set on its own, 
+% following combinations: "{lo,ro}", "{lc,ro}", "{lo,rc}" and "{lc,rc}". However, every of them can also be set on its own,
 % e.g.\ "timing/interval={lc}" simply sets the interval to `left-closed' without changing the right border.
 %
 % The key "timing/interval/normal" (alternative: "timing/interval={normal}") sets the transitions back to their default.
@@ -2334,9 +2331,9 @@
 % See the \pkg{beamer} manual for more informations about overlays specifications.
 %
 % \subsection*{Usage}
-% Insert an overlay specification, e.g.~|<|\meta{number}|>|, inside the timing string. It will affect the 
+% Insert an overlay specification, e.g.~|<|\meta{number}|>|, inside the timing string. It will affect the
 % rest of the timing characters of the current diagram line.
-% Unfortunate due to the global nature of overlays it also affects the rest of the table. Therefore all 
+% Unfortunate due to the global nature of overlays it also affects the rest of the table. Therefore all
 % diagram lines should end with a specification which turns overlays off, i.e. |<*>| or |<0->|. Otherwise
 % strange results can occur (e.g.~wrong/missing background graphics).
 %
@@ -2362,7 +2359,7 @@
 % \subsection*{Display Columns Stepwise}
 % Different sections (`columns') of timing diagrams in a \env{tikztimingtable} can be uncovered stepwise using the way shown below.
 % In this example the second section/column will be uncovered in the second slide. The first is always visible. Further sections/columns
-% can be uncovered in further slides. 
+% can be uncovered in further slides.
 %
 % Please note that the total width of the table is constant and e.g.~\cs{tablerules} will always cover the full width independent of overlays.
 %
@@ -2397,17 +2394,17 @@
 %
 % \clearpage
 % \chapter{Examples}
-% This section shows some examples by putting either the full source code or 
-% only the needed characters beside the graphical result. Please note that the 
-% displayed syntax is the one of \cs{timing} where the initial character is 
-% declared as optional argument (\oarg{char}) \emph{inside}/\emph{together} with 
-% the logic characters. The syntax of \cs{textttiming} is identical except the 
-% initial character is given as a normal optional argument before the characters 
+% This section shows some examples by putting either the full source code or
+% only the needed characters beside the graphical result. Please note that the
+% displayed syntax is the one of \cs{timing} where the initial character is
+% declared as optional argument (\oarg{char}) \emph{inside}/\emph{together} with
+% the logic characters. The syntax of \cs{textttiming} is identical except the
+% initial character is given as a normal optional argument before the characters
 % argument.
 % All examples except Example~\ref{exa:adv} are attached in compilable form
 % to this PDF.
 % ^^A\\[\smallskipamount]
-% ^^A\emph{Example notation example:} "[c]cccc" means either 
+% ^^A\emph{Example notation example:} "[c]cccc" means either
 % ^^A|\timing{[c]cccc};| or |\texttiming[c]{cccc}|.
 %
 % \DeleteShortVerb{\|}
@@ -2460,9 +2457,9 @@
 % \end{tikztimingexampletable}%
 % }
 % \\\scriptsize
-% \emph{Note:} Optional argument must be placed before macro argument if 
+% \emph{Note:} Optional argument must be placed before macro argument if
 % \cs{texttiming} is used.
-% 
+%
 % \end{exampletable}
 % \MakeShortVerb{\|}
 %
@@ -2570,7 +2567,7 @@
 % \noexpand\usepackage{amsmath}}
 % \begin{examplecode}
 %   \def\degr#1{\makebox[2em][r]{#1}\ensuremath{{}^{\circ}}}%
-%   
+%
 %   \begin{tikztimingtable}[%
 %       timing/dslope=0.1, timing/.style={x=2ex,y=2ex}, x=2ex,
 %       timing/rowdist=3ex,
@@ -2580,7 +2577,7 @@
 %     Clock \degr{90} &  l  2{C} N(A1) 5{C}  \\
 %     Clock \degr{180}&  C  2{C} N(A2) 4{C} c\\
 %     Clock \degr{270}&  h  3{C} N(A3) 4{C}  \\
-%     Clock \degr{0}  & [C] 2{C} N(A0) 2{C} N(A4) 3{C}c ;[dotted] 
+%     Clock \degr{0}  & [C] 2{C} N(A0) 2{C} N(A4) 3{C}c ;[dotted]
 %                       2L; 2{C} N(A5) 3{C} \\
 %     Start of T$_{\text{sw}}$ & 4S G N(start) \\
 %     Input Pulse & 2.0L 2H 3.5L ;[dotted] 2L; 5L \\
@@ -2669,7 +2666,7 @@
 %    \end{pgfonlayer}
 %   \end{tikztimingtable}%
 % \end{examplecode}
-% \caption[SR flip-flop timing diagram]{SR flip-flop timing diagram\texta.  
+% \caption[SR flip-flop timing diagram]{SR flip-flop timing diagram\texta.
 % Redrawn from image\textb\\ {\small
 % \url{http://commons.wikimedia.org/wiki/File:SR_FF_timing_diagram.png}
 % }}
@@ -2711,7 +2708,7 @@
 %     \end{scope}
 %   \end{tikztimingtable}%
 % \end{examplecode}
-% \caption[SPI Interface Timing]{SPI Interface Timing.  Redrawn from 
+% \caption[SPI Interface Timing]{SPI Interface Timing.  Redrawn from
 % image {\small
 % \url{http://en.wikipedia.org/wiki/File:SPI_timing_diagram.svg}}}
 % \end{example}
@@ -2723,12 +2720,26 @@
 %</doc>
 % \fi
 %
+%
 % \chapter{Implementation}
-% \section{Package Header}
+%
+% \subsection{Package Header}
 % \iffalse
-%<*package>
+%<*tikz-timing.sty>
 % \fi
 %    \begin{macrocode}
+%<!COPYRIGHT>
+\NeedsTeXFormat{LaTeX2e}[1999/12/01]
+\ProvidesPackage{tikz-timing}[%
+%<!DATE>
+%<!VERSION>
+%<*DRIVER>
+    2099/01/01 develop
+%</DRIVER>
+    Digital Timing Diagrams using TikZ]
+%    \end{macrocode}
+%
+%    \begin{macrocode}
 \RequirePackage{tikz}
 
 \usetikzlibrary{calc}
@@ -2865,6 +2876,8 @@
   name/.style={inner sep=0pt,outer sep=0pt,minimum size=0pt},
   text format/.store in=\tikztiming at textformat,
   @/.style={},
+  every char/.style={},
+  every bg/.style={},
   D/.style={timing/d},
   D/text/.style={timing/d/text},
   D/background/.style={timing/d/background},
@@ -2953,7 +2966,7 @@
 %
 % \section{Text-Mode Macros}
 % \begin{macro}{\texttimingbefore}
-% This macro is executed inside the |tikzpicture| environment of \cs{texttiming} 
+% This macro is executed inside the |tikzpicture| environment of \cs{texttiming}
 % before the timing diagram is drawn.
 %    \begin{macrocode}
 \def\texttimingbefore{}
@@ -2961,7 +2974,7 @@
 % \end{macro}
 %
 % \begin{macro}{\texttimingafter}
-% This macro is executed inside the |tikzpicture| environment of \cs{texttiming} 
+% This macro is executed inside the |tikzpicture| environment of \cs{texttiming}
 % after the timing diagram is drawn.
 %    \begin{macrocode}
 \def\texttimingafter{}
@@ -2969,11 +2982,11 @@
 % \end{macro}
 %
 % \begin{macro}{\texttiminggrid}
-% Draws a background grid with the "timing/grid" setting. Should be used inside 
+% Draws a background grid with the "timing/grid" setting. Should be used inside
 % \cs{texttimingbefore}.
 %    \begin{macrocode}
 \def\texttiminggrid{%
-  \draw[xstep={\timingwidth/2.},ystep={\timingheight/2.},timing/grid] (0,0) grid 
+  \draw[xstep={\timingwidth/2.},ystep={\timingheight/2.},timing/grid] (0,0) grid
   (\timingwidth*\tikztimingwidth,\timingheight);
 }
 %    \end{macrocode}
@@ -2982,7 +2995,7 @@
 % \section{User Level Macros}
 %
 % \begin{macro}{\texttiming}[2]{Optional initial character}{Timing characters}
-% This macro now only parses it optional argument to check if it is a initial 
+% This macro now only parses it optional argument to check if it is a initial
 % character or some style settings and then calls \cs{timing} appropriately.
 %    \begin{macrocode}
 \DeclareRobustCommand*\texttiming[2][]{%
@@ -3049,9 +3062,9 @@
     \def\tikztimingwidth{0.0}%
     \setcounter{tikztimingtrans}{-1}%
     \setcounter{tikztimingtranspos}{0}%
-    \def\tikztiming at str{%
+    \tikztiming at initstr{%
       \useasboundingbox (0,0) rectangle (\tikztimingwidth,\timingheight);
-      \draw (0,0)
+      \draw [timing/every char] (0,0)
         coordinate (timing at refa)
         coordinate (timing at ref)  at (0,\timingheight/2)
         coordinate (timing at refb) at (0,\timingheight)
@@ -3098,9 +3111,9 @@
 \def\tikz at timing@[#1]{%
   \@ifnextchar{a}%
     {\tikz at timing@at{#1}}%
-    {\PackageWarning{tikz-timing}{The \string\timing\space command awaits now an 
-    `at' before the coordinate, like the \string\node\space command is doing.  
-    Please update your source code to ensure compatibility with newer 
+    {\PackageWarning{tikz-timing}{The \string\timing\space command awaits now an
+    `at' before the coordinate, like the \string\node\space command is doing.
+    Please update your source code to ensure compatibility with newer
     versions}{}{}{}%
      \@ifnextchar{+}%
       {\tikz at timing@@{#1}}%
@@ -3121,7 +3134,7 @@
 %    \end{macrocode}
 % \end{macro}
 %
-% \begin{macro}{\tikz at timing@@}[3]{Optional TikZ Keys}{Potential `+' or 
+% \begin{macro}{\tikz at timing@@}[3]{Optional TikZ Keys}{Potential `+' or
 % empty}{Coordinate}
 %    \begin{macrocode}
 \def\tikz at timing@@#1#2(#3){%
@@ -3130,7 +3143,7 @@
 %    \end{macrocode}
 % \end{macro}
 %
-% \begin{macro}{\tikz at timing@@@}[3]{Optional TikZ Keys}{Coordinate}{Timing 
+% \begin{macro}{\tikz at timing@@@}[3]{Optional TikZ Keys}{Coordinate}{Timing
 % Characters}
 %    \begin{macrocode}
 \def\tikz at timing@@@#1#2#3{%
@@ -3142,23 +3155,6 @@
         {\tikz at timing@@@init}%
         {\tikz at timing@@@init[]}%
       #3\relax
-      \ifnum\tikztiming at debug>1
-      \message{^^J\meaning\tikztiming at str^^J}%
-      \ifnum\tikztiming at debug>2
-      {%
-      \def\@protect##1{\def##1{\noexpand##1}}%
-      \@protect\useasboundingbox
-      \@protect\draw
-      \@protect\p
-      \@protect\n
-      \@protect\x
-      \@protect\y
-      \@protect\tikztiming at overlay@save
-      \edef\@tempa{\tikztiming at str}%
-      \message{^^J\meaning\@tempa^^J}%
-      }%
-      \fi
-      \fi
       \tikzset{timing/before}%
       \tikztiming at str;%
       \path let \p1 = (timing/end top), \p2 = (timing/end base),
@@ -3201,7 +3197,7 @@
   \if @\tikztiming at lastchar\relax\else
   \tikztiming at iftrans{@\tikztiming at lastchar}%
     {\tikztiming at nameaddtostr{@}{\tikztiming at lastchar}{}}%
-    {\PackageWarning{tikz-timing}{Start value for timing character 
+    {\PackageWarning{tikz-timing}{Start value for timing character
     '\tikztiming at lastchar' is not defined and will be ignored!}{}{}{}}%
   \fi
   \tikztiming at parser
@@ -3214,7 +3210,9 @@
 % \begin{macro}{\tikztiming at trans@}
 %    \begin{macrocode}
 \def\tikztiming at trans@#1#2#3#4{%
-  \csname\tikztiming at prefix #2#3#4\endcsname{#1}{#2}{#3}{#4}%
+    \unexpanded\expandafter\expandafter\expandafter{%
+        \csname\tikztiming at prefix #2#3#4\endcsname{#1}{#2}{#3}{#4}
+    }%
 }
 %    \end{macrocode}
 % \end{macro}
@@ -3290,7 +3288,18 @@
 %    \end{macrocode}
 % \end{macro}
 %
+%    \begin{macrocode}
+\iftrue
+%    \end{macrocode}
 %
+% \begin{macro}{\tikztiming at initstr}
+%    \begin{macrocode}
+\long\def\tikztiming at initstr{%
+    \def\tikztiming at str
+}
+%    \end{macrocode}
+% \end{macro}
+%
 % \begin{macro}{\tikztiming at eaddtostr}
 %    \begin{macrocode}
 \def\tikztiming at eaddtostr{%
@@ -3307,6 +3316,64 @@
 %    \end{macrocode}
 % \end{macro}
 %
+%    \begin{macrocode}
+\else
+%    \end{macrocode}
+%
+% \begin{macro}{\tikztiming at str}
+%    \begin{macrocode}
+\def\tikztiming at file{\jobname.ttg}
+\newwrite\tikztiming at fh
+\def\tikztiming at str{%
+    \tikztiming at addtostr{;}%
+    \immediate\closeout\tikztiming at fh
+    \begingroup
+    \makeatletter
+    \@@input\tikztiming at file\relax
+    \endgroup
+    \@ifnextchar;{\@gobble}{}%
+}
+%    \end{macrocode}
+% \end{macro}
+%
+% \begin{macro}{\tikztiming at initstr}
+%    \begin{macrocode}
+\long\def\tikztiming at initstr{%
+    \immediate\openout\tikztiming at fh= \tikztiming at file\relax
+    \tikztiming at addtostr
+}
+%    \end{macrocode}
+% \end{macro}
+%
+% \begin{macro}{\tikztiming at eaddtostr}
+%    \begin{macrocode}
+\long\def\tikztiming at eaddtostr#1{%
+  \begingroup
+    \tikztiming at internaldefs
+    \let\par\empty
+    \immediate\write\tikztiming at fh{#1}%
+  \endgroup
+}
+%    \end{macrocode}
+% \end{macro}
+%
+% \begin{macro}{\tikztiming at addtostr}
+%    \begin{macrocode}
+\long\def\tikztiming at addtostr#1{%
+  \begingroup
+    \tikztiming at internaldefs
+    \let\par\empty
+    \immediate\write\tikztiming at fh{\unexpanded{#1}}%
+  \endgroup
+}
+%    \end{macrocode}
+% \end{macro}
+%
+%    \begin{macrocode}
+\fi
+%    \end{macrocode}
+%
+%
 % \begin{macro}{\tikztiming at makeglobal}
 %    \begin{macrocode}
 \def\tikztiming at makeglobal#1{%
@@ -3349,17 +3416,17 @@
     % If both do not exist, search for aliases:
     \ifx\tikztiming at trans\relax
       \@ifundefined{tikztiming at alias@#1}%
-        {\edef\chara{#1}}%
-        {\edef\chara{#1,\csname tikztiming at alias@#1\endcsname}}%
+        {\edef\chara{{#1}}}%
+        {\edef\chara{{#1},{\csname tikztiming at alias@#1\endcsname}}}%
       \@ifundefined{tikztiming at alias@#2}%
-        {\edef\charb{#2}}%
-        {\edef\charb{#2,\csname tikztiming at alias@#2\endcsname}}%
+        {\edef\charb{{#2}}}%
+        {\edef\charb{{#2},{\csname tikztiming at alias@#2\endcsname}}}%
       \@ifundefined{tikztiming at triple@#2}%
         {\def\charc{\empty}}%
         {%
          \@ifundefined{tikztiming at alias@#3}%
-           {\edef\charc{#3,}}%
-           {\edef\charc{#3,\csname tikztiming at alias@#3\endcsname,}}%
+           {\edef\charc{{#3},}}%
+           {\edef\charc{{#3},{\csname tikztiming at alias@#3\endcsname},}}%
         }%
       \ifx\charb\empty
         \def\charb{\empty}%
@@ -3383,9 +3450,9 @@
                   \ifnum\tikztiming at debug>2
                     \expandafter\show\csname\tikztiming at pfxtr\tikztiming at trans\endcsname
                   \else
-                    \message{^^J\tikztiming at trans: 
+                    \message{^^J\tikztiming at trans:
                     \expandafter\meaning\csname\tikztiming at pfxtr\tikztiming at trans\endcsname^^J}%
-                    \message{^^J\a\b\c: 
+                    \message{^^J\a\b\c:
                     \expandafter\meaning\csname\tikztiming at prefix\a\b\c\endcsname^^J}%
                   \fi
                 \fi
@@ -3416,10 +3483,13 @@
 \def\tikztiming at nameaddtostr#1#2#3{%
   \tikztiming at iftrans{{#1}{#2}{#3}}%
    {%
+     %\edef\@tempa{\noexpand\tikztiming at trans@{\tikztiming at num}\tikztiming at trans}%
+     %\expandafter\tikztiming at addtostr
+     %\expandafter{\@tempa}%
      \edef\@tempa{\noexpand\tikztiming at trans@{\tikztiming at num}\tikztiming at trans}%
-     \expandafter\g at addto@macro
-     \expandafter\tikztiming at str
-     \expandafter{\@tempa}%
+     %\tikztiming at eaddtostr{\@percentchar\space {#1}{#2}{#3}}%
+     \tikztiming at eaddtostr{\@tempa}%
+     %\tikztiming at eaddtostr{\tikztiming at trans@{\tikztiming at num}\tikztiming at trans}%
    }%
    {\PackageWarning{tikz-timing}{No transitions '#1#2' (or '#1#2#3') defined!}}%
 }
@@ -3427,7 +3497,7 @@
 % \end{macro}
 %
 % \begin{macro}{\tikztiming at output@addcode}
-% Adds code to the output code buffer. The code will not be expanded, i.e.\ will 
+% Adds code to the output code buffer. The code will not be expanded, i.e.\ will
 % be protected from the expansion when the buffer is flushed.
 %    \begin{macrocode}
 \def\tikztiming at output@addcode#1{%
@@ -3437,7 +3507,7 @@
 % \end{macro}
 %
 % \begin{macro}{\tikztiming at output@eaddcode}
-% Adds code to the output code buffer. The code will be expanded when the buffer 
+% Adds code to the output code buffer. The code will be expanded when the buffer
 % is flushed.
 %    \begin{macrocode}
 \def\tikztiming at output@eaddcode#1{%
@@ -3447,7 +3517,7 @@
 % \end{macro}
 %
 % \begin{macro}{\tikztiming at output@Eaddcode}
-% Adds code to the output code buffer. The code will be expanded immediately and 
+% Adds code to the output code buffer. The code will be expanded immediately and
 % again when the buffer is flushed.
 %    \begin{macrocode}
 \def\tikztiming at output@Eaddcode{%
@@ -3532,15 +3602,17 @@
 % \begin{macro}{\tikztiming at output@codeflush}
 %    \begin{macrocode}
 \def\tikztiming at output@codeflush{%
-  \tikztiming at eaddtostr{\tikztiming at output@bufcode}%
-  \global\let\tikztiming at output@bufcode\empty%
+  \ifx\tikztiming at output@bufcode\empty\else
+    \tikztiming at eaddtostr{\tikztiming at output@bufcode}%
+    \global\let\tikztiming at output@bufcode\empty%
+  \fi
 }
 %    \end{macrocode}
 % \end{macro}
 %
 % \begin{macro}{\tikztiming at output@charflush}
-% A group is used to protect the current value of |num| which is the length of 
-% the new character after the flushed old character. This value will be assigned 
+% A group is used to protect the current value of |num| which is the length of
+% the new character after the flushed old character. This value will be assigned
 % to the new buffer length |bufnum|.
 %    \begin{macrocode}
 \def\tikztiming at output@charflush{%
@@ -3562,10 +3634,10 @@
 %
 % \section{Macros for Character Definitions}
 %
-% \begin{macro}{\tikztiming at nameedef}[4]{Macro name to be defined (without 
+% \begin{macro}{\tikztiming at nameedef}[4]{Macro name to be defined (without
 % prefix)}{Content of macro}
-% Defines internal tikztiming macro with name |\|\meta{prefix}\meta{name (\#2)}.  
-% The macro definition (\#3) is expanded while the internal drawing definitions 
+% Defines internal tikztiming macro with name |\|\meta{prefix}\meta{name (\#2)}.
+% The macro definition (\#3) is expanded while the internal drawing definitions
 % are active.
 %    \begin{macrocode}
 \newcommand\tikztiming at nameedef[4]{%
@@ -3581,7 +3653,7 @@
 % \end{macro}
 %
 % \begin{macro}{\tikztiming at namelet}[2]{Original Characters}{New Characters}
-% Only execute |\let| if the original macro is defined or the destination macro 
+% Only execute |\let| if the original macro is defined or the destination macro
 % is defined and would now set to undefined.
 %    \begin{macrocode}
 \newcommand\tikztiming at namelet[2]{%
@@ -3668,8 +3740,8 @@
 % \end{macro}
 %
 % \begin{macro}{\tikztiming at handletext}[1]{Text}
-% Looks ahead if the current character is the last one and sets the end-of-line 
-% marker if so. 
+% Looks ahead if the current character is the last one and sets the end-of-line
+% marker if so.
 %
 % This seems outdated because |handletext@| does not flush the output any more.
 %    \begin{macrocode}
@@ -3747,8 +3819,8 @@
 % \end{macro}
 %
 % \begin{macro}{\tikztiming at defcode{@}}
-% Simply executes given code. The |\relax| is added to have some protection 
-% against user code manipulating the parser macro. The "@" character can be both 
+% Simply executes given code. The |\relax| is added to have some protection
+% against user code manipulating the parser macro. The "@" character can be both
 % a letter (in style files) and a character (in user documents), so it is
 % defined twice.
 %    \begin{macrocode}
@@ -3767,8 +3839,8 @@
 % \end{macro}
 %
 % \begin{macro}{\tikztiming at defcode{DOLLAR}}
-% Takes the code between two dollar signs and parses it as math expression. The 
-% result is put back on the input stream. This allows the calculation of 
+% Takes the code between two dollar signs and parses it as math expression. The
+% result is put back on the input stream. This allows the calculation of
 % character width.
 %    \begin{macrocode}
 \tikztiming at defcode$#1${%
@@ -3783,7 +3855,7 @@
 %    \begin{macrocode}
 \tikztiming at defcode{,}{%
   \tikztiming at output@eaddcode{%
-    \newdraw
+    \newdraw [timing/every char]
   }%
   \tikztiming at parser
 }
@@ -3795,7 +3867,7 @@
 \tikztiming at defcode{;}{%
   \endgroup\begingroup
   \tikztiming at output@eaddcode{%
-    \newdrawns
+    \newdrawns [timing/every char]
   }%
   \tikztiming at parser
 }
@@ -3885,7 +3957,7 @@
 % \end{macro}
 %
 % \begin{macro}{\tikztiming at parseroption}[1]{Options}
-% Sets the given options immediately, so that they are in affect for the rest of 
+% Sets the given options immediately, so that they are in affect for the rest of
 % the parser run.
 %    \begin{macrocode}
 \def\tikztiming at parseroption!#1!]{%
@@ -3906,7 +3978,7 @@
 % \end{macro}
 %
 % \begin{macro}{\tikztiming at bothoption}[1]{Options}
-% Does executes and adds the options to the output code buffer. This is 
+% Does executes and adds the options to the output code buffer. This is
 % necessary for slopes if they are used in width calculations.
 %    \begin{macrocode}
 \def\tikztiming at bothoption[#1]]{%
@@ -3934,7 +4006,7 @@
 \tikztiming at defcode{\bgroup}{%
   \tikztiming at output@eaddcode{%
     [timing/pushoptions]
-    \newdraw
+    \newdraw [timing/every char]
   }%
   \tikztiming at parser
 }
@@ -3946,7 +4018,7 @@
 \tikztiming at defcode{\egroup}{%
   \tikztiming at output@eaddcode{%
     [timing/popoptions]
-    \newdraw
+    \newdraw [timing/every char]
   }%
   \tikztiming at parser
 }
@@ -4010,7 +4082,7 @@
 % \end{macro}
 %
 % \begin{macro}{\tikztiming at addnode@}[3]{Options}{Node name}{Node text}
-% The |fromchar| and |tochar| macros are to be expanded in the output routine, 
+% The |fromchar| and |tochar| macros are to be expanded in the output routine,
 % not inside this macro. They do not hold the correct values yet.
 %    \begin{macrocode}
 \def\tikztiming at addnode@#1#2#3{%
@@ -4042,7 +4114,7 @@
     \foreach \N in #2 {%
       \ifx\N\empty\else
         \tikztiming at markcmd
-        \path let \p1=(\N) in 
+        \path let \p1=(\N) in
           node [timing/debug/node] at ($ (\x1,\noexpand\@tempa) + (0,1) $) {\N};
       \fi
     }%
@@ -4095,7 +4167,7 @@
   \@ifnextchar\bgroup
     {\tikztiming at handlecode}%
     {%
-      \PackageWarning{tikz-timing}{Missing braces after '!' character. Ignoring 
+      \PackageWarning{tikz-timing}{Missing braces after '!' character. Ignoring
       this character}{}{}{}%
       \tikztiming at parser
     }%
@@ -4155,7 +4227,7 @@
 % \end{macro}
 %
 % \begin{macro}{\tikztiming at testfornum@}
-% The \cs{@let at token} set in \cs{tikztiming at parser} is used to handle "0" 
+% The \cs{@let at token} set in \cs{tikztiming at parser} is used to handle "0"
 % which can not be detected using the \cs{tikztiming at numint} value.
 %    \begin{macrocode}
 \def\tikztiming at testfornum@{%
@@ -4229,7 +4301,7 @@
 %    \end{macrocode}
 % \end{macro}
 %
-% \begin{macro}{\tikztiming at testfornum@@@@}[1]{Characters and other tokens to 
+% \begin{macro}{\tikztiming at testfornum@@@@}[1]{Characters and other tokens to
 % repeat}
 %    \begin{macrocode}
 \def\tikztiming at testfornum@@@@#1{%
@@ -4247,7 +4319,7 @@
 % \section{Meta-Characters}
 %
 % \begin{macro}{\tikztimingmetachar}[1]{Meta-character}
-% Checks if there is an optional argument and calls \cs{tikztiming at metachar} 
+% Checks if there is an optional argument and calls \cs{tikztiming at metachar}
 % appropriately.
 %    \begin{macrocode}
 \def\tikztimingmetachar#1{%
@@ -4258,7 +4330,7 @@
 %    \end{macrocode}
 % \end{macro}
 %
-% \begin{macro}{\tikztiming at metachar}[3]{Macro character}{Number of 
+% \begin{macro}{\tikztiming at metachar}[3]{Macro character}{Number of
 % Arguments}{Substituted Characters}
 %    \begin{macrocode}
 \def\tikztiming at metachar#1[#2]#3{%
@@ -4277,7 +4349,7 @@
     \fi
   \fi
   \ifnum\tikztiming at debug=-1
-    \message{^^J Defined meta-char '#1' as: 
+    \message{^^J Defined meta-char '#1' as:
       \expandafter\meaning\csname tikztiming at metachar@\meaning#1\endcsname ^^J}%
   \fi
 }
@@ -4285,7 +4357,7 @@
 % \end{macro}
 %
 % \begin{macro}{\if at tikztiming@metachar}[2]{True clause}{False clause}
-% Only works in an argument of |\@ifnextchar|. This macro sets the needed 
+% Only works in an argument of |\@ifnextchar|. This macro sets the needed
 % |\@let at token| macro.
 %    \begin{macrocode}
 \def\if at tikztiming@metachar#1#2{%
@@ -4477,7 +4549,7 @@
 %    \end{macrocode}
 % \end{macro}
 %
-% \begin{macro}{\tikztimingtable at row@}[3]{Cell 1}{Cell 2 or empty}{Potential 
+% \begin{macro}{\tikztimingtable at row@}[3]{Cell 1}{Cell 2 or empty}{Potential
 % further cells}
 %    \begin{macrocode}
 \long\def\tikztimingtable at row@#1&#2&#3\\{%
@@ -4810,9 +4882,9 @@
   \def\zslope{\noexpand\timingzslope}%
   \def\dslope{\noexpand\timingdslope}%
   \def\gslope{0}%
-  \def\style{timing/####3}%
-  \def\bgstyle{draw=none,timing/####3/background}%
-  \def\nstyle{timing/####4}%
+  \def\style{timing/every char,timing/####3}%
+  \def\bgstyle{draw=none,timing/every bg,timing/####3/background}%
+  \def\nstyle{timing/every char,timing/####4}%
   \def\newdraw{\tikztiming at newdraw}%
   \def\newdrawns{\tikztiming at newdraw@nosave}%
   \def\code##1{ [/utils/exec={\unexpanded{##1}}] }%
@@ -4874,7 +4946,7 @@
 %    \end{macrocode}
 % \end{macro}
 %
-% \begin{macro}{\tikztimingdef@}[3]{First character}{Second character or 
+% \begin{macro}{\tikztimingdef@}[3]{First character}{Second character or
 % empty}{Definition code}
 %    \begin{macrocode}
 \def\tikztimingdef@#1#2#3\relax#4{%
@@ -4923,7 +4995,7 @@
 %
 %
 % \begin{macro}{\tikztiming at chars}[1]{Comma to gobble}
-% Initial definition of character list. Will gobble the separation comma in 
+% Initial definition of character list. Will gobble the separation comma in
 % front of the first character which is added to the list.
 %    \begin{macrocode}
 \def\tikztiming at chars#1{}
@@ -4970,7 +5042,7 @@
 \@namedef{\tikztiming at prefix @@}#1#2#3#4{ coordinate (timing/start)}%
 %    \end{macrocode}
 %
-% \begin{macro}{\tikztimingchar@}[3]{Character}{Start position}{Character 
+% \begin{macro}{\tikztimingchar@}[3]{Character}{Start position}{Character
 % drawing code}
 %    \begin{macrocode}
 \def\tikztimingchar@#1#2#3{%
@@ -5040,7 +5112,7 @@
 %    \end{macrocode}
 %
 % \subsection{Character `S'}
-% This character is now implemented as modifier to avoid hassle with triple 
+% This character is now implemented as modifier to avoid hassle with triple
 % character transitions.
 %    \begin{macrocode}
 \tikztiming at defcode{S}{%
@@ -5085,8 +5157,8 @@
 }
 
 \def\tikztiming at glitch{%
-  {[timing/g] let \p1 = +(0,0) in (\x1,0) -- (\x1,\timingheight)
-   coordinate (timing at dstart) at (\x1,\timingheight/2) (\x1,\y1) 
+  {[timing/every char,timing/g] let \p1 = +(0,0) in (\x1,0) -- (\x1,\timingheight)
+   coordinate (timing at dstart) at (\x1,\timingheight/2) (\x1,\y1)
   }%
 }
 %    \end{macrocode}
@@ -5093,7 +5165,7 @@
 %
 % \subsection{Character `H'}
 %    \begin{macrocode}
-\tikztimingchar{H}{++(0,\height)}{-- ++(#1,0)}
+\tikztimingchar{H}{++(0,\height)}{[\style] -- ++(#1,0)}
 
 \tikztimingdef{HH}{
   -- ++(#1,0)
@@ -5105,7 +5177,7 @@
 }
 
 \tikztimingdef{ZH}{
-    \newdraw
+    \newdraw [\style]
   -- ++(\zslope,+\height/2.)
   -- ++($ (#1,0) - (\zslope,0) $)
 }
@@ -5133,7 +5205,7 @@
 % \subsection{Character `'}
 %    \begin{macrocode}
 
-\tikztimingchar{L}{++(0,0)}{-- ++(#1,0)}
+\tikztimingchar{L}{++(0,0)}{[\style] -- ++(#1,0)}
 
 \tikztimingchar{Z}{++(0,\height/2.)}{%
   \newdraw [\style]
@@ -5197,7 +5269,7 @@
   -- ++($ (#1,0) - (\zslope,0) $)
 }
 \tikztimingdef{ZL}{%
-  \newdraw
+  \newdraw [\style]
   -- ++(\zslope,-\height/2.)
   -- ++($ (#1,0) - (\zslope,0) $)
 }
@@ -5210,7 +5282,7 @@
 
 \def\tikztiming at chard#1{%
   \newdraw [\style,preaction={\bgstyle}]
-  coordinate (timing at dstart) 
+  coordinate (timing at dstart)
   -- +(\dslope/2,\height/2)
   --  ($ (timing at ref) + (#1,\height/2) $)
   -- +(\dslope/2,-\height/2)
@@ -5224,7 +5296,7 @@
   \tikztiming at oldnodecenter{%
     (-\dslope/2,-\height/2)
   }%
-  \newdraw
+  \newdraw [timing/every char]
 }
 
 \def\tikztiming at chard@#1{%
@@ -5247,7 +5319,7 @@
   \tikztiming at oldnodecenter{%
     (0,-\height/2)
   }%
-  \newdraw
+  \newdraw [timing/every char]
 }
 
 \def\tikztiming@@chard#1{%
@@ -5276,7 +5348,7 @@
   \tikztiming at oldnodecenter{%
     (-\dslope/2,-\height/2)
   }%
-  \newdraw
+  \newdraw [timing/every char]
 }
 
 \def\tikztiming@@chard@#1{%
@@ -5302,7 +5374,7 @@
   \tikztiming at oldnodecenter{%
     (0,-\height/2)
   }%
-  \newdraw
+  \newdraw [timing/every char]
 }
 
 \def\tikztiming at dchardu#1{%
@@ -5327,7 +5399,7 @@
   \tikztiming at oldnodecenter{%
     (-\dslope/2,-\height/2)
   }%
-  \newdraw
+  \newdraw [timing/every char]
 }
 
 \def\tikztiming at uchardd#1{%
@@ -5351,7 +5423,7 @@
   \tikztiming at oldnodecenter{%
       ($ (0,0) - (0,\height/2) $)
   }%
-  \newdraw
+  \newdraw [timing/every char]
 }
 
 \tikztimingdef{DD}{%
@@ -5381,7 +5453,7 @@
   \tikztiming at oldnodecenter{%
     (0,-\height/2)
   }%
-  \newdraw
+  \newdraw [timing/every char]
 }
 
 \tikztimingdef{DD@}{
@@ -5693,7 +5765,7 @@
 }
 
 \tikztimingdef{ZT}{%
-  \newdraw {[\style]
+  \newdraw [timing/every char] {[\style]
   \code{\setcounter{tikztimingtrans}{-\value{tikztimingtrans}}}
   -- ++(\zslope,\value{tikztimingtrans}*\height/2.)
   -- ++($ (#1,0) - (\zslope,0) $)
@@ -5711,7 +5783,7 @@
 \tikztimingdef{DT}{
   \code{\setcounter{tikztimingtrans}{-1}}
   \tikztiming at oldnodecenter@%
-  \newdraw {[\style]
+  \newdraw [timing/every char] {[\style]
   --  +(\dslope/2.,-\height/2)
   --   ($ (timing at ref) + (#1,-\height/2) $)
   }
@@ -5851,8 +5923,8 @@
   \tikztiming at library@#1,\relax
 }
 %    \end{macrocode}
-% Load the library as package. The \LaTeX\ core macro \cs{zap at space} is patched 
-% to a no-op to keep spaces in the option text. Otherwise the option keys may 
+% Load the library as package. The \LaTeX\ core macro \cs{zap at space} is patched
+% to a no-op to keep spaces in the option text. Otherwise the option keys may
 % not contain spaces.
 %    \begin{macrocode}
 \def\tikztiming at zap@space#1 \@empty{#1}
@@ -5873,17 +5945,28 @@
   \@ifnextchar\relax{}{\tikztiming at library@}%
 }
 %    \end{macrocode}
-%
 % \iffalse
-%</package>
+%</tikz-timing.sty>
 % \fi
 %
-% \section{Libraries}
+% \subsection{Libraries}
 %
-% \subsection{Either High or Low}
+% \subsubsection{Either High or Low}
 % \iffalse
-%<*lib-either>
+%<*tikz-timing-either.sty>
 % \fi
+%    \begin{macrocode}
+%<!COPYRIGHT>
+\NeedsTeXFormat{LaTeX2e}[1999/12/01]
+\ProvidesPackage{tikz-timing-either}[%
+%<!DATE>
+%<!VERSION>
+%<*DRIVER>
+    2099/01/01 develop
+%</DRIVER>
+    tikz-timing library for uncertain transitions]
+%    \end{macrocode}
+%
 % Provides character "E".
 %    \begin{macrocode}
 \tikztimingchar{E}{
@@ -5894,7 +5977,7 @@
   \code{\setcounter{tikztimingtranspos}{0}}%
   \code{\setcounter{tikztimingtrans}{1}}%
   \tikztiminguse{D}{#1}%
-  \newdraw
+  \newdraw [\style]
 }
 \def\tikztiming at triple@E{}%
 
@@ -5910,7 +5993,7 @@
      ++($ -1*(#1,\height) $)%
   -- ++($  1*(#1,0) $)%
      ++(0,.5\height)%
-  \newdraw
+  \newdraw [\nstyle]
   \code{\setcounter{tikztimingtranspos}{0}}%
   \code{\setcounter{tikztimingtrans}{1}}%
 }%
@@ -5927,7 +6010,7 @@
      ++($ -1*(#1,-\height) $)%
   -- ++($  1*(#1,0) $)%
      ++(0,-.5\height)%
-  \newdraw
+  \newdraw [\nstyle]
   \code{\setcounter{tikztimingtranspos}{1}}%
   \code{\setcounter{tikztimingtrans}{-1}}%
 }%
@@ -5944,7 +6027,7 @@
      ++($ -1*(#1,-\height * \value{tikztimingtrans}) $)%
   -- ++($  1*(#1,0) $)%
      ++(0,-1*\value{tikztimingtrans}*.5*\height)%
-  \newdraw
+  \newdraw [\nstyle]
 }%
 
 \tikztimingdef{LEL}{%
@@ -5955,7 +6038,7 @@
   -- +(0,0)
     ++(#1,\height/2) coordinate (timing at ref)
     ++(\slope,-\height/2)%
-  \newdraw
+  \newdraw [\nstyle]
 }%
 
 \tikztimingdef{LEH}{%
@@ -5966,7 +6049,7 @@
   -- +(0,0)
     ++(#1,\height/2) coordinate (timing at ref)
     ++(\slope,\height/2)%
-  \newdraw
+  \newdraw [\nstyle]
 }%
 
 \tikztimingdef{HEH}{%
@@ -5977,7 +6060,7 @@
   -- +(0,0)
     ++(#1,-\height/2) coordinate (timing at ref)
     ++(\slope,\height/2)%
-  \newdraw
+  \newdraw [\nstyle]
 }%
 
 \tikztimingdef{HEL}{%
@@ -5988,7 +6071,7 @@
   -- +(0,0)
     ++(#1,-\height/2) coordinate (timing at ref)
     ++(\slope,-\height/2)%
-  \newdraw
+  \newdraw [\nstyle]
 }%
 
 \tikztimingdef{HET}{
@@ -6003,7 +6086,7 @@
     ++(#1,-\height/2) coordinate (timing at ref)
     ++(\slope,-\height/2)%
   }
-  \newdraw
+  \newdraw [\nstyle]
   \code{\setcounter{tikztimingtrans}{-1}}%
 }
 
@@ -6020,13 +6103,13 @@
       coordinate (timing at ref)
     ++(\slope,\height/2)%
   }
-  \newdraw
+  \newdraw [\nstyle]
   \code{\setcounter{tikztimingtrans}{1}}%
 }
 
 \tikztimingdef{HEE}{%
   \newdraw [\style,preaction={\bgstyle}]
-  -- +(#1,0) coordinate (timing at refb) 
+  -- +(#1,0) coordinate (timing at refb)
       \tikztiming at setref{timing at ref}{0,-\height/2}
   -- +($ (#1,-\height) + (\slope,0) $) coordinate (timing at refa)
   -- +(\slope,-\height)
@@ -6035,7 +6118,7 @@
     ++($ (#1,-\height) + (\slope,0) $)%
   \code{\setcounter{tikztimingtranspos}{1}}%
   \code{\setcounter{tikztimingtrans}{-1}}%
-  \newdraw
+  \newdraw [\nstyle]
 }%
 
 \tikztimingdef{LEE}{%
@@ -6048,7 +6131,7 @@
     ++(#1,0) \tikztiming at setref{timing at ref}{0,\height/2}
   \code{\setcounter{tikztimingtranspos}{0}}%
   \code{\setcounter{tikztimingtrans}{1}}%
-  \newdraw
+  \newdraw [\nstyle]
 }%
 
 \tikztimingdef{TEE}{%
@@ -6063,7 +6146,7 @@
         coordinate (timing at refa)
       +($ (#1,0) + (\slope/2 - \slope/2 * \value{tikztimingtrans}, \height - \height/2 * \value{tikztimingtranspos}) $)
         coordinate (timing at refb)
-     ++(#1,0) 
+     ++(#1,0)
       \tikztiming at setref{timing at ref}{0,-\height/2 * \value{tikztimingtrans}}
      ++(
           .5 * \slope  + .5 * \value{tikztimingtrans} * \slope,
@@ -6070,7 +6153,7 @@
          -.5 * \height - .5 * \value{tikztimingtrans} * \height
        )
   \code{\setcounter{tikztimingtrans}{-\value{tikztimingtrans}}}
-  \newdraw
+  \newdraw [\nstyle]
 }%
 
 
@@ -6083,7 +6166,7 @@
   -- ++($ -1*(#1,0) - (\slope/2 + \slope/2 * \value{tikztimingtrans},0) $)
      ++($ (#1,-\height/2 * \value{tikztimingtrans}) $) coordinate (timing at ref)
      ++(\slope,\height/2)
-  \newdraw
+  \newdraw [\nstyle]
 }
 
 \tikztimingdef{TEL}{%
@@ -6095,7 +6178,7 @@
   -- ++($ -1*(#1,0) - (\slope/2 + -\slope/2 * \value{tikztimingtrans},0) $)
      ++($ (#1,-\height/2 * \value{tikztimingtrans}) $) coordinate (timing at ref)
      ++(\slope,-\height/2)
-  \newdraw
+  \newdraw [\nstyle]
 }
 
 \tikztimingdef{TEZ}{%
@@ -6110,7 +6193,7 @@
      ++($ (#1,0) + (0,-\height/2 * \value{tikztimingtrans}) $)
        coordinate (timing at ref)
      ++(\zslope,0)
-  \newdraw
+  \newdraw [\nstyle]
 }
 
 \tikztimingdef{TED}{%
@@ -6125,7 +6208,7 @@
      ++($ (#1,0) + (0,-\height/2 * \value{tikztimingtrans}) $)
        coordinate (timing at ref)
      ++(\dslope/2,0)
-  \newdraw
+  \newdraw [\nstyle]
 }
 
 \tikztimingdef{TET}{%
@@ -6142,7 +6225,7 @@
      ++(\slope, -\height/2 * \value{tikztimingtrans})%
    }
   \code{\setcounter{tikztimingtrans}{-\value{tikztimingtrans}}}
-  \newdraw
+  \newdraw [\nstyle]
 }%
 
 \tikztimingdef{EEZ}{%
@@ -6289,7 +6372,7 @@
       ++(#1,0) coordinate (timing at refa)
         coordinate (timing at refb) at ($ (timing at refb) + (#1,0) $)
         coordinate (timing at ref)  at ($ (timing at ref)  + (#1,0) $)
-  \newdraw
+  \newdraw [\nstyle]
 }%
 
 \tikztimingdef{EET}{%
@@ -6304,7 +6387,7 @@
       ($ (timing at ref)  + (#1,\height/2 * \value{tikztimingtrans}) + (\slope,0) $)
    }
       coordinate (timing at ref) at ($ (timing at ref) + (#1,0) $)
-  \newdraw
+  \newdraw [\nstyle]
 }%
 
 \tikztimingdef{EEL}{%
@@ -6315,7 +6398,7 @@
    --   (timing at refa)
         ($ (timing at ref)  + (#1,-\height/2) + (\slope,0) $)
       coordinate (timing at ref) at ($ (timing at ref) + (#1,0) $)
-  \newdraw
+  \newdraw [\nstyle]
 }%
 
 \tikztimingdef{EEH}{%
@@ -6326,7 +6409,7 @@
    --   (timing at refa)
         ($ (timing at ref)  + (#1,+\height/2) + (\slope,0) $)
       coordinate (timing at ref) at ($ (timing at ref) + (#1,0) $)
-  \newdraw
+  \newdraw [\nstyle]
 }%
 
 
@@ -6344,7 +6427,7 @@
      +(0,\y1-\y2)
   --  (\p1)
       ($ (timing at ref) + (#1,0) $) coordinate (timing at ref)
-  \newdraw
+  \newdraw [\nstyle]
 }%
 
 \tikztimingdef{ZE@}{
@@ -6372,7 +6455,7 @@
   -- +(0,0)
     ++(#1,0) coordinate (timing at ref)
     ++(\slope, \height/2)
-  \newdraw
+  \newdraw [\nstyle]
 }
 
 \tikztimingdef{ZEL}{%
@@ -6384,7 +6467,7 @@
   -- +(0,0)
     ++(#1,0) coordinate (timing at ref)
     ++(\slope, -\height/2)
-  \newdraw
+  \newdraw [\nstyle]
 }
 
 \tikztimingdef{ZET}{%
@@ -6401,7 +6484,7 @@
      ++(\slope,-\height/2 * \value{tikztimingtrans})
   }
   \code{\setcounter{tikztimingtrans}{-\value{tikztimingtrans}}}
-  \newdraw
+  \newdraw [\nstyle]
 }
 
 \tikztimingdef{DET}{%
@@ -6419,7 +6502,7 @@
      ++(\slope,-\height/2 * \value{tikztimingtrans})
   }
   \code{\setcounter{tikztimingtrans}{-\value{tikztimingtrans}}}
-  \newdraw
+  \newdraw [\nstyle]
 }
 
 \tikztimingdef{ZEZ}{%
@@ -6432,7 +6515,7 @@
   -- +(0,0)
     ++(#1,0) coordinate (timing at ref)
     ++(\zslope, 0)
-  \newdraw
+  \newdraw [\nstyle]
 }
 
 \tikztimingdef{ZEE}{%
@@ -6475,7 +6558,7 @@
       ($ (timing at ref) + (#1,0) $)
       coordinate (timing at ref)
     ++(\dslope/2,0)
-  \newdraw
+  \newdraw [\nstyle]
 }
 
 \tikztimingdef{ZED}{%
@@ -6488,7 +6571,7 @@
   -- +(0,0)
     ++(#1,0) coordinate (timing at ref)
     ++(\dslope/2, 0)
-  \newdraw
+  \newdraw [\nstyle]
 }
 
 \tikztimingdef{DEZ}{%
@@ -6503,7 +6586,7 @@
       ($ (timing at ref) + (#1,0) $)
       coordinate (timing at ref)
     ++(\zslope, 0)
-  \newdraw
+  \newdraw [\nstyle]
 }
 
 
@@ -6511,13 +6594,13 @@
   \tikztiming at oldnodecenter@%
   \newdraw [\style,preaction={\bgstyle}]
   -- +(\dslope/2, \height/2)
-  --  ($ (timing at ref) + (#1,0) + (\slope, \height/2) $) 
+  --  ($ (timing at ref) + (#1,0) + (\slope, \height/2) $)
   --  ($ (timing at ref) + (#1,-\height/2) $)
   --  ($ (timing at save) + (\dslope/2, -\height/2) $)
   --  (timing at save)
       ($ (timing at ref) + (#1,0) $) coordinate (timing at ref)
     ++(\slope, \height/2)
-  \newdraw
+  \newdraw [\nstyle]
 }
 
 \tikztimingdef{DEL}{%
@@ -6525,12 +6608,12 @@
   \newdraw [\style,preaction={\bgstyle}]
   -- +(\dslope/2, \height/2)
   --  ($ (timing at ref) + (#1,\height/2) $)
-  --  ($ (timing at ref) + (#1,0) + (\slope, -\height/2) $) 
+  --  ($ (timing at ref) + (#1,0) + (\slope, -\height/2) $)
   --  ($ (timing at save) + (\dslope/2, -\height/2) $)
   --  (timing at save)
       ($ (timing at ref) + (#1,0) $) coordinate (timing at ref)
     ++(\slope, -\height/2)
-  \newdraw
+  \newdraw [\nstyle]
 }
 
 
@@ -6544,6 +6627,10 @@
   \tikztiming@@chard{#1}%
 }
 \tikztimingdef{DDE}{
+    ++(0,-\height/2)
+  \tikztiming at oldnodecenter{%
+    (0,+\height/2)
+  }%
   \tikztiming@@chard{#1}%
 }
 
@@ -6561,7 +6648,7 @@
    -- +(0,0)
      ++(#1,\height/2) coordinate (timing at ref)
      ++(\slope,\height/2)
-  \newdraw
+  \newdraw [\nstyle]
 }
 
 \tikztimingdef{@ET}{%
@@ -6584,7 +6671,7 @@
       ($ (timing at ref) + (#1,0) $) coordinate (timing at ref)
     ++(\slope,\height/2)
   }
-  \newdraw
+  \newdraw [\nstyle]
   \code{\setcounter{tikztimingtrans}{-\value{tikztimingtrans}}}
 }
 
@@ -6608,7 +6695,7 @@
    -- +(0,0)
      ++(#1,\height/2) coordinate (timing at ref)
      ++(\slope,-\height/2)
-  \newdraw
+  \newdraw [\nstyle]
 }
 
 \tikztimingdef{@ED}{%
@@ -6669,25 +6756,44 @@
 \def\tikztiming at nocombine@E{}%%
 %    \end{macrocode}
 %
-%  \iffalse
-%</lib-either>
+% \iffalse
+%</tikz-timing-either.sty>
 % \fi
 %
-% \subsection{Clock Arrows}
+% \subsubsection{Clock Arrows}
 % \iffalse
-%<*lib-clockarrows>
-%  \fi
+%<*tikz-timing-clockarrows.sty>
+% \fi
 %    \begin{macrocode}
+%<!COPYRIGHT>
+\NeedsTeXFormat{LaTeX2e}[1999/12/01]
+\ProvidesPackage{tikz-timing-clockarrows}[%
+%<!DATE>
+%<!VERSION>
+%<*DRIVER>
+    2099/01/01 develop
+%</DRIVER>
+    tikz-timing library for timing clock arrows]
+%    \end{macrocode}
+%
+%    \begin{macrocode}
 \tikztiming at iftrans{CC}%
   {\let\tikztiming at trans@C at normal@C\tikztiming at trans@CC}%
-  {\PackageError{\@currname}{No 'CC' transition defined by the main tikz-timing 
+  {\PackageError{\@currname}{No 'CC' transition defined by the main tikz-timing
   package.}{}}%
+\tikztiming at iftrans{HC}%
+  {\let\tikztiming at trans@H at normal@C\tikztiming at trans@HC}%
+  {\PackageError{\@currname}{No 'HC' transition defined by the main tikz-timing
+  package.}{}}%
+\tikztiming at iftrans{LC}%
+  {\let\tikztiming at trans@L at normal@C\tikztiming at trans@LC}%
+  {\PackageError{\@currname}{No 'LC' transition defined by the main tikz-timing
+  package.}{}}%
 
 \tikztimingdef{CC}{%
   \code{\setcounter{tikztimingtrans}{-\value{tikztimingtrans}}}
   [timing/c/save]
-  \newdraw 
-  [\style,timing/c/restore,>=\noexpand\tikztiming at c@arrow at tip,timing/c/arrow at style]
+  \newdraw [\style,timing/c/restore,>=\noexpand\tikztiming at c@arrow at tip,timing/c/arrow at style]
   -- ++(\slope*\noexpand\tikztiming at c@arrow at pos,\value{tikztimingtrans}*\height*\noexpand\tikztiming at c@arrow at pos)
   ; \draw [timing/restore,timing/c/restore] (timing at save) ++(0,0) [\style]
   -- ++(\slope,\value{tikztimingtrans}*\height)
@@ -6695,21 +6801,52 @@
 }
 \let\tikztiming at trans@C at arrow@C\tikztiming at trans@CC
 
+\tikztimingdef{HC}{%
+  \code{\setcounter{tikztimingtrans}{-1}}
+  [timing/c/save]
+  \newdraw [\style,timing/c/restore,>=\noexpand\tikztiming at c@arrow at tip,timing/c/arrow at style]
+  -- ++(\slope*\noexpand\tikztiming at c@arrow at pos,\value{tikztimingtrans}*\height*\noexpand\tikztiming at c@arrow at pos)
+  ; \draw [timing/restore,timing/c/restore] (timing at save) ++(0,0) [\style]
+  -- ++(\slope,\value{tikztimingtrans}*\height)
+  -- ++($ (#1,0) - (\slope,0) $)
+}
+\let\tikztiming at trans@H at arrow@C\tikztiming at trans@HC
+
+\tikztimingdef{LC}{%
+  \code{\setcounter{tikztimingtrans}{+1}}
+  [timing/c/save]
+  \newdraw [\style,timing/c/restore,>=\noexpand\tikztiming at c@arrow at tip,timing/c/arrow at style]
+  -- ++(\slope*\noexpand\tikztiming at c@arrow at pos,\value{tikztimingtrans}*\height*\noexpand\tikztiming at c@arrow at pos)
+  ; \draw [timing/restore,timing/c/restore] (timing at save) ++(0,0) [\style]
+  -- ++(\slope,\value{tikztimingtrans}*\height)
+  -- ++($ (#1,0) - (\slope,0) $)
+}
+\let\tikztiming at trans@L at arrow@C\tikztiming at trans@LC
+
+
 \tikzset{timing/c/.cd,
   rising arrows/.code={%
-    \def\tikztiming at trans@CC{\tikztiming at trans@C at arrow@C}%
+    \let\tikztiming at trans@CC\tikztiming at trans@C at arrow@C%
+    \let\tikztiming at trans@LC\tikztiming at trans@L at arrow@C%
+    \let\tikztiming at trans@HC\tikztiming at trans@H at arrow@C%
     \def\tikztiming at clockarrow@style{\ifnum1=\c at tikztimingtrans\tikzset{->,timing/c/arrow}\fi}%
   },%
   falling arrows/.code={%
-    \def\tikztiming at trans@CC{\tikztiming at trans@C at arrow@C}%
+    \let\tikztiming at trans@CC\tikztiming at trans@C at arrow@C%
+    \let\tikztiming at trans@LC\tikztiming at trans@L at arrow@C%
+    \let\tikztiming at trans@HC\tikztiming at trans@H at arrow@C%
     \def\tikztiming at clockarrow@style{\ifnum-1=\c at tikztimingtrans\tikzset{->,timing/c/arrow}\fi}%
   },%
   dual arrows/.code={%
-    \def\tikztiming at trans@CC{\tikztiming at trans@C at arrow@C}%
+    \let\tikztiming at trans@CC\tikztiming at trans@C at arrow@C%
+    \let\tikztiming at trans@LC\tikztiming at trans@L at arrow@C%
+    \let\tikztiming at trans@HC\tikztiming at trans@H at arrow@C%
     \def\tikztiming at clockarrow@style{\tikzset{->,timing/c/arrow}}%
   },%
   no arrows/.code={%
-    \def\tikztiming at trans@CC{\tikztiming at trans@C at normal@C}%
+    \let\tikztiming at trans@CC\tikztiming at trans@C at normal@C%
+    \let\tikztiming at trans@LC\tikztiming at trans@L at normal@C%
+    \let\tikztiming at trans@HC\tikztiming at trans@H at normal@C%
     \def\tikztiming at clockarrow@style{}%
   },%
   arrow at style/.code={\tikztiming at clockarrow@style},%
@@ -6742,16 +6879,28 @@
 \ProcessPgfOptions{/tikz/timing/c}
 %    \end{macrocode}
 % \iffalse
-%</lib-clockarrows>
+%</tikz-timing-clockarrows.sty>
 % \fi
 %
-% \subsection{Arrows}
+% \subsubsection{Arrows}
 % \iffalse
-%<*lib-arrows>
+%<*tikz-timing-arrows.sty>
 % \fi
+%    \begin{macrocode}
+%<!COPYRIGHT>
+\NeedsTeXFormat{LaTeX2e}[1999/12/01]
+\ProvidesPackage{tikz-timing-arrows}[%
+%<!DATE>
+%<!VERSION>
+%<*DRIVER>
+    2099/01/01 develop
+%</DRIVER>
+    tikz-timing library for timing arrows]
+%    \end{macrocode}
+%
 % This library is only defining the "A" and "W" basic transitions ("AA", "AW", "WA", "WW").
 % While "W" is simply a copy of "A" with a different style. Both simple draw a line from |low|
-% to |high| and than move the position to the right according to the |width| value and back to 
+% to |high| and than move the position to the right according to the |width| value and back to
 % the |low| position. The different arrow directions are done by different styles.
 %    \begin{macrocode}
 \tikzset{timing/.cd,
@@ -6763,7 +6912,7 @@
 
 \tikztimingchar{A}{++(0,0)}{%
   \newdraw [\style] -- ++(0,\height)
-  \newdraw ++(#1,-\height)
+  \newdraw [timing/every char] ++(#1,-\height)
 }
 \def\tikztiming at nocombine@A{}%
 
@@ -6771,20 +6920,32 @@
 %    \end{macrocode}
 %
 % \iffalse
-%</lib-arrows>
+%</tikz-timing-arrows.sty>
 % \fi
 %
-% \subsection{Overlays}
+% \subsubsection{Overlays}
 % \iffalse
-%<*lib-overlays>
+%<*tikz-timing-overlays.sty>
 % \fi
+%    \begin{macrocode}
+%<!COPYRIGHT>
+\NeedsTeXFormat{LaTeX2e}[1999/12/01]
+\ProvidesPackage{tikz-timing-overlays}[%
+%<!DATE>
+%<!VERSION>
+%<*DRIVER>
+    2099/01/01 develop
+%</DRIVER>
+    tikz-timing library for timing overlays]
+%    \end{macrocode}
+%
 % \begin{macro}{\tikztiming at defcode{O}}
-% The last character before the "O" is saved and restored. Also the drawing 
-% state is saved and restored by the \cs{tikztiming at overlay@begin} and 
-% \cs{tikztiming at overlay@end} macros. The parser end macro 
-% \cs{tikztiming at parser@end} which is triggered at the end of the overlay string 
-% is redefined to avoid problems. The double \TeX\ group is necessary because 
-% the overlay string can close and reopen the inner \TeX\ 
+% The last character before the "O" is saved and restored. Also the drawing
+% state is saved and restored by the \cs{tikztiming at overlay@begin} and
+% \cs{tikztiming at overlay@end} macros. The parser end macro
+% \cs{tikztiming at parser@end} which is triggered at the end of the overlay string
+% is redefined to avoid problems. The double \TeX\ group is necessary because
+% the overlay string can close and reopen the inner \TeX\
 % group.
 %    \begin{macrocode}
 \tikztiming at defcode{O}#1{%
@@ -6821,10 +6982,10 @@
 %
 % \begin{macro}{\tikztiming at overlay@begin}
 % The drawing transition state (for "T", etc.) is saved and restored.
-% In order to be able to include an "O" inside the argument of another one the 
-% overlay save node coordinates (\cs{pfg at sh@nt at tikztiming@overlay at node}) is also 
-% saved and restored. The \cs{tikztiming at overlay@save} macro also includes an 
-% self-assignment to its old version, which implements a stack. The macros must 
+% In order to be able to include an "O" inside the argument of another one the
+% overlay save node coordinates (\cs{pfg at sh@nt at tikztiming@overlay at node}) is also
+% saved and restored. The \cs{tikztiming at overlay@save} macro also includes an
+% self-assignment to its old version, which implements a stack. The macros must
 % be global because the overlay string can reopen a new TikZ path.
 %    \begin{macrocode}
 \def\tikztiming at overlay@begin{
@@ -6862,13 +7023,25 @@
 %
 %
 % \iffalse
-%</lib-overlays>
+%</tikz-timing-overlays.sty>
 % \fi
 %
-% \subsection{Column Type}
+% \subsubsection{Column Type}
 % \iffalse
-%<*lib-columntype>
+%<*tikz-timing-columntype.sty>
 % \fi
+%    \begin{macrocode}
+%<!COPYRIGHT>
+\NeedsTeXFormat{LaTeX2e}[1999/12/01]
+\ProvidesPackage{tikz-timing-columntype}[%
+%<!DATE>
+%<!VERSION>
+%<*DRIVER>
+    2099/01/01 develop
+%</DRIVER>
+    tikz-timing library for timing cell types]
+%    \end{macrocode}
+%
 % The \pkg{array} package is needed to define the column type.
 %    \begin{macrocode}
 \RequirePackage{array}
@@ -6877,7 +7050,7 @@
   \newcolumntype{#1}{>{\celltiming}#2<{\endcelltiming}}%
 }%
 %    \end{macrocode}
-% 
+%
 % The options |type| (calls |timing/columntype|) and |notype| are defined.
 %    \begin{macrocode}
 \RequirePackage{pgfopts}
@@ -6889,7 +7062,7 @@
 
 \ProcessPgfOptions{/tikz/timing/columntype}
 %    \end{macrocode}
-% Use default settings if no options where given. This works because all options 
+% Use default settings if no options where given. This works because all options
 % so far will change the default type.
 %    \begin{macrocode}
 \expandafter\ifx\csname opt@\@currname.\@currext\endcsname\empty
@@ -6898,11 +7071,11 @@
 %    \end{macrocode}
 %
 % \begin{macro}{\celltiming}[1]{Some ignored tokens}
-% The macro first reads everything to the |\ignorespaces| placed by the 
-% |tabular|. After placing the tokens except |\ignorespaces| back a 
-% |tikzpicture| is started. The \cs{tikztiming at endhook} is defined to call 
+% The macro first reads everything to the |\ignorespaces| placed by the
+% |tabular|. After placing the tokens except |\ignorespaces| back a
+% |tikzpicture| is started. The \cs{tikztiming at endhook} is defined to call
 % \cs{end at celltiming}.
-% After the usual init process the input is tested for an optional argument and 
+% After the usual init process the input is tested for an optional argument and
 % \cs{tikztiming at celltiming} is called accordantly.
 %    \begin{macrocode}
 \def\celltiming#1\ignorespaces{%
@@ -6919,18 +7092,18 @@
 %    \end{macrocode}
 % \end{macro}
 %
-% \begin{macro}{\tikztiming at celltiming}[1]{Optional Initial Character or 
+% \begin{macro}{\tikztiming at celltiming}[1]{Optional Initial Character or
 % Settings}
-% First the optional argument is tested to see if it is a single initial 
-% character or some settings. The \cs{tikztiming at testoptarg} macro sets the 
+% First the optional argument is tested to see if it is a single initial
+% character or some settings. The \cs{tikztiming at testoptarg} macro sets the
 % \cs{lastchar} and \cs{settings} macros to the appropriate values.
 %
 % If the \cs{lastchar} is empty it is set to the normal start value.
 %
-% Then a \pkg{pgf} scope with the potential user settings is started. The macros  
-% |\unskip| and |\\| which are used internally by the |tabular| environment are 
-% |\let| to |\relax| to work as end marker for the \cs{tikztiming at parser}.  This 
-% will not influence the table because they will revert to their original 
+% Then a \pkg{pgf} scope with the potential user settings is started. The macros
+% |\unskip| and |\\| which are used internally by the |tabular| environment are
+% |\let| to |\relax| to work as end marker for the \cs{tikztiming at parser}.  This
+% will not influence the table because they will revert to their original
 % definition at the end of the |tikzpicture| environment.
 %
 % Finally the \cs{tikztiming at parser} is called.
@@ -6952,15 +7125,15 @@
 % \end{macro}
 %
 % \begin{macro}{\end at celltiming}
-% This macro is called from the \cs{tikztiming at endhook} which is located in 
-% \cs{tikztiming at parser@end} when the end marker (|\relax| or alias) is 
-% encountered. It executes the accumulated \cs{tikztiming at str} and places the 
+% This macro is called from the \cs{tikztiming at endhook} which is located in
+% \cs{tikztiming at parser@end} when the end marker (|\relax| or alias) is
+% encountered. It executes the accumulated \cs{tikztiming at str} and places the
 % timing shape. Finally the |scope| and |tikzpicture| is closed.
 %    \begin{macrocode}
 \def\end at celltiming{%
     \tikzset{timing/before}%
     \tikztiming at str;
-    \expandafter\node 
+    \expandafter\node
     \expandafter[\tikztiming at settings,shape=tikztiming at shape,anchor=origin] at (0,0) {};
     \tikzset{timing/after}%
   \endscope
@@ -6970,13 +7143,25 @@
 % \end{macro}
 %
 % \iffalse
-%</lib-columntype>
+%</tikz-timing-columntype.sty>
 % \fi
 %
-% \subsection{Nice Timing Tables}
+% \subsubsection{Nice Timing Tables}
 % \iffalse
-%<*lib-nicetabs>
+%<*tikz-timing-nicetabs.sty>
 % \fi
+%    \begin{macrocode}
+%<!COPYRIGHT>
+\NeedsTeXFormat{LaTeX2e}[1999/12/01]
+\ProvidesPackage{tikz-timing-nicetabs}[%
+%<!DATE>
+%<!VERSION>
+%<*DRIVER>
+    2099/01/01 develop
+%</DRIVER>
+    tikz-timing library for nice timing tables]
+%    \end{macrocode}
+%
 % The dimensions of the following packages are used.
 %    \begin{macrocode}
 \RequirePackage{array}
@@ -6991,8 +7176,8 @@
 \newcommand*\tikztiming at nicetabs@tableheader[1][]{%
   \path [timing/table/midrules] [/utils/exec=\xdef\@gtempa{\the\pgflinewidth}];
   \path [timing/table/header,#1]
-    let \p1 = (0,\belowrulesep + \aboverulesep + \@gtempa 
-            + \arraystretch\ht\strutbox + \arraystretch*\extrarowheight 
+    let \p1 = (0,\belowrulesep + \aboverulesep + \@gtempa
+            + \arraystretch\ht\strutbox + \arraystretch*\extrarowheight
             + \arraystretch\dp\strutbox)
     in
       coordinate (diagram at header) at (0,\y1)
@@ -7087,14 +7272,26 @@
 \ProcessPgfOptions{/tikz/timing/nicetabs}
 %    \end{macrocode}
 % \iffalse
-%</lib-nicetabs>
+%</tikz-timing-nicetabs.sty>
 % \fi
 %
-% \subsection{Counters}
+% \subsubsection{Counters}
 % \iffalse
-%<*lib-counters>
+%<*tikz-timing-counters.sty>
 % \fi
+%    \begin{macrocode}
+%<!COPYRIGHT>
+\NeedsTeXFormat{LaTeX2e}[1999/12/01]
+\ProvidesPackage{tikz-timing-counters}[%
+%<!DATE>
+%<!VERSION>
+%<*DRIVER>
+    2099/01/01 develop
+%</DRIVER>
+    tikz-timing library for counter values]
+%    \end{macrocode}
 %
+%
 %    \begin{macrocode}
 \newif\if at tikztiming@counter at wraps
 
@@ -7170,7 +7367,7 @@
   \pgfqkeys{/tikz/timing/counter/opt}{#1}%
   \tikzset{timing/counter/opt/char/.get=\counterchar}%
   \ifx\counterchar\empty
-    \PackageError{tikz-timing-counters}{Counter character must be given using 
+    \PackageError{tikz-timing-counters}{Counter character must be given using
     the 'char' key!}{}%
     \endgroup
   \else
@@ -7230,7 +7427,7 @@
     \pgfkeys{/tikz/timing/counter/opt/text style/.get=\textstyle}%
     \pgfkeys{/tikz/timing/counter/opt/text format/.get=\textformat}%
 %    \end{macrocode}
-% Finally the \cs{tikztiming at counter@new@} macro is called with most of the 
+% Finally the \cs{tikztiming at counter@new@} macro is called with most of the
 % settings as expanded arguments.
 %    \begin{macrocode}
     \pgfkeys{/tikz/timing/counter/opt/increment/.get=\increment}%
@@ -7257,7 +7454,7 @@
 %    \end{macrocode}
 % \end{macro}
 %
-% \begin{macro}{\tikztiming at counter@new@}[9]{Character}{Base}{Half Width 
+% \begin{macro}{\tikztiming at counter@new@}[9]{Character}{Base}{Half Width
 % Character}{Reset Character}{Number of Digits}{Increment}{Boundary Code}{Min Value}{Reset Type}
 %    \begin{macrocode}
 \def\tikztiming at counter@new@#1#2#3#4#5#6#7#8#9{%
@@ -7323,7 +7520,7 @@
 % \end{macro}
 %
 % \begin{macro}{\tikztiming at counter@reset}[2]{Character to Reset}{Reset value}
-% The counter is set first using pgf to round the value correctly and then again 
+% The counter is set first using pgf to round the value correctly and then again
 % with \cs{setcounter} to make it global.
 %    \begin{macrocode}
 \def\tikztiming at counter@reset#1#2{%
@@ -7412,14 +7609,26 @@
 \ProcessPgfOptions{/tikz/timing/counter}
 %    \end{macrocode}
 % \iffalse
-%</lib-counters>
+%</tikz-timing-counters.sty>
 % \fi
 %
-% \subsection{Advanced Nodes}
+% \subsubsection{Advanced Nodes}
 % \iffalse
-%<*lib-advnodes>
+%<*tikz-timing-advnodes.sty>
 % \fi
 %    \begin{macrocode}
+%<!COPYRIGHT>
+\NeedsTeXFormat{LaTeX2e}[1999/12/01]
+\ProvidesPackage{tikz-timing-advnodes}[%
+%<!DATE>
+%<!VERSION>
+%<*DRIVER>
+    2099/01/01 develop
+%</DRIVER>
+    tikz-timing library for advanced nodes]
+%    \end{macrocode}
+%
+%    \begin{macrocode}
 
 \let\tikztiming at orig@oldnodecenter\tikztiming at oldnodecenter
 
@@ -7448,8 +7657,8 @@
 
 \def\anchoralias#1#2{%
   \expandafter\def
-  \csname pgf at anchor@\shape at name @#1\expandafter\endcsname
-  \expandafter{\csname pgf at anchor@\shape at name @#2\endcsname}%
+  \csname pgf at anchor@\pgf at sm@shape at name @#1\expandafter\endcsname
+  \expandafter{\csname pgf at anchor@\pgf at sm@shape at name @#2\endcsname}%
 }
 
 \def\tikztiming at anchorpoint#1#2#3{%
@@ -7581,7 +7790,7 @@
   \anchor{low2}{\tikztiming at useanchor{low2}}%
   \anchor{high2}{\tikztiming at useanchor{high2}}%
   %
-  \expandafter\anchorborder\expandafter{\csname pgf at anchor@\shape at name @center\endcsname}%
+  \expandafter\anchorborder\expandafter{\csname pgf at anchor@\pgf at sm@shape at name @center\endcsname}%
   %
   \nodeparts{}%
 }
@@ -8018,15 +8227,26 @@
 \ProcessPgfOptions{/tikz/timing/node}
 %    \end{macrocode}
 % \iffalse
-%</lib-advnodes>
+%</tikz-timing-advnodes.sty>
 % \fi
 %
-% \subsection{Intervals}
+% \subsubsection{Intervals}
 % \iffalse
-%<*lib-interval>
+%<*tikz-timing-interval.sty>
 % \fi
 %    \begin{macrocode}
-
+%<!COPYRIGHT>
+\NeedsTeXFormat{LaTeX2e}[1999/12/01]
+\ProvidesPackage{tikz-timing-interval}[%
+%<!DATE>
+%<!VERSION>
+%<*DRIVER>
+    2099/01/01 develop
+%</DRIVER>
+    tikz-timing library for alternative Z transitions]
+%    \end{macrocode}
+%
+%    \begin{macrocode}
 \let\tikztiming at linterval\relax
 \let\tikztiming at rinterval\relax
 
@@ -8099,13 +8319,25 @@
 
 %    \end{macrocode}
 % \iffalse
-%</lib-interval>
+%</tikz-timing-interval.sty>
 % \fi
 %
-% \subsection{Beamer Overlay Support}
+% \subsubsection{Beamer Overlay Support}
 % \iffalse
-%<*lib-beamer>
+%<*tikz-timing-beamer.sty>
 % \fi
+%    \begin{macrocode}
+%<!COPYRIGHT>
+\NeedsTeXFormat{LaTeX2e}[1999/12/01]
+\ProvidesPackage{tikz-timing-beamer}[%
+%<!DATE>
+%<!VERSION>
+%<*DRIVER>
+    2099/01/01 develop
+%</DRIVER>
+    tikz-timing library for beamer overlay support]
+%    \end{macrocode}
+%
 % Experimental library for marginal beamer overlay support. It will change in future versions. Use at own risk!
 %    \begin{macrocode}
 
@@ -8121,14 +8353,26 @@
 }
 %    \end{macrocode}
 % \iffalse
-%</lib-beamer>
+%</tikz-timing-beamer.sty>
 % \fi
 %
-% \subsection{Compatibility with \protect\pkg{ifsym} Macros}
+% \subsubsection{Compatibility with \protect\pkg{ifsym} Macros}
 % \iffalse
-%<*lib-ifsym>
+%<*tikz-timing-ifsym.sty>
 % \fi
+%    \begin{macrocode}
+%<!COPYRIGHT>
+\NeedsTeXFormat{LaTeX2e}[1999/12/01]
+\ProvidesPackage{tikz-timing-ifsym}[%
+%<!DATE>
+%<!VERSION>
+%<*DRIVER>
+    2099/01/01 develop
+%</DRIVER>
+    tikz-timing library for ifsym compatible macros]
+%    \end{macrocode}
 %
+%
 % Set up styles to match behaviour of \pkg{ifsym}. Slope and size is is adjusted.
 % The macros only have 60\% of the height.
 %    \begin{macrocode}
@@ -8142,7 +8386,7 @@
 %    \begin{macrocode}
     timing/metachar={|}{G},
 %    \end{macrocode}
-% The "X" is used for "M" and is set to black. 
+% The "X" is used for "M" and is set to black.
 %    \begin{macrocode}
     timing/x/.style={},
 %    \end{macrocode}
@@ -8231,11 +8475,9 @@
 \let\tikztiming at ifsym@def\@undefined
 %    \end{macrocode}
 % \iffalse
-%</lib-ifsym>
+%</tikz-timing-ifsym.sty>
 % \fi
 %
+%
 % \Finale
-\endinput
-% \iffalse
-% vim: foldmarker=%<*,%</ foldmethod=marker foldenable foldtext=foldtext()
-% \fi
+% \endinput

Modified: trunk/Master/texmf-dist/source/latex/tikz-timing/tikz-timing.ins
===================================================================
--- trunk/Master/texmf-dist/source/latex/tikz-timing/tikz-timing.ins	2017-12-11 01:54:21 UTC (rev 46034)
+++ trunk/Master/texmf-dist/source/latex/tikz-timing/tikz-timing.ins	2017-12-11 22:21:38 UTC (rev 46035)
@@ -1,43 +1,21 @@
-% $Id: tikz-timing.ins 2026 2011-01-08 12:14:28Z martin $
-\input docstrip.tex
-\preamble
-
-Copyright (C) 2009-2011 by Martin Scharrer <martin at scharrer-online.de>
-
-This work may be distributed and/or modified under the
-conditions of the LaTeX Project Public License, either version 1.3c
-of this license or (at your option) any later version.
-The latest version of this license is in
-
-   http://www.latex-project.org/lppl.txt
-
-and version 1.3c or later is part of all distributions of LaTeX
-version 2008/05/04 or later.
-
-This work has the LPPL maintenance status `maintained'.
-
-The Current Maintainer of this work is Martin Scharrer.
-
-This work consists of the files tikz-timing.dtx, tikz-timing.ins
-and the derived file tikz-timing.sty.
-
-\endpreamble
+\input ydocstrip.tex
 \keepsilent
+\askforoverwritefalse
 
 \generate{%
-  \file{tikz-timing.sty}{\from{tikz-timing.dtx}{package}}%
-  \file{tikz-timing-arrows.sty}{\from{tikz-timing.dtx}{lib,lib-arrows}}%
-  \file{tikz-timing-either.sty}{\from{tikz-timing.dtx}{lib,lib-either}}%
-  \file{tikz-timing-overlays.sty}{\from{tikz-timing.dtx}{lib,lib-overlays}}%
-  \file{tikz-timing-clockarrows.sty}{\from{tikz-timing.dtx}{lib,lib-clockarrows}}%
-  \file{tikz-timing-columntype.sty}{\from{tikz-timing.dtx}{lib,lib-columntype}}%
-  \file{tikz-timing-nicetabs.sty}{\from{tikz-timing.dtx}{lib,lib-nicetabs}}%
-  \file{tikz-timing-counters.sty}{\from{tikz-timing.dtx}{lib,lib-counters}}%
-  \file{tikz-timing-advnodes.sty}{\from{tikz-timing.dtx}{lib,lib-advnodes}}%
-  \file{tikz-timing-interval.sty}{\from{tikz-timing.dtx}{lib,lib-interval}}%
-  \file{tikz-timing-beamer.sty}{\from{tikz-timing.dtx}{lib,lib-beamer}}%
-  \file{tikz-timing-ifsym.sty}{\from{tikz-timing.dtx}{lib,lib-ifsym}}%
-%  \file{tikz-timing-examplecode.sty}{\from{tikz-timing.dtx}{examplecode}}%
+  \file{tikz-timing.sty}{\from{tikz-timing.dtx}{tikz-timing.sty}}%
+  \file{tikz-timing-arrows.sty}{\from{tikz-timing.dtx}{tikz-timing-arrows.sty}}%
+  \file{tikz-timing-either.sty}{\from{tikz-timing.dtx}{tikz-timing-either.sty}}%
+  \file{tikz-timing-overlays.sty}{\from{tikz-timing.dtx}{tikz-timing-overlays.sty}}%
+  \file{tikz-timing-clockarrows.sty}{\from{tikz-timing.dtx}{tikz-timing-clockarrows.sty}}%
+  \file{tikz-timing-columntype.sty}{\from{tikz-timing.dtx}{tikz-timing-columntype.sty}}%
+  \file{tikz-timing-nicetabs.sty}{\from{tikz-timing.dtx}{tikz-timing-nicetabs.sty}}%
+  \file{tikz-timing-counters.sty}{\from{tikz-timing.dtx}{tikz-timing-counters.sty}}%
+  \file{tikz-timing-advnodes.sty}{\from{tikz-timing.dtx}{tikz-timing-advnodes.sty}}%
+  \file{tikz-timing-interval.sty}{\from{tikz-timing.dtx}{tikz-timing-interval.sty}}%
+  \file{tikz-timing-beamer.sty}{\from{tikz-timing.dtx}{tikz-timing-beamer.sty}}%
+  \file{tikz-timing-ifsym.sty}{\from{tikz-timing.dtx}{tikz-timing-ifsym.sty}}%
+%  \file{tikz-timing-examplecode.sty}{\from{tikz-timing.dtx}{tikz-timing-examplecode.sty}}%
 }
 
 \obeyspaces

Deleted: trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-advnodes.sty
===================================================================
--- trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-advnodes.sty	2017-12-11 01:54:21 UTC (rev 46034)
+++ trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-advnodes.sty	2017-12-11 22:21:38 UTC (rev 46035)
@@ -1,616 +0,0 @@
-%%
-%% This is file `tikz-timing-advnodes.sty',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% tikz-timing.dtx  (with options: `lib,lib-advnodes')
-%% 
-%% Copyright (C) 2009-2011 by Martin Scharrer <martin at scharrer-online.de>
-%% 
-%% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either version 1.3c
-%% of this license or (at your option) any later version.
-%% The latest version of this license is in
-%% 
-%%    http://www.latex-project.org/lppl.txt
-%% 
-%% and version 1.3c or later is part of all distributions of LaTeX
-%% version 2008/05/04 or later.
-%% 
-%% This work has the LPPL maintenance status `maintained'.
-%% 
-%% The Current Maintainer of this work is Martin Scharrer.
-%% 
-%% This work consists of the files tikz-timing.dtx, tikz-timing.ins
-%% and the derived file tikz-timing.sty.
-%% 
-\RequirePackage{svn-prov}[2009/05/03]
-\ProvidesPackageSVN[tikz-timing-advnodes]
-  {$Id: tikz-timing.dtx 2038 2011-01-09 20:44:26Z martin $}
-  [v0.7d
-   TikZ-Timing Library for
-   advanced nodes]
-\GetFileInfoSVN*%
-\RequirePackage{tikz-timing}[\filedate]%
-\DefineFileInfoSVN
-
-\let\tikztiming at orig@oldnodecenter\tikztiming at oldnodecenter
-
-\tikzset{timing/nodes/.cd,
-  simple/.code={%
-    \let\tikztiming at oldnodecenter\tikztiming at orig@oldnodecenter
-    \tikzset{%
-      timing/inline node/.style={shape=coordinate},
-    }%
-  },
-  advanced/.code={%
-    \let\tikztiming at oldnodecenter\@gobble
-    \tikzset{%
-      timing/inline node/.style={shape=tikztiming coordinate},
-      timing/nodes/new center,
-    }%
-  },
-  old center/.code={%
-    \let\tikztiming at nodecenteranchor\tikztiming at old@nodecenteranchor
-  },%
-  new center/.code={%
-    \let\tikztiming at nodecenteranchor\empty
-  },%
-}
-\tikzset{timing/nodes/.cd,advanced,new center}
-
-\def\anchoralias#1#2{%
-  \expandafter\def
-  \csname pgf at anchor@\shape at name @#1\expandafter\endcsname
-  \expandafter{\csname pgf at anchor@\shape at name @#2\endcsname}%
-}
-
-\def\tikztiming at anchorpoint#1#2#3{%
-  \pgf at xa=#2\relax
-  \pgf at ya=#3\relax
-  \expandafter\edef\csname#1\endcsname{%
-    \pgf at x=\the\pgf at xa\relax
-    \pgf at y=\the\pgf at ya\relax
-  }%
-  \expandafter\addtosavedmacro\csname#1\endcsname
-}
-\def\tikztiming at tryanchor#1#2{%
-  \let\tikztiming at next\relax
-  \ifnum\tikztiming at debug>2
-    \message{^^J Try Anchor: '#1' '#2' ^^J }%
-    \def\tikztiming at next{\message{^^J TERM ^^J}}%
-  \fi
-  \ifx\relax#1\empty\else
-  \ifx\relax#2\empty\else
-    \def\tikztiming at next{%
-      \@ifundefined{tikztiming at anchors@#1@#2}%
-        {%
-          \edef\@tempa{%
-            {\csname tikztiming at alias@#1\endcsname}%
-            {\csname tikztiming at alias@#2\endcsname}%
-          }%
-          \expandafter\tikztiming at tryanchor@\@tempa{#1}{#2}%
-        }%
-        {\let\tikztiming at tryanchor\@gobbletwo
-         \ifnum\tikztiming at debug>2
-           \message{^^J Anchor: '#1' '#2' ^^J }%
-         \fi
-         \@nameuse{tikztiming at anchors@#1@#2}%
-        }%
-    }%
-  \fi\fi
-  \tikztiming at next
-}
-\def\tikztiming at tryanchor@#1#2#3#4{%
-  \tikztiming at tryanchor{#3}{#2}%
-  \tikztiming at tryanchor{#1}{#4}%
-  \tikztiming at tryanchor{#1}{#2}%
-  \let\tikztiming at tryanchor@\@gobblefour
-  \tikztiming at tryanchor{#3}{}%
-  \tikztiming at tryanchor{}{#4}%
-}
-\pgfdeclareshape{tikztiming coordinate}{%
-  \savedmacro\anchorpoints{%
-    \let\anchorpoint\tikztiming at anchorpoint
-    \let\slope\@tempdima
-    \let\dslope\@tempdimb
-    \let\zslope\@tempdimc
-    \let\height\pgf at yb
-    \let\fromchar\tikztiming at node@fromchar
-    \let\tochar\tikztiming at node@tochar
-    %
-    \ifnum\tikztiming at debug>2
-      \message{^^J Node: \fromchar \tochar ^^J}%
-    \fi
-    %
-    \edef\@tempa{{timing/\tochar}}%
-    \expandafter\lowercase\expandafter
-      {\expandafter\tikzset\@tempa}%
-    \pgfpointxy{\timingslope}{0}%
-    \slope=\pgf at x\relax
-    \pgfpointxy{\timingdslope}{0}%
-    \dslope=\pgf at x\relax
-    \pgfpointxy{\timingzslope}{0}%
-    \zslope=\pgf at x\relax
-    \pgfpointxy{0}{\timingheight}%
-    \height=\pgf at y\relax
-    \edef\anchorpoints{%
-      \noexpand\pgf at yb=\the\height\relax
-      \let\noexpand\height\noexpand\pgf at yb
-    }%
-    %
-    \tikztiming at tryanchor{\fromchar}{\tochar}%
-  }
-  \savedanchor\lowpoint{%
-    \pgfpointanchor{timing/start base}{center}%
-    \pgf at x=0pt
-  }%
-  \anchor{origin}{%
-    \pgfpointorigin
-    \anchorpoints
-    \@nameuse{originoffset}
-    \pgf at x=-\pgf at x
-    \pgf at y=-\pgf at y
-  }%
-  \anchor{old center}{%
-    \pgfpointorigin
-    \tikztiming at old@nodecenteranchor
-  }%
-  \anchor{new center}{\pgfpointorigin}%
-  \anchor{center}{%
-    \pgfpointorigin
-    \tikztiming at nodecenteranchor
-  }%
-  \anchor{MID}{\tikztiming at useanchor{HIGH}\advance\pgf at y by -.5\height\relax }%
-  \anchor{LOW}{\tikztiming at useanchor{HIGH}\advance\pgf at y by -\height\relax   }%
-  \anchor{HIGH}{\tikztiming at useanchor{HIGH}}%
-  \anchor{TOP}{%
-    \tikztiming at nodes@getoffset
-    \tikztiming at useanchor{HIGH}
-    \advance\pgf at y by  \pgf at ya\relax
-  }%
-  \anchor{BOTTOM}{%
-    \tikztiming at nodes@getoffset
-    \tikztiming at useanchor{HIGH}
-    \advance\pgf at y by -\pgf at ya\relax
-    \advance\pgf at y by -\height\relax
-  }%
-  \anchor{mid}{\tikztiming at useanchor{mid}}%
-  \anchor{low}{\tikztiming at useanchor{low}}%
-  \anchor{high}{\tikztiming at useanchor{high}}%
-  \anchor{low2}{\tikztiming at useanchor{low2}}%
-  \anchor{high2}{\tikztiming at useanchor{high2}}%
-  %
-  \expandafter\anchorborder\expandafter{\csname pgf at anchor@\shape at name @center\endcsname}%
-  %
-  \nodeparts{}%
-}
-
-\def\tikztiming at nodes@getoffset{%
-  \begingroup
-    \pgfpointxy{0}{1}%
-    \pgfmathsetresultunitscale{\pgf at y}%
-    \pgfpoint{0}{\tikztiming at nodes@offset}%
-    \global\pgf at ya=\pgf at y
-  \endgroup
-}
-
-\tikzset{%
-  timing/nodes/.cd,
-  offset/.store in=\tikztiming at nodes@offset,
-  offset=0.25,
-}
-
-\def\tikztiming at nodecenteranchor{}
-
-\def\tikztiming at old@nodecenteranchor{%
-    \anchorpoints
-    \@ifundefined{oldcenter}%
-      {\@nameuse{originoffset}%
-       \pgf at x=-\pgf at x\relax
-       \pgf at y=-\pgf at y\relax
-      }%
-      {\@nameuse{oldcenter}}%
-}
-
-\def\tikztiming at useanchor#1{%
-  \anchorpoints
-  \@ifundefined{#1}%
-   {\PackageError{tikz-timing}%
-      {No such anchor '#1' defined for this transition!}{}%
-    \pgfpointorigin
-   }%
-   {\@nameuse{#1}}%
-}
-
-\tikzset{%
-  every tikztiming coordinate node/.style={anchor=origin},
-}
-\def\tikztiming at anchors#1#2{%
-  \@namedef{tikztiming at anchors@#1@#2}%
-}
-\def\tikztiming at anchorslet#1#2#3#4{%
-  \expandafter\let
-  \csname tikztiming at anchors@#1@#2\expandafter\endcsname
-  \csname tikztiming at anchors@#3@#4\endcsname
-}
-
-\tikztiming at anchors{@}{D}{%
-  \anchorpoint{originoffset}{0pt}{.5\height}%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{high}{0pt}{.5\height}%
-  \anchorpoint{low}{0pt}{-.5\height}%
-  \anchorpoint{HIGH}{0pt}{.5\height}%
-}
-
-\tikztiming at anchors{@}{H}{%
-  \anchorpoint{originoffset}{0pt}{\height}%
-  \anchorpoint{high}{0pt}{0pt}%
-  \anchorpoint{HIGH}{0pt}{0pt}%
-}
-
-\tikztiming at anchors{@}{L}{%
-  \anchorpoint{originoffset}{0pt}{0pt}%
-  \anchorpoint{low}{0pt}{0pt}%
-  \anchorpoint{HIGH}{0pt}{\height}%
-}
-
-\tikztiming at anchors{@}{T}{%
-  \anchorpoint{originoffset}{0pt}{0pt}%
-  \anchorpoint{low}{0pt}{0pt}%
-  \anchorpoint{HIGH}{0pt}{\height}%
-}
-
-\tikztiming at anchors{@}{Z}{%
-  \anchorpoint{originoffset}{0pt}{.5\height}%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{HIGH}{0pt}{.5\height}%
-}
-
-\tikztiming at anchors{D}{D}{%
-  \anchorpoint{originoffset}{0pt}{0pt}%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{HIGH}{0pt}{.5\height}%
-  \anchorpoint{high}{0pt}{.5\height}%
-  \anchorpoint{low}{0pt}{-.5\height}%
-}
-
-\tikztiming at anchors{L}{H}{%
-  \anchorpoint{originoffset}{.5\slope}{.5\height}%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{high}{.5\slope}{.5\height}%
-  \anchorpoint{low}{-.5\slope}{-.5\height}%
-  \anchorpoint{HIGH}{-.5\slope}{.5\height}%
-}
-
-\tikztiming at anchors{E}{H}{%
-  \anchorpoint{originoffset}{-.5\slope}{-.5\height}%
-  \anchorpoint{oldcenter}{-.5\slope}{-.5\height}%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{high}{.5\slope}{.5\height}%
-  \anchorpoint{low}{-.5\slope}{-.5\height}%
-  \anchorpoint{HIGH}{-.5\slope}{.5\height}%
-}
-
-\tikztiming at anchors{T}{T}{%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{HIGH}{-.5\slope}{.5\height}%
-  \ifnum 1=\c at tikztimingtrans
-    \anchorpoint{originoffset}{.5\slope}{-.5\height}%
-    \anchorpoint{high}{-.5\slope}{.5\height}%
-    \anchorpoint{low}{.5\slope}{-.5\height}%
-  \else
-    \anchorpoint{originoffset}{.5\slope}{.5\height}%
-    \anchorpoint{high}{.5\slope}{.5\height}%
-    \anchorpoint{low}{-.5\slope}{-.5\height}%
-  \fi
-}
-\tikztiming at anchorslet{T}{E}{T}{T}%
-
-\tikztiming at anchors{T}{@}{%
-  \ifnum 1=\c at tikztimingtrans
-    \anchorpoint{high}{0pt}{0pt}%
-    \anchorpoint{HIGH}{0pt}{0pt}%
-  \else
-    \anchorpoint{low}{0pt}{0pt}%
-    \anchorpoint{HIGH}{0pt}{\height}%
-  \fi
-}
-
-\tikztiming at anchors{H}{H}{%
-  \anchorpoint{originoffset}{0pt}{0pt}%
-  \anchorpoint{high}{0pt}{0pt}%
-  \anchorpoint{HIGH}{0pt}{0pt}%
-}
-
-\tikztiming at anchors{L}{L}{%
-  \anchorpoint{originoffset}{0pt}{0pt}%
-  \anchorpoint{low}{0pt}{0pt}%
-  \anchorpoint{HIGH}{0pt}{\height}%
-}
-
-\tikztiming at anchors{Z}{Z}{%
-  \anchorpoint{originoffset}{0pt}{0pt}%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{HIGH}{0pt}{.5\height}%
-}
-
-\tikztiming at anchors{E}{E}{%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \ifnum 1=\c at tikztimingtrans
-    \anchorpoint{originoffset}{.5\slope}{.5\height}%
-    \anchorpoint{HIGH}{-.5\slope}{.5\height}%
-    \anchorpoint{high}{.5\slope}{.5\height}%
-    \anchorpoint{low}{-.5\slope}{-.5\height}%
-  \else
-    \anchorpoint{originoffset}{-.5\slope}{.5\height}%
-    \anchorpoint{oldcenter}{-.5\slope}{-.5\height}%
-    \anchorpoint{HIGH}{-.5\slope}{.5\height}%
-    \anchorpoint{high}{-.5\slope}{.5\height}%
-    \anchorpoint{low}{.5\slope}{-.5\height}%
-  \fi
-}
-
-\tikztiming at anchors{H}{L}{%
-  \anchorpoint{originoffset}{.5\slope}{-.5\height}%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{high}{-.5\slope}{.5\height}%
-  \anchorpoint{HIGH}{-.5\slope}{.5\height}%
-  \anchorpoint{low}{.5\slope}{-.5\height}%
-}
-\tikztiming at anchorslet{H}{E}{H}{L}%
-
-\tikztiming at anchors{E}{L}{%
-  \anchorpoint{originoffset}{-.5\slope}{.5\height}%
-  \anchorpoint{oldcenter}{-.5\slope}{-.5\height}%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{high}{-.5\slope}{.5\height}%
-  \anchorpoint{HIGH}{-.5\slope}{.5\height}%
-  \anchorpoint{low}{.5\slope}{-.5\height}%
-}
-
-\tikztiming at anchors{E}{T}{%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{HIGH}{-.5\slope}{.5\height}%
-  \ifnum 1=\c at tikztimingtrans
-    \anchorpoint{originoffset}{-.5\slope}{-.5\height}%
-    \anchorpoint{oldcenter}{-.5\slope}{-.5\height}%
-    \anchorpoint{high}{.5\slope}{.5\height}%
-    \anchorpoint{low}{-.5\slope}{-.5\height}%
-  \else
-    \anchorpoint{originoffset}{-.5\slope}{.5\height}%
-    \anchorpoint{oldcenter}{-.5\slope}{-.5\height}%
-    \anchorpoint{high}{-.5\slope}{.5\height}%
-    \anchorpoint{low}{.5\slope}{-.5\height}%
-  \fi
-}
-
-\tikztiming at anchors{E}{Z}{%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{oldcenter}{-\zslope}{-.5\height}%
-  \anchorpoint{HIGH}{-\zslope}{.5\height}%
-  \anchorpoint{high}{-\zslope}{.5\height}%
-  \anchorpoint{low}{-\zslope}{-.5\height}%
-}
-
-\tikztiming at anchors{Z}{D}{%
-  \anchorpoint{originoffset}{0pt}{0pt}%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{HIGH}{0pt}{.5\height}%
-  \anchorpoint{high}{.5\dslope}{.5\height}%
-  \anchorpoint{low}{.5\dslope}{-.5\height}%
-}
-
-\tikztiming at anchors{D}{Z}{%
-  \anchorpoint{originoffset}{0pt}{0pt}%
-  \anchorpoint{oldcenter}{-.5\dslope}{-.5\height}%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{HIGH}{-.5\dslope}{.5\height}%
-  \anchorpoint{high}{-.5\dslope}{.5\height}%
-  \anchorpoint{low}{-.5\dslope}{-.5\height}%
-}
-
-\tikztiming at anchors{D}{H}{%
-  \anchorpoint{originoffset}{0pt}{0pt}%
-  \anchorpoint{oldcenter}{-.5\dslope}{-.5\height}%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{HIGH}{-.5\dslope}{.5\height}%
-  \anchorpoint{high}{.5\dslope}{.5\height}%
-  \anchorpoint{high2}{-.5\dslope}{.5\height}%
-  \anchorpoint{low}{-.5\dslope}{-.5\height}%
-}
-
-\tikztiming at anchors{D}{L}{%
-  \anchorpoint{originoffset}{0pt}{0pt}%
-  \anchorpoint{oldcenter}{-.5\dslope}{-.5\height}%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{HIGH}{-.5\dslope}{.5\height}%
-  \anchorpoint{high}{-.5\dslope}{.5\height}%
-  \anchorpoint{low2}{-.5\dslope}{-.5\height}%
-  \anchorpoint{low}{.5\dslope}{-.5\height}%
-}
-\tikztiming at anchorslet{D}{T}{D}{L}%
-
-\tikztiming at anchors{D at edge@}{D}{%
-  \anchorpoint{originoffset}{0pt}{0pt}%
-  \anchorpoint{oldcenter}{-.5\dslope}{-.5\height}%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{HIGH}{-.5\dslope}{.5\height}%
-  \anchorpoint{high}{-.5\dslope}{.5\height}%
-  \anchorpoint{high2}{.5\dslope}{.5\height}%
-  \anchorpoint{low}{-.5\dslope}{-.5\height}%
-  \anchorpoint{low2}{.5\dslope}{-.5\height}%
-}
-\tikztiming at anchorslet{D}{U}{D at edge@}{D}
-\tikztiming at anchorslet{U}{D}{D at edge@}{D}
-\tikztiming at anchorslet{D}{D at edge@}{D at edge@}{D}
-\tikztiming at anchorslet{D at edge@}{D at edge@}{D at edge@}{D}
-\tikztiming at anchorslet{D}{E}{D at edge@}{D}
-\tikztiming at anchorslet{E}{D}{D at edge@}{D}
-
-\tikztiming at anchorslet{L}{E}{L}{H}%
-\tikztiming at anchorslet{L}{T}{L}{H}%
-\tikztiming at anchorslet{H}{T}{H}{L}%
-\tikztiming at anchorslet{T}{H}{H}{L}%
-
-\tikztiming at anchors{D}{D}{%
-  \anchorpoint{originoffset}{0pt}{0pt}%
-  \anchorpoint{oldcenter}{0pt}{-.5\height}%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{high}{0pt}{.5\height}%
-  \anchorpoint{low}{0pt}{-.5\height}%
-  \anchorpoint{HIGH}{0pt}{.5\height}%
-}
-\tikztiming at anchorslet{D}{@}{D}{D}
-\tikztiming at anchorslet{E}{@}{D}{D}
-\tikztiming at anchorslet{U}{U}{D}{D}
-
-\tikztiming at anchorslet{@}{E}{@}{D}
-
-\tikztiming at anchors{L}{D}{%
-  \anchorpoint{originoffset}{.5\dslope}{.5\height}%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{high}{.5\dslope}{.5\height}%
-  \anchorpoint{low}{-.5\dslope}{-.5\height}%
-  \anchorpoint{low2}{.5\dslope}{-.5\height}%
-  \anchorpoint{HIGH}{-.5\dslope}{.5\height}%
-}
-
-\tikztiming at anchors{T}{D}{%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{HIGH}{-.5\dslope}{.5\height}%
-  \ifnum 1=\c at tikztimingtrans
-    \anchorpoint{originoffset}{.5\dslope}{-.5\height}%
-    \anchorpoint{high}{-.5\dslope}{.5\height}%
-    \anchorpoint{high2}{.5\dslope}{.5\height}%
-    \anchorpoint{low}{.5\dslope}{-.5\height}%
-  \else
-    \anchorpoint{originoffset}{.5\dslope}{.5\height}%
-    \anchorpoint{high}{.5\dslope}{.5\height}%
-    \anchorpoint{low}{-.5\dslope}{-.5\height}%
-    \anchorpoint{low2}{.5\dslope}{-.5\height}%
-  \fi
-}
-
-\tikztiming at anchors{H}{D}{%
-  \anchorpoint{originoffset}{.5\dslope}{-.5\height}%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{HIGH}{-.5\dslope}{.5\height}%
-  \anchorpoint{high}{-.5\dslope}{.5\height}%
-  \anchorpoint{high2}{.5\dslope}{.5\height}%
-  \anchorpoint{low}{.5\dslope}{-.5\height}%
-}
-
-\tikztiming at anchors{Z}{E}{%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{high}{\zslope}{.5\height}%
-  \anchorpoint{low}{\zslope}{-.5\height}%
-  \anchorpoint{HIGH}{0pt}{.5\height}%
-}
-
-\tikztiming at anchors{Z}{H}{%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{high}{\zslope}{.5\height}%
-  \anchorpoint{HIGH}{0pt}{.5\height}%
-}
-
-\tikztiming at anchors{Z}{T}{%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{HIGH}{0pt}{.5\height}%
-  \ifnum1=\c at tikztimingtrans\relax
-    \anchorpoint{low}{\zslope}{-.5\height}%
-  \else
-    \anchorpoint{high}{\zslope}{.5\height}%
-  \fi
-}
-
-\tikztiming at anchors{T}{H}{%
-  \ifnum1=\c at tikztimingtrans\relax
-    \anchorpoint{high}{0pt}{0pt}%
-    \anchorpoint{HIGH}{0pt}{0pt}%
-  \else
-    \anchorpoint{originoffset}{.5\slope}{.5\height}%
-    \anchorpoint{low}{-.5\slope}{-.5\height}%
-    \anchorpoint{mid}{0pt}{0pt}%
-    \anchorpoint{high}{.5\slope}{.5\height}%
-    \anchorpoint{HIGH}{-.5\slope}{.5\height}%
-  \fi
-}
-
-\tikztiming at anchors{T}{L}{%
-  \ifnum1=\c at tikztimingtrans\relax
-    \anchorpoint{originoffset}{.5\slope}{-.5\height}%
-    \anchorpoint{low}{.5\slope}{-.5\height}%
-    \anchorpoint{mid}{0pt}{0pt}%
-    \anchorpoint{high}{-.5\slope}{.5\height}%
-    \anchorpoint{HIGH}{-.5\slope}{.5\height}%
-  \else
-    \anchorpoint{low}{0pt}{0pt}%
-    \anchorpoint{HIGH}{0pt}{\height}%
-  \fi
-}
-
-\tikztiming at anchors{T}{Z}{%
-  \ifnum1=\c at tikztimingtrans\relax
-    \anchorpoint{high}{0pt}{0pt}%
-    \anchorpoint{mid}{\zslope}{-.5\height}%
-    \anchorpoint{HIGH}{0pt}{0pt}%
-  \else
-    \anchorpoint{low}{0pt}{0pt}%
-    \anchorpoint{mid}{\zslope}{.5\height}%
-    \anchorpoint{HIGH}{0pt}{\height}%
-  \fi
-}
-
-\tikztiming at anchors{Z}{L}{%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{low}{\zslope}{-.5\height}%
-  \anchorpoint{HIGH}{0pt}{.5\height}%
-}
-
-\tikztiming at anchors{H}{Z}{%
-  \anchorpoint{high}{0pt}{0pt}%
-  \anchorpoint{mid}{\zslope}{-.5\height}%
-  \anchorpoint{HIGH}{0pt}{0pt}%
-}
-
-\tikztiming at anchors{L}{Z}{%
-  \anchorpoint{low}{0pt}{0pt}%
-  \anchorpoint{mid}{\zslope}{.5\height}%
-  \anchorpoint{HIGH}{0pt}{\height}%
-}
-
-\tikztiming at anchors{Z}{Z}{%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{HIGH}{0pt}{.5\height}%
-}
-
-\tikztiming at anchors{H}{@}{%
-  \anchorpoint{high}{0pt}{0pt}%
-  \anchorpoint{HIGH}{0pt}{0pt}%
-}
-
-\tikztiming at anchors{L}{@}{%
-  \anchorpoint{low}{0pt}{0pt}%
-  \anchorpoint{HIGH}{0pt}{\height}%
-}
-
-\tikztiming at anchors{Z}{@}{%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{HIGH}{0pt}{.5\height}%
-}
-
-\tikztiming at anchors{}{@}{%
-  \anchorpoint{originoffset}{0pt}{.5\height}%
-  \anchorpoint{mid}{0pt}{0pt}%
-  \anchorpoint{high}{0pt}{.5\height}%
-  \anchorpoint{low}{0pt}{-.5\height}%
-  \anchorpoint{HIGH}{0pt}{.5\height}%
-}
-
-\RequirePackage{pgfopts}
-\ProcessPgfOptions{/tikz/timing/node}
-\endinput
-%%
-%% End of file `tikz-timing-advnodes.sty'.

Deleted: trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-arrows.sty
===================================================================
--- trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-arrows.sty	2017-12-11 01:54:21 UTC (rev 46034)
+++ trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-arrows.sty	2017-12-11 22:21:38 UTC (rev 46035)
@@ -1,53 +0,0 @@
-%%
-%% This is file `tikz-timing-arrows.sty',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% tikz-timing.dtx  (with options: `lib,lib-arrows')
-%% 
-%% Copyright (C) 2009-2011 by Martin Scharrer <martin at scharrer-online.de>
-%% 
-%% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either version 1.3c
-%% of this license or (at your option) any later version.
-%% The latest version of this license is in
-%% 
-%%    http://www.latex-project.org/lppl.txt
-%% 
-%% and version 1.3c or later is part of all distributions of LaTeX
-%% version 2008/05/04 or later.
-%% 
-%% This work has the LPPL maintenance status `maintained'.
-%% 
-%% The Current Maintainer of this work is Martin Scharrer.
-%% 
-%% This work consists of the files tikz-timing.dtx, tikz-timing.ins
-%% and the derived file tikz-timing.sty.
-%% 
-\RequirePackage{svn-prov}[2009/05/03]
-\ProvidesPackageSVN[tikz-timing-arrows]
-  {$Id: tikz-timing.dtx 2038 2011-01-09 20:44:26Z martin $}
-  [v0.7d
-   TikZ-Timing Library for
-   timing arrows]
-\GetFileInfoSVN*%
-\RequirePackage{tikz-timing}[\filedate]%
-\DefineFileInfoSVN
-\tikzset{timing/.cd,
-  A/.style={timing/a},
-  W/.style={timing/w},
-  a/.style={->},
-  w/.style={<-},
-}
-
-\tikztimingchar{A}{++(0,0)}{%
-  \newdraw [\style] -- ++(0,\height)
-  \newdraw ++(#1,-\height)
-}
-\def\tikztiming at nocombine@A{}%
-
-\tikztimingecopy{W}{A}
-\endinput
-%%
-%% End of file `tikz-timing-arrows.sty'.

Deleted: trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-beamer.sty
===================================================================
--- trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-beamer.sty	2017-12-11 01:54:21 UTC (rev 46034)
+++ trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-beamer.sty	2017-12-11 22:21:38 UTC (rev 46035)
@@ -1,50 +0,0 @@
-%%
-%% This is file `tikz-timing-beamer.sty',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% tikz-timing.dtx  (with options: `lib,lib-beamer')
-%% 
-%% Copyright (C) 2009-2011 by Martin Scharrer <martin at scharrer-online.de>
-%% 
-%% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either version 1.3c
-%% of this license or (at your option) any later version.
-%% The latest version of this license is in
-%% 
-%%    http://www.latex-project.org/lppl.txt
-%% 
-%% and version 1.3c or later is part of all distributions of LaTeX
-%% version 2008/05/04 or later.
-%% 
-%% This work has the LPPL maintenance status `maintained'.
-%% 
-%% The Current Maintainer of this work is Martin Scharrer.
-%% 
-%% This work consists of the files tikz-timing.dtx, tikz-timing.ins
-%% and the derived file tikz-timing.sty.
-%% 
-\RequirePackage{svn-prov}[2009/05/03]
-\ProvidesPackageSVN[tikz-timing-beamer]
-  {$Id: tikz-timing.dtx 2038 2011-01-09 20:44:26Z martin $}
-  [v0.7d
-   TikZ-Timing Library for
-   beamer overlay support]
-\GetFileInfoSVN*%
-\RequirePackage{tikz-timing}[\filedate]%
-\DefineFileInfoSVN
-
-\PackageWarning{\@currname}{This library is experimental and will change in future versions!}{}{}
-
-\tikztiming at defcode<#1>{
-  \tikztiming at output@addcode{
-    node [timing/save] (timing at save) {};%
-    \onslide<#1>
-    \draw [timing/restore] (timing at save) ++(0,0)
-  }
-  \tikztiming at parser
-}
-\endinput
-%%
-%% End of file `tikz-timing-beamer.sty'.

Deleted: trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-clockarrows.sty
===================================================================
--- trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-clockarrows.sty	2017-12-11 01:54:21 UTC (rev 46034)
+++ trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-clockarrows.sty	2017-12-11 22:21:38 UTC (rev 46035)
@@ -1,98 +0,0 @@
-%%
-%% This is file `tikz-timing-clockarrows.sty',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% tikz-timing.dtx  (with options: `lib,lib-clockarrows')
-%% 
-%% Copyright (C) 2009-2011 by Martin Scharrer <martin at scharrer-online.de>
-%% 
-%% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either version 1.3c
-%% of this license or (at your option) any later version.
-%% The latest version of this license is in
-%% 
-%%    http://www.latex-project.org/lppl.txt
-%% 
-%% and version 1.3c or later is part of all distributions of LaTeX
-%% version 2008/05/04 or later.
-%% 
-%% This work has the LPPL maintenance status `maintained'.
-%% 
-%% The Current Maintainer of this work is Martin Scharrer.
-%% 
-%% This work consists of the files tikz-timing.dtx, tikz-timing.ins
-%% and the derived file tikz-timing.sty.
-%% 
-\RequirePackage{svn-prov}[2009/05/03]
-\ProvidesPackageSVN[tikz-timing-clockarrows]
-  {$Id: tikz-timing.dtx 2038 2011-01-09 20:44:26Z martin $}
-  [v0.7d
-   TikZ-Timing Library for
-   timing clock arrows]
-\GetFileInfoSVN*%
-\RequirePackage{tikz-timing}[\filedate]%
-\DefineFileInfoSVN
-\tikztiming at iftrans{CC}%
-  {\let\tikztiming at trans@C at normal@C\tikztiming at trans@CC}%
-  {\PackageError{\@currname}{No 'CC' transition defined by the main tikz-timing
-  package.}{}}%
-
-\tikztimingdef{CC}{%
-  \code{\setcounter{tikztimingtrans}{-\value{tikztimingtrans}}}
-  [timing/c/save]
-  \newdraw
-  [\style,timing/c/restore,>=\noexpand\tikztiming at c@arrow at tip,timing/c/arrow at style]
-  -- ++(\slope*\noexpand\tikztiming at c@arrow at pos,\value{tikztimingtrans}*\height*\noexpand\tikztiming at c@arrow at pos)
-  ; \draw [timing/restore,timing/c/restore] (timing at save) ++(0,0) [\style]
-  -- ++(\slope,\value{tikztimingtrans}*\height)
-  -- ++($ (#1,0) - (\slope,0) $)
-}
-\let\tikztiming at trans@C at arrow@C\tikztiming at trans@CC
-
-\tikzset{timing/c/.cd,
-  rising arrows/.code={%
-    \def\tikztiming at trans@CC{\tikztiming at trans@C at arrow@C}%
-    \def\tikztiming at clockarrow@style{\ifnum1=\c at tikztimingtrans\tikzset{->,timing/c/arrow}\fi}%
-  },%
-  falling arrows/.code={%
-    \def\tikztiming at trans@CC{\tikztiming at trans@C at arrow@C}%
-    \def\tikztiming at clockarrow@style{\ifnum-1=\c at tikztimingtrans\tikzset{->,timing/c/arrow}\fi}%
-  },%
-  dual arrows/.code={%
-    \def\tikztiming at trans@CC{\tikztiming at trans@C at arrow@C}%
-    \def\tikztiming at clockarrow@style{\tikzset{->,timing/c/arrow}}%
-  },%
-  no arrows/.code={%
-    \def\tikztiming at trans@CC{\tikztiming at trans@C at normal@C}%
-    \def\tikztiming at clockarrow@style{}%
-  },%
-  arrow at style/.code={\tikztiming at clockarrow@style},%
-  arrow/.style={},%
-  arrow pos/.store in=\tikztiming at c@arrow at pos,
-  arrow tip/.store in=\tikztiming at c@arrow at tip,
-  save/.code={%
-    \global\let\tikztiming at clockarrow@savedstyle\tikztiming at clockarrow@style
-    \global\let\tikztiming at trans@saved at CC\tikztiming at trans@CC
-    \global\let\tikztiming at c@arrow at savedpos\tikztiming at c@arrow at pos
-    \global\let\tikztiming at c@arrow at savedtip\tikztiming at c@arrow at tip
-  },
-  restore/.code={%
-    \let\tikztiming at clockarrow@style\tikztiming at clockarrow@savedstyle
-    \let\tikztiming at trans@CC\tikztiming at trans@saved at CC
-    \let\tikztiming at c@arrow at pos\tikztiming at c@arrow at savedpos
-    \let\tikztiming at c@arrow at tip\tikztiming at c@arrow at savedtip
-  },
-}
-\tikzset{timing/c/.cd,
-  no arrows,
-  arrow pos=0.95,
-  arrow tip=to,
-}
-
-\RequirePackage{pgfopts}
-\ProcessPgfOptions{/tikz/timing/c}
-\endinput
-%%
-%% End of file `tikz-timing-clockarrows.sty'.

Deleted: trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-columntype.sty
===================================================================
--- trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-columntype.sty	2017-12-11 01:54:21 UTC (rev 46034)
+++ trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-columntype.sty	2017-12-11 22:21:38 UTC (rev 46035)
@@ -1,88 +0,0 @@
-%%
-%% This is file `tikz-timing-columntype.sty',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% tikz-timing.dtx  (with options: `lib,lib-columntype')
-%% 
-%% Copyright (C) 2009-2011 by Martin Scharrer <martin at scharrer-online.de>
-%% 
-%% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either version 1.3c
-%% of this license or (at your option) any later version.
-%% The latest version of this license is in
-%% 
-%%    http://www.latex-project.org/lppl.txt
-%% 
-%% and version 1.3c or later is part of all distributions of LaTeX
-%% version 2008/05/04 or later.
-%% 
-%% This work has the LPPL maintenance status `maintained'.
-%% 
-%% The Current Maintainer of this work is Martin Scharrer.
-%% 
-%% This work consists of the files tikz-timing.dtx, tikz-timing.ins
-%% and the derived file tikz-timing.sty.
-%% 
-\RequirePackage{svn-prov}[2009/05/03]
-\ProvidesPackageSVN[tikz-timing-columntype]
-  {$Id: tikz-timing.dtx 2038 2011-01-09 20:44:26Z martin $}
-  [v0.7d
-   TikZ-Timing Library for
-   timing cell types]
-\GetFileInfoSVN*%
-\RequirePackage{tikz-timing}[\filedate]%
-\DefineFileInfoSVN
-\RequirePackage{array}
-
-\tikzset{timing/columntype/.code 2 args =
-  \newcolumntype{#1}{>{\celltiming}#2<{\endcelltiming}}%
-}%
-\RequirePackage{pgfopts}
-\tikzset{timing/columntype/.cd,
-  type/.style 2 args={/tikz/timing/columntype={#1}{#2}},%
-  notype/.code={},
-  notype/.value forbidden={},
-}
-
-\ProcessPgfOptions{/tikz/timing/columntype}
-\expandafter\ifx\csname opt@\@currname.\@currext\endcsname\empty
-  \tikzset{timing/columntype={T}{l}}%
-\fi
-\def\celltiming#1\ignorespaces{%
-  #1%
-  \begin{tikzpicture}[timing/picture,baseline={(0,0)}]
-    \def\tikztiming at endhook{\end at celltiming}
-    \tikztiming at init
-    \let\tikztiming at settings\empty
-    \@ifnextchar{[}%
-      {\tikztiming at celltiming}%
-      {\tikztiming at celltiming[]}%
-}
-\let\endcelltiming\relax
-\def\tikztiming at celltiming[#1]{%
-  \ifx\relax#1\relax\else
-    \tikztiming at testoptarg#1\relax\relax
-  \fi
-  \ifx\tikztiming at lastchar\empty
-    \def\tikztiming at lastchar{@}%
-  \fi
-  \expandafter\scope\expandafter[\tikztiming at settings]%
-    \begingroup
-    \let\unskip\relax
-    \let\\\relax
-    \tikztiming at parser
-}
-\def\end at celltiming{%
-    \tikzset{timing/before}%
-    \tikztiming at str;
-    \expandafter\node
-    \expandafter[\tikztiming at settings,shape=tikztiming at shape,anchor=origin] at (0,0) {};
-    \tikzset{timing/after}%
-  \endscope
-  \end{tikzpicture}%
-}
-\endinput
-%%
-%% End of file `tikz-timing-columntype.sty'.

Deleted: trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-counters.sty
===================================================================
--- trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-counters.sty	2017-12-11 01:54:21 UTC (rev 46034)
+++ trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-counters.sty	2017-12-11 22:21:38 UTC (rev 46035)
@@ -1,262 +0,0 @@
-%%
-%% This is file `tikz-timing-counters.sty',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% tikz-timing.dtx  (with options: `lib,lib-counters')
-%% 
-%% Copyright (C) 2009-2011 by Martin Scharrer <martin at scharrer-online.de>
-%% 
-%% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either version 1.3c
-%% of this license or (at your option) any later version.
-%% The latest version of this license is in
-%% 
-%%    http://www.latex-project.org/lppl.txt
-%% 
-%% and version 1.3c or later is part of all distributions of LaTeX
-%% version 2008/05/04 or later.
-%% 
-%% This work has the LPPL maintenance status `maintained'.
-%% 
-%% The Current Maintainer of this work is Martin Scharrer.
-%% 
-%% This work consists of the files tikz-timing.dtx, tikz-timing.ins
-%% and the derived file tikz-timing.sty.
-%% 
-\RequirePackage{svn-prov}[2009/05/03]
-\ProvidesPackageSVN[tikz-timing-counters]
-  {$Id: tikz-timing.dtx 2038 2011-01-09 20:44:26Z martin $}
-  [v0.7d
-   TikZ-Timing Library for
-   counter values]
-\GetFileInfoSVN*%
-\RequirePackage{tikz-timing}[\filedate]%
-\DefineFileInfoSVN
-\newif\if at tikztiming@counter at wraps
-
-\tikzset{%
-  timing/new counter/.style={timing/counter/new={#1}},
-  timing/counter/.cd,
-  new/.code={\tikztiming at counter@new{#1}},
-  new/.value required,
-  opt/.cd,
-  char/.initial=,
-  char/.value required,
-  reset char/.initial=,
-  reset char/.value required,
-  reset type/.is choice,
-  reset type/width/.code={\def\tikztiming at resettype{0}},
-  reset type/arg/.code={\def\tikztiming at resettype{1}},
-  reset type/both/.code={\def\tikztiming at resettype{2}},
-  reset type/Both/.code={\def\tikztiming at resettype{3}},
-  half width char/.initial=,
-  half width char/.value required,
-  base/.initial=10,
-  base/.value required,
-  increment/.initial=1,
-  increment/.value required,
-  max value/.initial=,
-  max value/.value required,
-  min value/.initial=,
-  min value/.value required,
-  wraps/.is if=@tikztiming at counter@wraps,
-  digits/.initial=,
-  digits/.value required,
-  fg style/.initial=,
-  bg style/.initial=,
-  text style/.initial=,
-  text format/.initial=,
-  fg style/.value required,
-  bg style/.value required,
-  text style/.value required,
-  text format/.value required,
-}
-\def\tikztiming at counter@textformat{}%
-\def\tikztimingcounter#1{%
-  \csname tikztiming at counter@#1\endcsname
-}
-\def\tikztimingsetcounter#1#2{%
-  \begingroup
-    \pgfmathtruncatemacro\@tempa{#2}%
-    \expandafter\global\expandafter\let\csname tikztiming at counter@#1\endcsname\@tempa
-  \endgroup
-}
-\def\tikztiming at counter@new#1{%
- \begingroup
-  \def\tikztiming at resettype{0}%
-  \pgfqkeys{/tikz/timing/counter/opt}{#1}%
-  \tikzset{timing/counter/opt/char/.get=\counterchar}%
-  \ifx\counterchar\empty
-    \PackageError{tikz-timing-counters}{Counter character must be given using
-    the 'char' key!}{}%
-    \endgroup
-  \else
-    \pgfkeys{/tikz/timing/counter/opt/min value/.get=\min}%
-    \pgfkeys{/tikz/timing/counter/opt/max value/.get=\max}%
-    \if at tikztiming@counter at wraps
-      \ifx\min\empty
-        \def\min{0}%
-      \fi
-      \ifx\max\empty
-        \PackageError{tikz-timing-counters}{The option 'wraps' needs the option 'max value' to be set!}{}%
-      \fi
-      \def\@tempb{%
-        \noexpand\tikztiming at counter@wrap%
-          {\expandafter\unexpanded\expandafter{\min}}%
-          {\expandafter\unexpanded\expandafter{\max}}%
-      }%
-    \else
-      \ifx\min\empty
-        \ifx\max\empty
-          \let\@tempb\empty
-        \else
-          \def\@tempb{%
-            \noexpand\tikztiming at counter@maxsat%
-              {\expandafter\unexpanded\expandafter{\max}}%
-          }%
-        \fi
-      \else
-        \ifx\max\empty
-          \def\@tempb{%
-            \noexpand\tikztiming at counter@minsat%
-              {\expandafter\unexpanded\expandafter{\min}}%
-          }%
-        \else
-          \def\@tempb{%
-            \noexpand\tikztiming at counter@minmaxsat%
-              {\expandafter\unexpanded\expandafter{\min}}%
-              {\expandafter\unexpanded\expandafter{\max}}%
-          }%
-        \fi
-      \fi
-    \fi
-    \pgfkeys{/tikz/timing/counter/opt/fg style/.get=\fgstyle}%
-    \pgfkeys{/tikz/timing/counter/opt/bg style/.get=\bgstyle}%
-    \pgfkeys{/tikz/timing/counter/opt/text style/.get=\textstyle}%
-    \pgfkeys{/tikz/timing/counter/opt/text format/.get=\textformat}%
-    \pgfkeys{/tikz/timing/counter/opt/increment/.get=\increment}%
-    \edef\@tempa{%
-      \noexpand\tikztiming at counter@new@
-        {\pgfkeysvalueof{/tikz/timing/counter/opt/char}}%
-        {\pgfkeysvalueof{/tikz/timing/counter/opt/base}}%
-        {\pgfkeysvalueof{/tikz/timing/counter/opt/half width char}}%
-        {\pgfkeysvalueof{/tikz/timing/counter/opt/reset char}}%
-        {\pgfkeysvalueof{/tikz/timing/counter/opt/digits}}%
-        {\expandafter\unexpanded\expandafter{\increment}}%
-        {\@tempb}%
-        {\min}%
-        {\tikztiming at resettype}%
-        {\expandafter\unexpanded\expandafter{\fgstyle}}%
-        {\expandafter\unexpanded\expandafter{\bgstyle}}%
-        {\expandafter\unexpanded\expandafter{\textstyle}}%
-        {\expandafter\unexpanded\expandafter{\textformat}}%
-    }%
-    \expandafter\expandafter\expandafter\endgroup
-    \expandafter\@tempa
-  \fi
-}
-\def\tikztiming at counter@new@#1#2#3#4#5#6#7#8#9{%
-  \ifx\empty#8\empty
-    \@namedef{tikztiming at counter@#1}{0}%
-  \else
-    \expandafter
-    \pgfmathtruncatemacro\csname tikztiming at counter@#1\endcsname{#8}%
-  \fi
-  \tikztimingmetachar{#1}[1]{ { [timing/counter/#1] ##1D{[timing/counter/#1/text]\tikztiming at counter@vs{#1}{#2}{#5}{#6}{#7}} } }%
-  \ifx\empty#3\empty
-      \tikztiming at iflower{#1}{}%
-        {\lowercase{\tikztimingmetachar{#1}}[1]%
-          { { [timing/counter/#1] ##1d{[timing/counter/#1/text]\tikztiming at counter@vs{#1}{#2}{#5}{#6}{#7}}} }%
-        }%
-  \else
-    \tikztimingmetachar{#3}[1]{%
-      { [timing/counter/#1] ##1d{[timing/counter/#1/text]\tikztiming at counter@vs{#1}{#2}{#5}{#6}{#7}} }%
-    }%
-  \fi
-  \ifx\empty#4\empty\else
-    \ifcase0#9\relax
-      \tikztimingmetachar{#4}[1]{[|/utils/exec=\tikztiming at counter@reset{#1}{##1}|]}%
-    \or
-      \tikztimingmetachar{#4}[2]{[|/utils/exec=\tikztimingsetcounter{#1}{##2}|]}%
-    \or
-      \uppercase{\tikztimingmetachar{#4}}[1]{[|/utils/exec=\tikztiming at counter@reset{#1}{##1}|]}%
-      \lowercase{\tikztimingmetachar{#4}}[2]{[|/utils/exec=\tikztimingsetcounter{#1}{##2}|]}%
-    \or
-      \lowercase{\tikztimingmetachar{#4}}[1]{[|/utils/exec=\tikztiming at counter@reset{#1}{##1}|]}%
-      \uppercase{\tikztimingmetachar{#4}}[2]{[|/utils/exec=\tikztimingsetcounter{#1}{##2}|]}%
-    \fi
-  \fi
-  \tikztiming at counter@new@@{#1}%
-}
-\def\tikztiming at counter@new@@#1#2#3#4#5{%
-  \tikzset{timing/counter/#1/.style={}}%
-  \ifx\empty#2\empty\else
-    \tikzset{timing/counter/#1/.append style={%
-      /tikz/timing/d/.style={#2}%
-    }}%
-  \fi
-  \ifx\empty#3\empty\else
-    \tikzset{timing/counter/#1/.append style={%
-      /tikz/timing/d/background/.style={#3}%
-    }}%
-  \fi
-  \tikzset{timing/counter/#1/text/.style={#4}}%
-  \ifx\empty#5\empty\else
-    \tikzset{timing/counter/#1/.append style={%
-      /utils/exec={\def\tikztiming at counter@textformat{#5}}%
-    }}%
-  \fi
-}
-\def\tikztiming at counter@reset#1#2{%
-  \begingroup
-    \pgfmathtruncatemacro\@tempa{round((#2)/\tikztiming at wscale)}%
-    \expandafter\global\expandafter\let\csname tikztiming at counter@#1\endcsname\@tempa
-  \endgroup
-}
-\def\tikztiming at counter@vs#1#2#3#4#5{%
-  \begingroup
-    \ifx\empty#3\empty\else
-      \pgfmathsetbasenumberlength{#3}%
-    \fi
-    \ifnum#2=10
-      \expandafter\expandafter\expandafter\tikztiming at counter@textformat
-      \expandafter\expandafter\expandafter{\csname tikztiming at counter@#1\endcsname}%
-    \else
-      \pgfmathdectoBase\pgfmathresult{\@nameuse{tikztiming at counter@#1}}{#2}%
-      \expandafter\tikztiming at counter@textformat\expandafter{\pgfmathresult}%
-    \fi
-    \edef\N{\@nameuse{tikztiming at counter@#1}}%
-    \pgfmathtruncatemacro\N{\N + #4}%
-    #5%
-    \expandafter\global\expandafter\let\csname tikztiming at counter@#1\endcsname\N
-  \endgroup
-}
-\def\tikztiming at counter@minsat#1{%
-  \pgfmathtruncatemacro\MIN{#1}%
-  \ifnum\N<\MIN \let\N\MIN \fi
-}
-\def\tikztiming at counter@maxsat#1{%
-  \pgfmathtruncatemacro\MAX{#1}%
-  \ifnum\N>\MAX \let\N\MAX \fi
-}
-\def\tikztiming at counter@minmaxsat#1#2{%
-  \tikztiming at counter@minsat{#1}%
-  \tikztiming at counter@maxsat{#2}%
-}
-\def\tikztiming at counter@wrap#1#2{%
-  \pgfmathtruncatemacro\MIN{#1}%
-  \pgfmathtruncatemacro\MAX{#2}%
-  \ifnum\N>\MAX
-    \pgfmathtruncatemacro\N{\MIN + (\N-\MAX-1)}%
-  \fi
-  \ifnum\N<\MIN
-    \pgfmathtruncatemacro\N{\MAX - (\MIN-\N+1)}%
-  \fi
-}
-\RequirePackage{pgfopts}
-\ProcessPgfOptions{/tikz/timing/counter}
-\endinput
-%%
-%% End of file `tikz-timing-counters.sty'.

Deleted: trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-either.sty
===================================================================
--- trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-either.sty	2017-12-11 01:54:21 UTC (rev 46034)
+++ trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-either.sty	2017-12-11 22:21:38 UTC (rev 46035)
@@ -1,809 +0,0 @@
-%%
-%% This is file `tikz-timing-either.sty',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% tikz-timing.dtx  (with options: `lib,lib-either')
-%% 
-%% Copyright (C) 2009-2011 by Martin Scharrer <martin at scharrer-online.de>
-%% 
-%% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either version 1.3c
-%% of this license or (at your option) any later version.
-%% The latest version of this license is in
-%% 
-%%    http://www.latex-project.org/lppl.txt
-%% 
-%% and version 1.3c or later is part of all distributions of LaTeX
-%% version 2008/05/04 or later.
-%% 
-%% This work has the LPPL maintenance status `maintained'.
-%% 
-%% The Current Maintainer of this work is Martin Scharrer.
-%% 
-%% This work consists of the files tikz-timing.dtx, tikz-timing.ins
-%% and the derived file tikz-timing.sty.
-%% 
-\RequirePackage{svn-prov}[2009/05/03]
-\ProvidesPackageSVN[tikz-timing-either]
-  {$Id: tikz-timing.dtx 2038 2011-01-09 20:44:26Z martin $}
-  [v0.7d
-   TikZ-Timing Library for
-   uncertain transitions]
-\GetFileInfoSVN*%
-\RequirePackage{tikz-timing}[\filedate]%
-\DefineFileInfoSVN
-\tikztimingchar{E}{
-  ++(0,0)
-  \code{\setcounter{tikztimingtranspos}{0}}%
-  \code{\setcounter{tikztimingtrans}{1}}%
-}{
-  \code{\setcounter{tikztimingtranspos}{0}}%
-  \code{\setcounter{tikztimingtrans}{1}}%
-  \tikztiminguse{D}{#1}%
-  \newdraw
-}
-\def\tikztiming at triple@E{}%
-
-\tikztimingdef{LE@}{%
-  \newdraw [\bgstyle]
-  -- ++(\slope,\height)%
-  -- ++($ (#1,0) - (\slope,0) $)%
-  -- ++(0,-\height)%
-  -- ++($ -1*(#1,0) $)%
-  \newdraw [\style]
-  -- ++(\slope,\height)%
-  -- ++($ (#1,0) - (\slope,0) $)%
-     ++($ -1*(#1,\height) $)%
-  -- ++($  1*(#1,0) $)%
-     ++(0,.5\height)%
-  \newdraw
-  \code{\setcounter{tikztimingtranspos}{0}}%
-  \code{\setcounter{tikztimingtrans}{1}}%
-}%
-
-\tikztimingdef{HE@}{%
-  \newdraw [\bgstyle]
-  -- ++(\slope,-\height)%
-  -- ++($ (#1,0) - (\slope,0) $)%
-  -- ++(0,\height)%
-  -- ++($ -1*(#1,0) $)%
-  \newdraw [\style]
-  -- ++(\slope,-\height)%
-  -- ++($ (#1,0) - (\slope,0) $)%
-     ++($ -1*(#1,-\height) $)%
-  -- ++($  1*(#1,0) $)%
-     ++(0,-.5\height)%
-  \newdraw
-  \code{\setcounter{tikztimingtranspos}{1}}%
-  \code{\setcounter{tikztimingtrans}{-1}}%
-}%
-
-\tikztimingdef{TE@}{%
-  \newdraw [\bgstyle]
-  -- ++(\slope,-\height * \value{tikztimingtrans})%
-  -- ++($ (#1,0) - (\slope,0) $)%
-  -- ++(0,\height * \value{tikztimingtrans})%
-  -- ++($ -1*(#1,0) $)%
-  \newdraw [\style]
-  -- ++(\slope,-\height * \value{tikztimingtrans})%
-  -- ++($ (#1,0) - (\slope,0) $)%
-     ++($ -1*(#1,-\height * \value{tikztimingtrans}) $)%
-  -- ++($  1*(#1,0) $)%
-     ++(0,-1*\value{tikztimingtrans}*.5*\height)%
-  \newdraw
-}%
-
-\tikztimingdef{LEL}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(\slope,\height)%
-  -- +(#1,\height)%
-  -- +($ (#1,0) + (\slope,0) $)%
-  -- +(0,0)
-    ++(#1,\height/2) coordinate (timing at ref)
-    ++(\slope,-\height/2)%
-  \newdraw
-}%
-
-\tikztimingdef{LEH}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(\slope,\height)%
-  -- +($ (#1,\height) + (\slope,0) $)%
-  -- +(#1,0)%
-  -- +(0,0)
-    ++(#1,\height/2) coordinate (timing at ref)
-    ++(\slope,\height/2)%
-  \newdraw
-}%
-
-\tikztimingdef{HEH}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +($ (#1,0) + (\slope,0) $)%
-  -- +(#1,-\height)%
-  -- +(\slope,-\height)
-  -- +(0,0)
-    ++(#1,-\height/2) coordinate (timing at ref)
-    ++(\slope,\height/2)%
-  \newdraw
-}%
-
-\tikztimingdef{HEL}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(#1,0)
-  -- +($ (#1,-\height) + (\slope,0) $)%
-  -- +(\slope,-\height)
-  -- +(0,0)
-    ++(#1,-\height/2) coordinate (timing at ref)
-    ++(\slope,-\height/2)%
-  \newdraw
-}%
-
-\tikztimingdef{HET}{
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(#1,0)
-  {[\nstyle]
-  -- +($ (#1,-\height) + (\slope,0) $)%
-  }
-  -- +(\slope,-\height)
-  -- +(0,0)
-  {[\nstyle]
-    ++(#1,-\height/2) coordinate (timing at ref)
-    ++(\slope,-\height/2)%
-  }
-  \newdraw
-  \code{\setcounter{tikztimingtrans}{-1}}%
-}
-
-\tikztimingdef{LET}{
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(\slope,\height)%
-  {[\nstyle]
-  -- +($ (#1,\height) + (\slope,0) $)%
-  }
-  -- +(#1,0)%
-  -- +(0,0)
-  {[\nstyle]
-    ++(#1,\height/2)%
-      coordinate (timing at ref)
-    ++(\slope,\height/2)%
-  }
-  \newdraw
-  \code{\setcounter{tikztimingtrans}{1}}%
-}
-
-\tikztimingdef{HEE}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(#1,0) coordinate (timing at refb)
-      \tikztiming at setref{timing at ref}{0,-\height/2}
-  -- +($ (#1,-\height) + (\slope,0) $) coordinate (timing at refa)
-  -- +(\slope,-\height)
-  -- +(0,0)
-      \tikztiming at setref{timing at ref}{#1,-\height/2}
-    ++($ (#1,-\height) + (\slope,0) $)%
-  \code{\setcounter{tikztimingtranspos}{1}}%
-  \code{\setcounter{tikztimingtrans}{-1}}%
-  \newdraw
-}%
-
-\tikztimingdef{LEE}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(#1,0) coordinate (timing at refa)
-      \tikztiming at setref{timing at ref}{0,\height/2}
-  -- +($ (#1,\height) + (\slope,0) $) coordinate (timing at refb)
-  -- +(\slope,\height)
-  -- +(0,0)
-    ++(#1,0) \tikztiming at setref{timing at ref}{0,\height/2}
-  \code{\setcounter{tikztimingtranspos}{0}}%
-  \code{\setcounter{tikztimingtrans}{1}}%
-  \newdraw
-}%
-
-\tikztimingdef{TEE}{%
-  \newdraw [\style,preaction={\bgstyle}]
-   -- +(\slope, -\height * \value{tikztimingtrans})%
-   -- +($ (#1,0) + (\slope, -\height * \value{tikztimingtrans}) $)
-   -- +(#1,0)
-   -- +(0,0)%
-      \code{\setcounter{tikztimingtranspos}{\value{tikztimingtrans}}%
-      \addtocounter{tikztimingtranspos}{+1}}
-      +($ (#1,0) + (\slope/2 + \slope/2 * \value{tikztimingtrans}, -\height/2 * \value{tikztimingtranspos}) $)
-        coordinate (timing at refa)
-      +($ (#1,0) + (\slope/2 - \slope/2 * \value{tikztimingtrans}, \height - \height/2 * \value{tikztimingtranspos}) $)
-        coordinate (timing at refb)
-     ++(#1,0)
-      \tikztiming at setref{timing at ref}{0,-\height/2 * \value{tikztimingtrans}}
-     ++(
-          .5 * \slope  + .5 * \value{tikztimingtrans} * \slope,
-         -.5 * \height - .5 * \value{tikztimingtrans} * \height
-       )
-  \code{\setcounter{tikztimingtrans}{-\value{tikztimingtrans}}}
-  \newdraw
-}%
-
-\tikztimingdef{TEH}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- ++(\slope,-\height * \value{tikztimingtrans})
-  -- ++($ (#1,0) - (\slope/2 + \slope/2 * \value{tikztimingtrans},0) $)
-  -- ++(\slope * \value{tikztimingtrans},
-        \height * \value{tikztimingtrans})
-  -- ++($ -1*(#1,0) - (\slope/2 + \slope/2 * \value{tikztimingtrans},0) $)
-     ++($ (#1,-\height/2 * \value{tikztimingtrans}) $) coordinate (timing at ref)
-     ++(\slope,\height/2)
-  \newdraw
-}
-
-\tikztimingdef{TEL}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- ++(\slope,-\height * \value{tikztimingtrans})
-  -- ++($ (#1,0) - (\slope/2 - \slope/2 * \value{tikztimingtrans},0) $)
-  -- ++(-\slope * \value{tikztimingtrans},
-        \height * \value{tikztimingtrans})
-  -- ++($ -1*(#1,0) - (\slope/2 + -\slope/2 * \value{tikztimingtrans},0) $)
-     ++($ (#1,-\height/2 * \value{tikztimingtrans}) $) coordinate (timing at ref)
-     ++(\slope,-\height/2)
-  \newdraw
-}
-
-\tikztimingdef{TEZ}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- ++(\slope,-\height * \value{tikztimingtrans})
-  -- ++($ (#1,0) - (\slope,0) $)
-  -- ++(\zslope,
-        \height/2 * \value{tikztimingtrans})
-  -- ++(-\zslope,
-        \height/2 * \value{tikztimingtrans})
-  -- ++($ -1*(#1,0) $)
-     ++($ (#1,0) + (0,-\height/2 * \value{tikztimingtrans}) $)
-       coordinate (timing at ref)
-     ++(\zslope,0)
-  \newdraw
-}
-
-\tikztimingdef{TED}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- ++(\slope,-\height * \value{tikztimingtrans})
-  -- ++($ (#1,0) - (\slope,0) $)
-  -- ++(\dslope/2,
-        \height/2 * \value{tikztimingtrans})
-  -- ++(-\dslope/2,
-        \height/2 * \value{tikztimingtrans})
-  -- ++($ -1*(#1,0) $)
-     ++($ (#1,0) + (0,-\height/2 * \value{tikztimingtrans}) $)
-       coordinate (timing at ref)
-     ++(\dslope/2,0)
-  \newdraw
-}
-
-\tikztimingdef{TET}{%
-  \newdraw [\style,preaction={\bgstyle}]
-   -- +(\slope, -\height * \value{tikztimingtrans})%
-   {[\nstyle]
-   -- +($ (#1,0) + (\slope, -\height * \value{tikztimingtrans}) $)%
-   }
-   -- +(#1,0)%
-   -- +(0,0)%
-   {[\nstyle]
-     ++($ (#1,0) + (0, -\height/2 * \value{tikztimingtrans}) $)%
-       coordinate (timing at ref)
-     ++(\slope, -\height/2 * \value{tikztimingtrans})%
-   }
-  \code{\setcounter{tikztimingtrans}{-\value{tikztimingtrans}}}
-  \newdraw
-}%
-
-\tikztimingdef{EEZ}{%
-  \newdraw [\style,preaction={\bgstyle}]
-   --   (timing at refb)
-   --   ($ (timing at ref)  + (#1,+\height/2) $)
-   --   ($ (timing at ref)  + (#1,0) + (\zslope,0) $)
-   --   ($ (timing at ref)  + (#1,-\height/2) $)
-   --   (timing at refa)
-        ($ (timing at ref)  + (#1,0) + (\zslope,0) $)
-      coordinate (timing at ref) at ($ (timing at ref) + (#1,0) $)
-  \newdraw
-}%
-
-\tikztimingdef{EED}{%
-  \newdraw [\style,preaction={\bgstyle}]
-   --   (timing at refb)
-   --   ($ (timing at ref)  + (#1,+\height/2) $)
-   --   ($ (timing at ref)  + (#1,0) + (\dslope/2,0) $)
-   --   ($ (timing at ref)  + (#1,-\height/2) $)
-   --   (timing at refa)
-        ($ (timing at ref)  + (#1,0) + (\dslope/2,0) $)
-      coordinate (timing at ref) at ($ (timing at ref) + (#1,0) $)
-  \newdraw
-}%
-
-\tikztimingdef{HEZ}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(#1,0)
-  -- +($ (#1,-\height/2) + (\zslope,0) $)%
-  -- +(#1,-\height)
-  -- +(\slope,-\height)
-  -- +(0,0)
-    ++(#1,-\height/2) coordinate (timing at ref)
-    ++(\zslope,0)%
-  \newdraw
-}%
-
-\tikztimingdef{LEZ}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(\slope,\height)
-  -- +(#1,\height)
-  -- +($ (#1,\height/2) + (\zslope,0) $)%
-  -- +(#1,0)
-  -- +(0,0)
-    ++(#1,\height/2) coordinate (timing at ref)
-    ++(\zslope,0)%
-  \newdraw
-}%
-
-\tikztimingdef{LED}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(\slope,\height)
-  -- +(#1,\height)
-  -- +($ (#1,\height/2) + (\dslope/2,0) $)%
-  -- +(#1,0)
-  -- +(0,0)
-    ++(#1,\height/2) coordinate (timing at ref)
-    ++(\dslope/2,0)%
-  \newdraw
-}%
-
-\tikztimingdef{HED}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(#1,0)
-  -- +($ (#1,-\height/2) + (\dslope/2,0) $)%
-  -- +(#1,-\height)
-  -- +(\slope,-\height)
-  -- +(0,0)
-    ++(#1,-\height/2) coordinate (timing at ref)
-    ++(\dslope/2,0)%
-  \newdraw
-}%
-
-\tikztimingdef{EZ}{%
-  \newdraw [\style]
-  --   ($ (timing at ref) + (#1,0) $)%
-}
-
-\tikztimingdef{EM}{%
-  \newdraw [\style]
-  --   ($ (timing at ref) + (#1,0) $)%
-  \newdraw [\style/base]
-}
-
-\tikztimingdef{EL}{%
-  --   ($ (timing at ref) + (#1,-\height/2) $)%
-}%
-\tikztimingdef{EH}{%
-  --   ($ (timing at ref) + (#1,+\height/2) $)%
-}%
-
-\tikztimingdef{ED@}{%
-  \tikztiming at chard@{#1}%
-}
-\tikztimingcpy{E{D at edge@}@}{ED@}
-
-\tikztimingdef{ED}{%
-  \tikztiming at chard{#1}%
-}
-\tikztimingcpy{E{D at edge@}}{ED}
-\tikztimingdef{EDD}{%
-  \tikztiming at chard@{#1}%
-}
-\tikztimingdef{EUU}{%
-  \tikztiming at chard@{#1}%
-}
-\tikztimingdef{EDU}{%
-  \tikztiming at chard{#1}%
-}
-\tikztimingdef{EUD}{%
-  \tikztiming at chard{#1}%
-}
-
-\tikztimingdef{DE@}{%
-  \tikztiming at oldnodecenter@%
-  \newdraw [\bgstyle]
-  -- +(\dslope/2,\height/2)
-  --  ($ (timing at ref) + (#1,\height/2) $)%
-  --  ($ (timing at ref) + (#1,-\height/2) $)%
-  --  ($ (timing at save) + (\dslope/2,-\height/2) $)
-  --  (timing at save)
-  \newdraw [\style]
-  -- +(\dslope/2,\height/2)
-  --  ($ (timing at ref) + (#1,\height/2) $)%
-      ($ (timing at ref) + (#1,-\height/2) $)%
-  --  ($ (timing at save) + (\dslope/2,-\height/2) $)
-  --  (timing at save)
-      ($ (timing at ref) + (#1,0) $)%
-      coordinate (timing at ref)
-}
-
-\tikztimingdef{EEE}{%
-  \newdraw [\style,preaction={\bgstyle}]
-   --   (timing at refb)
-   --   ($ (timing at refb)  + (#1,0) $)
-   --   ($ (timing at refa)  + (#1,0) $)
-   --   (timing at refa)
-      ++(#1,0) coordinate (timing at refa)
-        coordinate (timing at refb) at ($ (timing at refb) + (#1,0) $)
-        coordinate (timing at ref)  at ($ (timing at ref)  + (#1,0) $)
-  \newdraw
-}%
-
-\tikztimingdef{EET}{%
-  \newdraw [\style,preaction={\bgstyle}]
-   --   (timing at refb)
-   {[\nstyle]
-   --   ($ (timing at ref)  + (#1,+\height/2) + (\slope/2 + \slope/2 * \value{tikztimingtrans},0) $)
-   --   ($ (timing at ref)  + (#1,-\height/2) + (\slope/2 - \slope/2 * \value{tikztimingtrans},0) $)
-   }
-   --   (timing at refa)
-   {[\nstyle]
-      ($ (timing at ref)  + (#1,\height/2 * \value{tikztimingtrans}) + (\slope,0) $)
-   }
-      coordinate (timing at ref) at ($ (timing at ref) + (#1,0) $)
-  \newdraw
-}%
-
-\tikztimingdef{EEL}{%
-  \newdraw [\style,preaction={\bgstyle}]
-   --   (timing at refb)
-   --   ($ (timing at ref)  + (#1,+\height/2) $)
-   --   ($ (timing at ref)  + (#1,-\height/2) + (\slope,0) $)
-   --   (timing at refa)
-        ($ (timing at ref)  + (#1,-\height/2) + (\slope,0) $)
-      coordinate (timing at ref) at ($ (timing at ref) + (#1,0) $)
-  \newdraw
-}%
-
-\tikztimingdef{EEH}{%
-  \newdraw [\style,preaction={\bgstyle}]
-   --   (timing at refb)
-   --   ($ (timing at ref)  + (#1,+\height/2) + (\slope,0) $)
-   --   ($ (timing at ref)  + (#1,-\height/2) $)
-   --   (timing at refa)
-        ($ (timing at ref)  + (#1,+\height/2) + (\slope,0) $)
-      coordinate (timing at ref) at ($ (timing at ref) + (#1,0) $)
-  \newdraw
-}%
-
-\tikztimingdef{EE@}{%
-  \newdraw [\bgstyle]
-      let \p0 = (timing at ref), \p1 = (timing at refa), \p2 = (timing at refb) in
-  --  (\p2)
-  --  ($ (\x0,\y2) + (#1,0) $)
-  -- +(0,\y1-\y2)
-  --  (\p1)
-  \newdraw [\style]
-      let \p0 = (timing at ref), \p1 = (timing at refa), \p2 = (timing at refb) in
-  --  (\p2)
-  --  ($ (\x0,\y2) + (#1,0) $)
-     +(0,\y1-\y2)
-  --  (\p1)
-      ($ (timing at ref) + (#1,0) $) coordinate (timing at ref)
-  \newdraw
-}%
-
-\tikztimingdef{ZE@}{
-  \newdraw [\bgstyle]
-  -- +(\zslope,\height/2)
-  -- +(#1,\height/2)%
-  -- +(#1,-\height/2)%
-  -- +(\zslope,-\height/2)
-  -- +(0,0)
-  \newdraw [\style]
-  -- +(\zslope,\height/2)
-  -- +(#1,\height/2)%
-     +(#1,-\height/2)%
-  -- +(\zslope,-\height/2)
-  -- +(0,0)
-    ++(#1,0) coordinate (timing at ref)
-}
-
-\tikztimingdef{ZEH}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(\zslope, \height/2)
-  -- +($ (#1,0) + (\slope, \height/2) $)
-  -- +(#1,-\height/2)
-  -- +(\zslope, -\height/2)
-  -- +(0,0)
-    ++(#1,0) coordinate (timing at ref)
-    ++(\slope, \height/2)
-  \newdraw
-}
-
-\tikztimingdef{ZEL}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(\zslope, \height/2)
-  -- +(#1,\height/2)
-  -- +($ (#1,0) + (\slope, -\height/2) $)
-  -- +(\zslope, -\height/2)
-  -- +(0,0)
-    ++(#1,0) coordinate (timing at ref)
-    ++(\slope, -\height/2)
-  \newdraw
-}
-
-\tikztimingdef{ZET}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(\zslope, \height/2)
-  {[\nstyle]
-  -- +($ (#1, \height/2) + (\slope/2 - \slope/2 * \value{tikztimingtrans}, 0) $)
-  -- +($ (#1,-\height/2) + (\slope/2 + \slope/2 * \value{tikztimingtrans}, 0) $)
-  }
-  -- +(\zslope, -\height/2)
-  -- +(0,0)
-  {[\nstyle]
-     ++(#1,0) coordinate (timing at ref)
-     ++(\slope,-\height/2 * \value{tikztimingtrans})
-  }
-  \code{\setcounter{tikztimingtrans}{-\value{tikztimingtrans}}}
-  \newdraw
-}
-
-\tikztimingdef{DET}{%
-  \tikztiming at oldnodecenter@%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(\dslope/2, \height/2)
-  {[\nstyle]
-  --  ($ (timing at ref) + (#1, \height/2) + (\slope/2 - \slope/2 * \value{tikztimingtrans}, 0) $)
-  --  ($ (timing at ref) + (#1,-\height/2) + (\slope/2 + \slope/2 * \value{tikztimingtrans}, 0) $)
-  }
-  --  ($ (timing at save) + (\dslope/2, -\height/2) $)
-  --  (timing at save)
-  {[\nstyle]
-       ($ (timing at ref) + (#1,0) $) coordinate (timing at ref)
-     ++(\slope,-\height/2 * \value{tikztimingtrans})
-  }
-  \code{\setcounter{tikztimingtrans}{-\value{tikztimingtrans}}}
-  \newdraw
-}
-
-\tikztimingdef{ZEZ}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(\zslope, \height/2)
-  -- +(#1,\height/2)
-  -- +($ (#1,0) + (\zslope, 0) $)
-  -- +(#1,-\height/2)
-  -- +(\zslope, -\height/2)
-  -- +(0,0)
-    ++(#1,0) coordinate (timing at ref)
-    ++(\zslope, 0)
-  \newdraw
-}
-
-\tikztimingdef{ZEE}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(\zslope, \height/2)
-  -- +($ (#1,0) + (\slope, \height/2) $) coordinate (timing at refb)
-  -- +(#1,-\height/2) coordinate (timing at refa)
-  -- +(\zslope, -\height/2)
-  -- +(0,0)
-     +(#1,0) coordinate (timing at ref)
-    ++(#1,-\height/2)
-  \code{\setcounter{tikztimingtranspos}{0}}%
-  \code{\setcounter{tikztimingtrans}{1}}%
-}
-
-\tikztimingdef{DEE}{%
-  \tikztiming at oldnodecenter@
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(\dslope/2, \height/2)
-  --  ($ (timing at ref) + (#1,0) + (\slope, \height/2) $) coordinate (timing at refb)
-  --  ($ (timing at ref) + (#1,-\height/2) $) coordinate (timing at refa)
-  --  ($ (timing at save) + (\dslope/2, -\height/2) $)
-  --  (timing at save)
-      coordinate (timing at ref) at ($ (timing at ref) + (#1,0) $)
-      (timing at refa)
-  \code{\setcounter{tikztimingtranspos}{0}}%
-  \code{\setcounter{tikztimingtrans}{1}}%
-}
-
-\tikztimingdef{DED}{%
-  \tikztiming at oldnodecenter@%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(\dslope/2, \height/2)
-  --  ($ (timing at ref) + (#1,\height/2) $)
-  --  ($ (timing at ref) + (#1,0) + (\dslope/2,0) $)
-  --  ($ (timing at ref) + (#1,-\height/2) $)
-  --  ($ (timing at save) + (\dslope/2, -\height/2) $)
-  --  (timing at save)
-      ($ (timing at ref) + (#1,0) $)
-      coordinate (timing at ref)
-    ++(\dslope/2,0)
-  \newdraw
-}
-
-\tikztimingdef{ZED}{%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(\zslope, \height/2)
-  -- +(#1,\height/2)
-  -- +($ (#1,0) + (\dslope/2, 0) $)
-  -- +(#1,-\height/2)
-  -- +(\zslope, -\height/2)
-  -- +(0,0)
-    ++(#1,0) coordinate (timing at ref)
-    ++(\dslope/2, 0)
-  \newdraw
-}
-
-\tikztimingdef{DEZ}{%
-  \tikztiming at oldnodecenter@
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(\dslope/2, \height/2)
-  --  ($ (timing at ref) + (#1,\height/2) $)
-  --  ($ (timing at ref) + (#1,0) + (\zslope, 0) $)
-  --  ($ (timing at ref) + (#1,-\height/2) $)
-  --  ($ (timing at save) + (\dslope/2, -\height/2) $)
-  --  (timing at save)
-      ($ (timing at ref) + (#1,0) $)
-      coordinate (timing at ref)
-    ++(\zslope, 0)
-  \newdraw
-}
-
-\tikztimingdef{DEH}{%
-  \tikztiming at oldnodecenter@%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(\dslope/2, \height/2)
-  --  ($ (timing at ref) + (#1,0) + (\slope, \height/2) $)
-  --  ($ (timing at ref) + (#1,-\height/2) $)
-  --  ($ (timing at save) + (\dslope/2, -\height/2) $)
-  --  (timing at save)
-      ($ (timing at ref) + (#1,0) $) coordinate (timing at ref)
-    ++(\slope, \height/2)
-  \newdraw
-}
-
-\tikztimingdef{DEL}{%
-  \tikztiming at oldnodecenter@%
-  \newdraw [\style,preaction={\bgstyle}]
-  -- +(\dslope/2, \height/2)
-  --  ($ (timing at ref) + (#1,\height/2) $)
-  --  ($ (timing at ref) + (#1,0) + (\slope, -\height/2) $)
-  --  ($ (timing at save) + (\dslope/2, -\height/2) $)
-  --  (timing at save)
-      ($ (timing at ref) + (#1,0) $) coordinate (timing at ref)
-    ++(\slope, -\height/2)
-  \newdraw
-}
-
-\tikztimingdef{@E}{%
-  \code{\setcounter{tikztimingtranspos}{0}}%
-  \code{\setcounter{tikztimingtrans}{1}}%
-  \tikztiminguse{@D}{#1}
-}
-
-\tikztimingdef{@DE}{%
-  \tikztiming@@chard{#1}%
-}
-\tikztimingdef{DDE}{
-  \tikztiming@@chard{#1}%
-}
-
-\tikztimingdef{@EH}{%
-  \tikztiming at setref{timing/start}{0,\height/2}
-  \newdraw [\bgstyle]
-  -- +(0,\height)
-  -- +($ (#1,\height) + (\slope,0) $)
-  -- +(#1,0)
-  -- +(0,0)
-  \newdraw [\style]
-      +(0,\height)
-   -- +($ (#1,\height) + (\slope,0) $)
-   -- +(#1,0)
-   -- +(0,0)
-     ++(#1,\height/2) coordinate (timing at ref)
-     ++(\slope,\height/2)
-  \newdraw
-}
-
-\tikztimingdef{@ET}{%
-  \tikztiming at setref{timing/start}{0,\height/2}
-  \newdraw [\bgstyle]
-  -- +(0,\height)
-  {[\nstyle]
-  --  ($ (timing at ref) + (#1,\height/2) + (\slope,0) $)
-  }
-  --  ($ (timing at ref) + (#1,-\height/2) $)
-  --  (timing at save)
-  \newdraw [\style]
-     +(0,\height)
-  {[\nstyle]
-  --  ($ (timing at ref) + (#1,\height/2) + (\slope,0) $)
-  }
-  --  ($ (timing at ref) + (#1,-\height/2) $)
-  --  (timing at save)
-  {[\nstyle]
-      ($ (timing at ref) + (#1,0) $) coordinate (timing at ref)
-    ++(\slope,\height/2)
-  }
-  \newdraw
-  \code{\setcounter{tikztimingtrans}{-\value{tikztimingtrans}}}
-}
-
-\tikztimingdef{ET}{%
-  {[\style]
-  --   ($ (timing at ref) + (#1,\height/2 * \value{tikztimingtrans}) $)
-  }
-}
-
-\tikztimingdef{@EL}{%
-  \tikztiming at setref{timing/start}{0,\height/2}
-  \newdraw [\bgstyle]
-  -- +(0,\height)
-  -- +(#1,\height)
-  -- +($ (#1,0) + (\slope,0) $)
-  -- +(0,0)
-  \newdraw [\style]
-      +(0,\height)
-   -- +(#1,\height)
-   -- +($ (#1,0) + (\slope,0) $)
-   -- +(0,0)
-     ++(#1,\height/2) coordinate (timing at ref)
-     ++(\slope,-\height/2)
-  \newdraw
-}
-
-\tikztimingdef{@ED}{%
-  \tikztiming at setref{timing/start}{0,\height/2}
-  \newdraw [\bgstyle]
-  -- +(0,\height)
-  -- +(#1,\height)
-  -- +($ (#1,\height/2) + (\dslope/2,0) $)
-  -- +(#1,0)
-  -- +(0,0)
-  \newdraw [\style]
-      +(0,\height)
-   -- +(#1,\height)
-   -- +($ (#1,\height/2) + (\dslope/2,0) $)
-   -- +(#1,0)
-   -- +(0,0)
-     ++(#1,\height/2) coordinate (timing at ref)
-     ++(\dslope/2,0)
-}
-
-\tikztimingdef{@EZ}{%
-  \tikztiming at setref{timing/start}{0,\height/2}
-  \newdraw [\bgstyle]
-  -- +(0,\height)
-  -- +(#1,\height)
-  -- +($ (#1,\height/2) + (\zslope,0) $)
-  -- +(#1,0)
-  -- +(0,0)
-  \newdraw [\style]
-      +(0,\height)
-   -- +(#1,\height)
-   -- +($ (#1,\height/2) + (\zslope,0) $)
-   -- +(#1,0)
-   -- +(0,0)
-     ++(#1,\height/2) coordinate (timing at ref)
-     ++(\zslope,0)
-}
-
-\tikztimingdef{@EE}{%
-  \tikztiming at setref{timing/start}{0,\height/2}
-  \newdraw [\bgstyle]
-  -- +(0,\height)
-  -- +($ (#1,\height) + (\slope,0) $)
-  -- +(#1,0)
-  -- +(0,0)
-  \newdraw [\style]
-      +(0,\height)
-   -- +($ (#1,\height) + (\slope,0) $) coordinate (timing at refb)
-   -- +(#1,0) coordinate (timing at refa)
-   -- +(0,0)
-     ++(#1,0)
-     \tikztiming at setref{timing at ref}{0,\height/2}
-  \code{\setcounter{tikztimingtranspos}{0}}%
-  \code{\setcounter{tikztimingtrans}{1}}%
-}
-
-\def\tikztiming at nocombine@E{}%%
-\endinput
-%%
-%% End of file `tikz-timing-either.sty'.

Deleted: trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-ifsym.sty
===================================================================
--- trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-ifsym.sty	2017-12-11 01:54:21 UTC (rev 46034)
+++ trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-ifsym.sty	2017-12-11 22:21:38 UTC (rev 46035)
@@ -1,88 +0,0 @@
-%%
-%% This is file `tikz-timing-ifsym.sty',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% tikz-timing.dtx  (with options: `lib,lib-ifsym')
-%% 
-%% Copyright (C) 2009-2011 by Martin Scharrer <martin at scharrer-online.de>
-%% 
-%% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either version 1.3c
-%% of this license or (at your option) any later version.
-%% The latest version of this license is in
-%% 
-%%    http://www.latex-project.org/lppl.txt
-%% 
-%% and version 1.3c or later is part of all distributions of LaTeX
-%% version 2008/05/04 or later.
-%% 
-%% This work has the LPPL maintenance status `maintained'.
-%% 
-%% The Current Maintainer of this work is Martin Scharrer.
-%% 
-%% This work consists of the files tikz-timing.dtx, tikz-timing.ins
-%% and the derived file tikz-timing.sty.
-%% 
-\RequirePackage{svn-prov}[2009/05/03]
-\ProvidesPackageSVN[tikz-timing-ifsym]
-  {$Id: tikz-timing.dtx 2038 2011-01-09 20:44:26Z martin $}
-  [v0.7d
-   TikZ-Timing Library for
-   ifsym compatible macros]
-\GetFileInfoSVN*%
-\RequirePackage{tikz-timing}[\filedate]%
-\DefineFileInfoSVN
-\tikzset{%
-  timing/ifsym/macro/.style={/tikz/timing/ifsym,/utils/exec={\pgfmathparse{.6*\f at size}\let\ysize\pgfmathresult},/tikz/y=\ysize},
-  timing/ifsym/.style={%
-    /tikz,timing/slope=0,x=\f at size,y=\f at size,line width=0.1ex,
-    timing/metachar={|}{G},
-    timing/x/.style={},
-    timing/metachar={M}[1]{#1X},
-    timing/metachar={m}[1]{#1x},
-    /utils/exec={%
-\def\tikztimingsetdslope##1{%
-  \pgfmathparse{max(0.0,##1)}%
-  \let\tikztiming at dslope\pgfmathresult
-  \edef\timingdslope{\tikztiming at dslope*\noexpand\timingwidth}%
-}
-\tikztiming at defcode{<}{%
-  \@ifnextchar{<}%
-    {\tikztiming at ifsym@longslope{X}{D}}%
-    {\tikztiming at parser [timing/dslope=1] 0Xd;}%
-}%
-\tikztiming at defcode{>}{%
-  \@ifnextchar{>}%
-    {\tikztiming at ifsym@longslope{D}{X}}%
-    {\tikztiming at parser [timing/dslope=1] 0Dx;}%
-}%
-\def\tikztiming at ifsym@longslope##1##2##3{
-    \tikztiming at parser [timing/dslope=2.] 0##1 ##2;%
-}%
-  }},
-}
-\tikzset{%
-  timing/ifsym/.cd,
-  provide/.code={\let\tikztiming at ifsym@def\providecommand},
-  renew/.code={\let\tikztiming at ifsym@def\renewcommand},
-  new/.code={\let\tikztiming at ifsym@def\newcommand},
-  off/.code={\let\tikztiming at ifsym@def\@gobbletwo},
-}
-\tikzset{timing/ifsym/provide}%
-\RequirePackage{pgfopts}
-\ProcessPgfOptions{/tikz/timing/ifsym}
-\tikztiming at ifsym@def{\RaisingEdge}{\hbox{\texttiming[timing/ifsym/macro]{.4L .4H}}}
-\tikztiming at ifsym@def{\FallingEdge}{\hbox{\texttiming[timing/ifsym/macro]{.4H .4L}}}
-\tikztiming at ifsym@def{\ShortPulseHigh}{\hbox{\texttiming[timing/ifsym/macro]{.4L .2H .4L}}}
-\tikztiming at ifsym@def{\ShortPulseLow}{\hbox{\texttiming[timing/ifsym/macro]{.4H .2L .4H}}}
-\tikztiming at ifsym@def{\PulseHigh}{\hbox{\texttiming[timing/ifsym/macro]{.4L .6H .4L}}}
-\tikztiming at ifsym@def{\PulseLow}{\hbox{\texttiming[timing/ifsym/macro]{.4H .6L .4H}}}
-\tikztiming at ifsym@def{\LongPulseHigh}{\hbox{\texttiming[timing/ifsym/macro]{.4L H .4L}}}
-\tikztiming at ifsym@def{\LongPulseLow}{\hbox{\texttiming[timing/ifsym/macro]{.4H L .4H}}}
-\tikztiming at ifsym@def{\textifsym}{\texttiming[timing/ifsym]}
-\let\tikztiming at ifsym@def\@undefined
-\endinput
-%%
-%% End of file `tikz-timing-ifsym.sty'.

Deleted: trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-interval.sty
===================================================================
--- trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-interval.sty	2017-12-11 01:54:21 UTC (rev 46034)
+++ trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-interval.sty	2017-12-11 22:21:38 UTC (rev 46035)
@@ -1,110 +0,0 @@
-%%
-%% This is file `tikz-timing-interval.sty',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% tikz-timing.dtx  (with options: `lib,lib-interval')
-%% 
-%% Copyright (C) 2009-2011 by Martin Scharrer <martin at scharrer-online.de>
-%% 
-%% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either version 1.3c
-%% of this license or (at your option) any later version.
-%% The latest version of this license is in
-%% 
-%%    http://www.latex-project.org/lppl.txt
-%% 
-%% and version 1.3c or later is part of all distributions of LaTeX
-%% version 2008/05/04 or later.
-%% 
-%% This work has the LPPL maintenance status `maintained'.
-%% 
-%% The Current Maintainer of this work is Martin Scharrer.
-%% 
-%% This work consists of the files tikz-timing.dtx, tikz-timing.ins
-%% and the derived file tikz-timing.sty.
-%% 
-\RequirePackage{svn-prov}[2009/05/03]
-\ProvidesPackageSVN[tikz-timing-interval]
-  {$Id: tikz-timing.dtx 2038 2011-01-09 20:44:26Z martin $}
-  [v0.7d
-   TikZ-Timing Library for
-   alternative Z transitions]
-\GetFileInfoSVN*%
-\RequirePackage{tikz-timing}[\filedate]%
-\DefineFileInfoSVN
-
-\let\tikztiming at linterval\relax
-\let\tikztiming at rinterval\relax
-
-\tikztimingdef{LZ}{
-  \tikztiming at rinterval
-  {\newdraw [\style]}
-  {-- ++(\zslope,+\height/2.)}
-  -- ++($ (#1,0) - (\zslope,0) $)
-}
-
-\tikztimingdef{HZ}{%
-  \tikztiming at rinterval
-  {\newdraw [\style]}
-  {-- ++(\zslope,-\height/2.)}
-  -- ++($ (#1,0) - (\zslope,0) $)
-}
-
-\tikztimingdef{TZ}{%
-  \code{\setcounter{tikztimingtrans}{-\value{tikztimingtrans}}}
-  \tikztiming at rinterval
-  {\newdraw [\style]}
-  {-- ++(\zslope,\value{tikztimingtrans}*\height/2.)}
-  -- ++($ (#1,0) - (\zslope,0) $)
-}
-
-\tikztimingdef{ZL}{%
-  \tikztiming at linterval
-  {\newdraw}
-  {-- ++(\zslope,-\height/2.)}
-  -- ++($ (#1,0) - (\zslope,0) $)
-}
-
-\tikztimingdef{ZH}{%
-  \tikztiming at linterval
-  {\newdraw}
-  {-- ++(\zslope,\height/2.)}
-  -- ++($ (#1,0) - (\zslope,0) $)
-}
-
-\tikztimingdef{ZT}{%
-  \code{\setcounter{tikztimingtrans}{-\value{tikztimingtrans}}}
-  \tikztiming at linterval
-  {\newdraw [\style]}
-  {-- ++(\zslope,\value{tikztimingtrans}*\height/2.)}
-  -- ++($ (#1,0) - (\zslope,0) $)
-}
-
-\def\tikztiming at onetwo#1#2{#1#2}
-\def\tikztiming at twoone#1#2{#2#1}
-
-\let\tikztiming at linterval\tikztiming at onetwo
-\let\tikztiming at rinterval\tikztiming at onetwo
-
-\tikzset{timing/interval/.code={\pgfqkeys{/tikz/timing/interval}{#1}}}
-\tikzset{timing/interval/.cd,
-   lo/.style={/tikz/timing/interval/left open},
-   lc/.style={/tikz/timing/interval/left close},
-   ro/.style={/tikz/timing/interval/right open},
-   rc/.style={/tikz/timing/interval/right close},
-   left close/.code={\let\tikztiming at linterval\tikztiming at onetwo},
-   left open/.code={\let\tikztiming at linterval\tikztiming at twoone},
-   right open/.code={\let\tikztiming at rinterval\tikztiming at onetwo},
-   right close/.code={\let\tikztiming at rinterval\tikztiming at twoone},
-}
-\tikzset{
-  timing/interval/normal/.style={/tikz/timing/interval/left close,/tikz/timing/interval/right open},
-  timing/interval/verilog/.style={/tikz/timing/interval/normal},
-  timing/interval/metachar/.style={/tikz/timing/metachar={#1}[2]{[timing/interval={##2}]}},
-}
-
-\endinput
-%%
-%% End of file `tikz-timing-interval.sty'.

Deleted: trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-nicetabs.sty
===================================================================
--- trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-nicetabs.sty	2017-12-11 01:54:21 UTC (rev 46034)
+++ trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-nicetabs.sty	2017-12-11 22:21:38 UTC (rev 46035)
@@ -1,125 +0,0 @@
-%%
-%% This is file `tikz-timing-nicetabs.sty',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% tikz-timing.dtx  (with options: `lib,lib-nicetabs')
-%% 
-%% Copyright (C) 2009-2011 by Martin Scharrer <martin at scharrer-online.de>
-%% 
-%% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either version 1.3c
-%% of this license or (at your option) any later version.
-%% The latest version of this license is in
-%% 
-%%    http://www.latex-project.org/lppl.txt
-%% 
-%% and version 1.3c or later is part of all distributions of LaTeX
-%% version 2008/05/04 or later.
-%% 
-%% This work has the LPPL maintenance status `maintained'.
-%% 
-%% The Current Maintainer of this work is Martin Scharrer.
-%% 
-%% This work consists of the files tikz-timing.dtx, tikz-timing.ins
-%% and the derived file tikz-timing.sty.
-%% 
-\RequirePackage{svn-prov}[2009/05/03]
-\ProvidesPackageSVN[tikz-timing-nicetabs]
-  {$Id: tikz-timing.dtx 2038 2011-01-09 20:44:26Z martin $}
-  [v0.7d
-   TikZ-Timing Library for
-   nice timing tables]
-\GetFileInfoSVN*%
-\RequirePackage{tikz-timing}[\filedate]%
-\DefineFileInfoSVN
-\RequirePackage{array}
-\RequirePackage{booktabs}
-
-\newcommand*\tikztiming at nicetabs@tableheader[1][]{%
-  \path [timing/table/midrules] [/utils/exec=\xdef\@gtempa{\the\pgflinewidth}];
-  \path [timing/table/header,#1]
-    let \p1 = (0,\belowrulesep + \aboverulesep + \@gtempa
-            + \arraystretch\ht\strutbox + \arraystretch*\extrarowheight
-            + \arraystretch\dp\strutbox)
-    in
-      coordinate (diagram at header) at (0,\y1)
-      coordinate (label at header)   at ($ -1*(\tikztiming at coldist,0) + (0,\y1) $)
-    ;
-  \tikztiming at normal@tableheader[#1]%
-}
-\newcommand*\tikztiming at nicetabs@tablerules[1][]{%
-  \begin{scope}[#1]
-    \coordinate (NW) at (current bounding box.north west);
-    \coordinate (SE) at (current bounding box.south east);
-    %
-    \draw [timing/table/rules]
-    let
-      \p1 = (NW),
-      \p2 = (SE),
-      \p3 = (last label.base),
-      \p4 = ($ (0,\y3) - (0,\arraystretch\dp\strutbox + \aboverulesep +
-        .5\pgflinewidth) $)
-    in
-      (\x1-\tabcolsep,\y4) -- (\x2+\tabcolsep,\y4)
-     \iftikztiming at tablehead
-      let
-        \p5 = (diagram at header.base),
-        \p6 = ($ (0,\y5) + (0,\arraystretch\ht\strutbox + \arraystretch*\extrarowheight
-        + \belowrulesep + .5\pgflinewidth) $)
-      in
-        (\x1-\tabcolsep,\y6) -- (\x2+\tabcolsep,\y6)
-     \fi
-    ;
-    \draw
-     \iftikztiming at tablehead [timing/table/midrules] \else [timing/table/rules] \fi
-    let
-      \p1 = (NW),
-      \p2 = (SE),
-      \p3 = (0, \arraystretch\ht\strutbox + \arraystretch*\extrarowheight +
-        \belowrulesep + .5\pgflinewidth)
-    in
-      (\x1-\tabcolsep, \y3)
-       --
-      (\x2+\tabcolsep, \y3)
-    ;
-  \end{scope}
-}
-\let\tikztiming at normal@tableheader\tikztiming at tableheader
-\let\tikztiming at normal@tablerules\tikztiming at tablerules
-\let\tikztiming at normal@coldist\tikztiming at coldist
-\let\tikztiming at normal@rowdist\tikztiming at rowdist
-
-\tikzset{%
-  timing/no nice tabs/.code={%
-    \let\tikztiming at coldist\tikztiming at normal@coldist
-    \let\tikztiming at rowdist\tikztiming at normal@rowdist
-    \let\tikztiming at tableheader\tikztiming at normal@tableheader
-    \let\tikztiming at tablerules\tikztiming at normal@tablerules
-  },
-  timing/nice tabs/.code={%
-    \ifx\tikztiming at tableheader\tikztiming at nicetabs@tableheader\else
-      \let\tikztiming at normal@coldist\tikztiming at coldist
-      \let\tikztiming at normal@rowdist\tikztiming at rowdist
-    \fi
-    \def\tikztiming at rowdist{%
-       \arraystretch\ht\strutbox
-      +\arraystretch*\extrarowheight
-      +\arraystretch\dp\strutbox
-    }%
-    \def\tikztiming at coldist{2\tabcolsep}%
-    \let\tikztiming at tableheader\tikztiming at nicetabs@tableheader
-    \let\tikztiming at tablerules\tikztiming at nicetabs@tablerules
-  },
-  timing/nicetabs/no nice tabs/.style={/tikz/timing/no nice tabs},
-  timing/nicetabs/off/.style={/tikz/timing/no nice tabs},
-  timing/nicetabs/nice tabs/.style={/tikz/timing/nice tabs},
-  timing/nicetabs/on/.style={/tikz/timing/nice tabs},
-}
-\tikzset{timing/nice tabs}%
-\RequirePackage{pgfopts}
-\ProcessPgfOptions{/tikz/timing/nicetabs}
-\endinput
-%%
-%% End of file `tikz-timing-nicetabs.sty'.

Deleted: trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-overlays.sty
===================================================================
--- trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-overlays.sty	2017-12-11 01:54:21 UTC (rev 46034)
+++ trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing-overlays.sty	2017-12-11 22:21:38 UTC (rev 46035)
@@ -1,88 +0,0 @@
-%%
-%% This is file `tikz-timing-overlays.sty',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% tikz-timing.dtx  (with options: `lib,lib-overlays')
-%% 
-%% Copyright (C) 2009-2011 by Martin Scharrer <martin at scharrer-online.de>
-%% 
-%% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either version 1.3c
-%% of this license or (at your option) any later version.
-%% The latest version of this license is in
-%% 
-%%    http://www.latex-project.org/lppl.txt
-%% 
-%% and version 1.3c or later is part of all distributions of LaTeX
-%% version 2008/05/04 or later.
-%% 
-%% This work has the LPPL maintenance status `maintained'.
-%% 
-%% The Current Maintainer of this work is Martin Scharrer.
-%% 
-%% This work consists of the files tikz-timing.dtx, tikz-timing.ins
-%% and the derived file tikz-timing.sty.
-%% 
-\RequirePackage{svn-prov}[2009/05/03]
-\ProvidesPackageSVN[tikz-timing-overlays]
-  {$Id: tikz-timing.dtx 2038 2011-01-09 20:44:26Z martin $}
-  [v0.7d
-   TikZ-Timing Library for
-   timing overlays]
-\GetFileInfoSVN*%
-\RequirePackage{tikz-timing}[\filedate]%
-\DefineFileInfoSVN
-\tikztiming at defcode{O}#1{%
-  \ifx\relax#1\empty
-    \def\tikztiming at next{\tikztiming at parser#1}%
-  \else
-    \let\tikztiming at overlay@lastchar\tikztiming at lastchar
-    \let\tikztiming at overlay@width\tikztimingwidth
-    \tikztiming at output@addcode{\tikztiming at overlay@begin}%
-    \begingroup
-      \def\tikztiming at parser@end{%
-        \def\tikztiming at output@nextchar{@}%
-        \tikztiming at output@flush
-      }
-      \begingroup
-        \tikztiming at parser #1\relax
-      \endgroup
-    \endgroup
-    \tikztiming at output@addcode{\tikztiming at overlay@end}%
-    \global\let\tikztiming at lastchar\tikztiming at overlay@lastchar
-    \global\let\tikztimingwidth\tikztiming at overlay@width
-    \def\tikztiming at next{\expandafter\tikztiming at parser\@firstofone}%
-  \fi
-  \tikztiming at next
-}
-\let\tikztiming at overlay@save\empty
-\let\pgf at sh@nt at tikztiming@overlay at node\empty
-\def\tikztiming at overlay@begin{
-    [/utils/exec={%
-    \xdef\tikztiming at overlay@save{%
-      \noexpand\global\noexpand\c at tikztimingtrans\the\c at tikztimingtrans\relax%
-      \noexpand\global\noexpand\c at tikztimingtranspos\the\c at tikztimingtranspos\relax%
-      \noexpand\gdef\noexpand\pgf at sh@nt at tikztiming@overlay at node
-        {\csname pgf at sh@nt at tikztiming@overlay at node\endcsname}%
-      \noexpand\gdef\noexpand\pgf at sh@nt at timing@refa
-        {\csname pgf at sh@nt at timing@refa\endcsname}%
-      \noexpand\gdef\noexpand\pgf at sh@nt at timing@refb
-        {\csname pgf at sh@nt at timing@refb\endcsname}%
-      \noexpand\gdef\noexpand\pgf at sh@nt at timing@ref
-        {\csname pgf at sh@nt at timing@ref\endcsname}%
-      \noexpand\gdef\noexpand\tikztiming at overlay@save{%
-        \expandafter\unexpanded\expandafter{\tikztiming at overlay@save}%
-      }%
-    }%
-    }]%
-    node [timing/save] (tikztiming at overlay@node) {}
-  }%
-\def\tikztiming at overlay@end{%
-  \tikztiming at newdraw (tikztiming at overlay@node)
-  [/utils/exec={\tikztiming at overlay@save}]
-}%
-\endinput
-%%
-%% End of file `tikz-timing-overlays.sty'.

Modified: trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing.sty
===================================================================
--- trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing.sty	2017-12-11 01:54:21 UTC (rev 46034)
+++ trunk/Master/texmf-dist/tex/latex/tikz-timing/tikz-timing.sty	2017-12-11 22:21:38 UTC (rev 46035)
@@ -4,33 +4,44 @@
 %%
 %% The original source files were:
 %%
-%% tikz-timing.dtx  (with options: `package')
+%% tikz-timing.dtx  (with options: `tikz-timing.sty')
 %% 
-%% Copyright (C) 2009-2011 by Martin Scharrer <martin at scharrer-online.de>
+%% IMPORTANT NOTICE:
 %% 
+%% For the copyright see the source file.
+%% 
+%% Any modified versions of this file must be renamed
+%% with new filenames distinct from tikz-timing.sty.
+%% 
+%% For distribution of the original source see the terms
+%% for copying and modification in the file tikz-timing.dtx.
+%% 
+%% This generated file may be distributed as long as the
+%% original source files, as listed above, are part of the
+%% same distribution. (The sources need not necessarily be
+%% in the same archive or directory.)
+%% Copyright (C) 2009-2012 by Martin Scharrer <martin at scharrer-online.de>
+%% ----------------------------------------------------------------------
 %% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either version 1.3c
+%% conditions of the LaTeX Project Public License, either version 1.3
 %% of this license or (at your option) any later version.
 %% The latest version of this license is in
-%% 
-%%    http://www.latex-project.org/lppl.txt
-%% 
-%% and version 1.3c or later is part of all distributions of LaTeX
-%% version 2008/05/04 or later.
-%% 
+%%   http://www.latex-project.org/lppl.txt
+%% and version 1.3 or later is part of all distributions of LaTeX
+%% version 2005/12/01 or later.
+%%
 %% This work has the LPPL maintenance status `maintained'.
-%% 
+%%
 %% The Current Maintainer of this work is Martin Scharrer.
-%% 
-%% This work consists of the files tikz-timing.dtx, tikz-timing.ins
-%% and the derived file tikz-timing.sty.
-%% 
-\RequirePackage{svn-prov}[2009/05/03]
-\ProvidesPackageSVN
-  {$Id: tikz-timing.dtx 2038 2011-01-09 20:44:26Z martin $}
-  [v0.7d
-   Digital Timing Diagrams using TikZ]
-\DefineFileInfoSVN[tikztiming]
+%%
+%% This work consists of the files tikz-timing.dtx and tikz-timing.ins
+%% and the derived filebase tikz-timing*.sty.
+%%
+\NeedsTeXFormat{LaTeX2e}[1999/12/01]
+\ProvidesPackage{tikz-timing}[%
+    2017/12/10
+    v0.7e
+    Digital Timing Diagrams using TikZ]
 \RequirePackage{tikz}
 
 \usetikzlibrary{calc}
@@ -159,6 +170,8 @@
   name/.style={inner sep=0pt,outer sep=0pt,minimum size=0pt},
   text format/.store in=\tikztiming at textformat,
   @/.style={},
+  every char/.style={},
+  every bg/.style={},
   D/.style={timing/d},
   D/text/.style={timing/d/text},
   D/background/.style={timing/d/background},
@@ -297,9 +310,9 @@
     \def\tikztimingwidth{0.0}%
     \setcounter{tikztimingtrans}{-1}%
     \setcounter{tikztimingtranspos}{0}%
-    \def\tikztiming at str{%
+    \tikztiming at initstr{%
       \useasboundingbox (0,0) rectangle (\tikztimingwidth,\timingheight);
-      \draw (0,0)
+      \draw [timing/every char] (0,0)
         coordinate (timing at refa)
         coordinate (timing at ref)  at (0,\timingheight/2)
         coordinate (timing at refb) at (0,\timingheight)
@@ -349,23 +362,6 @@
         {\tikz at timing@@@init}%
         {\tikz at timing@@@init[]}%
       #3\relax
-      \ifnum\tikztiming at debug>1
-      \message{^^J\meaning\tikztiming at str^^J}%
-      \ifnum\tikztiming at debug>2
-      {%
-      \def\@protect##1{\def##1{\noexpand##1}}%
-      \@protect\useasboundingbox
-      \@protect\draw
-      \@protect\p
-      \@protect\n
-      \@protect\x
-      \@protect\y
-      \@protect\tikztiming at overlay@save
-      \edef\@tempa{\tikztiming at str}%
-      \message{^^J\meaning\@tempa^^J}%
-      }%
-      \fi
-      \fi
       \tikzset{timing/before}%
       \tikztiming at str;%
       \path let \p1 = (timing/end top), \p2 = (timing/end base),
@@ -403,7 +399,9 @@
   \tikztiming at parser
 }
 \def\tikztiming at trans@#1#2#3#4{%
-  \csname\tikztiming at prefix #2#3#4\endcsname{#1}{#2}{#3}{#4}%
+    \unexpanded\expandafter\expandafter\expandafter{%
+        \csname\tikztiming at prefix #2#3#4\endcsname{#1}{#2}{#3}{#4}
+    }%
 }
 \def\tikztiming at beforenextcode@D at edge@{%
   \if D\tikztiming at currentchar\else
@@ -439,6 +437,10 @@
     }%
   \endgroup
 }
+\iftrue
+\long\def\tikztiming at initstr{%
+    \def\tikztiming at str
+}
 \def\tikztiming at eaddtostr{%
   \tikztiming at eaddto\tikztiming at str
 }
@@ -445,6 +447,37 @@
 \def\tikztiming at addtostr{%
   \g at addto@macro\tikztiming at str
 }
+\else
+\def\tikztiming at file{\jobname.ttg}
+\newwrite\tikztiming at fh
+\def\tikztiming at str{%
+    \tikztiming at addtostr{;}%
+    \immediate\closeout\tikztiming at fh
+    \begingroup
+    \makeatletter
+    \@@input\tikztiming at file\relax
+    \endgroup
+    \@ifnextchar;{\@gobble}{}%
+}
+\long\def\tikztiming at initstr{%
+    \immediate\openout\tikztiming at fh= \tikztiming at file\relax
+    \tikztiming at addtostr
+}
+\long\def\tikztiming at eaddtostr#1{%
+  \begingroup
+    \tikztiming at internaldefs
+    \let\par\empty
+    \immediate\write\tikztiming at fh{#1}%
+  \endgroup
+}
+\long\def\tikztiming at addtostr#1{%
+  \begingroup
+    \tikztiming at internaldefs
+    \let\par\empty
+    \immediate\write\tikztiming at fh{\unexpanded{#1}}%
+  \endgroup
+}
+\fi
 \def\tikztiming at makeglobal#1{%
   \global\let#1#1\relax\relax
 }
@@ -473,17 +506,17 @@
     % If both do not exist, search for aliases:
     \ifx\tikztiming at trans\relax
       \@ifundefined{tikztiming at alias@#1}%
-        {\edef\chara{#1}}%
-        {\edef\chara{#1,\csname tikztiming at alias@#1\endcsname}}%
+        {\edef\chara{{#1}}}%
+        {\edef\chara{{#1},{\csname tikztiming at alias@#1\endcsname}}}%
       \@ifundefined{tikztiming at alias@#2}%
-        {\edef\charb{#2}}%
-        {\edef\charb{#2,\csname tikztiming at alias@#2\endcsname}}%
+        {\edef\charb{{#2}}}%
+        {\edef\charb{{#2},{\csname tikztiming at alias@#2\endcsname}}}%
       \@ifundefined{tikztiming at triple@#2}%
         {\def\charc{\empty}}%
         {%
          \@ifundefined{tikztiming at alias@#3}%
-           {\edef\charc{#3,}}%
-           {\edef\charc{#3,\csname tikztiming at alias@#3\endcsname,}}%
+           {\edef\charc{{#3},}}%
+           {\edef\charc{{#3},{\csname tikztiming at alias@#3\endcsname},}}%
         }%
       \ifx\charb\empty
         \def\charb{\empty}%
@@ -533,10 +566,13 @@
 \def\tikztiming at nameaddtostr#1#2#3{%
   \tikztiming at iftrans{{#1}{#2}{#3}}%
    {%
+     %\edef\@tempa{\noexpand\tikztiming at trans@{\tikztiming at num}\tikztiming at trans}%
+     %\expandafter\tikztiming at addtostr
+     %\expandafter{\@tempa}%
      \edef\@tempa{\noexpand\tikztiming at trans@{\tikztiming at num}\tikztiming at trans}%
-     \expandafter\g at addto@macro
-     \expandafter\tikztiming at str
-     \expandafter{\@tempa}%
+     %\tikztiming at eaddtostr{\@percentchar\space {#1}{#2}{#3}}%
+     \tikztiming at eaddtostr{\@tempa}%
+     %\tikztiming at eaddtostr{\tikztiming at trans@{\tikztiming at num}\tikztiming at trans}%
    }%
    {\PackageWarning{tikz-timing}{No transitions '#1#2' (or '#1#2#3') defined!}}%
 }
@@ -606,8 +642,10 @@
   \tikztiming at output@codeflush
 }
 \def\tikztiming at output@codeflush{%
-  \tikztiming at eaddtostr{\tikztiming at output@bufcode}%
-  \global\let\tikztiming at output@bufcode\empty%
+  \ifx\tikztiming at output@bufcode\empty\else
+    \tikztiming at eaddtostr{\tikztiming at output@bufcode}%
+    \global\let\tikztiming at output@bufcode\empty%
+  \fi
 }
 \def\tikztiming at output@charflush{%
   \begingroup
@@ -758,7 +796,7 @@
 }
 \tikztiming at defcode{,}{%
   \tikztiming at output@eaddcode{%
-    \newdraw
+    \newdraw [timing/every char]
   }%
   \tikztiming at parser
 }
@@ -765,7 +803,7 @@
 \tikztiming at defcode{;}{%
   \endgroup\begingroup
   \tikztiming at output@eaddcode{%
-    \newdrawns
+    \newdrawns [timing/every char]
   }%
   \tikztiming at parser
 }
@@ -829,7 +867,7 @@
 \tikztiming at defcode{\bgroup}{%
   \tikztiming at output@eaddcode{%
     [timing/pushoptions]
-    \newdraw
+    \newdraw [timing/every char]
   }%
   \tikztiming at parser
 }
@@ -836,7 +874,7 @@
 \tikztiming at defcode{\egroup}{%
   \tikztiming at output@eaddcode{%
     [timing/popoptions]
-    \newdraw
+    \newdraw [timing/every char]
   }%
   \tikztiming at parser
 }
@@ -1422,9 +1460,9 @@
   \def\zslope{\noexpand\timingzslope}%
   \def\dslope{\noexpand\timingdslope}%
   \def\gslope{0}%
-  \def\style{timing/####3}%
-  \def\bgstyle{draw=none,timing/####3/background}%
-  \def\nstyle{timing/####4}%
+  \def\style{timing/every char,timing/####3}%
+  \def\bgstyle{draw=none,timing/every bg,timing/####3/background}%
+  \def\nstyle{timing/every char,timing/####4}%
   \def\newdraw{\tikztiming at newdraw}%
   \def\newdrawns{\tikztiming at newdraw@nosave}%
   \def\code##1{ [/utils/exec={\unexpanded{##1}}] }%
@@ -1576,11 +1614,11 @@
 }
 
 \def\tikztiming at glitch{%
-  {[timing/g] let \p1 = +(0,0) in (\x1,0) -- (\x1,\timingheight)
+  {[timing/every char,timing/g] let \p1 = +(0,0) in (\x1,0) -- (\x1,\timingheight)
    coordinate (timing at dstart) at (\x1,\timingheight/2) (\x1,\y1)
   }%
 }
-\tikztimingchar{H}{++(0,\height)}{-- ++(#1,0)}
+\tikztimingchar{H}{++(0,\height)}{[\style] -- ++(#1,0)}
 
 \tikztimingdef{HH}{
   -- ++(#1,0)
@@ -1592,7 +1630,7 @@
 }
 
 \tikztimingdef{ZH}{
-    \newdraw
+    \newdraw [\style]
   -- ++(\zslope,+\height/2.)
   -- ++($ (#1,0) - (\zslope,0) $)
 }
@@ -1612,7 +1650,7 @@
 }
 
 
-\tikztimingchar{L}{++(0,0)}{-- ++(#1,0)}
+\tikztimingchar{L}{++(0,0)}{[\style] -- ++(#1,0)}
 
 \tikztimingchar{Z}{++(0,\height/2.)}{%
   \newdraw [\style]
@@ -1667,7 +1705,7 @@
   -- ++($ (#1,0) - (\zslope,0) $)
 }
 \tikztimingdef{ZL}{%
-  \newdraw
+  \newdraw [\style]
   -- ++(\zslope,-\height/2.)
   -- ++($ (#1,0) - (\zslope,0) $)
 }
@@ -1694,7 +1732,7 @@
   \tikztiming at oldnodecenter{%
     (-\dslope/2,-\height/2)
   }%
-  \newdraw
+  \newdraw [timing/every char]
 }
 
 \def\tikztiming at chard@#1{%
@@ -1717,7 +1755,7 @@
   \tikztiming at oldnodecenter{%
     (0,-\height/2)
   }%
-  \newdraw
+  \newdraw [timing/every char]
 }
 
 \def\tikztiming@@chard#1{%
@@ -1746,7 +1784,7 @@
   \tikztiming at oldnodecenter{%
     (-\dslope/2,-\height/2)
   }%
-  \newdraw
+  \newdraw [timing/every char]
 }
 
 \def\tikztiming@@chard@#1{%
@@ -1772,7 +1810,7 @@
   \tikztiming at oldnodecenter{%
     (0,-\height/2)
   }%
-  \newdraw
+  \newdraw [timing/every char]
 }
 
 \def\tikztiming at dchardu#1{%
@@ -1797,7 +1835,7 @@
   \tikztiming at oldnodecenter{%
     (-\dslope/2,-\height/2)
   }%
-  \newdraw
+  \newdraw [timing/every char]
 }
 
 \def\tikztiming at uchardd#1{%
@@ -1821,7 +1859,7 @@
   \tikztiming at oldnodecenter{%
       ($ (0,0) - (0,\height/2) $)
   }%
-  \newdraw
+  \newdraw [timing/every char]
 }
 
 \tikztimingdef{DD}{%
@@ -1851,7 +1889,7 @@
   \tikztiming at oldnodecenter{%
     (0,-\height/2)
   }%
-  \newdraw
+  \newdraw [timing/every char]
 }
 
 \tikztimingdef{DD@}{
@@ -2155,7 +2193,7 @@
 }
 
 \tikztimingdef{ZT}{%
-  \newdraw {[\style]
+  \newdraw [timing/every char] {[\style]
   \code{\setcounter{tikztimingtrans}{-\value{tikztimingtrans}}}
   -- ++(\zslope,\value{tikztimingtrans}*\height/2.)
   -- ++($ (#1,0) - (\zslope,0) $)
@@ -2173,7 +2211,7 @@
 \tikztimingdef{DT}{
   \code{\setcounter{tikztimingtrans}{-1}}
   \tikztiming at oldnodecenter@%
-  \newdraw {[\style]
+  \newdraw [timing/every char] {[\style]
   --  +(\dslope/2.,-\height/2)
   --   ($ (timing at ref) + (#1,-\height/2) $)
   }



More information about the tex-live-commits mailing list