%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% 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