MODULE ObValue_NonRemObjHook_v1 EXPORTS ObValue, ObValue_NonRemObjHook_v1;
IMPORT Rd, Wr, StubLib, ObValue, Thread, NetObj;
CONST Protocol: StubLib.StubProtocol = 1;
TYPE
Methods = {Get, init};
ReturnCodes = {OK};
PROCEDURE Surrogate_init(
self: ObValue.NonRemObjHook;
remObj_arg: ObValue.ValObj): ObValue.NonRemObjHook
RAISES {NetObj.Error, Thread.Alerted} =
VAR reuse := FALSE;
rep: StubLib.DataRep;
c: StubLib.Conn;
dataPresent: BOOLEAN; <* NOWARN *>
res: ObValue.NonRemObjHook;
BEGIN
TRY
c := StubLib.StartCall(self, Protocol);
TRY
StubLib.OutInt32(c, ORD(Methods.init));
StubLib.OutRef(c, remObj_arg);
rep := StubLib.AwaitResult(c);
CASE StubLib.InInt32(c, rep) OF
| ORD(ReturnCodes.OK) =>
res := StubLib.InRef(c, rep, TYPECODE(ObValue.NonRemObjHook));
reuse := TRUE;
ELSE
StubLib.RaiseUnmarshalFailure();
END
FINALLY
StubLib.EndCall(c, reuse);
END;
EXCEPT
| Rd.Failure(ec) => StubLib.RaiseCommFailure(ec);
| Wr.Failure(ec) => StubLib.RaiseCommFailure(ec);
END;
RETURN res;
END Surrogate_init;
PROCEDURE Surrogate_Get(self: ObValue.NonRemObjHook): ObValue.ValObj
RAISES {NetObj.Error, Thread.Alerted} =
VAR reuse := FALSE;
rep: StubLib.DataRep;
c: StubLib.Conn;
dataPresent: BOOLEAN; <* NOWARN *>
res: ObValue.ValObj;
BEGIN
TRY
c := StubLib.StartCall(self, Protocol);
TRY
StubLib.OutInt32(c, ORD(Methods.Get));
rep := StubLib.AwaitResult(c);
CASE StubLib.InInt32(c, rep) OF
| ORD(ReturnCodes.OK) =>
res := StubLib.InRef(c, rep, TYPECODE(ObValue.ValObj));
reuse := TRUE;
ELSE
StubLib.RaiseUnmarshalFailure();
END
FINALLY
StubLib.EndCall(c, reuse);
END;
EXCEPT
| Rd.Failure(ec) => StubLib.RaiseCommFailure(ec);
| Wr.Failure(ec) => StubLib.RaiseCommFailure(ec);
END;
RETURN res;
END Surrogate_Get;
PROCEDURE Invoke(
c: StubLib.Conn;
obj: NetObj.T;
rep: StubLib.DataRep;
stubProt: StubLib.StubProtocol)
RAISES {NetObj.Error, Rd.Failure,
Wr.Failure, Thread.Alerted} =
VAR t := NARROW(obj, ObValue.NonRemObjHook);
BEGIN
IF stubProt # Protocol THEN StubLib.RaiseUnmarshalFailure() END;
TRY
CASE StubLib.InInt32(c, rep) OF
| ORD(Methods.init) => Stub_init(t, c, rep);
| ORD(Methods.Get) => Stub_Get(t, c, rep);
ELSE
StubLib.RaiseUnmarshalFailure();
END;
EXCEPT
END;
END Invoke;
PROCEDURE Stub_init(
self: ObValue.NonRemObjHook;
c: StubLib.Conn;
<* NOWARN *> rep: StubLib.DataRep) RAISES {NetObj.Error, Rd.Failure,
Wr.Failure, Thread.Alerted}=
VAR remObj_arg: ObValue.ValObj;
res: ObValue.NonRemObjHook;
dataPresent: BOOLEAN <* NOWARN *>;
BEGIN
remObj_arg := StubLib.InRef(c, rep, TYPECODE(ObValue.ValObj));
res := self.init(remObj_arg);
StubLib.StartResult(c);
StubLib.OutInt32(c, ORD(ReturnCodes.OK));
StubLib.OutRef(c, res);
END Stub_init;
PROCEDURE Stub_Get(
self: ObValue.NonRemObjHook;
c: StubLib.Conn;
<* NOWARN *> rep: StubLib.DataRep) RAISES {NetObj.Error, Rd.Failure,
Wr.Failure, Thread.Alerted}=
VAR res: ObValue.ValObj;
dataPresent: BOOLEAN <* NOWARN *>;
BEGIN
res := self.Get();
StubLib.StartResult(c);
StubLib.OutInt32(c, ORD(ReturnCodes.OK));
StubLib.OutRef(c, res);
END Stub_Get;
BEGIN
StubLib.Register(TYPECODE(ObValue.NonRemObjHook), 1, TYPECODE(Surrogate_ObValue_NonRemObjHook), Invoke);
END ObValue_NonRemObjHook_v1.