%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% 2001-02-14-12:58
% TeXProject.sty                                        %
% Copyright (C) 1995 Stephane Bressan & Eitan M. Gurari %
%                                                       %
% This program can redistributed and/or modified under  %
% the terms of the LaTeX Project Public License         %
% Distributed from CTAN archives in directory           %
% macros/latex/base/lppl.txt; either version 1 of the   %
% License, or (at your option) any later version.       %
%                                                       %
% However, you are allowed to modify this program       %
% without changing its name, if you modify its          %
% signature. Changes to the signature can be introduced %
% with a directive of the form                          %
%            \message{signature}                        %
%                                                       %
% [email protected]   [email protected]  %
% http://www.cse.ohio-state.edu/~gurari/                %
% Needs:                                                %
%   DraTex.sty and AlDraTex.sty                         %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\immediate\write-1{version 2001-02-14-12:58}
\ifx\Draw\UnDefined
  \def\DrawRect{\input DraTex.sty }
  \expandafter\DrawRect
\fi
\ifx\Tree\UnDefined
 \def\Tree{\input AlDraTex.sty }
 \expandafter\Tree
\fi
\expandafter\edef\csname :RestoreCatcodes\endcsname{%
  \catcode`\noexpand\noexpand\noexpand \^=\the\catcode`\^%
}
\catcode`\^=7
\expandafter\edef\csname :RestoreCatcodes\endcsname{%
  \csname :RestoreCatcodes\endcsname
  \catcode`\noexpand \_=\the\catcode`\_%
  \catcode`\noexpand \ =\the\catcode`\ %
  \catcode`\noexpand \&=\the\catcode`\&%
  \catcode`\noexpand :=\the\catcode`:%
  \catcode`\noexpand \^^M=\the\catcode`\^^M%
  \let\expandafter\noexpand
      \csname:RestoreCatcodes\endcsname=\noexpand\undefined}
\catcode`\^^M=9        \catcode`\ =9      \catcode`\&=13  \relax
 \expandafter
  \def\csname reseffB:\endcsname#1{\csname reseffC:\endcsname#1:}
