<> <> DIRECTORY Basics, CharDisplays, Commander, CommandTool, DisplayControllers, FS, IO, RedBlackTree, Rope, TermProgs; TermProgsImpl: CEDAR PROGRAM IMPORTS CommandTool, FS, IO, RedBlackTree, Rope EXPORTS TermProgs = {OPEN TermProgs; TermData: TYPE = REF TermDataRep; TermDataRep: TYPE = RECORD [ termName, bcdBase, bcdDir: ROPE _ NIL, term: Term _ NIL]; terms: RedBlackTree.Table; GetTerm: PUBLIC PROC [name: ROPE, cmd: Commander.Handle] RETURNS [term: Term] = { td: TermData _ NARROW[terms.Lookup[name]]; IF td = NIL THEN RETURN [NIL]; IF td.term # NIL THEN RETURN [td.term]; [] _ CommandTool.DoCommand[ commandLine: IO.PutFR[ "Push %g\nRun %g\nPop", IO.rope[td.bcdDir], IO.rope[td.bcdBase]], parent: cmd]; td _ NARROW[terms.Lookup[name]]; term _ IF td # NIL THEN td.term ELSE NIL; }; RegTerm: PUBLIC PROC [name: ROPE, term: Term] = { td: TermData _ NARROW[terms.Lookup[name]]; IF td = NIL THEN { td _ NEW [TermDataRep _ [termName: name]]; terms.Insert[td, name]}; td.term _ term; }; EnumerateTerms: PUBLIC PROC [consume: PROC [name: ROPE, term: Term]] = { PerTermData: PROC [item: REF ANY] RETURNS [stop: BOOL] = { td: TermData _ NARROW[item]; consume[td.termName, td.term]; stop _ FALSE}; terms.EnumerateIncreasing[PerTermData]; }; CompareTermDatas: PROC [k, data: REF ANY] RETURNS [c: Basics.Comparison] = { r1: ROPE _ NARROW[k]; r2: ROPE _ GetTermKey[data]; c _ r1.Compare[r2, FALSE]}; GetTermKey: PROC [data: REF ANY] RETURNS [key: ROPE] = {td: TermData _ NARROW[data]; key _ td.termName}; Start: PROC = { ConsumeTerms: PROC [fullFName: ROPE] RETURNS [continue: BOOL] = { termsFName, bcdDir: ROPE; cp: FS.ComponentPositions; fromTerms: IO.STREAM _ NIL; continue _ TRUE; [termsFName, cp] _ FS.ExpandName[fullFName]; IF termsFName.Substr[cp.server.start, cp.server.length].Length[] > 0 THEN ERROR; IF termsFName.Substr[cp.dir.start, cp.dir.length].Length[] > 0 THEN ERROR; bcdDir _ Rope.Cat[ "[]<>", termsFName.Substr[cp.subDirs.start, cp.subDirs.length] ]; fromTerms _ FS.StreamOpen[termsFName]; FOR i: INT _ fromTerms.SkipWhitespace[], fromTerms.SkipWhitespace[] WHILE NOT fromTerms.EndOf[] DO termName: ROPE _ fromTerms.GetRopeLiteral[]; td: TermData _ NEW [TermDataRep _ [ termName: termName, bcdBase: termsFName.Substr[cp.base.start, cp.base.length], bcdDir: bcdDir ]]; terms.Insert[td, termName]; ENDLOOP; fromTerms.Close[]; }; terms _ RedBlackTree.Create[GetTermKey, CompareTermDatas]; FS.EnumerateForNames["Em*.terms!H", ConsumeTerms]; }; Start[]; }.