CHOpsP2V3AuxImpl:
CEDAR
PROGRAM
IMPORTS Convert, Rope, AuthenticationP14V2Aux, CHNameP2V0Aux
EXPORTS CHOpsP2V3Aux ~ {
OPEN CHOpsP2V3, CHOpsP2V3Aux;
ROPE: TYPE ~ Rope.ROPE;
ExposeObjectNameSequence:
PUBLIC
PROC [arg: ObjectNameSequence, level:
NAT]
RETURNS [res:
ROPE] ~ {
res ¬ "[";
FOR i:
CARDINAL
IN [0..arg.length)
DO
res ¬ Rope.Cat[res, IF i>0 THEN ", " ELSE NIL, CHNameP2V0Aux.ExposeThreePartName[arg.body[i], (level+1)]];
ENDLOOP;
res ¬ Rope.Concat[res, "]"];
};
ExposeWhichArgument:
PUBLIC
PROC [arg: WhichArgument, level:
NAT]
RETURNS [res:
ROPE] ~ {
SELECT arg
FROM
first => res ¬ "first";
second => res ¬ "second";
ENDCASE => ERROR
};
ExposeStreamOfThreePartName:
PUBLIC
PROC [arg: StreamOfThreePartName, level:
NAT]
RETURNS [res:
ROPE] ~ {
res ¬ Rope.Cat["StreamOfThreePartName(", ExposeStreamKind[arg.type, (level+1)], "): "];
WITH arg
SELECT
FROM
it:
REF StreamOfThreePartNameObject.nextSegment => {
res ¬ Rope.Concat[res, ExposeThreePartNameSequence[it.nextSegment, (level+1)]] };
it:
REF StreamOfThreePartNameObject.lastSegment => {
res ¬ Rope.Concat[res, ExposeThreePartNameSequence[it.lastSegment, (level+1)]] };
ENDCASE => ERROR
};
ExposeStreamOfDomain:
PUBLIC
PROC [arg: StreamOfDomain, level:
NAT]
RETURNS [res:
ROPE] ~ {
res ¬ Rope.Cat["StreamOfDomain(", ExposeStreamKind[arg.type, (level+1)], "): "];
WITH arg
SELECT
FROM
it:
REF StreamOfDomainObject.nextSegment => {
res ¬ Rope.Concat[res, ExposeDomainSequence[it.nextSegment, (level+1)]] };
it:
REF StreamOfDomainObject.lastSegment => {
res ¬ Rope.Concat[res, ExposeDomainSequence[it.lastSegment, (level+1)]] };
ENDCASE => ERROR
};
ExposeDomainNameSequence:
PUBLIC
PROC [arg: DomainNameSequence, level:
NAT]
RETURNS [res:
ROPE] ~ {
res ¬ "[";
FOR i:
CARDINAL
IN [0..arg.length)
DO
res ¬ Rope.Cat[res, IF i>0 THEN ", " ELSE NIL, CHNameP2V0Aux.ExposeTwoPartName[arg.body[i], (level+1)]];
ENDLOOP;
res ¬ Rope.Concat[res, "]"];
};
ExposeStreamOfOrganization:
PUBLIC
PROC [arg: StreamOfOrganization, level:
NAT]
RETURNS [res:
ROPE] ~ {
res ¬ Rope.Cat["StreamOfOrganization(", ExposeStreamKind[arg.type, (level+1)], "): "];
WITH arg
SELECT
FROM
it:
REF StreamOfOrganizationObject.nextSegment => {
res ¬ Rope.Concat[res, ExposeOrganizationSequence[it.nextSegment, (level+1)]] };
it:
REF StreamOfOrganizationObject.lastSegment => {
res ¬ Rope.Concat[res, ExposeOrganizationSequence[it.lastSegment, (level+1)]] };
ENDCASE => ERROR
};
ExposeStreamOfDomainName:
PUBLIC
PROC [arg: StreamOfDomainName, level:
NAT]
RETURNS [res:
ROPE] ~ {
res ¬ Rope.Cat["StreamOfDomainName(", ExposeStreamKind[arg.type, (level+1)], "): "];
WITH arg
SELECT
FROM
it:
REF StreamOfDomainNameObject.nextSegment => {
res ¬ Rope.Concat[res, ExposeDomainNameSequence[it.nextSegment, (level+1)]] };
it:
REF StreamOfDomainNameObject.lastSegment => {
res ¬ Rope.Concat[res, ExposeDomainNameSequence[it.lastSegment, (level+1)]] };
ENDCASE => ERROR
};
ExposeArgumentProblem:
PUBLIC
PROC [arg: ArgumentProblem, level:
NAT]
RETURNS [res:
ROPE] ~ {
SELECT arg
FROM
illegalProperty => res ¬ "illegalProperty";
illegalOrganizationName => res ¬ "illegalOrganizationName";
illegalDomainName => res ¬ "illegalDomainName";
illegalObjectName => res ¬ "illegalObjectName";
noSuchOrganization => res ¬ "noSuchOrganization";
noSuchDomain => res ¬ "noSuchDomain";
noSuchObject => res ¬ "noSuchObject";
ENDCASE => ERROR
};
ExposeDomainSequence:
PUBLIC
PROC [arg: DomainSequence, level:
NAT]
RETURNS [res:
ROPE] ~ {
res ¬ "[";
FOR i:
CARDINAL
IN [0..arg.length)
DO
res ¬ Rope.Cat[res, IF i>0 THEN ", " ELSE NIL, arg.body[i]];
ENDLOOP;
res ¬ Rope.Concat[res, "]"];
};
ExposeThreePartNameSequence:
PUBLIC
PROC [arg: ThreePartNameSequence, level:
NAT]
RETURNS [res:
ROPE] ~ {
res ¬ "[";
FOR i:
CARDINAL
IN [0..arg.length)
DO
res ¬ Rope.Cat[res, IF i>0 THEN ", " ELSE NIL, CHNameP2V0Aux.ExposeThreePartName[arg.body[i], (level+1)]];
ENDLOOP;
res ¬ Rope.Concat[res, "]"];
};
ExposeStreamKind:
PUBLIC
PROC [arg: StreamKind, level:
NAT]
RETURNS [res:
ROPE] ~ {
SELECT arg
FROM
nextSegment => res ¬ "nextSegment";
lastSegment => res ¬ "lastSegment";
ENDCASE => ERROR
};
ExposeNetworkAddress:
PUBLIC
PROC [arg: NetworkAddress, level:
NAT]
RETURNS [res:
ROPE] ~ {
res ¬ "[";
FOR i:
CARDINAL
IN [0..6)
DO
res ¬ Rope.Cat[res, IF i>0 THEN ", " ELSE NIL, Convert.RopeFromCard[arg[i]]];
ENDLOOP;
res ¬ Rope.Concat[res, "]"];
};
ExposeCallProblem:
PUBLIC
PROC [arg: CallProblem, level:
NAT]
RETURNS [res:
ROPE] ~ {
SELECT arg
FROM
accessRightsInsufficient => res ¬ "accessRightsInsufficient";
tooBusy => res ¬ "tooBusy";
serverDown => res ¬ "serverDown";
useCourier => res ¬ "useCourier";
other => res ¬ "other";
ENDCASE => ERROR
};
ExposeAuthenticator:
PUBLIC
PROC [arg: Authenticator, level:
NAT]
RETURNS [res:
ROPE] ~ {
res ¬ "[";
res ¬ Rope.Cat[res, "credentials~", AuthenticationP14V2Aux.ExposeCredentials[arg.credentials, (level+1)], ", "];
res ¬ Rope.Cat[res, "verifier~", AuthenticationP14V2Aux.ExposeSeqWords[arg.verifier, (level+1)], "]"];
};
ExposeNetworkAddressList:
PUBLIC
PROC [arg: NetworkAddressList, level:
NAT]
RETURNS [res:
ROPE] ~ {
res ¬ "[";
FOR i:
CARDINAL
IN [0..arg.length)
DO
res ¬ Rope.Cat[res, IF i>0 THEN ", " ELSE NIL, ExposeNetworkAddress[arg.body[i], (level+1)]];
ENDLOOP;
res ¬ Rope.Concat[res, "]"];
};
ExposeStreamOfObject:
PUBLIC
PROC [arg: StreamOfObject, level:
NAT]
RETURNS [res:
ROPE] ~ {
res ¬ Rope.Cat["StreamOfObject(", ExposeStreamKind[arg.type, (level+1)], "): "];
WITH arg
SELECT
FROM
it:
REF StreamOfObjectObject.nextSegment => {
res ¬ Rope.Concat[res, ExposeObjectSequence[it.nextSegment, (level+1)]] };
it:
REF StreamOfObjectObject.lastSegment => {
res ¬ Rope.Concat[res, ExposeObjectSequence[it.lastSegment, (level+1)]] };
ENDCASE => ERROR
};
ExposeItem:
PUBLIC
PROC [arg: Item, level:
NAT]
RETURNS [res:
ROPE] ~ {
res ¬ "[";
FOR i:
CARDINAL
IN [0..arg.length)
DO
res ¬ Rope.Cat[res, IF i>0 THEN ", " ELSE NIL, Convert.RopeFromCard[arg.body[i]]];
ENDLOOP;
res ¬ Rope.Concat[res, "]"];
};
ExposeOrganizationSequence:
PUBLIC
PROC [arg: OrganizationSequence, level:
NAT]
RETURNS [res:
ROPE] ~ {
res ¬ "[";
FOR i:
CARDINAL
IN [0..arg.length)
DO
res ¬ Rope.Cat[res, IF i>0 THEN ", " ELSE NIL, arg.body[i]];
ENDLOOP;
res ¬ Rope.Concat[res, "]"];
};
ExposeStreamOfObjectName:
PUBLIC
PROC [arg: StreamOfObjectName, level:
NAT]
RETURNS [res:
ROPE] ~ {
res ¬ Rope.Cat["StreamOfObjectName(", ExposeStreamKind[arg.type, (level+1)], "): "];
WITH arg
SELECT
FROM
it:
REF StreamOfObjectNameObject.nextSegment => {
res ¬ Rope.Concat[res, ExposeObjectNameSequence[it.nextSegment, (level+1)]] };
it:
REF StreamOfObjectNameObject.lastSegment => {
res ¬ Rope.Concat[res, ExposeObjectNameSequence[it.lastSegment, (level+1)]] };
ENDCASE => ERROR
};
ExposeProperties:
PUBLIC
PROC [arg: Properties, level:
NAT]
RETURNS [res:
ROPE] ~ {
res ¬ "[";
FOR i:
CARDINAL
IN [0..arg.length)
DO
res ¬ Rope.Cat[res, IF i>0 THEN ", " ELSE NIL, Convert.RopeFromCard[arg.body[i]]];
ENDLOOP;
res ¬ Rope.Concat[res, "]"];
};
ExposePropertyProblem:
PUBLIC
PROC [arg: PropertyProblem, level:
NAT]
RETURNS [res:
ROPE] ~ {
SELECT arg
FROM
missing => res ¬ "missing";
wrongType => res ¬ "wrongType";
ENDCASE => ERROR
};
ExposeUpdateProblem:
PUBLIC
PROC [arg: UpdateProblem, level:
NAT]
RETURNS [res:
ROPE] ~ {
SELECT arg
FROM
noChange => res ¬ "noChange";
outOfDate => res ¬ "outOfDate";
objectOverflow => res ¬ "objectOverflow";
databaseOverflow => res ¬ "databaseOverflow";
ENDCASE => ERROR
};
ExposeObjectSequence:
PUBLIC
PROC [arg: ObjectSequence, level:
NAT]
RETURNS [res:
ROPE] ~ {
res ¬ "[";
FOR i:
CARDINAL
IN [0..arg.length)
DO
res ¬ Rope.Cat[res, IF i>0 THEN ", " ELSE NIL, arg.body[i]];
ENDLOOP;
res ¬ Rope.Concat[res, "]"];
};
}...