\expandafter
  \def\csname reseffC:\endcsname#1:#2:{
                                   \csname reseff:\endcsname{#1}{#2}}
    \catcode`\:=11 \relax
 \newif\ifpwarnn:
\def\warningsoff{\pwarnn:false}
\def\warningson{\pwarnn:true}
\warningson
\def\pwarn:#1{\ifpwarnn: \immediate\write16{l.\the\inputlineno
                                  \space--- warning ---\space #1}\fi}
\def\whitedef:#1{
 \expandafter\def\csname #1\endcsname{\bgroup
   \ignorewhite:  \csname #1:X\endcsname}

 \expandafter\def\csname #1:X\endcsname##1{\egroup
    \expandafter\ifx\csname##1 :type\endcsname\relax \else
       \pwarn:{Redefining\space##1?}
    \fi
    \edef\items:{\item:{##1}\items:}
    \expandafter\let\csname##1 :bool\endcsname=\empty
    \expandafter\edef\csname##1 :prjid\endcsname{
         \expandafter\noexpand\csname\projectid: :minmax\endcsname}
    \csname #1:Y\endcsname{##1}}
 \expandafter\def\csname #1:Y\endcsname}

\def\ignorewhite:{ \ifnum \the\catcode`\ =9 \else
   \catcode`\ =9   \catcode`\^^M=9 \catcode`\^^I=9 \relax \fi }
\def\forbiencomm:{\pwarn:{\string\newproject\space missing}}
\def\defcom#1{
 \expandafter\def\csname#1\endcsname{
    \bgroup  \ignorewhite:  \csname#1:A\endcsname}
 \expandafter\def\csname#1:A\endcsname##1{\egroup
     \csname#1:B\endcsname{##1}}
 \expandafter\def\csname#1:B\endcsname}
\def\verify:::#1{
  \expandafter\ifx\csname#1 :title\endcsname\relax \pwarn:{#1?} \fi
  \csname#1 :prjid\endcsname
%
}
\IntVar\I:I    \IntVar\J:J   \IntVar\K:K
\DecVar\Q:Q    \DecVar\R:R   \DecVar\T:T

 \def\tasknode:{0}
\def\milestonenode:{1}
\def\projectnode:{2}
\whitedef:{DEFTASK:}#1#2{
 \expandafter\edef\csname#1 :type\endcsname{\tasknode:}
 \expandafter\def\csname#1 :title\endcsname{#2}
 \bgroup   \ignorewhite:  \deftaskA:{#1}}

\def\deftaskA:#1#2#3#4#5{\egroup
 \expandafter\edef\csname#1 :date1\endcsname{#2}
 \expandafter\edef\csname#1 :date2\endcsname{#3}
 \def\temp:{#4}
\ifx\temp:\empty
  \pwarn:{`#1'\space has\space no\space contributions}
\else
  \getlist:{#1 :eff}{#4}\reseffA:
  \let\reseff:=\relax
  \let\reseffA:=\reseffB:
  \expandafter\edef\csname#1 :eff\endcsname{\csname#1 :eff\endcsname}
\fi

 \setprev:{#1}{#5}
 \deftaskB:{#1}}

\def\deftaskB:#1#2{
 \expandafter\def\csname#1 :desc\endcsname{#2}
 \trace:{#1} }
\whitedef:{DEFMILESTONE:}#1#2#3{
 \expandafter\edef\csname#1 :type\endcsname{\milestonenode:}
 \expandafter\def\csname#1 :title\endcsname{#2}
 \expandafter\edef\csname#1 :date\endcsname{#3}
 \bgroup   \ignorewhite:  \defmilestoneA:{#1}}

\def\defmilestoneA:#1#2{\egroup
 \setprev:{#1}{#2}
 \defmilestoneB:{#1}}

\def\defmilestoneB:#1#2{
 \expandafter\def\csname#1 :desc\endcsname{#2}
 \trace:{#1}}
\whitedef:{DEFPROJECT:}#1#2{
 \expandafter\edef\csname#1 :type\endcsname{\projectnode:}
 \edef\projects:{{#1}{\projects:}}
 \expandafter\def\csname#1 :title\endcsname{#2}
 \bgroup  \ignorewhite: \defprojectA:{#1}}

\def\defprojectA:#1#2#3{\egroup
 \getlist:{#1 :under}{#2}\utask:
\def\utask:##1{%
 \sapply{:temp,merge,
     {\expandafter \ifx \csname ##1:ancs\endcsname\relax\else
      \csname ##1:ancs\endcsname\fi},{#1}}
 \expandafter \let \csname ##1: ancs\endcsname= \:temp:mkls
 \let\:temp:mkls =\:UnDef
 }
\csname#1: under\endcsname


 \setprev:{#1}{#3}
 \defprojectB:{#1}}

\def\defprojectB:#1#2{
 \expandafter\def\csname#1 :desc\endcsname{#2}
 \trace:{#1}}
\def\setproject:data#1{
  \expandafter\ifx\csname#1 :type\endcsname\relax
     \pwarn:{Missing\space `#1'}
  \fi
  \ifnum\csname#1 :type\endcsname=\projectnode:\relax
     \expandafter\ifx\csname#1 :date1\endcsname\relax
       \def\minY:{10000}  \def\minM:{10000}  \def\minD:{10000}
\def\maxY:{0}  \def\maxM:{0}    \def\maxD:{0}

          \let\utask:=\utask:I
\csname#1 :under\endcsname

       \expandafter\edef\csname#1 :date1\endcsname{\minD:/\minM:/\minY:}
\expandafter\edef\csname#1 :date2\endcsname{\maxD:/\maxM:/\maxY:}

  \fi \fi
}

 \def\newproject{
  \let\item:=\relax
\def\items:{}
\tcount:=0\relax
\let\deftask=\DEFTASK:
\let\defmilestone=\DEFMILESTONE:
\let\defproject=\DEFPROJECT:
\let\restoregal::=~
\def\restoregal:{\let~=\restoregal::}
\def\projects:{}
\def\verify:##1{}
\def\verify::##1{}
\let\minmaxdates=\MINMAXDATES:
\MINMAXDATES:{1/1/0//31/12/99}

}
\def\endprojectdefA:{  \let\deftask=\forbiencomm:
\let\defmilestone=\deftask
\let\defproject=\deftask
\let\minmaxdates=\forbiencomm:

}
\endprojectdefA:

\def\endnewproject{
  \endprojectdefA:       \def\item:##1{
  \let\prev:=\checkmemb:    \csname##1 :prev\endcsname
  \let\utask:=\checkmemb:   \csname##1 :under\endcsname
}
\items:

\ifx \projects:\empty\else
 \expandafter\setproject:\projects:
 \expandafter\verify:dates:\projects:
\fi

  \def\item:##1{ \expandafter\let\csname##1 :bool\endcsname=\UnDef: }
\items:
\let\item:=\UnDef:
\let\items:=\UnDef:
\restoregal:
\let\projects:=\UnDef:
\let\verify:=\verify:::
\let\verify::=\verify:::

  \I:I=\projectid:;  \I:I+1;  \edef\projectid:{\Val\I:I}
}

 \def\filtercommand{
 \def\filtercommand:##1{
   \def\putcommand{##1}
   \let\filtercommand:=\empty
} }
\let\filtercommand:=\empty
\defcom{name}#1{    \verify:{#1}
  \expandafter\expandafter\expandafter\filtercommand:
     \expandafter\expandafter\expandafter{\csname#1 :title\endcsname }}
\defcom{annotation}#1{ \verify:{#1}
   \expandafter\expandafter\expandafter\filtercommand:
   \expandafter\expandafter\expandafter{\csname#1 :desc\endcsname}}
\defcom{resource}#1{{ \verify:{#1}
\ifnum\csname#1 :type\endcsname=\milestonenode:\space
  \pwarn:{`#1'\space has\space no\space resources} ???
\fi
\def\sepitems:{\def\sepitems:{\append:Def\all:des{,\space}}}
\let\reseff:=\reseffI:   \let\all:des=\empty
\traversedo:{#1}\listrsrc:
\expandafter\def\expandafter\all:des
   \expandafter{\expandafter\filtercommand:\expandafter{\all:des}}
\expandafter}\all:des}
\defcom{effort}#1{{ \def\temp:##1,##2,##3//{
  \def\first:{##1} \def\second:{##2}
}
\temp:#1,,//   \verify:{\first:}
\ifnum\csname\first: :type\endcsname=\milestonenode:\space
   \pwarn:{`#1'\space has\space no\space resources} ???
   \let\:temp=\empty
\else
   \findeffort:\first:\second:
   \edef\:temp{\noexpand\filtercommand:{\temp:}}
\fi
\expandafter}\:temp}
\defcom{contributions}#1{{  \verify:{#1}
\ifnum\csname#1 :type\endcsname=\milestonenode:\space
        \pwarn:{`#1'\space has\space no\space contributions} ???
\else    \findthecontri:{#1}   \fi
 }}
\defcom{start}#1{ \verify:{#1} \startfinish:{#1}1 }

\defcom{finish}#1{\verify:{#1} \startfinish:{#1}2 }

\def\startfinish:#1#2{
 \ifnum\csname#1 :type\endcsname=\milestonenode:\relax
    \expandafter\expandafter\expandafter
    \filtercommand: \expandafter\expandafter\expandafter
        {\expandafter\expandafter\expandafter
        \showdate:\csname#1 :date\endcsname/0/0/0//}
 \else
    \expandafter\expandafter\expandafter
    \filtercommand:  \expandafter\expandafter\expandafter
        {\expandafter\expandafter\expandafter
       \showdate:\csname#1 :date#2\endcsname/0/0/0//}
\fi }
\defcom{apply}#1{ \apply:#1,,,,//  }
\defcom{rapply}#1{ \rapply:#1,,,,//  }
\defcom{sapply}#1{
  \edef\:temp{\Val\I:I}
\push:macro\:temp

  \def\temp:##1,##2,##3,##4/+/-]/[{
  \def\result:lst{##1}  \let\list:op=\empty
  \IF \EqText(##2,merge)\THEN
     \def\list:op{\two:args#1,/+/-]/[
\expandafter\edef\csname \result:lst :mkls\endcsname{\arg:one,\arg:two}
\cln:res

}\FI
  \IF \EqText(##2,intersect)\THEN
     \def\list:op{\two:args#1,/+/-]/[
\get:result\in:both
\cln:res

} \FI
  \IF \EqText(##2,subtract)\THEN
     \def\list:op{\two:args#1,/+/-]/[
\get:result\first:only
\cln:res

} \FI
  \IF \EqText(##2,milestones)\THEN
     \def\list:op{\one:args#1,/+/-]/[
\let\arg:one=\arg:two
\get:result\scr:mi
\cln:res

} \FI
  \IF \EqText(##2,tasks)\THEN
     \def\list:op{\one:args#1,/+/-]/[
\let\arg:one=\arg:two
\get:result\scr:ta
\cln:res

} \FI
  \IF \EqText(##2,projects)\THEN
     \def\list:op{\one:args#1,/+/-]/[
\let\arg:one=\arg:two
\get:result\scr:pr
\cln:res

} \FI
  \IF \EqText(##2,after)\THEN
     \def\list:op{\one:args#1,/+/-]/[
\let\arg:one=\arg:two
\get:result\scr:af
\cln:res

}\FI
  \IF \EqText(##2,before)\THEN
     \def\list:op{\one:args#1,/+/-]/[
\let\arg:one=\arg:two  \def\prev:########1{,########1}
\get:result\scr:be
\cln:res

}\FI
  \IF \EqText(##2,up)\THEN
     \def\list:op{\one:args#1,/+/-]/[
\let\arg:one=\arg:two
\get:result\scr:up
\cln:res

} \FI
  \IF \EqText(##2,down)\THEN
     \def\list:op{\one:args#1,/+/-]/[
\let\arg:one=\arg:two  \def\utask: ########1{,########1}
\get:result\scr:dw
\cln:res

} \FI
  \IF \EqText(##2,sort)\THEN
     \def\list:op{\one:args#1,/+/-]/[
\let\arg:one=\arg:two
\let\:temp\empty
\get:result\scr:srt  \sapply{##1,\gob:I}

} \FI
  \IF \EqText(##2,defproject)\THEN
     \def\list:op{\one:args#1,/+/-]/[
\df:spr#1/+/-]/[
\ifx \arg:two\empty
  \pwarn:{defproject\space ##1\space without\space members?}
\else
  \let\arg:one=\arg:two
  \get:result\scr:df
  \edef\:temp{{##1}{\AA:k}{\:temp}{}{\BB:k}}
   \expandafter\let\csname##1 :date1\endcsname\relax
   \expandafter\let\csname##1 :date2\endcsname\relax
  \push:macro\checkmemb:  \def\checkmemb:########1{}
  \newproject   \expandafter\defproject\:temp   \endnewproject
  \pop:macro\checkmemb:
\fi
} \FI
  \IF \EqText(##1,traceon)\THEN
     \def\list:op{\let\rs:trc=\empty
} \FI
  \IF \EqText(##1,traceoff)\THEN
     \def\list:op{\def\rs:trc########1{}
} \FI
  \ifx \list:op\empty
     \def\list:op{\futurelet
  \:temp\sapply:apply #1,,,,/+/-]/[
}
  \fi
  \list:op  }
\temp:#1,,,,/+/-]/[

  \pop:macro\:temp
\I:I=\:temp;

}
\IntVar\s:appN
\def\sapply:apply#1,#2,#3/+/-]/[{
  \ifx \:temp\bgroup \else
 \expandafter\ifx\csname #1:mkls\endcsname\relax
    \pwarn:{\string\sapply{#1,\string#2,...}?}
\fi\fi

  \expandafter\edef\csname \result:lst :mkls\endcsname{\ifx
     \:temp\bgroup #1\else
          \expandafter\ifx\csname #1:mkls\endcsname\relax #1
          \else \csname #1:mkls\endcsname
     \fi \fi}
  \cln:res

  \def\breadth{0}
  \def\app:mi{#2}
  \expandafter\expandafter\expandafter\r:app
  \expandafter\expandafter\expandafter\s:app
      \csname \result:lst :mkls\endcsname,/+/-]/[
}
\def\s:app#1{\I:I=\breadth; \I:I+1; \edef\breadth{\Val\I:I}
 \push:macro\breadth
\push:macro\app:mi
\push:macro\app:pr
\push:macro\app:ta

 \app:mi{#1}
 \pop:macro\app:ta
\pop:macro\app:pr
\pop:macro\app:mi
\pop:macro\breadth

}
\def\s:appA#1{\I:I=\breadth; \I:I+1; \edef\breadth{\Val\I:I}
 \push:macro\breadth
\push:macro\app:mi
\push:macro\app:pr
\push:macro\app:ta

 \apply{#1,\app:mi,\app:pr,\app:ta}
 \pop:macro\app:ta
\pop:macro\app:pr
\pop:macro\app:mi
\pop:macro\breadth

}
\def\scr:ta#1{\ifnum\csname#1:type\endcsname=\tasknode:\space
  \edef\:temp{\:temp,#1}\fi }
\def\scr:mi#1{\ifnum\csname#1:type\endcsname=\milestonenode:\space
  \edef\:temp{\:temp,#1}\fi }
\def\scr:pr#1{\ifnum\csname#1:type\endcsname=\projectnode:\space
  \edef\:temp{\:temp,#1}\fi }
\def\df:spr#1,#2,#3,#4,#5/+/-]/[{%
  \def\AA:k{#4}
  \def\BB:k{#5}
}
\def\scr:df#1{\edef\:temp{\ifx\:temp\empty \else \:temp,\fi #1}}
\def\first:only#1{
  \def\a:temp{#1}
  \expandafter\r:app\expandafter\also:second\arg:two,,/+/-]/[
  \ifx \a:temp\empty\else \edef\:temp{\:temp,#1}\fi
}
\def\also:second#1{\def\b:temp{#1}\ifx \a:temp\b:temp
  \let\a:temp\empty\fi}
\def\in:both#1{
  \def\a:temp{#1}
  \expandafter\r:app\expandafter\found:both\arg:two,,/+/-]/[
}
\def\found:both#1{\def\b:temp{#1}\ifx \a:temp\b:temp
  \edef\:temp{\:temp,#1}\fi}
\def\two:args#1,#2,{\futurelet\:temp\first:arg}
\def\first:arg#1,{\verify:arg{#1}
  \edef\arg:one{\ifx \:temp\bgroup
                        #1\else \csname #1:mkls\endcsname \fi}
  \futurelet\:temp\second:arg}
\def\second:arg#1,#2/+/-]/[{\verify:arg{#1}
  \edef\arg:two{\ifx \:temp\bgroup
                        #1\else \csname #1:mkls\endcsname \fi}}
\def\one:args#1,#2,{\futurelet\:temp\second:arg}
\def\verify:arg#1{
  \ifx \:temp\bgroup\else
     \expandafter\ifx \csname #1:mkls\endcsname\relax
         \pwarn:{`#1'\space in\space \string\sapply?}
  \fi \fi}
\def\cln:res{
  \let\:temp=\empty   \car:dinality=0;
  \expandafter\expandafter\expandafter\r:app
  \expandafter\expandafter\expandafter\pre:dup
    \csname \result:lst :mkls\endcsname,,/+/-]/[%
  \expandafter\let\csname \result:lst :mkls\endcsname=\:temp
  \edef\breadth{\Val\car:dinality}
  \rs:trc{\immediate\write16{...[\result:lst]........\:temp}}
}
\IntVar\car:dinality
\def\scr:srt#1{
\expandafter\let\expandafter\:temp\expandafter\empty
 \expandafter\next:compare\:temp,,,/+/-]/[#1/+/-]/[
}
\def\next:compare#1,#2/+/-]/[#3/+/-]/[{
  \if :#1:
     \edef\:temp{\ifx\:temp\empty\else \:temp,\fi#3}
     \def\next:##1/+/-]/[##2/+/-]/[{}
  \else   \comp:r{#1}{#3}
     \ifnum \com:p>0
        \edef\:temp{\ifx\:temp\empty\else \:temp,\fi#3,#1}
        \def\next:##1,,##2/+/-]/[##3/+/-]/[{\edef
                \:temp{\ifx\:temp\empty\else \:temp,\fi##1}}
     \else \edef\:temp{\ifx\:temp\empty\else \:temp,\fi#1}
         \if :#2:
            \edef\:temp{\ifx\:temp\empty\else \:temp,\fi#3}
            \def\next:##1/+/-]/[##2/+/-]/[{}
         \else
            \let\next:=\next:compare
  \fi\fi \fi
  \next: #2/+/-]/[#3/+/-]/[
}
\def\comp:r#1#2{
 \def\com:p{0}%
 \comp:re#1/+/-]/[#2/+/-]/[%
}
\def\comp:re#1#2/+/-]/[#3#4/+/-]/[{%
  \ifnum `#1<`#3\def\com:p{-1}\let\next:=\relax
  \else \ifnum `#1>`#3\def\com:p{1}\let\next:=\relax
  \else \def\next:{\comp:re#2/+/-]/[#4/+/-]/[}%
        \if !#2!\let\next:=\relax  \fi
        \if !#4!\let\next:=\relax  \fi
        \def\:tempa{#2}\def\:tempb{#4}%
        \ifx \:tempa\space
            \ifx \:tempb\:tempa \else \def\com:p{-1}\fi
            \let\next:=\relax
        \else\ifx \:tempb\space \def\com:p{1}\let\next:=\relax
        \fi\fi
  \fi\fi
  \next:
}
\def\rs:trc#1{}
\def\get:result#1{
  \let\:temp=\empty
  \expandafter\r:app\expandafter#1\arg:one,,/+/-]/[%
  \expandafter\let\csname \result:lst :mkls\endcsname=\:temp}
\def\scr:af#1{%
\expandafter\ifx \csname#1:succe\endcsname\relax\else
  \expandafter\expandafter\expandafter\r:app
  \expandafter\expandafter\expandafter\scr:aff
  \csname #1:succe\endcsname,/+/-]/[
\fi}
\def\scr:aff#1{\edef\:temp{\:temp,#1}}
\def\scr:up#1{%
\expandafter\ifx \csname#1:ancs\endcsname\relax\else
 \expandafter\expandafter\expandafter\r:app
 \expandafter\expandafter\expandafter\scr:aff
 \csname #1:ancs\endcsname,/+/-]/[
\fi}
\def\scr:dw#1{\expandafter\ifx \csname #1:under\endcsname\relax\else
  \edef\:temp{\:temp,\csname #1:under\endcsname}\fi}
\def\scr:be#1{\expandafter\ifx \csname #1:prev\endcsname\relax\else
  \edef\:temp{\:temp,\csname #1:prev\endcsname}\fi}
\def\pre:dup#1{%
  \def\a:temp{#1}\let\c:temp=\empty
  \expandafter\r:app\expandafter\is:dup\:temp,/+/-]/[%
  \ifx \c:temp\empty
     \car:dinality+1;
     \edef\:temp{\:temp\ifx \:temp\empty\else ,\fi#1}\fi}
\def\is:dup#1{\def\b:temp{#1}\ifx \a:temp\b:temp \let\c:temp=\b:temp\fi}
\def\r:app#1#2,#3/+/-]/[{%
  \if !#2!\else #1{#2}\fi
  \if !#3!\expandafter\r:gobble\else \expandafter\r:app\fi
  #1#3/+/-]/[}
\def\r:gobble#1/+/-]/[{}


 \def\prjc:VII#1#2#3#4#5#6#7{
  \gdef\all:prjc{}
  { \contributionsstyle{
     \expandafter \gdef \expandafter\all:prjc
         \expandafter{\all:prjc\add:contrib{##1}{#1}}
    }{}{}
    \contributions{#1}
   }
   \all:prjc
}
\def\gob:V#1#2#3#4#5{}
\def\f:cntr#1{\apply{#1,\gob:V,\findcontribution,\gob:V}}

\IntVar\cntr:N

\def\add:contrib#1#2{
  \let\N:EXT=\empty
  \def\findcontribution##1##2##3##4##5{
    \IF \EqText(##2,#1) \THEN
       \gdef\N:EXT{##1}
    \FI
  }
  \sapply{con.TRIB,\f:cntr}
  \ifx \N:EXT\empty
     \cntr:N+1;
     \sapply{\pc:id.\Val\cntr:N,defproject,{#2},#1,}
     \sapply{con.TRIB,merge,con.TRIB,{\pc:id.\Val\cntr:N}}
  \else
     \sapply{ts.k,down,{\N:EXT}}
     \sapply{ts.k,merge,ts.k,{#2}}
     \expandafter\let\csname\N:EXT :type\endcsname\relax
     \sapply{\N:EXT,defproject,ts.k,#1,}
  \fi
}
\def\contributorsproject#1#2#3#4{
 \push:macro\checkmemb:  \def\checkmemb:##1{}
 \cntr:N=0; \def\pc:id{#1}
 \sapply{con.TRIB,merge,{},{}}
 \sapply{#1,defproject,{#3},,}
 \rapply{#1,\gob:V,\gob:V,\prjc:VII}
 \expandafter\let\csname#1 :type\endcsname\relax
 \sapply{#1,defproject,con.TRIB,#2,#4}
 \pop:macro\checkmemb:
 \sapply{#1,down,{#1}}
\sapply{#1,\connect:up{#1}}
\sapply{#1,merge,{},{}}

 \sapply{con.TRIB,merge,{},{}}
}

 \def\setnumericdate#1#2{{
  \expandafter \ifx \csname maxMM:\endcsname\relax
    \getminmaxdates:1/1/0//31/12/99//
  \fi
  \def\yrS:{0}  \def\moS:{0}  \def\dateS:{0}
  \if /\actual:date #2///+/-]/[/
      \date:Coordinate#1#2,,/+/-]/[
  \else
     \def\real::date##1,##2/+/-]/[{##1}
     \edef\real::date{\real::date #2,/+/-]/[}
     \axisdate:#1{real:}\empty
  \fi
  \edef#1{\def\noexpand#1{#1}}
  \expandafter}#1}

\def\actual:date#1/#2/#3/+/-]/[{#2}
\def\date:Coordinate#1#2,#3,#4/+/-]/[{
 \expandafter \ifx \csname#2 :type\endcsname\relax
     \def#1{0}
     \pwarn:{\noexpand\setnumericdate for\space `#2'?}
 \else\ifnum\csname#2 :type\endcsname=\milestonenode:\relax
     \axisdate:#1{#2}\empty
 \else
     \IF \EqText(start,#3) \THEN
       \axisdate:#1{#2}1
     \ELSE      \IF \EqText(finish,#3) \THEN
       \axisdate:#1{#2}2
     \ELSE
       \def#1{0}
       \pwarn:{\noexpand\setnumericdate for\space `#3'?}
     \FI \FI
  \fi \fi
}
\def\datesproject#1#2#3#4{
 \push:macro\checkmemb:   \def\checkmemb:##1{}   \def\pc:id{#1}
 \let\all:prjc=\empty
 \sapply{#1,defproject,{#3},,}
 \cntr:N=1000;
\bck:N=2;
\rapply{#1,\cnt:V,\cnt:V,\cnt:VII}
\bck:N*2;  \bck:N+1000;

 \rapply{#1,\prjd:V,\prjd:V,\prjd:VII}
 \edef\:temp{\noexpand \sapply{#1,sort,{\all:prjc}}}\:temp
 \let\all:prjc=\empty
 \sapply{#1.m,merge,{},{}}
 \let\prv:=\empty  \cntr:N=0;
 \push:macro\pwarn:   \def\pwarn:##1{}
 \sapply{#1,\set:dateprj}
 \sapply{#1,defproject,#1.m,#2,#4}
 \pop:macro\pwarn:
 \pop:macro\checkmemb:
 \sapply{#1,\cp:dt}

 \sapply{#1,down,{#1}}
\sapply{#1,\connect:up{#1}}
\sapply{#1,merge,{},{}}

 \sapply{#1.m,merge,{},{}}
}
\def\connect:up#1#2{\expandafter \edef \csname #2: ancs\endcsname{#1}}
\def\prjd:VII#1#2#3#4#5#6#7{\prjd:{#1}}
\def\prjd:V#1#2#3#4#5{\prjd:{#1}}
\def\prjd:#1{
 \cntr:N+1; \bck:N-1;
  {\datestyle{
     \setnumericdate\:dateA{#1,start}
\setnumericdate\:dateB{#1,finish}
\I:I=\:dateA; \I:I+1000000000; \edef\:dateA{\Val\I:I}
\I:I=\:dateB; \I:I+1000000000; \edef\:dateB{\Val\I:I}
\def\xx{#1}\ifx \xx\pc:id \else
 \xdef\all:prjc{\ifx \all:prjc\empty \else \all:prjc,\fi}
 \ifnum\csname#1 :type\endcsname=\milestonenode:\relax
    \xdef\all:prjc{\all:prjc \:dateA.\Val\cntr:N.0.#1}
 \else
    \xdef\all:prjc{\all:prjc \:dateA.\Val\cntr:N.1.#1,
           \:dateB.
           \ifnum\csname#1 :type\endcsname=\projectnode:\space
                    \Val\bck:N\else   \Val\cntr:N\fi
            .2.#1}
\fi \fi

     }{}{}
     \def\pwarn:##1{} \start{#1}
   }
}
\def\cp:dt#1{
  \def\:temp##1##2{##2}
  \edef\:tmp{\expandafter\expandafter\expandafter
       \:temp\csname#1 :under\endcsname}
  \ifnum\csname\:tmp :type\endcsname=\milestonenode:\relax
     \edef\:temp{\csname\:tmp :date\endcsname}
  \else
     \edef\:tempa{\noexpand\IF\noexpand\EqText(\csname#1
                                              :desc\endcsname,start)}
     \:tempa
         \edef\:temp{\csname\:tmp :date1\endcsname}
     \ELSE
         \edef\:temp{\csname\:tmp :date2\endcsname}
     \FI
  \fi
  \expandafter\let\csname#1 :date1\endcsname=\:temp
  \expandafter\let\csname#1 :date2\endcsname=\:temp
}
\IntVar\bck:N
\def\cnt:V#1#2#3#4#5{\bck:N+1;}
\def\cnt:VII#1#2#3#4#5#6#7{\bck:N+1;}

 \newif\iftrace: \trace:false
\def\traceon{\trace:true  }
\def\traceoff{\trace:false  }

\def\trace:#1{%
  \iftrace:
     \apply{#1,\traceM:,\traceP:,\traceT:}%
  \fi
}
\def\traceM:#1#2#3#4#5{%
  \immediate\write16{\string\defmilestone{#1}{#2}{#3}{#4}{#5}}}
\def\traceP:#1#2#3#4#5{%
  \immediate\write16{\string\defproject{#1}{#2}{#3}{#4}{#5}}}
\def\traceT:#1#2#3#4#5#6#7{%
  \immediate\write16{\string\deftask{#1}{#2}{#3}{#4}{#5}{#6}{#7}}}
\def\getlist:#1#2#3{
  \def\op:{#3}  \let#3=\relax
  \let~=\space  \let\temp:=\empty  \getlist::#2,,,/+/-]/[    \restoregal:
  \expandafter\let\csname#1\endcsname=\temp:
}
\def\getlist::#1,#2,#3/+/-]/[{
  \def\next:{#1}
  \ifx\next:\empty
     \def\temp::{#3} \ifx\temp::\empty\else  \missingiem:#3// \fi
  \else
     \edef\temp:{\temp: \op:{#1}}
     \def\next:{\getlist::#2,#3/+/-]/[} \expandafter\next:
  \fi
}
\def\missingiem:#1,,,//{
  \pwarn:{missing\space item\space in\space,,#1}
}
\def\setprev:#1#2{
 \def\temp:{#2}
 \ifx\temp:\empty    \expandafter\def\csname#1 :prev\endcsname{}
 \else
    \getlist:{#1 :prev}{#2}\prev:
    \def\prev:##1{\expandafter \edef \csname ##1: succe\endcsname
  {\expandafter \ifx \csname ##1: succe\endcsname\relax\else
   \csname ##1: succe\endcsname ,\fi#1}}
\csname#1: prev\endcsname

 \fi
}
\def\projectid:{0}
\def\setproject:#1#2{
 \traversedo:{#1}\setproject:data

 \def\temp:{#2}
 \ifx\temp:\empty\else  \def\temp:{\setproject:#2}   \fi
 \temp:
}
\def\verify:dates:#1#2{
 \traversedo:{#1}\checknodedates:

 \def\temp:{#2}
 \ifx\temp:\empty\else  \def\temp:{\verify:dates:#2}   \fi
 \temp:
}
\def\traversedo:#1#2{
 \def\utask:##1{
    \expandafter\let\csname##1 :sve\endcsname =\utask:
    \csname##1 :under\endcsname
    #2{##1}
    \def\utask:{\let\utask: =}
    \expandafter\utask:\csname##1 :sve\endcsname
 }
 \csname#1 :under\endcsname     #2{#1}
}
\def\checkmemb:#1{
  \expandafter\ifx\csname#1 :bool\endcsname\relax
     \pwarn:{definition\space for\space '#1'?}
  \fi
}
\def\utask:I#1{
 \ifnum\csname#1 :type\endcsname=\milestonenode:\relax
   \edef\temp:{\csname#1 :date\endcsname}
   \expandafter\maxDate:\temp:/
\else
   \edef\temp:{\csname#1 :date2\endcsname}
   \expandafter\maxDate:\temp:/
   \edef\temp:{\csname#1 :date1\endcsname}
\fi
\expandafter\minDate:\temp:/

}
\def\minDate:#1/#2/#3/{
  \ifnum #3<\minY:\relax      \def\minD:{#1} \def\minM:{#2} \def\minY:{#3}
  \else \ifnum #3=\minY:\relax
     \ifnum #2<\minM:         \def\minD:{#1} \def\minM:{#2}
     \else \ifnum #2=\minM:
        \ifnum #1<\minD:\relax\def\minD:{#1}     \fi
     \fi\fi
  \fi\fi }

\def\maxDate:#1/#2/#3/{
  \ifnum #3>\maxY:\relax      \def\maxD:{#1} \def\maxM:{#2} \def\maxY:{#3}
  \else \ifnum #3=\maxY:\relax
     \ifnum #2>\maxM:         \def\maxD:{#1} \def\maxM:{#2}
     \else \ifnum #2=\maxM:
        \ifnum #1>\maxD:\relax\def\maxD:{#1} \fi
     \fi\fi
  \fi\fi }
\def\getitems:#1#2{
 \def\items:{}   \let\item:=\relax
 \tcount:=#2 \relax     \advance\tcount: by -1\relax
 \let\utask:=\getchi:
 \csname#1 :under\endcsname
 \def\item:##1{    \expandafter\let\csname##1 :bool\endcsname=\UnDef: }
 \items:
}
\def\getchi:#1{
  \expandafter\ifx\csname#1 :bool\endcsname\relax
     \def\next:{  \edef\items:{ \item:{#1} \items: }  }
     \ifnum\csname#1 :type\endcsname=\projectnode:\space
        \ifnum 0<\tcount:
  \def\next:{
     \advance\tcount: by -1 \relax
     \csname#1 :under\endcsname  \relax
     \advance\tcount: by 1 \relax
  }
\fi

     \fi
     \expandafter\next:
  \fi
 }
\newcount\tcount:
\def\checknodedates:#1{
 \def\prev:##1{ \checkafter:{#1}{##1} }
 \csname#1 :prev\endcsname
}
\def\checkafter:#1#2{
  \getdate:\temp:A{#1}1
  \getdate:\temp:B{#2}2
  \edef\temp:{\temp:A/\temp:B/{`#1'\space starts\space
                             before\space `#2'\space ends}}
  \expandafter\checkdates:\temp:
}

\def\getdate:#1#2#3{
  \ifnum\csname#2 :type\endcsname=\milestonenode:\space
             \edef#1{\csname#2 :date\endcsname}
  \else      \edef#1{\csname#2 :date#3\endcsname}
  \fi
}

\def\checkdates:#1/#2/#3/#4/#5/#6/#7{
  \ifnum       #6>#3\space \pwarn:{#7}
  \else \ifnum #6=#3\space
     \ifnum       #5>#2\space \pwarn:{#7}
     \else \ifnum #5=#2\space
       \ifnum       #4>#1\space \pwarn:{#7} \fi
     \fi\fi
  \fi\fi   }
\def\listrsrc:#1{
 \ifnum\csname#1 :type\endcsname=\tasknode:\space
    \csname#1 :eff\endcsname
 \else
    \expandafter\expandafter  \csname#1 :under\endcsname
 \fi
}
\long\def\append:Def#1#2{%
  \def\:temp{\def#1}%
  \expandafter\expandafter\expandafter\:temp\expandafter{#1#2}}
\def\reseffI:#1#2{
  \expandafter\ifx\csname#1 :bool\endcsname\relax
     \sepitems: \append:Def\all:des{#1}
     \expandafter\let\csname#1 :bool\endcsname=\empty
  \fi
}
\def\effortout:{
 \I:I[\Q:Q];
 \IF \EqDec(\I:I,\Q:Q)  \THEN   \edef\temp:{\Val\I:I}
 \ELSE                      \edef\temp:{\Val\Q:Q}      \FI
}
\long\def\contr::#1#2#3{
 \def\contr:##1##2{  \ifnum 0<\tcount:\relax#3\fi #1#2 }
}
\def\contributionsstyle{  \contr::
}
\contributionsstyle{#1}{\space (#2)}{,\space}

\def\findeffort:#1#2{  \ifx#2\empty
 \def\reseff:##1##2{  \Q:Q + ##2; }
\else
 \def\reseff:##1##2{
    \def\temp:{##1}
    \ifx\temp:#2  \Q:Q + ##2;  \fi
 }
\fi
\Q:Q=0;
\ifnum\csname#1 :type\endcsname=\tasknode:\space
   \csname#1 :eff\endcsname
\else
   \getitems:{#1}{999}
   \def\item:##1{ \csname##1 :eff\endcsname }
   \items:
\fi
\effortout:
}
\def\findthecontri:#1{\def\reseff:##1##2{
  \expandafter\ifx\csname##1 :bool\endcsname\relax
     \expandafter\def\csname##1 :bool\endcsname{##2}
     \edef\alls:{\alls: \all:{##1}}
  \else
     \Q:Q=\csname##1 :bool\endcsname;
     \Q:Q+##2;
     \expandafter\edef\csname##1 :bool\endcsname{\Val\Q:Q}
  \fi
}
\let\alls:=\empty \let\all:=\relax
\ifnum\csname#1 :type\endcsname=\tasknode:\space
  \csname#1 :eff\endcsname
\else
  \getitems:{#1}{999}
  \def\item:##1{ \ifx  \yrS:  \:UnDef  \csname##1 :eff\endcsname
\else
  \edef\svK:K{\Val\K:K}
  \axisdate:\temp:{##1}1 \ifnum \temp:<\dateA:\else
     \axisdate:\temp:{##1}2 \ifnum \temp:>\dateB:\else
        \csname##1 :eff\endcsname
  \fi\fi
  \K:K=\svK:K;
\fi
}
  \items:
\fi
\tcount:=0
\def\all:##1{
 \Q:Q=\csname##1 :bool\endcsname;
 \contr:{##1}{{\effortout:\temp:}}
 \tcount:=1
}
\alls:
}
\def\datestyle{\def\showdate:##1/##2/##3/##4//}
\datestyle{#1/#2/#3}
\def\apply:#1,#2,#3,#4,#5//{
  \verify:{#1}    \def\verify:##1{}
  \extract:
  \def\mop:{#2}  \def\pop:{#3}  \def\top:{#4}
  \apply::{#1}
  \let\verify:=\verify::
}
\def\rapply:#1,#2,#3,#4,#5//{
  \verify:{#1}     \def\verify:##1{}
  \def\utask:##1{
    \def\mop:{#2}  \def\pop:{#3}  \def\top:{#4}
    \apply::{##1}
    \I:I=\depth;  \I:I+1;  \edef\depth{\Val\I:I}
    \ifnum\csname#1 :type\endcsname=\projectnode:\space
        \csname##1 :under\endcsname
    \fi
    \I:I=\depth;  \I:I-1;  \edef\depth{\Val\I:I}
  }
  \utask:{#1}   \let\verify:=\verify::
}

\def\depth{0}\def\apply::#1{
  \push:macro\utask:
\push:macro\contr:

  \extract:
  \let\temp:=\empty
  \ifnum \csname#1 :type\endcsname=\milestonenode:\space
     \ifx   \mop:\empty \else
  \edef\temp:{\expandafter\noexpand\mop:{#1}{\csname#1 :title\endcsname}{\csname#1 :date\endcsname}
{\expandafter\ifx\csname#1 :prev\endcsname\empty\else
  \pp:\csname#1 :prev\endcsname
\fi}
{\expandafter\noexpand\csname#1 :desc\endcsname}
}
\fi

  \else
     \ifnum \csname#1 :type\endcsname=\projectnode:\space
        \ifx   \pop:\empty \else
  \edef\temp:{\expandafter\noexpand\pop:{#1}{\csname#1 :title\endcsname}{
\expandafter\ifx\csname#1 :under\endcsname\relax\else
  \pp:\csname#1 :under\endcsname
\fi}
{\expandafter\ifx\csname#1 :prev\endcsname\empty\else
   \pp:\csname#1 :prev\endcsname
\fi}{\expandafter\noexpand\csname#1 :desc\endcsname}
}
\fi

     \else
        \ifx   \top:\empty \else
  \edef\temp:{\expandafter\noexpand
     \top:{#1}{\csname#1 :title\endcsname}
{\csname#1 :date1\endcsname}
{\csname#1 :date2\endcsname}
{\expandafter\ifx\csname#1 :eff\endcsname\relax\else
  \pp:\csname#1 :eff\endcsname
\fi}
{\expandafter\ifx\csname#1 :prev\endcsname\empty\else
  \pp:\csname#1 :prev\endcsname
\fi}{\expandafter\noexpand\csname#1 :desc\endcsname}
}
\fi

     \fi
  \fi
  \temp:
  \pop:macro\contr:
\pop:macro\utask:

}
\def\extract:{
  \def\pp:{\expandafter\expandafter\expandafter\expandafter\expandafter
           \expandafter\expandafter\ppp:}
  \def\ppp:##1,{}
  \def\prev:##1{,##1}
  \def\utask:##1{,##1}
  \edef\reseff:##1##2{,##1\string :##2}
}
\def\push:macro#1{
  \expandafter\let\csname appl:\Val\s:appN\endcsname#1
  \s:appN+1;
}
\def\pop:macro#1{
  \s:appN-1;
  \expandafter\let\expandafter#1\csname appl:\Val\s:appN\endcsname
}
\def\set:dateprj#1{\set:dtpr#1,}
\def\set:dtpr#1.#2.#3.#4,{
 \I:I=#1; \I:I-1000000000;
 \edef\:temp{\noexpand \sapply{\pc:id.#4\ifcase#3\space\else .#3\fi
      ,defproject,{#4},\Val\I:I,
       \ifcase#3\space \or start\or finish\else \fi}}   \:temp
 \ifx \prv:\empty \else
   \expandafter\edef\csname \pc:id.#4\ifcase#3\space\else .#3\fi
        :prev\endcsname {\noexpand \prev:{\pc:id.\prv:}}
   \expandafter\edef\csname  \pc:id.\prv: :succe\endcsname
        {\pc:id.#4\ifcase#3\space\else .#3\fi}
 \fi
 \edef\prv:{#4\ifcase#3\space\else .#3\fi}
 \edef\all:prjc{\ifx \all:prjc\empty\else \all:prjc,\fi
        \pc:id.#4\ifcase#3\space\else .#3\fi}
 \edef\:temp{\noexpand \sapply{\pc:id.m,merge,
        \pc:id.m,{\pc:id.#4\ifcase#3\space\else .#3\fi}}} \:temp
}
\def\gettree:{
  \let\nextrow:=\empty     \J:J=0;  \row:     \edef\tree:{ \tree: // }
  \ifx\nextrow:\empty \else
     \let\row:=\nextrow:  \K:K-1;
     \expandafter\gettree:
  \fi
}
\def\getnode:#1{
 \I:I=0;  \J:J+1;
 \ifnum\csname#1 :type\endcsname=\projectnode:\space
    \expandafter\expandafter \csname#1 :under\endcsname
 \fi
 \expandafter\ifx\csname#1 :bool\endcsname\relax
  \expandafter\let\csname#1 :bool\endcsname=\empty
\else
  \advance\tcount: by 1\space
  \expandafter\edef\csname##1 :id\endcsname{\the\tcount:}
\fi

 \edef\tree:{  \tree:
    \ifnum\Val\J:J>1\empty~ \fi
    \Val\I:I, \csname#1 :type\endcsname, {\treetext:{#1}}
    \nodeid:{#1}
 }
}
\:DefineExt\treestyle(5){\endgroup
  \def\temp:{#1} \ifx\temp:\empty\else   \let\project:node=#1         \fi
  \def\temp:{#2} \ifx\temp:\empty\else   \let\milestone:node=#2       \fi
  \def\temp:{#3} \ifx\temp:\empty\else   \let\task:node=#3            \fi
  \def\temp:{#4} \ifx\temp:\empty\else   \let\project:edge=#4         \fi
  \def\temp:{#5} \ifx\temp:\empty\else   \def\treenodewidth:{#5pt}    \fi
}
\treestyle(\VRectNode, \RectNode, \SRectNode,\TreeEdge,70)
\def\getparms:#1,#2,#3,#4,#5,#6,#7,#8,#9//{
  \def\first:{#1}   \def\second:{#2}     \def\third:{#3}
  \def\fourth:{#4}  \def\fifth:{#5}      \def\sixth:{#6}
  \def\seventh:{#7} \def\eighth:{#8}            }
\def\axisdate:#1#2#3{
  \breakdate:\DD:\MM:\YY:{#2}#3
  \K:K=\YY:;  \IF \LtInt(\K:K,\yrS:) \THEN \K:K+\maxYY:;  \FI
  \K:K*\maxMM:;  \K:K+\MM:;
  \IF \EqInt(\maxYY:,0)  \THEN
     \IF \LtInt(\K:K,\moS:) \THEN \K:K+\maxMM:;  \FI
  \FI
  \K:K*\maxDD:;  \K:K+\DD:;
  \K:K-\dateS:; \edef#1{\Val\K:K}
}
\def\breakdate:#1#2#3#4#5{
 \expandafter\ifx \csname#4 :date#5\endcsname\relax
    \pwarn:{Dates\space not\space available\space for\space #4}
 \else
    \def\temp:##1/##2/##3/{\def#1{##1}\def#2{##2}\def#3{##3}}
    \expandafter\expandafter
        \expandafter\temp:\csname#4 :date#5\endcsname/
 \fi
}

\def\titletext:#1{
 \Text(--\titletextA:{#1}--)
}

\def\titletextA:#1{\ifdim\nodewidth:>0in
   \vbox\bgroup  \hsize=\nodewidth:
   \leftskip     0pt plus 0.5\hsize
   \rightskip    0pt plus 0.5\hsize
   \parfillskip  0pt                   \fi
   #1                 \ifdim\nodewidth:>0in
        \egroup                         \fi}
\def\treenodestyle{\def\treetext:##1}
\treenodestyle{\csname#1 :title\endcsname}
\def\last:segdraw#1{
  \ifnum \effort:n>1
    \I:I=\effort:n;    \I:I-1; \edef\effort:n{\Val\I:I}
    \I:I=\effort:from; \I:I+\effort:step; \edef\effort:from{\Val\I:I}
    \I:I=\effort:to; \I:I+\effort:step;  \edef\effort:to{\Val\I:I}
    \ifnum \effort:max < \effort:to \let\effort:to=\effort:max \fi
    \expandafter\expandafter\expandafter#1
  \fi
}
\def\doelements:#1{%
  \ifx\fifth:\empty  \def\fifth:{1}\fi
  \IF \EqInt(\fifth:,0)\THEN      \chartelement:{#1}%
  \ELSE       \rapply{#1,\milestonechild:,\projectchild:,\taskchild:}\FI}

\def\milestonechild:#1#2#3#4#5{\child:{#1}}
\def\taskchild:#1#2#3#4#5#6#7{\child:{#1}}
\def\projectchild:#1#2#3#4#5{\IF \EqInt(\depth,\fifth:)\THEN
  \chartelement:{#1}\FI}

\def\child:#1{\IF \GtInt(\depth,\fifth:)\ELSE
  \chartelement:{#1}\FI }
\def\getscale:#1{
  \def\scale:{1}
  \K:K=#1;
  \Do(0,4){ \IF \GtInt(\K:K,1000) \K:K/10;  \edef\scale:{\scale:0}  \FI }
  \R:R=200;    \R:R/\K:K;  \R:R*\:Cons\:Xunits;  \Scale(\Val\R:R,4)
}
\defcom{MINMAXDATES:}#1{
  \expandafter\edef\csname\projectid: :minmax\endcsname{
      \noexpand \getminmaxdates:#1//}
 }
\def\getminmaxdates:#1/#2/#3//#4/#5/#6//{
  \I:I=#4;  \I:I-#1;  \I:I+1;  \edef\maxDD:{\Val\I:I}
  \I:I=#5;  \I:I-#2;  \I:I+1;  \edef\maxMM:{\Val\I:I}
  \I:I=#6;  \I:I-#3;  \I:I+1;  \edef\maxYY:{\Val\I:I}
}
\newif\ifpflag:
\def\cutprojectstasksA:#1{
  \axisdate:\dateA:{#1}1
  \axisdate:\dateB:{#1}2
  \ifnum   \dateB:<0\space        \pflag:false \fi
  \ifnum   \dateA:>\dateF:\space  \pflag:false \fi
  \ifnum   \dateA:<0\space        \def\dateA:{0} \fi
  \ifnum   \dateB:>\dateF:\space  \let\dateB:=\dateF: \fi
  \ifnum   \optt:=\csname#1 :type\endcsname\space   \pflag:false \fi
  \ifnum   \optp:=\csname#1 :type\endcsname\space   \pflag:false \fi
}
\Define\ignoredepth:{
  \let\sv:AddBarDepth=\:AddBarDepth
  \Define\:AddBarDepth(2){\let\:AddBarDepth=\sv:AddBarDepth }
}
\def\movemilestonesym:#1,#2//{\Q:Q=#1;\Q:Q-#2; \Q:Q/2;
  \Move(0,\Val\Q:Q) }
\def\putbartext:{
 \if        E\bareff:     \efforts:(\Val\K:K,\Val\K:K){ \geteff: }
 \else  \if T\bartext:
    \K:K+1;   \names:Tbl:(\Val\K:K,\Val\K:K){ \getname: }
 \else  \let\bareff:=X
 \fi\fi
 \if X\bareff: \else
    \K:K+1;
    \let\nodewidth:=\scnodewidth:   \titletext:{\temp:}
    \MoveToExit(-1.1,1.1)  \MarkLoc(1-:)
    \MoveToExit(1.1,-1.1)  \MarkLoc(2-:)  \CSeg\Clip(2-:,1-:)
 \fi
}
\Define\getname:(1){ \def\temp:{#1} }
\Define\geteff:(1){\findeffort:{#1}\empty}
\def\datesaxis(#1)(#2){ \scheaxis:{#1}{#2}\dates:}
\def\nonamesaxis(#1)(#2){ \scheaxis:{#1}{#2}\nonames:}
\def\namesaxis(#1)(#2){{\let\TicText=\TicName::
   \scheaxis:{#1}{#2}\names: }}
\def\scheaxis:#1#2#3{ \def~{\noexpand&}
   \edef\temp:{\noexpand\Axis(#1)(#2,#3) } \temp: }
\TextPar\Define\TicName::(1){\IF \EqText(,#1) \THEN
  \ELSE      \let\nodewidth:=\scnodewidth:
  \titletext:{#1} \FI}
\:DefineExt\schedulestyle(7){\endgroup
  \def\baropt:##1##2##3##4//{
      \let\baropt:=\empty  \let\txtopt:=\UndDef:
      \baroptA:##1  \baroptA:##2  \baroptA:##3
     }
  \let\baropts:=\empty  \let\bartext:=x  \let\barIIID:=x
  \let\baraxis:=x       \let\bareff:=x
  \def\temp:{#1}   \ifx\temp:\empty\else   \baropt:#1......//     \fi
  \def\temp:{#2#3} \ifx\temp:\empty\else   \def\barloc:{#2,#3}    \fi
  \def\temp:{#4}   \ifx\temp:\empty\else   \def\projectcolor:{#4} \fi
  \def\temp:{#5}   \ifx\temp:\empty\else   \def\taskcolor:{#5}    \fi
  \def\temp:{#6}   \ifx\temp:\empty\else   \def\milestonesym:{#6} \fi
  \def\temp:{#7}   \ifx\temp:\empty\else   \def\scnodewidth:{#7pt} \fi
}
\:DefineExt\schedulelimits(1){\endgroup
  \schedulelimits:#1,,,//
}
\expandafter\long\expandafter\def\csname
   .:\string \schedulelimits\endcsname(#1){\endgroup
  \schedulelimits:#1,,,//
}
\long\def\schedulelimits:#1,#2,#3//{
  \def\temp:{#1}   \ifx\temp:\empty\else   \def\schedulelimit:{#1} \fi
  \def\temp:{#2}   \ifx\temp:\empty\else   \def\schedulecode:{#2}  \fi
}
\schedulelimits(10000,\par)
\def\baroptA:#1{
  \if#1T                               \let\bartext:=T  \fi
  \if#1A                               \let\baraxis:=A  \fi
  \if#1E            \let\bareff:=E     \let\baraxis:=A  \fi
  \if3#1  \let\barIID:=3    \edef\baropts:{\baropts: 3} \fi
}

\schedulestyle(A,2.5,7.5,3,0,$\otimes$,70)
\def\cutoffdates:{
  \def\yrS:{0}  \def\moS:{0}  \def\dateS:{0}
\ifx\second:\empty
  \axisdate:\dateS:{\first:}1
\else
  \let\:date:=\second:
  \axisdate:\dateS:{}:
\fi
\let\dyS:=\DD:   \let\moS:=\MM:   \let\yrS:=\YY:
\ifx\third:\empty
  \axisdate:\dateF:{\first:}2
\else
  \let\:date:=\third:
  \axisdate:\dateF:{}:
\fi
\let\dyF:=\DD:   \let\moF:=\MM:   \let\yrF:=\YY:

}
\def\cutofftypes:{
 \def\optm:{-1}   \def\optt:{-1}   \def\optp:{-1}
 \expandafter\cutofftypesA:\fourth:....//
}
\def\cutofftypesA:#1#2#3#4//{
  \chkop:#1  \chkop:#2  \chkop:#3
}
\def\chkop:#1{
  \if M#1 \let\optm:=\milestonenode:   \fi
  \if T#1 \let\optt:=\tasknode:        \fi
  \if P#1 \let\optp:=\projectnode:     \fi
}
\def\getint:#1.#2.#3//{ \K:K=#1; \def\frac:{0.#2} }
\def\utaskII:#1{
 \ifnum \csname#1 :type\endcsname=\milestonenode:\space \else
   \pflag:true
   \edef\svK:K{\Val\K:K}   \cutprojectstasks:{#1}    \K:K=\svK:K;
   \ifpflag:   \ifnum \csname#1 :type\endcsname=\projectnode:\space
      \J:J=0; \contributionsstyle{}{}{}  \findthecontri:{#1}
\def\all:##1{ \reseffII:{##1}{\csname##1 :bool\endcsname}
             \expandafter\let\csname##1 :bool\endcsname=\:UnDef
}
\alls:

\else  \J:J=0;
\let\reseff:=\reseffII:
\csname#1 :eff\endcsname
      \fi
\R:R=\J:J;   \R:R/2;   \R:R+\K:K;   \K:K+\J:J;
\edef\names:{   \names:   \ifx\names:  \empty\else ~ \fi
               \Val\R:R,\csname#1 :title\endcsname    }
\edef\nonames:{ \nonames: \ifx\nonames:\empty\else ~ \fi
                \Val\K:K,\relax
                 }
\edef\lastnames:{ \Val\K:K }

  \fi
 \fi
}
\def\reseffII:#1#2{  \J:J+1;
\IF \GtDec(#2,\maxeffort:) \edef\maxeffort:{#2} \fi
\edef\bars:{  #2,#1  \ifx\bars:\empty\else ~ \fi   \bars:  }
 }
\def\dec:dim#1{%
  \def~{\noexpand&} \edef\tmp:i{\bars:}
  \expandafter\Table\expandafter\tmp:i\expandafter{\tmp:i}
  \Define\tmp:ii(1){} \I:I=0;  \tmp:i(0,999){\I:I+1; \tmp:ii}
  \edef\effort:max{\Val\I:I} \I:I+#1; \I:I-1;
  \I:I / #1;
  \edef\effort:n{\Val\I:I}  \J:J=\effort:max; \J:J/\effort:n;
  \I:I=\J:J; \I:I*\effort:n; \IF \LtInt(\I:I,\effort:max) \J:J+1;\FI
  \def\effort:from{1} \edef\effort:to{\Val\J:J}
  \let\effort:step=\effort:to
}
\def\cnd:starts#1{
  \aft:edraw

  \df:bfs

  \snd:bxo #1
  \global \expandafter\setbox
          \csname dra:bx\effort:n\endcsname=\hbox
}
\def\aft:edraw{
 \ifx \effort:boxes\:Undef
    \gdef\effort:boxes{\global\let\effort:boxes=\:Undef}
    \global\let\ef:EndDraw=\EndDraw
    \gdef\EndDraw{\ef:EndDraw \global\let\EndDraw=\:UnDef \effort:boxes }
 \fi
}
\def\df:bfs{
  \expandafter\ifx \csname dra:bx\effort:n\endcsname\relax
     \global\csname newbox\expandafter
         \endcsname \csname dra:bx\effort:n\endcsname \fi
}
\def\snd:bxo#1{
  \expandafter\ifx \csname right:mrk\endcsname\relax
  \tmp:dim=\:RBorder
  \advance\tmp:dim by -\:LBorder
\else
  \tmp:dim=\right:mrk pt \advance\tmp:dim by - \left:mrk pt
  \global\let\right:mrk\:UnDef
\fi

  \expandafter\tmp:toks\expandafter{\effort:boxes}
  \expandafter\expandafter\expandafter\tmp:toks
     \expandafter\expandafter\expandafter{\expandafter
     \the\expandafter\tmp:toks  #1}
  \xdef\effort:boxes{\the\tmp:toks \noexpand\Draw
  \noexpand\Text(--\noexpand  \hbox to\the\tmp:dim{
\hss

     \box \csname dra:bx\effort:n\endcsname
  }

  --)\noexpand\EndDraw }
}
\ifx \tmp:toks\:UnDef \csname newtoks\endcsname \tmp:toks \fi
\def\sv:forchart{
  \let\sv:bars=\bars:
  \let\sv:names=\names:
  \let\sv:nonames=\nonames:
  \let\gall:=~
}
\def\recall:forchart{
  \let\bars:=\sv:bars
  \let\names:=\sv:names
  \let\nonames:=\sv:nonames
  \let~=\gall:
}
\TextPar\Define\EffortBarText:(1){
  \MoveToLoc(BarBot)  \Move(5pt\du,0)
  \EntryExit(-1,0,0,0) \Text(--#1--)
    \MoveToExit(-1.1,1.1)  \MarkLoc(1-:)
    \MoveToExit(1.1,-1.1)  \MarkLoc(2-:)  \CSeg\Clip(2-:,1-:)
}
\:DefineExt\effortstyle(1){\endgroup\effortstyle:(#1,,,)}
\Define\effortstyle:(6){
  \def\baropt:##1##2##3##4//{
      \effortbaroptA:##1  \effortbaroptA:##2   \effortbaroptA:##3
     }
  \let\effortbaropts:=\empty     \let\effortbaraxis:=x
  \let\effortbartext:=x          \let\effortbarIIID:=x
  \def\temp:{#1}   \ifx\temp:\empty\else   \baropt:#1......//  \fi
  \def\temp:{#2#3} \ifx\temp:\empty\else   \def\effortbarloc:{#2,#3} \fi
  \def\temp:{#4}   \ifx\temp:\empty\else   \def\effortcolor:{#4}     \fi
  \def\temp:{#5}   \ifx\temp:\empty\else   \def\efftextwidth:{#5pt}  \fi
}
\:DefineExt\effortlimits(1){\endgroup
  \effortlimits:#1,,,//
}
\expandafter\long\expandafter\def\csname
   .:\string \effortlimits\endcsname(#1){\endgroup
  \effortlimits:#1,,,//
}
\long\def\effortlimits:#1,#2,#3//{
  \def\temp:{#1}   \ifx\temp:\empty\else   \def\effortlimit:{#1} \fi
  \def\temp:{#2}   \ifx\temp:\empty\else   \def\effortcode:{#2}  \fi
}
\effortlimits(10000,\par)
\def\effortbaroptA:#1{
  \if#1A  \let\effortbaraxis:=A                      \fi
  \if#1T  \let\effortbartext:=T                      \fi
  \if3#1  \let\effortbarIIID:=3
          \edef\effortbaropts:{\effortbaropts: 3}    \fi
}

\effortstyle(A,2.5,7.5,1,70)
\let\effortaxis=\datesaxis
\TextPar\Define\TicName:(1){ \IF \EqText(,#1) \THEN
                    \ELSE \let\nodewidth:=\efftextwidth:
                            \titletext:{#1} \FI}
\def\sort:{
 \let\sorted:=\empty
 \pflag:false
 \expandafter\sortA:\dates:{}
 \let\dates:=\sorted:
 \ifpflag: \expandafter\sort: \fi}
\def\sortA:#1#2{
 \def\temp:{#2}
 \ifx\temp:\empty  \edef\sorted:{\sorted: {#1}}   \let\next:=\relax
 \else
    \ifnum #1>#2\space
        \pflag:true
        \edef\sorted:{\sorted: {#2}}   \def\next:{\sortA:{#1}}
    \else
        \edef\sorted:{\sorted: {#1}}   \def\next:{\sortA:{#2}}
    \fi
 \fi
 \next:
}
\def\indexIII:#1{
  \Q:Q = 0;  \I:I = 0;
  \csname#1 :prev\endcsname
  \IF  \GtInt(\I:I,0)  \THEN  \Q:Q / \I:I;  \FI
  \def\entry:{#1}  \let\next:=\empty
  \expandafter\addtocurrow:\currow:{}{}
}
\def\prevI:#1{
 \expandafter\ifx\csname#1  : in/cl: \endcsname\relax \else
    \Q:Q + \csname#1  : in/cl: \endcsname;
    \I:I + 1;
 \fi
}
\def\addtocurrow:#1#2{
  \def\temp:{#1}
  \ifx\temp:\empty
     \edef\next:{\next:{\Val\Q:Q}{\entry:}}   \let\currow:=\next:
  \else
     \IF \GtDec(#1,\Q:Q)  \THEN
        \edef\next:{\next:{\Val\Q:Q}{\entry:}}
        \Q=#1; \def\entry:{#2}
     \ELSE
        \edef\next:{\next:{#1}{#2}}
     \FI
     \expandafter\addtocurrow:
  \fi    }
\def\inserttocol:#1#2{
  \def\temp:{#1}  \ifx\temp:\empty  \else
     \expandafter\edef\csname \the\tcount: :nodes\endcsname{
        \csname\the\tcount: :nodes\endcsname
        \node:{#2} }
     \expandafter\edef\csname#2  : in/cl: \endcsname{\the\tcount:}
     \advance\tcount: by 1\relax
     \expandafter\inserttocol:
  \fi
}
\def\pertnodestyle{\def\perttext:##1}
\pertnodestyle{\csname#1 :title\endcsname}
\def\subsort:{
  \pflag:false
  \expandafter\subsortA:\elms:{}
  \ifpflag:  \expandafter\subsort: \fi
}

\def\subsortA:#1{
  \def\cur:{#1}
  \ifx\cur:\empty      \else
     \csname#1 :prev\endcsname
     \expandafter\subsortA:
  \fi
}

\def\compr:#1{
  \def\temp:{#1}
  \ifx\temp:\bef:
     \I:I=\csname#1 :boolA\endcsname;  \I:I+1;
     \IF  \GtInt(\I:I,\csname\cur: :boolA\endcsname) \THEN
         \pflag:true
         \expandafter\edef\csname\cur: :boolA\endcsname{\Val\I:I}
         \IF \GtInt(\I:I,\maxsub:) \THEN  \edef\maxsub:{\Val\I:I}  \FI
     \FI
  \fi
  \ifx\temp:\empty\else  \expandafter\compr:\fi
}
\def\indexII:#1{
  \ifnum\csname#1 :boolA\endcsname=\DoReg
        \I:I=\csname#1 : in/cl:\endcsname;
  \CSeg\:GetXY(origin:,col.\Val\I:I)
  \def\adjprt:{0}
\ifx\prtadjtbl:\empty\else
 \Define\searchadj:(2){ \IF \EqText(##1,#1) \THEN \def\adjprt:{##2}\FI}
 \prtadjtbl:(0,999){\searchadj:}
\fi

  \if H\hpert:
     \IF \LtDec(\Va,\T:T) \THEN \Va=\T:T; \FI
     \IF \LtDec(\R:R,\Va) \THEN \R:R=\Va; \FI
     \Vb+\adjprt:;

  \else
     \IF \GtDec(\Vb,\T:T) \THEN \Vb=\T:T; \FI
     \IF \GtDec(\R:R,\Vb) \THEN \R:R=\Vb; \FI
     \Va+\adjprt:;

  \fi
  \MoveTo(\Val\Va,\Val\Vb)
\seg:prt

\ifx \:tmp\def
 \if H\hpert:
  \IF \LtInt(\I:I,\u:pert) \THEN
    \sapply{up,merge,up,{#1}}

  \ELSE    \IF \GtInt(\I:I,\d:pert) \THEN
    \sapply{down,merge,down,{#1}}

  \ELSE    \IF \LtInt(\DoReg,\l:pert) \THEN
    \sapply{temp,intersect,done,{#1}}
\sapply{temp,\Va=1;\gob:I}
\sapply{left,merge,left,{#1}}

  \ELSE    \IF \GtInt(\DoReg,\r:pert) \THEN
    \MarkLoc(here)  \CSeg\:GetY(col.maxY,here)
\IF  \LtDec(\Vb,0)  \THEN \MarkLoc(col.maxY) \FI
\CSeg\:GetX(col.maxX,here)
\IF  \LtDec(\Va,0)  \THEN
  \CSeg\:GetX(origin:,here)
  \Va/\node:wh;  \Va+\l:pert; \Va-1;
  \IF \LtDec(\Va,\r:pert)  \Va=-1; \FI
\FI
\sapply{temp,intersect,done,{#1}}
\sapply{temp,\Va=1;\gob:I}
\IF \LtDec(\Va,0)  \THEN
  \Va=-1;
\sapply{temp,intersect,done,{#1}}
\sapply{temp,\Va=1;\gob:I}
\IF \LtDec(\Va,0) \THEN
  \IF \GtInt(\DoReg,\r:pert) \THEN \ELSE
  \MarkLoc(.) \CSeg\:GetX(origin:,.)
  \Va/\node:wh; \Va/\step:right;
% \immediate\write16{..(\the\DoReg,\Val\I:I).......\Val\Vb....\step:down}
  \IF \GtDec(\Va,1.3) \THEN
     \gdef\overflow:col{Y}
  \ELSE
      \Va=-1;
  \FI
\FI

\FI
\IF \LtDec(\Va,0) \THEN
 \MarkLoc(before)  \PutNode(#1)   \MarkLoc(here)
\CSeg\:GetX(before,here)
\IF  \LtDec(\Va,\node:wh)  \THEN
  \edef\node:wh{\Val\Va}
\FI
\sapply{in,merge,in,{#1}}

 \Move(\openpertH:,-\adjprt:)
\ELSE
 \sapply{temp,intersect,done,{#1}}
\sapply{temp,\Va=1;\gob:I}
\sapply{left,merge,left,{#1}}

\FI

\ELSE
  \sapply{right,merge,right,{#1}}
\FI

  \ELSE  \Va=-1;
\sapply{temp,intersect,done,{#1}}
\sapply{temp,\Va=1;\gob:I}
\IF \LtDec(\Va,0) \THEN
  \IF \GtInt(\DoReg,\r:pert) \THEN \ELSE
  \MarkLoc(.) \CSeg\:GetX(origin:,.)
  \Va/\node:wh; \Va/\step:right;
% \immediate\write16{..(\the\DoReg,\Val\I:I).......\Val\Vb....\step:down}
  \IF \GtDec(\Va,1.3) \THEN
     \gdef\overflow:col{Y}
  \ELSE
      \Va=-1;
  \FI
\FI

\FI
\IF \LtDec(\Va,0) \THEN
 \MarkLoc(before)  \PutNode(#1)   \MarkLoc(here)
\CSeg\:GetX(before,here)
\IF  \LtDec(\Va,\node:wh)  \THEN
  \edef\node:wh{\Val\Va}
\FI
\sapply{in,merge,in,{#1}}

 \Move(\openpertH:,-\adjprt:)
\ELSE
 \sapply{temp,intersect,done,{#1}}
\sapply{temp,\Va=1;\gob:I}
\sapply{left,merge,left,{#1}}

\FI

  \FI \FI \FI \FI
\else
  \IF \LtInt(\I:I,\l:pert) \THEN
    \sapply{left,merge,left,{#1}}

  \ELSE    \IF \GtInt(\I:I,\r:pert) \THEN
    \sapply{right,merge,right,{#1}}

  \ELSE   \IF \LtInt(\DoReg,\u:pert) \THEN
    \sapply{temp,intersect,done,{#1}}
\sapply{temp,\Va=1;\gob:I}
\sapply{up,merge,up,{#1}}

  \ELSE    \IF \GtInt(\DoReg,\d:pert) \THEN
    \MarkLoc(here)  \CSeg\:GetY(here,col.maxY)
\IF  \LtDec(\Vb,0)  \THEN
  \CSeg\:GetY(here,origin:)
  \Vb/\node:wh;  \Vb+\u:pert; \Vb-1;
  \IF \LtDec(\Vb,\d:pert)  \Vb=-1; \FI
\FI
\sapply{temp,intersect,done,{#1}}
\sapply{temp,\Vb=1;\gob:I}
\IF \LtDec(\Vb,0)  \THEN
  \Va=-1;
\sapply{temp,intersect,done,{#1}}
\sapply{temp,\Va=1;\gob:I}
\IF \LtDec(\Va,0) \THEN
 \IF \GtInt(\DoReg,\d:pert) \THEN \ELSE
  \MarkLoc(.) \CSeg\:GetY(.,origin:)
  \Vb/\node:wh; \Vb/\step:down;
% \immediate\write16{..(\the\DoReg,\Val\I:I).......\Val\Vb....\step:down}
  \IF \GtDec(\Vb,1.2) \THEN
     \gdef\overflow:col{Y} \Va=1;
  \FI
\FI

\FI
\IF \LtDec(\Va,0) \THEN
 \MarkLoc(before)     \PutNode(#1)
\MarkLoc(here)
\CSeg\:GetY(here,before)
\IF  \LtDec(\Vb,\node:wh)  \THEN
  \edef\node:wh{\Val\Vb}
\FI
\CSeg\:GetY(here,col.maxY)
\IF  \GtDec(\Vb,0)  \THEN  \MarkLoc(col.maxY)  \FI
\sapply{in,merge,in,{#1}}

 \Move(-\adjprt:,-\openpertV:)
\ELSE
  \sapply{down,merge,down,{#1}}
\FI

\ELSE
  \sapply{down,merge,down,{#1}}

\FI

  \ELSE  \Va=-1;
\sapply{temp,intersect,done,{#1}}
\sapply{temp,\Va=1;\gob:I}
\IF \LtDec(\Va,0) \THEN
 \IF \GtInt(\DoReg,\d:pert) \THEN \ELSE
  \MarkLoc(.) \CSeg\:GetY(.,origin:)
  \Vb/\node:wh; \Vb/\step:down;
% \immediate\write16{..(\the\DoReg,\Val\I:I).......\Val\Vb....\step:down}
  \IF \GtDec(\Vb,1.2) \THEN
     \gdef\overflow:col{Y} \Va=1;
  \FI
\FI

\FI
\IF \LtDec(\Va,0) \THEN
 \MarkLoc(before)     \PutNode(#1)
\MarkLoc(here)
\CSeg\:GetY(here,before)
\IF  \LtDec(\Vb,\node:wh)  \THEN
  \edef\node:wh{\Val\Vb}
\FI
\CSeg\:GetY(here,col.maxY)
\IF  \GtDec(\Vb,0)  \THEN  \MarkLoc(col.maxY)  \FI
\sapply{in,merge,in,{#1}}

 \Move(-\adjprt:,-\openpertV:)
\ELSE
  \sapply{down,merge,down,{#1}}
\FI

  \FI \FI \FI \FI
\fi

\else
    \PutNode(#1)
  \if H\hpert:    \Move(\openpertH:,-\adjprt:)
  \else           \Move(-\adjprt:,-\openpertV:)  \fi

\fi
\MarkLoc(col.\Val\I:I)
\MoveToNode(#1,1,1)  \MarkLoc(.)
\CSeg\:GetX(col.maxX,.)
\IF  \GtDec(\Va,0)  \THEN    \MarkLoc(col.maxX)  \FI


  \fi
}
\Define\adjustpert(1){
  \def\prtadjtbl:{#1}
  \ifx\prtadjtbl:\empty \else  \Table\prtadjtbl:{#1}  \fi
}
\adjustpert()
\def\utaskIV:#1{ \def\cur:{#1}  \csname#1 :prev\endcsname }
\def\clipper:#1{
  \pflag:true
  \seg:prt

\ifx \:tmp\def  \pflag:false \fi
\sapply{temp,merge,in,left}
\sapply{temp,merge,right,temp}
\sapply{temp,merge,up,temp}
\sapply{temp,merge,down,temp}
\sapply{temp,intersect,temp,{#1}}
\sapply{temp,\pflag:true \gob:I}

  \ifpflag:
    \def\temp::{#1}
\ifx     \temp::\cur:   \pflag:false
\else\ifx\temp::\from:  \pflag:false
    \else       \MoveToLoc(\cur:)  \CSeg[0.5]\Move(\cur:,\from:)   \MarkLoc(:=center=:)
\CSeg\:GetXY(\cur:,:=center=:)
\IF  \LtDec(\Va,0)  \THEN  \Va=-\Va;  \FI      \edef\HH:{\Val\Va}
\IF  \LtDec(\Vb,0)  \THEN  \Vb=-\Vb;  \FI      \edef\VV:{\Val\Vb}

                \MoveToNode(#1,0,-1) \MarkLoc(:=loc=:)
\CSeg\:GetY(:=center=:,:=loc=:)
\IF  \GtDec(\Vb,\VV:)  \THEN  \pflag:false   \ELSE
 \MoveToNode(#1,0,1) \MarkLoc(:=loc=:)
 \CSeg\:GetY(:=loc=:,:=center=:)
 \IF  \GtDec(\Vb,\VV:)  \THEN  \pflag:false  \ELSE
   \MoveToNode(#1,1,0) \MarkLoc(:=loc=:)
   \CSeg\:GetX(:=loc=:,:=center=:)
   \IF  \GtDec(\Va,\HH:)  \THEN  \pflag:false \ELSE
     \MoveToNode(#1,-1,0) \MarkLoc(:=loc=:)
     \CSeg\:GetX(:=center=:,:=loc=:)
     \IF  \GtDec(\Va,\HH:)  \THEN  \pflag:false  \FI
   \FI
 \FI
\FI

\fi  \fi

  \fi
  \ifpflag:
     \MoveToNode(#1,1,1)    \MarkLoc(b:)
     \MoveToNode(#1,-1,-1)  \MarkLoc(a:)  \CSeg\Clip(a:,b:)
  \fi
}
\:DefineExt\pertstyle(7){\endgroup
  \def\baropt:##1##2//{
      \pertoptA:##1
     }
  \let\hpert:=x
  \def\temp:{#1}   \ifx\temp:\empty\else   \baropt:#1......//    \fi
  \def\temp:{#2}   \ifx\temp:\empty\else   \def\openpertH:{#2}   \fi
  \def\temp:{#3}   \ifx\temp:\empty\else   \def\openpertV:{#3}   \fi
  \def\temp:{#4}   \ifx\temp:\empty\else   \let\MilestoneNode:=#4\fi
  \def\temp:{#5}   \ifx\temp:\empty\else   \let\ProjectNode:=#5  \fi
  \def\temp:{#6}   \ifx\temp:\empty\else   \let\TaskNode:=#6     \fi
  \def\temp:{#7}   \ifx\temp:\empty\else   \def\pertw:{#7pt}     \fi
}
\def\pertoptA:#1{
  \if#1H  \let\hpert:=H                         \fi
}

\pertstyle(,30,20,\RectNode,\VRectNode,\SRectNode,70)

 \def\treediagram(#1){{ \getparms:#1,,,,,,,,,//
  \verify:{\first:}      \def\verify:##1{}
  \ifx\EndDraw\UnDef:
     \pwarn:{\string\treediagram\space not\space within\space
                             \string\Draw...\string\EndDraw}
  \fi
  \ifx\second:\empty  \def\second:{999} \fi    \K:K=\second:;
  \ifnum\csname\first: :type\endcsname=\projectnode:\space
  \else  \K:K=0; \fi
  \IF \EqInt(\K:K,0)  \THEN
     \ifnum\csname\first: type\endcsname=\projectnode:\space
         \let\temp:=\projectnode
\else
  \ifnum\csname\first: type\endcsname=\tasknode:\space
         \let\temp:=\tasknode
  \else  \let\temp:=\milestonenode
  \fi
\fi
\temp:()(--{\treetext:{\first:}}--)

  \ELSE
    \tcount: = 0   \let\nodeid: = \relax

\let\node:=\getnode:
\def\row:{ \node:{\first:} }
\let~=\relax
\let\tree:=\empty
\def\utask:##1{
    \IF \GtInt(\K:K,0) \THEN
       \I:I+1;
       \let\node:=\relax
       \edef\nextrow:{ \nextrow: \node:{##1} }
       \let\node:=\getnode:
    \FI
}

    \TextNode(1){  \titletext:{##1}  }
\let\nodewidth:=\treenodewidth:
\def\temp:{\noexpand&}
\edef\temp:{
 \noexpand\TreeSpec
        (\projectnode:  ,\noexpand\project:node   \temp:
         \tasknode:     ,\noexpand\task:node      \temp:
         \milestonenode:,\noexpand
                           \milestone:node)()(\noexpand\project:edge)
}   \temp:

    \gettree:   \def~{\noexpand&}
    \def\nodeid:##1{
  \expandafter\ifx\csname##1 :id\endcsname\relax \else
     ${}^{\csname##1 :id\endcsname}$
  \fi  }

    \edef~{\noexpand\Tree()(\tree:)}  ~
  \FI
}}

\def\schedulechart(#1){    \getparms:#1,,,,,,,,,//
 \verify:{\first:}     \def\verify:##1{}
 \def\efforts:##1{}

 \let\gal:=~
 \let~=\relax
 \let\cutprojectstasks:=\cutprojectstasksA:
 \cutoffdates:   \getscale:\dateF:
 \I:I=\K:K;
\IF  \LtInt(\I:I,3)  \THEN   \I:I=3;
\ELSE
 \I:I=\yrF:;  \I:I-\yrS:;   \IF  \LtInt(\I:I,0)  \I:I+\maxYY:;  \FI
 \IF  \LtInt(\I:I,2)  \THEN
   \I:I*\maxMM:;  \I:I+\moF:;  \I:I-\moS:;
 \FI
\FI
\let\nodates:=\empty
\Do(1,\Val\I:I){ \edef\nodates:{\nodates: ~} }

\edef\dates:{\showdate:\dyS:/\moS:/\yrS:/0// \nodates:
            \showdate:\dyF:/\moF:/\yrF:/0//}

 \cutofftypes:
 \let\bars:=\empty    \let\names:=\empty    \let\nonames:=\empty
\def\chartelement:##1{ \pflag:true
\ifnum \csname##1 :type\endcsname=\milestonenode:\space
 \axisdate:\dateA:{##1}\empty
\I:I=\dateA:;   \def\temp:{-1} \J:J=0;    \K:K=0;
\ifnum   \dateA:<0\space                           \pflag:false \fi
\ifnum   \dateA:>\dateF:\space                     \pflag:false \fi
\ifnum   \optm:=\csname##1 :type\endcsname\space   \pflag:false \fi

\else
 \cutprojectstasks:{##1}
\def\temp:{0}
\ifnum \csname##1 :type\endcsname=\projectnode:\space
          \I:I=\dateA:;  \J:J=\dateB:;  \K:K=0;         \J:J-\I:I;
\else      \I:I=\dateA:;  \J:J=0;        \K:K=\dateB:;   \K:K-\I:I;
\fi

\fi
\I:I/\scale:;  \J:J/\scale:;    \K:K/\scale:;
\ifpflag:
 \edef\bars:{ \bars:  \ifx\bars:\empty\else ~ \fi
              \Val\I:I,\temp:,\Val\J:J,\Val\K:K  }
 \edef\names:{ ~  \csname##1 :title\endcsname   ~  \names:}
\edef\nonames:{\nonames:~}
\edef\efforts:{\efforts: ~ ##1 }

\fi
 }
\doelements:{\first:}

 \Define\DrawBar(2){
\IF  \GtInt(\J:J,0)  \THEN
 \IF \EqInt(\J:J,1)  \THEN
   \IF \EqInt(##1,-1)  \THEN
      \EntryExit(0,0,0,0)  \expandafter\movemilestonesym:\barloc://
      \Text(--\milestonesym:--)
      \MoveToExit(0,1) \Move(0,5pt\du)    \EntryExit(0,-1,0,0)  \putbartext:

      \ignoredepth:
   \FI
 \ELSE
   \IF \GtDec(##1,0)  \THEN
      \MarkLoc(o)    \R:R=##1;   \R:R/2;  \Q:Q=##2;  \Q:Q/2;
\Move(\Val\R:R,\Val\Q:Q)
\EntryExit(0,0,0,0)  \putbartext:  \MoveToLoc(o)

      \DrawRect(##1,##2)
   \FI
 \FI
\ELSE \ignoredepth: \FI
\J:J+1;  \IF  \EqInt(\J:J,4)  \THEN  \J:J=0;  \FI
}
\edef\temp:{\noexpand\BarChartSpec(HS\baropts:,\barloc: \noexpand &
         \barloc:  \noexpand & \barloc:  \noexpand & \barloc:)
     (0 \noexpand& 0 \noexpand& \projectcolor: \noexpand& \taskcolor:)}
\temp:

 \let~=\gal:
 \sv:forchart

 \ifnum \schedulelimit:=10000 \else
    \ifnum \schedulelimit:=10000 \else
  \def~{\noexpand&}   \edef\tmp:i{\bars:}  \let~=\relax
  \expandafter\Table\expandafter\tmp:i\expandafter{\tmp:i}
  \def\maxeffort:{0}
  \Define\tmp:ii(4){
    \K:K=##1; \K:K+##4;
    \IF \GtInt(\K:K,\maxeffort:) \THEN \edef\maxeffort:{\Val\K:K}\FI
  }
  \tmp:i(0,999){\tmp:ii}
\fi

    \dec:dim\schedulelimit:

 \fi
 \put:schedulechart
 \let~=\gal:
 \let\verify:=\verify::
}
\Define\put:schedulechart{
  \ifnum \schedulelimit:=10000 \else
    \I:I=\effort:from;  \J:J=\effort:to;  \let~=\relax
\I:I-1; \J:J-1;
\def~{\noexpand&}   \edef\tmp:i{\bars:}  \let~=\relax
\expandafter\Table\expandafter\tmp:i\expandafter{\tmp:i}
\let\bars:=\empty
\Define\tmp:ii(1){\edef\bars:{\ifx\bars:\empty\else\bars:~\fi##1}}
\tmp:i(\Val\I:I,\Val\J:J){\tmp:ii}

    \def~{\noexpand&}   \edef\tmp:i{\names:}  \let~=\relax
\expandafter\Table\expandafter\tmp:i\expandafter{\tmp:i}
\let\names:=\empty
\Define\tmp:ii(1){
  \IF \GtDec(\K:K,\min:sg) \THEN
  \IF \LtDec(\K:K,\max:sg) \THEN
     \edef\names:{\names:~ ##1}
  \FI \FI
  \K:K+1;
}
\K:K=\effort:max; \K:K-\effort:to;  \K:K*2;   \edef\min:sg{\Val\K:K}
\K:K=\effort:max; \K:K-\effort:from; \K:K+1;
              \K:K*2;  \K:K+1; \edef\max:sg{\Val\K:K}
\K:K=0;  \tmp:i(0,9999){\tmp:ii}

    \def~{\noexpand&}   \edef\tmp:i{\nonames:}  \let~=\relax
\expandafter\Table\expandafter\tmp:i\expandafter{\tmp:i}
\let\nonames:=\empty
\Define\tmp:ii(1){
  \IF \GtDec(\K:K,\min:sg) \THEN
  \IF \LtDec(\K:K,\max:sg) \THEN
     \edef\nonames:{\nonames:~##1}
  \FI \FI
  \K:K+1;
}
\K:K=\effort:from; \K:K-2; \edef\min:sg{\Val\K:K}
\K:K=\effort:to;            \edef\max:sg{\Val\K:K}
\K:K=0; \tmp:i(0,9999){\tmp:ii}

    \ifnum \effort:from>1
      \cnd:starts \schedulecode:
    \fi
    \bgroup
  \fi
  \def~{\noexpand&}      \pflag:true
\edef\temp:{ \noexpand\Table\noexpand\efforts:{ \efforts: }   }
\temp:
\if T\bartext:
  \edef\temp:{ \noexpand\Table\noexpand\names:Tbl:{ \names: }   }
  \temp:
  \let~=\relax
\Define\temp:(1){\edef\names:{##1~\names:}}
\let\names:=\empty
\names:Tbl:(0,99){\temp:}
\def~{\noexpand&}
\edef\temp:{ \noexpand\Table\noexpand\names:Tbl:{ \names: }   }
\temp:

\fi
  \J:J=0;  \K:K=0;
\edef\temp:{  \noexpand\BarChart( \bars: )  }             \temp:

  \ifnum \schedulelimit:=10000 \else
    \MoveToLoc(Origin) \Move(\maxeffort:,0)
\MarkLoc(NE)  \CSeg\Move(NW,SW)  \MarkLoc(SE)
\MoveToLoc(NE) \Text(----)


  \fi
  \let\nodewidth:=\scnodewidth:
\if A\baraxis:     \datesaxis(SW,NE)(S-1)

 \MoveToLoc(NE)  {\Text(--\phantom{\showdate:00/00/00/0//}--)
\MoveToExit(1,0) \Text(----)}


 \if T\bartext:
 \else            \MoveToLoc(SW)  \Move(-5pt\du,0) \MarkLoc(sw:)
\MoveToLoc(NE)  \Move(5pt\du,0)  \MarkLoc(ne:)
\CSeg\DrawRect(ne:,sw:)
\namesaxis(sw:,ne:)(W-0)
\nonamesaxis(sw:,ne:)(W-1)
\MoveToLoc(ne:) {\Text(--\phantom{\showdate:00/00/00/0//}--)
\MoveToExit(1,0) \Text(----)}



 \fi
\fi

  \ifnum \schedulelimit:=10000 \else
  \egroup
    \recall:forchart

    \last:segdraw\put:schedulechart

  \fi
}

\def\effortchart(#1){   \getparms:#1,,,,,,,,,//
 \verify:{\first:}      \def\verify:##1{}
 \ifnum\csname\first: :type\endcsname= \milestonenode: \space
    \pwarn:{\string\effortchart{\first:}?\space `\first:'\space is
         \space a\space milestone}
 \else
    \let\gal:=~
    \let~=\relax
    \edef\temp:{\second:\third:\fourth:}
\ifx\temp:\empty        \def\cutprojectstasks:##1{}
\else       \cutoffdates:  \cutofftypes:
                       \let\cutprojectstasks:=\cutprojectstasksA:
\fi

    \let\bars:=\empty    \let\names:=\empty    \let\nonames:=\empty
\def\maxeffort:{0}   \K:K=0;
\let\chartelement:=\utaskII:
\doelements:{\first:}

    \IF \EqInt(\K:K,0)  \THEN
       \pwarn:{empty\space effort\space chart\space for\space `#1'}
    \ELSE
       \expandafter\getint:\maxeffort:.0.0//  \getscale:\K:K
       \IF \GtInt(\scale:,1) \THEN
 \def~{\noexpand&}
 \edef\temp:{\noexpand\Table\noexpand\temp:{\bars:}}
 \temp:
 \let~=\relax
 \def\bars:##1{}
 \Define\tempa:(2){ \Q:Q=##1;
    \Q:Q/\scale:;  \edef\bars:{\bars: ~ \Val\Q:Q,##2}  }
 \temp:(0,99){\tempa:}
\FI

       \let\BarText=\EffortBarText:

\edef\temp:{\noexpand\BarChartSpec( HT\effortbaropts: , \effortbarloc: )
                                 ( \effortcolor: ) }
\temp:
\if A\effortbaraxis:   \if 3\effortbarIIID:  \BarGrid(0,,)  \FI\FI


       \edef\dates:{\maxeffort:}
\expandafter\getint:\maxeffort:.0.0//
\I:I=\K:K;  \I:I/2;  \K:K-\I:I; \K:K-\I:I;
\Q:Q=\frac:;  \Q:Q+\K:K; \Q:Q/2;
\IF \EqDec(\Q:Q,0)
      \edef\dates:{0 ~ \Val\I:I        ~ \dates:}
\ELSE  \Q:Q*10; \J:J[\Q:Q]; \edef\dates:{0 ~ \Val\I:I.\Val\J:J ~ \dates:}
\FI

       \edef\names:{0,\lastnames:~\names:}
\edef\nonames:{0,\lastnames: ~0,\relax~ \nonames:}

       \sv:forchart

       \ifnum \effortlimit:=10000 \else
          \dec:dim\effortlimit:

       \fi
       \put:effortchart
    \FI
    \let~=\gal:
 \fi
 \let\verify:=\verify::
}
\Define\put:effortchart{
  \ifnum \effortlimit:=10000 \else
    \I:I=\effort:from;  \J:J=\effort:to;  \let~=\relax
\I:I-1; \J:J-1;
\def~{\noexpand&}   \edef\tmp:i{\bars:}  \let~=\relax
\expandafter\Table\expandafter\tmp:i\expandafter{\tmp:i}
\let\bars:=\empty
\Define\tmp:ii(1){\edef\bars:{\ifx\bars:\empty\else\bars:~\fi##1}}
\tmp:i(\Val\I:I,\Val\J:J){\tmp:ii}

    \def~{\noexpand&}   \edef\tmp:i{\names:}  \let~=\relax
\expandafter\Table\expandafter\tmp:i\expandafter{\tmp:i}
\let\names:=\empty
\Define\tmp:ii(2){
  \T:T=\effort:max; \T:T-##1;
  \IF \GtDec(\T:T,\I:I) \THEN
  \IF \GtDec(\T:T,\effort:to) \THEN\ELSE
     \T:T=##1; \T:T-\effort:max;  \T:T+\effort:to;
     \IF \EqDec(\T:T,0.0) \THEN \T:T=0.25; \FI
     \edef\names:{\ifx\names:\empty\else\names:~\fi \Val\T:T,##2}
  \FI \FI
}
\tmp:i(1,9999){\tmp:ii}
\K:K=\effort:to; \K:K-\I:I;
\edef\names:{0,\Val\K:K\ifx \names:\empty\else ~\names:\fi}

    \def~{\noexpand&}   \edef\tmp:i{\nonames:}  \let~=\relax
\expandafter\Table\expandafter\tmp:i\expandafter{\tmp:i}
\let\nonames:=\empty
\Define\tmp:ii(2){
  \T:T=\effort:max; \T:T-##1;
  \IF \LtDec(\T:T,\I:I) \THEN \ELSE
  \IF \GtDec(\T:T,\effort:to) \THEN\ELSE
     \T:T=##1; \T:T-\effort:max;  \T:T+\effort:to;
     \edef\nonames:{\ifx\nonames:\empty\else\nonames:~\fi \Val\T:T,##2}
  \FI \FI
}
\tmp:i(1,9999){\tmp:ii}
\K:K=\effort:to; \K:K-\I:I;
\edef\nonames:{0,\Val\K:K\ifx \nonames:\empty\else ~\nonames:\fi}

    \ifnum \effort:from>1
      \cnd:starts \effortcode:
    \fi
    \bgroup
  \fi
  \def~{\noexpand&}
\edef\temp:{  \noexpand\BarChart( \bars: )  }        \temp:

  \ifnum \effortlimit:=10000 \else
    \MoveToLoc(Origin) \Move(\maxeffort:,0)
\MarkLoc(NE)  \CSeg\Move(NW,SW)  \MarkLoc(SE)
\MoveToLoc(NE) \Text(----)


  \fi
  \if A\effortbaraxis:
 \MoveToLoc(NE)  \Move(5pt\du,0)  \MarkLoc(ne:)
 \if 3\effortbarIIID:
    {\CSeg\Line(ne:,NW) } \CSeg\Line(NW,SW)   \CSeg\Line(ne:,NW)
 \else       \CSeg\DrawRect(ne:,SW)   \fi
 \effortaxis(SW,NE)(S-1)
 \namesaxis(SW,NE)(W5)
 \nonamesaxis(SW,ne:)(W8)
 \ifnum \effortlimit:=10000 \else
    \nonamesaxis(SW,ne:)(W-6)

 \fi
 \MoveToLoc(ne:) \Text(----)

\fi

  \ifnum \effortlimit:=10000 \else
    \egroup
    \recall:forchart

    \last:segdraw\put:effortchart

  \fi
}
\def\pertdiagram{\futurelet\:temp\pertd:ag}
\def\pertd:ag{\ifx \:temp*
     \def\date:less{\def\dateA:{0}}
     \def\:temp##1{\pertdiagram:}
  \else
     \let\date:less=\empty
     \let\:temp=\pertdiagram:
 \fi
 \:temp}
\def\pertdiagram:(#1){    \getparms:#1,,,,,,,,,//
 \verify:{\first:}     \def\verify:##1{}
 \ifnum\csname\first: :type\endcsname= \projectnode: \space
    \let\gal:=~
    \let~=\relax
    \cutoffdates:
    \cutofftypes:
    \let\index:=\relax  \let\dates:=\empty
\def\utask:##1{
  \expandafter\def\csname##1 :bool\endcsname{0}
  \ifnum\csname##1 :type\endcsname=\milestonenode:\space
     \axisdate:\dateA:{##1}\empty
  \else
     \axisdate:\dateA:{##1}1
  \fi
  \date:less
  \expandafter\ifx\csname -\dateA:-:\endcsname\relax
     \edef\dates:{  \dates: {\dateA:} }
  \fi
  \expandafter\edef\csname -\dateA:-:\endcsname{
      \expandafter\ifx\csname -\dateA:-:\endcsname\relax  \else
         \csname -\dateA:-:\endcsname
      \fi
      \index:{##1} }
}
\csname\first: :under\endcsname
\sort:
\def\prev:##1{
  \expandafter\ifx\csname##1 :bool\endcsname\relax

  \else
     \J:J=\csname##1 :bool\endcsname;  \J:J+1;
\IF  \GtInt(\J:J,\csname\cur: :bool\endcsname)  \THEN
  \pflag:true
  \expandafter\edef\csname\cur: :bool\endcsname{\Val\J:J}
\FI

  \fi  }
\def\utask:##1{
  \def\cur:{##1}
  \csname##1 :prev\endcsname   }
\def\setrows:{        \pflag:false
  \csname\first: :under\endcsname
  \ifpflag:
     \expandafter\setrows:
  \fi  }
\setrows:

    \J:J=-1;
\def\colsno:{0}  \expandafter\let\csname 0 :nodes\endcsname=\empty
\def\utask:##1{ \tcount:=\csname##1 :bool\endcsname\space
\expandafter\ifx\csname  col-:\the\tcount:\endcsname\relax
     \expandafter
 \def\csname  col-:\the\tcount: :+\endcsname{ \index:{##1} }

     \expandafter\def\csname  col-:\the\tcount:\endcsname{0}
     \tcount:=0\space  \J:J+1;
\else
     \expandafter\edef\csname  col-:\the\tcount: :+\endcsname{
  \csname  col-:\the\tcount: :+\endcsname \index:{##1} }

     \I:I=\csname  col-:\the\tcount:\endcsname;   \I:I+1;
     \expandafter\edef\csname  col-:\the\tcount:\endcsname{ \Val\I:I }
     \tcount:=\Val\I:I\space
     \ifnum \tcount:>\colsno:\space
  \expandafter\let\csname \the\tcount: :nodes\endcsname=\empty
  \edef\colsno:{\the\tcount:}
\fi

\fi
}
\csname\first: :under\endcsname

\Do(0,\Val\J:J){
  \J:J=\colsno:;  \J:J-\csname  col-:\the\DoReg\endcsname;   \J:J/2;
  \let\node:=\relax
\let\currow:=\empty
\let\index:=\indexIII:
\let\prev:=\prevI:
\csname col-:\the\DoReg :+\endcsname

\tcount:=\Val\J:J
\expandafter\inserttocol:\currow:{}{}


}




    \let\nodewidth:=\pertw:   \MarkLoc(origin:)  \edef\rowsno:{0}
\sapply{all,merge,{},{}}
\def\node:##1{
 \IF \GtInt(\I:I,\rowsno:) \edef\rowsno:{\Val\I:I} \FI  \I:I+1;
 \ifnum\csname##1 :type\endcsname=\milestonenode:\space
      \let\PertNode:=\MilestoneNode:
\else
  \ifnum\csname##1 :type\endcsname=\projectnode:\space
      \let\PertNode:=\ProjectNode:
  \else
      \let\PertNode:=\TaskNode:
  \fi
\fi

\DefNode\PertNode:(##1)(--\titletextA:{\perttext:{##1}}--)
\sapply{all,merge,all,{##1}}

 \AddNodeDim(##1)
}
\sapply{MaxXYI,merge,{},{}}
\Do(0,\colsno:){
 \I:I=0;
 \ZeroNodesDim
 \csname \the\DoReg :nodes\endcsname
 \sapply{MaxXYI,merge,MaxXYI,{\if H\hpert:  \MaxY
                                    \else \MaxX\fi :\the\DoReg}}

}

    \def\l:pert{0}  \def\u:pert{0}
\if H\hpert:
  \grps:ns\step:right\colsno:\pert:cols
  \grps:ns\step:down\rowsno:\pert:rows
\else
  \grps:ns\step:right\colsno:\pert:cols
  \grps:ns\step:down\rowsno:\pert:rows
\fi
\I:I=\step:right;  \I:I-1; \edef\r:pert{\Val\I:I}
\I:I=\step:down;   \I:I-1; \edef\d:pert{\Val\I:I}
\sapply{in,merge,{},{}}
\sapply{done,merge,{},{}}
\def\overflow:col{N}
\MoveToLoc(origin:)  \MarkLoc(col.minX)    \MarkLoc(col.maxX)
\MarkLoc(col.maxY)  \edef\node:wh{1000}

    \def\:temp{    \def\effort:n{-1}  \pert:diag{#1}
}
    \let~=\gal:
 \else    \pwarn:{\string\pertdiagram{\first:}?\space
                      not \space a \space project}
     \let\:temp\empty
 \fi
 \let\verify:=\verify::
 \:temp
}
\def\getnodesbydate:#1{
  \def\temp:{#1}
  \ifx \temp:\empty  \else
     \def\temp:{
        \let\index:=\indexI:
\Q:Q=0; \R:R=0;
\csname -#1-:\endcsname

        \let\elms:=\empty
\def\index:####1{
 \edef\elms:{\elms: {####1}}
 \expandafter\def\csname####1 :boolA\endcsname{0}
 }
\csname -#1-:\endcsname
\def\maxsub:{0}
\def\prev:####1{
  \def\bef:{####1}
  \expandafter\compr:\elms:{}
}
\subsort:

        \let\index:=\indexII:    \T:T=\prevstart:;
\Do(0,\maxsub:){
 \R:R=0;
 \csname -#1-:\endcsname
 \IF \GtDec(\R:R,\T:T)
    \T:T=\R:R;
    \if H\hpert:    \T:T+\openpertH:;  \else  \T:T-\openpertV:;  \fi
 \FI
}

        \getnodesbydate: }
     \expandafter\temp:
  \fi
}
\def\indexI:#1{
  \I:I=\csname#1 : in/cl:\endcsname;
  \CSeg\:GetXY(origin:,col.\Val\I:I)
  \if H\hpert:
    \IF \GtDec(\Va,\Q:Q)  \THEN  \Q:Q=\Va;  \FI
    \IF \GtDec(\prevstart:,\Q:Q)  \THEN  \Q:Q=\prevstart:;
    \Q:Q+\openpertH:;  \FI
  \else
    \IF \GtDec(\Q:Q,\Vb)  \THEN  \Q:Q=\Vb;  \FI
    \IF \GtDec(\Q:Q,\prevstart:)  \THEN  \Q:Q=\prevstart:;
        \Q:Q-\openpertV:;  \FI
  \fi
  \edef\prevstart:{\Val\Q:Q}
}
\def\pert:diag#1{
  \seg:prt

\ifx \:tmp\def
  \ifnum \effort:n>-1
     \sapply{prevdone,merge,done,{}}
     \global \expandafter\setbox
             \csname dra:bx\effort:n\endcsname=\hbox
  \fi
  \bgroup
\fi

  \def\MaxX##1{\MaxY##1/+/-]/[}
\def\MaxY##1:##2/+/-]/[{
  \def\:tmp####1{
  \ifnum \csname####1 : in/cl:\endcsname=##2
     \sapply{used,merge,used,{####1}}
  \fi
}
\sapply{used,merge,{},{}}
\sapply{all,\:tmp}
\sapply{used,subtract,used,done}
\let\:tmp=\relax
\sapply{used,\let\:tmp=\def\gob:I}

  \if H\hpert:
  \IF \LtInt(##2,\u:pert) \THEN           \let\:tmp=\relax
  \ELSE    \IF \GtInt(##2,\d:pert) \THEN  \let\:tmp=\relax
  \FI \FI
\else
  \IF \LtInt(##2,\l:pert) \THEN           \let\:tmp=\relax
  \ELSE    \IF \GtInt(##2,\r:pert) \THEN  \let\:tmp=\relax
  \FI \FI
\fi

  \ifx \:tmp\def
     \if H\hpert:
        \Move(0,-##1)   \MarkLoc(col.##2)     \Move(0,-##1)
        \Move(0,-\openpertV:)
     \else
        \Move(##1,0)    \MarkLoc(col.##2)     \Move(##1,0)
        \Move(\openpertH:,0)
     \fi
  \else \ifnum ##2>0
  \MarkLoc(.) \I:I=##2; \I:I-1; \MoveToLoc(col.\Val\I:I)
  \MarkLoc(col.##2)   \MoveToLoc(.)
\else  \MarkLoc(col.##2)  \fi
\fi
}
\sapply{MaxXYI,\MaxX}

\sapply{in,merge,{},{}}
\sapply{up,merge,{},{}}
\sapply{down,merge,{},{}}
\sapply{left,merge,{},{}}
\sapply{right,merge,{},{}}
\let\M:N\empty
\let\M:X\empty

  \if H\hpert:  \EntryExit(-1,0,1,0)  \def\prevstart:{-10}
\else         \EntryExit(0,1,0,-1)  \def\prevstart:{10}   \fi
\expandafter\getnodesbydate:\dates:{}

  \sapply{edges,merge,{},{}}
\def\prev:##1{ \sapply{temp,intersect,in,{##1,\cur:}}
\sapply{temp,\sapply{edges,merge,edges,{##1,\cur:}}\gob:I}
}
\let\utask:=\utaskIV:
\csname\first: :under\endcsname
\sapply{edges,subtract,edges,in}
\sapply{up,intersect,up,edges}
\sapply{down,intersect,down,edges}
\sapply{left,intersect,left,edges}
\sapply{right,intersect,right,edges}

\MoveToLoc(origin:) \Move(10,0) \MarkLoc(.)
\MoveToLoc(col.maxX) \Move(0,10) \MarkLoc(..)
\MoveToLL(origin:,.)(col.maxX,..)  \Move(0,5) \MarkLoc(col.maxX)
\MoveToLoc(col.minX)  \Move(0,5) \MarkLoc(col.minX)

\K:K=0;
\sapply{left,\K:K+1;\gob:I}  \J:J=\K:K;
\sapply{right,\K:K+1;\gob:I}
\sapply{down,\K:K+1;\gob:I}
\sapply{up,\K:K+1;\gob:I}
\CSeg\:GetY(col.maxY,origin:)  \Vb/\node:wh; \Vb*0.7;
\IF \GtDec(\Vb,\K:K)  \K:K*2;
  \IF \EqInt(\J:J,0) \K:K=-\K:K; \FI
\ELSE                 \K:K/2; \K:K-1; \FI

\sapply{up,\put:nd}
\sapply{left,\put:nd}
\sapply{right,\put:nd}
\sapply{down,\put:nd}

  \def\prev:##1{ \expandafter\ifx\csname##1 :bool\endcsname\relax

\else
  \def\from:{##1}
\let\utask:=\clipper:
\csname\first: :under\endcsname
\seg:prt

\ifx \:tmp\def
 \sapply{do,merge,{},{}}
\sapply{temp,intersect,in,{##1,\cur:}}
\sapply{temp,\sapply{do,merge,{##1},{}}\gob:I}
\sapply{do,\ifx\M:N\empty \edef\M:N{##1}\edef\M:X{##1}\fi
\def\:temp{
  \CSeg\:GetX(##1,\M:N)    \IF \GtDec(\Va,0) \edef\M:N{##1}\FI
  \CSeg\:GetX(\cur:,\M:N)  \IF \GtDec(\Va,0) \edef\M:N{\cur:}\FI
  \CSeg\:GetX(\M:X,##1)    \IF \GtDec(\Va,0) \edef\M:X{##1}\FI
  \CSeg\:GetX(\M:X,\cur:)  \IF \GtDec(\Va,0) \edef\M:X{\cur:}\FI
}
\:temp
{\Edge(##1,\cur:)}\gob:I}

\else
 \Edge(##1,\cur:)

\fi

\fi
\Clip()
\let\utask:=\utaskIV:
}
\let\utask:=\utaskIV:
\csname\first: :under\endcsname

  \sapply{in,\extrm:in}
\ifx \M:N\empty\else
  \MoveToNode(\M:N,-1,0) \MarkLoc(.\M:N)
  \MoveToNode(\M:X,1,0) \MarkLoc(.\M:X)
  {\Text(----)}

  \CSeg\:GetX(origin:,.\M:N)  \xdef\left:mrk{\Val\Va}
  \CSeg\:GetX(origin:,.\M:X)  \xdef\right:mrk{\Val\Va}
\fi

  \seg:prt

\ifx \:tmp\def
     \sapply{done,merge,done,in}
\edef\:temp{\noexpand \sapply{done,merge,{\csname
      done:mkls\endcsname},{}}}
\expandafter

  \egroup \:temp
  \ifnum \effort:n>-1
  \sapply{leftover,subtract,done,prevdone}
  \let\:tmp=\relax
  \sapply{leftover,\let\:tmp=\def\gob:I}
  \ifx \:tmp\def
     \snd:bxo \pertcode:
  \else
     \global \expandafter\setbox
          \csname dra:bx\effort:n\endcsname=\hbox{}
     \I:I=\effort:n; \I:I-1; \edef\effort:n{\Val\I:I}
  \fi
\fi

  \sapply{leftover,subtract,all,done}
  \let\:tmp=\relax
  \sapply{leftover,\let\:tmp=\def\gob:I}
  \ifx \:tmp\def
    \I:I=\effort:n; \I:I+1; \edef\effort:n{\Val\I:I}
    \if Y\overflow:col
 \def\overflow:col{N}
\else
  \I:I=\r:pert; \I:I+1;           \edef\l:pert{\Val\I:I}
  \I:I=\r:pert; \I:I+\step:right; \edef\r:pert{\Val\I:I}
  \ifnum \l:pert >     \if H\hpert:  \rowsno:    \else   \colsno: \fi
     \I:I=\d:pert; \I:I+1;          \edef\u:pert{\Val\I:I}
     \I:I=\d:pert; \I:I+\step:down; \edef\d:pert{\Val\I:I}
     \def\l:pert{0}  \I:I=\step:right;  \I:I-1; \edef\r:pert{\Val\I:I}
  \fi
\fi
\if H\hpert: \else
  \I:I=\l:pert; \I:I+7;
  \Do(\l:pert,\Val\I:I){
    \def\:tmp####1{
  \ifnum \csname####1 : in/cl:\endcsname=\DoReg
     \sapply{used,merge,used,{####1}}
  \fi
}
\sapply{used,merge,{},{}}
\sapply{all,\:tmp}
\sapply{used,subtract,used,done}
\let\:tmp=\relax
\sapply{used,\let\:tmp=\def\gob:I}
\ifx \:tmp\relax
   \I:I=\r:pert; \I:I+1; \edef\r:pert{\Val\I:I}
\fi

  }
\fi


    \aft:edraw

\df:bfs


    \expandafter\expandafter\expandafter\pert:diag
  \else
    \expandafter\expandafter\expandafter\gob:I
  \fi
\else
  \expandafter\gob:I
\fi {#1}

}
\def\seg:prt{
  \let\:tmp=\def
  \ifnum \pert:rows=10000
    \ifnum \pert:cols=10000
       \let\:tmp=\relax
  \fi \fi
}
\def\grps:ns#1#2#3{{
 \ifnum #3>#2
     \I:I=#3; \I:I+1;
 \else
     \R=#2; \R+1;  \R/#3;  \R+0.49999;  \J:J[\R];
     \R=#2; \R+1;  \R/\J:J;   \I:I[\R];
 \fi
 \edef#1{\def\noexpand#1{\Val\I:I}}
 \expandafter}#1}
\def\put:nd#1{
  \let\sv:EntryExit\:InOut
  \IF \LtInt(\K:K,0)
     \EntryExit(-1,1,-1,-1)
\MoveToLoc(col.maxX)  \Move(\openpertH:,0)
\FcNode(#1) \pert:bnode(#1)
\MoveToExit(0,1) \MarkLoc(from)   \MoveToExit(0,-1) \MarkLoc(to)
\MoveToLoc(col.maxX)  \CSeg\Move(from,to)
\Move(0,-\openpertV:)  \MarkLoc(col.maxX)

  \ELSE
     \EntryExit(1,1,1,-1)
\MoveToLoc(col.minX)  \Move(-\openpertH:,0)
\FcNode(#1)  \pert:bnode(#1)
\MoveToExit(0,1) \MarkLoc(from)   \MoveToExit(0,-1) \MarkLoc(to)
\MoveToLoc(col.minX)  \CSeg\Move(from,to)
\Move(0,-\openpertV:)  \MarkLoc(col.minX)

  \FI
  \K:K-1;
  \let\:InOut\sv:EntryExit
}
\def\gob:I#1{}
\:DefineExt\pertlimits(1){\endgroup
  \pertlimits:#1,,,,,//
}
\expandafter\long\expandafter\def\csname
   .:\string \pertlimits\endcsname(#1){\endgroup
  \pertlimits:#1,,,,,//
}
\long\def\pertlimits:#1,#2,#3,#4,#5//{
  \def\temp:{#1}   \ifx\temp:\empty\else   \def\pert:rows{#1} \fi
  \def\temp:{#2}   \ifx\temp:\empty\else   \def\pert:cols{#2} \fi
  \def\temp:{#3}   \ifx\temp:\empty\else   \def\pert:bnode{#3}  \fi
  \def\temp:{#3}   \ifx\temp:\empty\else   \def\pertcode:{#4}  \fi
}
\pertlimits(10000,10000,\ExtNode,\par)
\Define\ExtNode(1){
  \filtercommand\name{#1}
  \OvalNode(#1)(--\putcommand--)}
\def\extrm:in#1{\ifx\M:N\empty \edef\M:N{#1}\edef\M:X{#1}\fi
\def\:temp{
  \CSeg\:GetX(#1,\M:N)  \IF \GtDec(\Va,0) \edef\M:N{#1}\FI
  \CSeg\:GetX(\M:X,#1)  \IF \GtDec(\Va,0) \edef\M:X{#1}\FI
}
\:temp
}
\expandafter \ifx  \csname tmp:dim\endcsname \relax
  \csname newdimen\endcsname \tmp:dim
\fi


\:RestoreCatcodes    \endinput