%%
%% This is file `tikzlibraryrulercompass.code.tex',
%% generated with the docstrip utility.
%%
%% The original source files were:
%%
%% rulercompass.dtx  (with options: `tikzlibrary')
%% ---------------------------------------------------------------
%% rulercompass --- a TikZ/PGF library for drawing straight-edge
%%                  and compass diagrams
%% E-mail: stacey@math.ntnu.no
%% Released under the LaTeX Project Public Licence v1.3c or later
%% See http://www.latex-project.org/lppl.txt
%% ---------------------------------------------------------------
%% 
\usetikzlibrary{intersections,calc}
\newif\ifrc@draft
\newif\ifrc@beamer
\newif\ifrc@fliparc
\newcount\rc@picture@id
\newcounter{pointlabels}
\@ifclassloaded{beamer}{%
  \rc@beamertrue
}{}
\def\rc@pathsep{@}
\ifrc@beamer
\resetcounteronoverlays{pointlabels}
\resetcountonoverlays{rc@picture@id}
\tikzset{
  alt if exist/.code args={#1#2#3}{%
    \@ifundefined{path@\the\rc@picture@id @#1}{%
      \pgfkeysalso{#2}%
    }{
      \alt<.-\csname path@\the\rc@picture@id @#1\endcsname>{%
        \pgfkeysalso{#2}%
      }{
        \pgfkeysalso{#3}%
      }%
    }%
  },
  intersection/save/.code={%
    \only<.>{%
      \begingroup
      \tikz@intersect@path@names@parse#1\tikz@stop
      \protected@write\pgfutil@auxout{}{%
        \string\global\string\@namedef{path@\the\rc@picture@id @\tikz@intersect@path@a}{\the\beamer@slideinframe}%
        \string\global\string\@namedef{path@\the\rc@picture@id @\tikz@intersect@path@b}{\the\beamer@slideinframe}%
      }%
    \endgroup
    }%
  }
}
\newcommand<>\compass[3][]{%
  \draw#4[#1,ruler compass/compass={#2}{#3}];
}

\newcommand<>\ruler[3][]{%
  \draw#4[#1,ruler compass/ruler={#2}{#3}];
}
\newcommand<>\point[4][]{%
  {%
    \advance\c@pointlabels by 1\relax
    \xdef\rc@temp{\thepointlabels}%
  }%
  \edef\rc@tempa{\the\rc@picture@id}%
  \expandafter\ifx\csname rc@id@\rc@temp\endcsname\rc@tempa
    \path#5 (\rc@temp) node[ruler compass/point,#1] {};
  \else
    \path#5 [name intersections={use=#2 and #3}] (intersection-#4) node[ruler compass/point,#1] {};
  \fi
}
\else
\tikzset{
  alt if exist/.code args={#1#2#3}{%
    \pgfkeysalso{#2}%
  },
  intersection/save/.code={%
    \begingroup
    \tikz@intersect@path@names@parse#1\tikz@stop
    \protected@write\pgfutil@auxout{}{%
        \string\global\string\@namedef{path@\the\rc@picture@id @\tikz@intersect@path@a}{\thepage}%
        \string\global\string\@namedef{path@\the\rc@picture@id @\tikz@intersect@path@b}{\thepage}%
    }%
    \endgroup
  }
}
\newcommand\compass[3][]{%
  \draw [#1,ruler compass/compass={#2}{#3}];
}

\newcommand\ruler[3][]{%
  \draw [#1,ruler compass/ruler={#2}{#3}];
}

\newcommand\point[4][]{%
  \path [name intersections={use=#2 and #3}] (intersection-#4) node[ruler compass/point,#1] {};
}
\fi
\def\rc@processpt#1{%
  \pgfutil@ifnextchar.{\rc@processpt@@#1}{\rc@processpt@#1}}
\def\rc@processpt@#1#2\pgf@stop{%
  \pgfutil@in@+{#2}%
  \ifpgfutil@in@
   \let\@next=\rc@processpt@plus
  \else
   \pgfutil@in@-{#2}%
   \ifpgfutil@in@
    \let\@next=\rc@processpt@minus
   \else
    \let\@next=\rc@processpt@bare
   \fi
  \fi
  \@next#1#2\pgf@stop
}
\def\rc@processpt@@#1.#2\pgf@stop{%
  \def\rc@temp{#2}%
  \ifx\rc@temp\pgfutil@empty
  \edef\rc@temp{\thepointlabels}%
  \else
  \pgfmathparse{int(\the\c@pointlabels + #2)}%
  \begingroup
  \c@pointlabels=\pgfmathresult\relax
  \xdef\rc@temp{\thepointlabels}%
  \endgroup
  \fi
  \let#1\rc@temp
}
\def\rc@processpt@plus#1#2+#3\pgf@stop{%
  \pgfmathsetmacro\rc@temp{0}%
  \rc@reverse#2\pgf@stop%
  \pgfmathparse{int(\rc@temp + #3)}%
  \begingroup
  \c@pointlabels=\pgfmathresult\relax
  \xdef\rc@temp{\thepointlabels}%
  \endgroup
  \let#1\rc@temp
}
\def\rc@processpt@minus#1#2-#3\pgf@stop{%
  \pgfmathsetmacro\rc@temp{0}%
  \rc@reverse#2\pgf@stop%
  \pgfmathparse{int(\rc@temp - #3)}%
  \begingroup
  \c@pointlabels=\pgfmathresult\relax
  \xdef\rc@temp{\thepointlabels}%
  \endgroup
  \let#1\rc@temp
}
\def\rc@processpt@bare#1#2\pgf@stop{%
  \def#1{#2}}
\def\rc@reverse#1{%
  \ifx#1\pgf@stop
    \let\@next=\pgfutil@empty
  \else
    \let\@next=\rc@reverse
    \pgfutil@tempcnta=`#1\relax
    \pgfmathsetmacro\rc@temp{\rc@temp * \rc@factor + \the\pgfutil@tempcnta - \rc@initial}%
  \fi
  \@next}
\def\rc@parsepath#1#2#3#4\pgf@stop{%
  \rc@processpt\rc@tempa#3\pgf@stop
  \rc@processpt\rc@tempb#4\pgf@stop
  \xdef#1{#2\rc@pathsep\rc@tempa\rc@pathsep\rc@tempb}%
}
\tikzset{
  every picture/.append style={
    ruler compass/at begin picture
  },
  intersection/use/.code args={#1 and #2}{%
    \rc@parsepath\rc@pta#1\pgf@stop
    \rc@parsepath\rc@ptb#2\pgf@stop
    \pgfkeysalso{
      of={\rc@pta} and \rc@ptb,
      save={\rc@pta} and \rc@ptb,
    }
  },
  circle through/.style={
    to path={
      \pgfextra{
        \tikz@scan@one@point\pgfutil@firstofone(\tikztostart)\relax
        \pgf@xa=\pgf@x
        \pgf@ya=\pgf@y
        \tikz@scan@one@point\pgfutil@firstofone(\tikztotarget)\relax
        \pgfmathsetmacro\rc@radius{veclen(\pgf@x - \pgf@xa,\pgf@y - \pgf@ya)}%
      }
      circle[radius=\rc@radius pt] (\tikztotarget)
    }
  },
  arc flip/.is if=rc@fliparc,
  centred arc to/.code 2 args={%
    \tikz@scan@one@point\pgfutil@firstofone(#1)\relax
    \pgfmathsetmacro\rc@radius{veclen(\tikz@lastx-\pgf@x,\tikz@lasty-\pgf@y)}%
    \pgfmathsetmacro\rc@sangle{atan2(\tikz@lasty - \pgf@y,\tikz@lastx - \pgf@x)}%
    \pgf@xa=\pgf@x
    \pgf@ya=\pgf@y
    \tikz@scan@one@point\pgfutil@firstofone(#2)\relax
    \pgfmathsetmacro\rc@eangle{atan2(\pgf@y - \pgf@ya,\pgf@x - \pgf@xa)}%
    \pgfmathsetmacro\rc@eangle{\rc@eangle < \rc@sangle ? \rc@eangle +       360 : \rc@eangle}%
    \ifrc@fliparc
    \pgfmathsetmacro\rc@eangle{\rc@eangle - 360}%
    \fi
    \pgfkeysalso{start angle=\rc@sangle, end angle=\rc@eangle, radius=\rc@radius pt}
  },
  ruler compass/.is family,
  ruler compass/.cd,
  draft mode/.is if=rc@draft,
  at begin picture/.style={
    execute at begin picture={
      \global\advance\rc@picture@id by 1\relax
      \setcounter{pointlabels}{0}%
    },
  },
  point labels/.is choice,
  point labels/arabic/.code={%
    \renewcommand\thepointlabels{\@arabic \c@pointlabels}%
    \def\rc@initial{48}%
    \def\rc@factor{10}%
  },
  point labels/alph/.code={%
    \renewcommand\thepointlabels{\@alph \c@pointlabels}%
    \def\rc@initial{96}%
    \def\rc@factor{26}%
  },
  point labels/Alph/.code={%
    \renewcommand\thepointlabels{\@Alph \c@pointlabels}%
    \def\rc@initial{64}%
    \def\rc@factor{26}%
  },
  point labels/alphalph/.code={%
    \@ifundefined{alphalph}{%
      \message{The "alphalph" option only works if the 'alphalph' package has been loaded (using "alph" instead).}%
      \renewcommand\thepointlabels{\@alph \c@pointlabels}%
      \def\rc@initial{96}%
      \def\rc@factor{26}%
    }{%
      \renewcommand\thepointlabels{\alphalph \c@pointlabels}%
      \def\rc@initial{96}%
      \def\rc@factor{26}%
    }%
  },
  point labels/AlphAlph/.code={%
    \@ifundefined{alphalph}{%
      \message{The "AlphAlph" option only works if the 'alphalph' package has been loaded (using "Alph" instead).}%
      \renewcommand\thepointlabels{\@Alph \c@pointlabels}%
      \def\rc@initial{64}%
      \def\rc@factor{26}%
    }{%
      \renewcommand\thepointlabels{\AlphAlph \c@pointlabels}%
      \def\rc@initial{64}%
      \def\rc@factor{26}%
    }%
  },
  construction in use/.style={
    draw=blue
  },
  construction not in use/.style={
    draw=gray!75,
  },
  compass/.code 2 args={%
    \rc@processpt\rc@pta#1\pgf@stop
    \rc@processpt\rc@ptb#2\pgf@stop
    \pgfkeysalso{ruler compass/compass aux={\rc@pta}{\rc@ptb}}%
  },
  compass aux/.style 2 args={
    alt if exist={c\rc@pathsep#1\rc@pathsep#2}{
      ruler compass/construction in use/.try,
    }{
      ruler compass/construction not in use/.try
    },
    name path=c\rc@pathsep#1\rc@pathsep#2,
    ruler compass/every construction path/.try,
    ruler compass/every compass/.try,
    insert path={
      (#1) to[circle through] (#2)
      node[name=c\rc@pathsep#1\rc@pathsep#2\rc@pathsep centre,ruler compass/aux point={#1}] {}
      node[name=c\rc@pathsep#1\rc@pathsep#2\rc@pathsep rim,ruler compass/aux point={#2}] {}
    },
  },
  ruler/.code 2 args={%
    \rc@processpt\rc@pta#1\pgf@stop
    \rc@processpt\rc@ptb#2\pgf@stop
    \pgfkeysalso{ruler compass/ruler aux={\rc@pta}{\rc@ptb}}%
  },
  ruler aux/.style 2 args={
    overlay,
    alt if exist={r\rc@pathsep#1\rc@pathsep#2}{
      ruler compass/construction in use/.try
    }{
      ruler compass/construction not in use/.try
    },
    name path=r\rc@pathsep#1\rc@pathsep#2,
    ruler compass/every construction path/.try,
    ruler compass/every ruler/.try,
    insert path={
      ($(#1)!\pgfkeysvalueof{/tikz/ruler compass/ruler length}!(#2)$) -- ($(#2)!\pgfkeysvalueof{/tikz/ruler compass/ruler length}!(#1)$)
      node[name=r\rc@pathsep#1\rc@pathsep#2\rc@pathsep start,ruler compass/aux point={#1}] {}
      node[name=r\rc@pathsep#1\rc@pathsep#2\rc@pathsep end,ruler compass/aux point={#2}] {}
    },
  },
  ruler length/.initial=20,
  aux point/.style={
    node contents/.try={},
    at={(#1)},
    ruler compass/every aux point/.try
  },
  point/.style={
    ruler compass/name it,
    coordinate,
    node contents/.try={},
    insert path={
      node[
        fill=#1,
        circle,
        minimum width=1mm,
        inner sep=0mm,
        reset label anchor,
        anchor=center,
        node contents/.try={},
        ruler compass/every point/.try,
      ] {}
    }
  },
  name it/.code={%
    \ifx\tikz@fig@name\pgfutil@empty
    \stepcounter{pointlabels}%
    \pgfkeysalso{name=\thepointlabels}%
    \expandafter\xdef\csname rc@id@\thepointlabels\endcsname{\the\rc@picture@id}%
    \ifrc@draft
    \pgfkeysalso{label={[ruler compass/draft label/.try]\thepointlabels}}%
    \fi
    \fi
  },
  point/.default=black,
}
\def\rc@scale{1}
\def\rc@offset{0pt}
\def\jump@setbb#1#2#3{%
  \@ifundefined{jump@#1@maxbb}{%
    \expandafter\gdef\csname jump@#1@maxbb\endcsname{#3}%
  }{%
    \csname jump@#1@maxbb\endcsname
    \pgf@xa=\pgf@x
    \pgf@ya=\pgf@y
    #3
    \pgfmathsetlength\pgf@x{max(\pgf@x,\pgf@xa)}%
    \pgfmathsetlength\pgf@y{max(\pgf@y,\pgf@ya)}%
    \expandafter\xdef\csname jump@#1@maxbb\endcsname{\noexpand\pgfpoint{\the\pgf@x}{\the\pgf@y}}%
  }
  \@ifundefined{jump@#1@minbb}{%
    \expandafter\gdef\csname jump@#1@minbb\endcsname{#2}%
  }{%
    \csname jump@#1@minbb\endcsname
    \pgf@xa=\pgf@x
    \pgf@ya=\pgf@y
    #2
    \pgfmathsetlength\pgf@x{min(\pgf@x,\pgf@xa)}%
    \pgfmathsetlength\pgf@y{min(\pgf@y,\pgf@ya)}%
    \expandafter\xdef\csname jump@#1@minbb\endcsname{\noexpand\pgfpoint{\the\pgf@x}{\the\pgf@y}}%
  }
}
\tikzset{
  stop jumping/.style={
    execute at end picture={%
      \pgfmathsetlength\pgf@xa{\pgf@picminx/\rc@scale}%
      \pgfmathsetlength\pgf@ya{\pgf@picminy/\rc@scale}%
      \pgfmathsetlength\pgf@xb{\pgf@picmaxx/\rc@scale}%
      \pgfmathsetlength\pgf@yb{\pgf@picmaxy/\rc@scale}%
      \immediate\write\pgfutil@auxout{%
        \noexpand\jump@setbb{\the\rc@picture@id}{\noexpand\pgfpoint{\the\pgf@xa}{\the\pgf@ya}}{\noexpand\pgfpoint{\the\pgf@xb}{\the\pgf@yb}}%
      },
      \pgf@x=\pgf@picminx
      \pgf@y=\pgf@picminy
      \csname jump@\the\rc@picture@id @minbb\endcsname
      \pgf@xa=\pgf@x
      \pgf@ya=\pgf@y
      \pgf@x=\pgf@picmaxx
      \pgf@y=\pgf@picmaxy
      \csname jump@\the\rc@picture@id @maxbb\endcsname
      \edef\rc@temp{\noexpand\path (\the\pgf@xa - \rc@offset,\the\pgf@ya - \rc@offset) -- (\the\pgf@x + \rc@offset,\the\pgf@y + \rc@offset);}%
      \rc@temp
    },
  },
  max size/.code 2 args={%
    \pgfutil@ifundefined{jump@\the\rc@picture@id @maxbb}{}{%
      \csname jump@\the\rc@picture@id @maxbb\endcsname
      \pgf@xa=\pgf@x
      \pgf@ya=\pgf@y
      \csname jump@\the\rc@picture@id @minbb\endcsname
      \advance\pgf@xa by -\pgf@x
      \advance\pgf@ya by -\pgf@y
      \advance\pgf@xa by \rc@offset
      \advance\pgf@xa by \rc@offset
      \advance\pgf@ya by \rc@offset
      \advance\pgf@ya by \rc@offset
      \pgfmathsetmacro\rc@xratio{\pgf@xa > #1 ? \pgf@xa/#1 : 1}%
      \pgfmathsetmacro\rc@yratio{\pgf@ya > #2 ? \pgf@ya/#2 : 1}%
      \pgfmathsetmacro\rc@scale{1/max(\rc@xratio,\rc@yratio)}%
      \pgfkeysalso{scale=\rc@scale}%
    }
  },
  enclosing box/offset/.store in=\rc@offset,
  constrain/.style={
    execute at begin picture=\constrain
  }
}
\newcommand\constrain{%
  \pgfutil@ifundefined{jump@\the\rc@picture@id @minbb}{}{%
    \csname jump@\the\rc@picture@id @minbb\endcsname
    \pgfmathsetlength\pgf@xa{\pgf@x-\rc@offset}%
    \pgfmathsetlength\pgf@ya{\pgf@y-\rc@offset}%
    \csname jump@\the\rc@picture@id @maxbb\endcsname
    \pgfmathsetlength\pgf@xb{\pgf@x+\rc@offset}%
    \pgfmathsetlength\pgf@yb{\pgf@y+\rc@offset}%
    \edef\rc@temp{\noexpand\clip (\the\pgf@xa,\the\pgf@ya) rectangle (\the\pgf@xb,\the\pgf@yb);}
    \ifpgf@relevantforpicturesize
      \pgf@relevantforpicturesizefalse
      \rc@temp
      \pgf@relevantforpicturesizetrue
    \else
      \rc@temp
    \fi
  }%
}

\expandafter\def\csname pgf@sh@ns@enclosing box\endcsname{rectangle}
\expandafter\def\csname pgf@sh@np@enclosing box\endcsname{%
  \pgfutil@ifundefined{jump@\the\rc@picture@id @minbb}{%
    \def\southwest{\pgfqpoint{\pgf@picminx}{\pgf@picminy}}%
    \def\northeast{\pgfqpoint{\pgf@picmaxx}{\pgf@picmaxy}}%
}{%
    \csname jump@\the\rc@picture@id @minbb\endcsname
    \pgfmathsetlength\pgf@xa{\pgf@x-\rc@offset}%
    \pgfmathsetlength\pgf@ya{\pgf@y-\rc@offset}%
    \edef\southwest{\noexpand\pgfqpoint{\the\pgf@xa}{\the\pgf@ya}}%
    \csname jump@\the\rc@picture@id @maxbb\endcsname
    \pgfmathsetlength\pgf@xb{\pgf@x+\rc@offset}%
    \pgfmathsetlength\pgf@yb{\pgf@y+\rc@offset}%
    \edef\northeast{\noexpand\pgfqpoint{\the\pgf@xb}{\the\pgf@yb}}%
  }%
}
\expandafter\def\csname pgf@sh@nt@enclosing box\endcsname{{1}{0}{0}{1}{0pt}{0pt}}
\expandafter\def\csname pgf@sh@pi@enclosing box\endcsname{\pgfpictureid}

\tikzset{
  on layer/.code={
    \pgfonlayer{#1}\begingroup
    \aftergroup\endpgfonlayer
    \aftergroup\endgroup
  },
  node on layer/.code={
    \gdef\node@@on@layer{%
      \setbox\tikz@tempbox=\hbox\bgroup\pgfonlayer{#1}\unhbox\tikz@tempbox\endpgfonlayer\egroup}
    \aftergroup\node@on@layer
  },
  reset label anchor/.code={%
    \let\tikz@auto@anchor=\pgfutil@empty
    \def\tikz@anchor{#1}
  },
  reset label anchor/.default=center
}
\def\node@on@layer{\aftergroup\node@@on@layer}
\@ifpackageloaded{alphalph}%
{
  \tikzset{ruler compass/point labels=alphalph}
}
{
  \tikzset{ruler compass/point labels=alph}
}

%% 
%% Copyright (C) 2013 by Andrew Stacey <stacey@math.ntnu.no>
%% 
%% This file 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 is "maintained" (as per LPPL maintenance status) by
%% Andrew Stacey.
%% 
%% This work consists of the files  rulercompass.dtx
%%                                  rulercompass_doc.tex
%% and the derived files            tikzlibraryrulercompass.code.tex
%%                                  rulercompass.ins
%%                                  rulercompass.pdf
%%                                  rulercompass_doc.pdf
%%                                  README.txt
%% 
%% 
%%
%% End of file `tikzlibraryrulercompass.code.tex'.