spac-pag.mkiv / last modification: 2020-01-30 14:16
%D \module
%D   [       file=spac-pag,
%D        version=2009.10.16, % 1997.03.31, was core-spa.tex
%D          title=\CONTEXT\ Spacing Macros,
%D       subtitle=Pages,
%D         author=Hans Hagen,
%D           date=\currentdate,
%D      copyright={PRAGMA ADE \& \CONTEXT\ Development Team}]
%C
%C This module is part of the \CONTEXT\ macro||package and is
%C therefore copyrighted by \PRAGMA. See mreadme.pdf for
%C details.

\writestatus{loading}{ConTeXt Spacing Macros / Pages}

\unprotect

%D The code here has evolved over time and might not be the best
%D around. Maybe much will be gone a some point.

\installcorenamespace {alignswitch}

\letvalue{\??alignswitch\v!left  }\zerocount
\letvalue{\??alignswitch\v!middle}\plusone
\letvalue{\??alignswitch\v!right }\plustwo

\def\setalignmentswitch#1%
  {\chardef\alignmentswitch\csname\??alignswitch\ifcsname\??alignswitch#1\endcsname#1\else\v!left\fi\endcsname}

\newif      \ifpagestatemismatch
\newcount   \realpagestateno
\newconstant\frozenpagestate

\def\dotrackpagestate#1#2%
  {\ifdoublesided \ifinpagebody \else
     \doforcedtrackpagestate{#1}{#2}%
   \fi \fi}

\def\doforcedtrackpagestate#1#2%
  {\ifcase\frozenpagestate
     \global\advance#2\plusone
     \setpagestate[#1][\number#2]%
   \fi}

\let\m_spac_pagestates_realpage\empty

\newconditional\c_spac_pagestates_found

\unexpanded\def\docheckpagestate#1#2%
  {\ifcase\frozenpagestate
     \setpagestaterealpageno{#1}{\number#2}%
   \fi}

\unexpanded\def\doifelserightpagestate#1#2% not expandable !
  {\ifcase\frozenpagestate
     \pagestatemismatchfalse
     \realpagestateno\realfolio
     \ifinpagebody
       \ifdoublesided
         \ifodd\realpageno\relax
           \settrue\c_spac_pagestates_found
         \else
           \setfalse\c_spac_pagestates_found
         \fi
       \else
         \settrue\c_spac_pagestates_found
       \fi
     \else\ifdoublesided
       \edef\m_spac_pagestates_realpage{\pagestaterealpage{#1}{\number#2}}%
       \ifx\m_spac_pagestates_realpage\empty
         \ifodd\realpageno\relax
           \settrue\c_spac_pagestates_found
         \else
           \setfalse\c_spac_pagestates_found
         \fi
       \else
         \realpagestateno\m_spac_pagestates_realpage\relax
         \ifnum\realpagestateno=\realpageno \else
           \pagestatemismatchtrue
         \fi
         \ifodd\realpagestateno\relax
           \settrue\c_spac_pagestates_found
         \else
           \setfalse\c_spac_pagestates_found
         \fi
       \fi
     \else
       \settrue\c_spac_pagestates_found
     \fi\fi
   \else
     \ifodd\realpagestateno\relax
       \settrue\c_spac_pagestates_found
     \else
       \setfalse\c_spac_pagestates_found
     \fi
   \fi
   \ifconditional\c_spac_pagestates_found
     \expandafter\firstoftwoarguments
   \else
     \expandafter\secondoftwoarguments
   \fi}

\unexpanded\def\doifelseforcedrightpagestate#1#2%
  {\ifcase\frozenpagestate
     \pagestatemismatchfalse
     \realpagestateno\realfolio
     \edef\m_spac_pagestates_realpage{\pagestaterealpage{#1}{\number#2}}%
     \ifx\m_spac_pagestates_realpage\empty
       \ifodd\realpageno\relax
         \settrue\c_spac_pagestates_found
       \else
         \setfalse\c_spac_pagestates_found
       \fi
     \else
       \realpagestateno\m_spac_pagestates_realpage\relax
       \ifnum\realpagestateno=\realpageno \else
         \pagestatemismatchtrue
       \fi
       \ifodd\realpagestateno\relax
         \settrue\c_spac_pagestates_found
       \else
         \setfalse\c_spac_pagestates_found
       \fi
     \fi
   \else
     \ifodd\realpagestateno\relax
       \settrue\c_spac_pagestates_found
     \else
       \setfalse\c_spac_pagestates_found
     \fi
   \fi
   \ifconditional\c_spac_pagestates_found
     \expandafter\firstoftwoarguments
   \else
     \expandafter\secondoftwoarguments
   \fi}

\let\doifrightpagestateelse      \doifelserightpagestate
\let\doifforcedrightpagestateelse\doifelseforcedrightpagestate

\unexpanded\def\freezepagestate {\frozenpagestate\plusone  }
\unexpanded\def\defrostpagestate{\frozenpagestate\zerocount}

% we can make more of these on top, but how to deal with mixed frozen states

% \dorecurse{500}{\dontleavehmode\signalrightpage\doifrightpageelse{right}{left}\par} % given doublesided

\newcount\nofraggedparagraphs

\definepagestate[\s!paragraph]

\unexpanded\def\signalrightpage  {\dotrackpagestate      \s!paragraph\nofraggedparagraphs} % use \dontleavehmode if needed
\unexpanded\def\doifelserightpage{\doifelserightpagestate\s!paragraph\nofraggedparagraphs}
\unexpanded\def\rightpageorder   {\pagestaterealpageorder\s!paragraph\nofraggedparagraphs}

\let\doifrightpageelse\doifelserightpage

\installcorenamespace{pagechanges}

\newif\ifpagechanged \let\lastchangedpage\empty

\def\spac_pagechanges_check#1#2#3%
  {\pagechangedfalse
   \doforcedtrackpagestate{#2}{#3}%
   \edef\m_spac_pagestates_realpage{\pagestaterealpage{#2}{\number#3}}%
   \ifx\m_spac_pagestates_realpage\empty \else
     \ifnum\m_spac_pagestates_realpage>0\csname\??pagechanges#2:#1\endcsname\relax
       \pagechangedtrue
     \fi
   \fi
   \ifpagechanged
     \letgvalue{\??pagechanges#2:#1}\m_spac_pagestates_realpage
     \glet\lastchangedpage\m_spac_pagestates_realpage
   \else
     \glet\lastchangedpage\realfolio
   \fi}

\def\changedpagestate#1#2%
  {\executeifdefined{\??pagechanges#2:#1}0}

\def\checkpagechange#1{\spac_pagechanges_check{#1}\s!paragraph\nofraggedparagraphs}
\def\changedpage    #1{\changedpagestate{#1}\s!paragraph}

\protect \endinput