-- Stub file was translated on July 12, 1984 11:26:09 am PDT by Lupine of July 11, 1984 11:51:36 pm PDT -- Source interface Lark came from file Lark.bcd, which was created on March 22, 1984 5:24:03 pm PST with version stamp 363#357#6104565341 from source of December 19, 1983 1:34:23 pm PST. -- The RPC stub modules for Lark are: -- LarkRpcControl.mesa; -- LarkRpcClientImpl.mesa; -- LarkRpcBinderImpl.mesa; -- LarkRpcServerImpl.mesa. -- The parameters for this translation are: -- Target language = Cedar -- Default parameter passing = VALUE -- Deallocate server heap arguments = TRUE -- Inline RpcServerImpl dispatcher stubs = FALSE -- Declare signals = TRUE -- Warn about short POINTER ("MDS") allocations = TRUE -- Maximum number of dynamic heap NEWs = 50, MDS NEWs = 50 -- Acceptable parameter protocols = VersionRange[1..1]. DIRECTORY DESFace, PupTypes, RPC, RPCPkt, Lark, LarkRpcControl USING [InterMdsCallsOnly, LupineProtocolVersion, ProcedureIndex, SignalIndex], RPCLupine --USING SOME OF [Call, DataLength, Dispatcher, ExportHandle, -- ExportInterface, GetStubPkt, maxDataLength, maxPrincipalLength, -- maxShortStringLength, pktOverhead, ReceiveExtraPkt, SendPrelimPkt, -- StartCall, StartSignal, StubPkt, UnexportInterface]--, LupineRuntime --USING SOME OF [BindingError, CheckPktLength, CopyFromPkt, -- CopyFromMultiplePkts, CopyToPkt, CopyToMultiplePkts, defaultZones, -- DispatchingError, FinishThisPkt, ListHeader, MarshalingError, -- MarshalingExprError, NilHeader, ProtocolError, RopeHeader, RpcPktDoubleWord, -- RuntimeError, SequenceHeader, SHORT, StartNextPkt, StringHeader, -- StubPktDoubleWord, TranslationError, UnmarshalingError, UnmarshalingExprError, -- WordsForChars]--, LupineRuntimeExtras --USING SOME OF [MarshalRope, MarshalAtom, UnmarshalRope, -- UnmarshalAtom]--, Atom --USING SOME OF [GetPName, MakeAtom]--, Rope --USING SOME OF [InlineFlatten, Length, NewText, Text]--; LarkRpcServerImpl: MONITOR IMPORTS Lark, RpcPrivate: RPCLupine, Lupine: LupineRuntime, LupineRuntimeExtras: LupineRuntimeExtras, Atom, Rope EXPORTS LarkRpcControl SHARES Lark, LarkRpcControl, Rope = BEGIN OPEN Lark, RpcControl: LarkRpcControl, RpcPublic: RPC; -- Standard remote binding routines. bound: BOOLEAN ← FALSE; myInterface: RpcPrivate.ExportHandle; paramZones: RpcPublic.Zones ← RpcPublic.standardZones; ExportInterface: PUBLIC ENTRY SAFE PROCEDURE [ interfaceName: RpcPublic.InterfaceName, user: RpcPublic.Principal, password: RpcPublic.EncryptionKey, parameterStorage: RpcPublic.Zones ] = TRUSTED BEGIN ENABLE UNWIND => NULL; IsNull: PROCEDURE [string: Rope.ROPE] RETURNS [BOOLEAN] = INLINE {RETURN[string.Length[] = 0]}; IF bound THEN Lupine.BindingError; myInterface ← RpcPrivate.ExportInterface [ interface: [ type: IF ~IsNull[interfaceName.type] THEN interfaceName.type ELSE "Lark~363#357#6104565341", instance: interfaceName.instance, version: interfaceName.version ], user: user, password: password, dispatcher: ServerDispatcher, localOnly: RpcControl.InterMdsCallsOnly, stubProtocol: RpcControl.LupineProtocolVersion ]; paramZones ← [ gc: IF parameterStorage.gc # NIL THEN parameterStorage.gc ELSE Lupine.defaultZones.gc, heap: IF parameterStorage.heap # NIL THEN parameterStorage.heap ELSE Lupine.defaultZones.heap, mds: IF parameterStorage.mds # NIL THEN parameterStorage.mds ELSE Lupine.defaultZones.mds ]; bound ← TRUE; END; UnexportInterface: PUBLIC ENTRY SAFE PROCEDURE = TRUSTED BEGIN ENABLE UNWIND => NULL; IF ~bound THEN Lupine.BindingError; myInterface ← RpcPrivate.UnexportInterface[myInterface]; paramZones ← RpcPublic.standardZones; bound ← FALSE; END; -- Public procedure dispatcher and public signal and error catcher. ServerDispatcher: --PROCEDURE [pkt: RPCPkt, callLength: DataLength, -- lastPkt: BOOLEAN, localConversation: Conversation] RETURNS [returnLength: -- DataLength]-- RpcPrivate.Dispatcher = BEGIN -- Catch public signals. ENABLE BEGIN END; -- Catch public signals. -- Call public procedures (still in dispatcher). SELECT LOOPHOLE[pkt.data[0], RpcControl.ProcedureIndex] FROM Reset => RETURN[ ResetStub[pkt: pkt, callLength: callLength, lastPkt: lastPkt, localConversation: localConversation]]; GenerateTones => RETURN[ GenerateTonesStub[pkt: pkt, callLength: callLength, lastPkt: lastPkt, localConversation: localConversation]]; Feep => RETURN[ FeepStub[pkt: pkt, callLength: callLength, lastPkt: lastPkt, localConversation: localConversation]]; Commands => RETURN[ CommandsStub[pkt: pkt, callLength: callLength, lastPkt: lastPkt, localConversation: localConversation]]; Connect => RETURN[ ConnectStub[pkt: pkt, callLength: callLength, lastPkt: lastPkt, localConversation: localConversation]]; Disconnect => RETURN[ DisconnectStub[pkt: pkt, callLength: callLength, lastPkt: lastPkt, localConversation: localConversation]]; PleaseRegister => RETURN[ PleaseRegisterStub[pkt: pkt, callLength: callLength, lastPkt: lastPkt, localConversation: localConversation]]; WhatIsStatus => RETURN[ WhatIsStatusStub[pkt: pkt, callLength: callLength, lastPkt: lastPkt, localConversation: localConversation]]; WhatAreConnections => RETURN[ WhatAreConnectionsStub[pkt: pkt, callLength: callLength, lastPkt: lastPkt, localConversation: localConversation]]; WhatAreTones => RETURN[ WhatAreTonesStub[pkt: pkt, callLength: callLength, lastPkt: lastPkt, localConversation: localConversation]]; SetKeyTable => RETURN[ SetKeyTableStub[pkt: pkt, callLength: callLength, lastPkt: lastPkt, localConversation: localConversation]]; CommandString => RETURN[ CommandStringStub[pkt: pkt, callLength: callLength, lastPkt: lastPkt, localConversation: localConversation]]; PleaseLogin => RETURN[ PleaseLoginStub[pkt: pkt, callLength: callLength, lastPkt: lastPkt, localConversation: localConversation]]; EchoSupression => RETURN[ EchoSupressionStub[pkt: pkt, callLength: callLength, lastPkt: lastPkt, localConversation: localConversation]]; SetHostNumber => RETURN[ SetHostNumberStub[pkt: pkt, callLength: callLength, lastPkt: lastPkt, localConversation: localConversation]]; ENDCASE => RETURN[Lupine.DispatchingError[]]; END; -- ServerDispatcher -- Public procedure dispatcher stubs. ResetStub: --PROCEDURE [shh: SHHH, rName: ROPE]-- RpcPrivate.Dispatcher = BEGIN rName: ROPE; pktLength: RpcPrivate.DataLength ← 1; BEGIN -- Unmarshal rName: ROPE from pkt.data[pktLength]. [rName, pktLength] ← LupineRuntimeExtras.UnmarshalRope[pkt, pktLength]; END; -- Unmarshal rName. Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength]; Reset[localConversation, rName]; pktLength ← 0; RETURN[returnLength: pktLength]; END; -- ResetStub. GenerateTonesStub: --PROCEDURE [shh: SHHH, f1: Hertz, f2: Hertz, -- modulation: Hertz, on: Milliseconds, off: Milliseconds, repetitions: -- CARDINAL, waveTable: CARDINAL, queueIt: BOOLEAN, notify: CommandEvent] -- RETURNS [ok: BOOLEAN]-- RpcPrivate.Dispatcher = BEGIN ArgumentOverlay: TYPE = MACHINE DEPENDENT RECORD [ transferIndex (0): RpcControl.ProcedureIndex, f1 (1): Hertz, f2 (2): Hertz, modulation (3): Hertz, on (4): Milliseconds, off (5): Milliseconds, repetitions (6): CARDINAL, waveTable (7): CARDINAL, queueIt (8): BOOLEAN, notify (9): CommandEvent]; ResultOverlay: TYPE = MACHINE DEPENDENT RECORD [ ok (0): BOOLEAN]; argPkt: LONG POINTER TO ArgumentOverlay = @pkt.data[0]; resPkt: LONG POINTER TO ResultOverlay = @pkt.data[0]; pktLength: RpcPrivate.DataLength ← 10; Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength]; [resPkt.ok] ← GenerateTones[localConversation, argPkt.f1, argPkt.f2, argPkt.modulation, argPkt.on, argPkt.off, argPkt.repetitions, argPkt.waveTable, argPkt.queueIt, argPkt.notify]; pktLength ← 1; RETURN[returnLength: pktLength]; END; -- GenerateTonesStub. FeepStub: --PROCEDURE [shh: SHHH, on: Milliseconds, off: Milliseconds, -- waveTable: CARDINAL, queueIt: BOOLEAN, notify: CommandEvent, events: -- CommandEvents] -- RETURNS [ok: BOOLEAN]-- RpcPrivate.Dispatcher = BEGIN events: CommandEvents; ArgumentOverlay: TYPE = MACHINE DEPENDENT RECORD [ transferIndex (0): RpcControl.ProcedureIndex, on (1): Milliseconds, off (2): Milliseconds, waveTable (3): CARDINAL, queueIt (4): BOOLEAN, notify (5): CommandEvent]; ResultOverlay: TYPE = MACHINE DEPENDENT RECORD [ ok (0): BOOLEAN]; argPkt: LONG POINTER TO ArgumentOverlay = @pkt.data[0]; resPkt: LONG POINTER TO ResultOverlay = @pkt.data[0]; pktLength: RpcPrivate.DataLength ← 6; BEGIN -- Unmarshal events: CommandEvents from pkt.data[pktLength]. [events, pktLength] ← UnmarshalCommandEvents[pkt, pktLength]; END; -- Unmarshal events. Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength]; [resPkt.ok] ← Feep[localConversation, argPkt.on, argPkt.off, argPkt.waveTable, argPkt.queueIt, argPkt.notify, events]; pktLength ← 1; RETURN[returnLength: pktLength]; END; -- FeepStub. CommandsStub: --PROCEDURE [shh: SHHH, events: CommandEvents]-- RpcPrivate.Dispatcher = BEGIN events: CommandEvents; pktLength: RpcPrivate.DataLength ← 1; BEGIN -- Unmarshal events: CommandEvents from pkt.data[pktLength]. [events, pktLength] ← UnmarshalCommandEvents[pkt, pktLength]; END; -- Unmarshal events. Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength]; Commands[localConversation, events]; pktLength ← 0; RETURN[returnLength: pktLength]; END; -- CommandsStub. ConnectStub: --PROCEDURE [shh: SHHH, specs: ConnectionSpec]-- RpcPrivate.Dispatcher = BEGIN specs: ConnectionSpec; pktLength: RpcPrivate.DataLength ← 1; BEGIN -- Unmarshal specs: ConnectionSpec from pkt.data[pktLength]. [specs, pktLength] ← UnmarshalConnectionSpec[pkt, pktLength]; END; -- Unmarshal specs. Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength]; Connect[localConversation, specs]; pktLength ← 0; RETURN[returnLength: pktLength]; END; -- ConnectStub. DisconnectStub: --PROCEDURE [shh: SHHH, buffer: VoiceBuffer]-- RpcPrivate.Dispatcher = BEGIN ArgumentOverlay: TYPE = MACHINE DEPENDENT RECORD [ transferIndex (0): RpcControl.ProcedureIndex, buffer (1): VoiceBuffer]; argPkt: LONG POINTER TO ArgumentOverlay = @pkt.data[0]; pktLength: RpcPrivate.DataLength ← 2; Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength]; Disconnect[localConversation, argPkt.buffer]; pktLength ← 0; RETURN[returnLength: pktLength]; END; -- DisconnectStub. PleaseRegisterStub: --PROCEDURE [shh: SHHH]-- RpcPrivate.Dispatcher = BEGIN pktLength: RpcPrivate.DataLength ← 1; Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength]; PleaseRegister[localConversation]; pktLength ← 0; RETURN[returnLength: pktLength]; END; -- PleaseRegisterStub. WhatIsStatusStub: --PROCEDURE [shh: SHHH, which: CARDINAL] RETURNS -- [next: CARDINAL, events: StatusEvents]-- RpcPrivate.Dispatcher = BEGIN events: StatusEvents; ArgumentOverlay: TYPE = MACHINE DEPENDENT RECORD [ transferIndex (0): RpcControl.ProcedureIndex, which (1): CARDINAL]; ResultOverlay: TYPE = MACHINE DEPENDENT RECORD [ next (0): CARDINAL]; argPkt: LONG POINTER TO ArgumentOverlay = @pkt.data[0]; resPkt: LONG POINTER TO ResultOverlay = @pkt.data[0]; pktLength: RpcPrivate.DataLength ← 2; Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength]; [resPkt.next, events] ← WhatIsStatus[localConversation, argPkt.which]; pktLength ← 1; BEGIN -- Marshal events: StatusEvents to pkt.data[pktLength]. pktLength ← MarshalStatusEvents[events, pkt, pktLength]; END; -- Marshal events. RETURN[returnLength: pktLength]; END; -- WhatIsStatusStub. WhatAreConnectionsStub: --PROCEDURE [shh: SHHH, which: CARDINAL] -- RETURNS [next: CARDINAL, specs: ConnectionSpec]-- RpcPrivate.Dispatcher = BEGIN specs: ConnectionSpec; ArgumentOverlay: TYPE = MACHINE DEPENDENT RECORD [ transferIndex (0): RpcControl.ProcedureIndex, which (1): CARDINAL]; ResultOverlay: TYPE = MACHINE DEPENDENT RECORD [ next (0): CARDINAL]; argPkt: LONG POINTER TO ArgumentOverlay = @pkt.data[0]; resPkt: LONG POINTER TO ResultOverlay = @pkt.data[0]; pktLength: RpcPrivate.DataLength ← 2; Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength]; [resPkt.next, specs] ← WhatAreConnections[localConversation, argPkt.which]; pktLength ← 1; BEGIN -- Marshal specs: ConnectionSpec to pkt.data[pktLength]. pktLength ← MarshalConnectionSpec[specs, pkt, pktLength]; END; -- Marshal specs. RETURN[returnLength: pktLength]; END; -- WhatAreConnectionsStub. WhatAreTonesStub: --PROCEDURE [shh: SHHH] RETURNS [anonP1id1871918: -- BOOLEAN]-- RpcPrivate.Dispatcher = BEGIN ResultOverlay: TYPE = MACHINE DEPENDENT RECORD [ anonP1id1871918 (0): BOOLEAN]; resPkt: LONG POINTER TO ResultOverlay = @pkt.data[0]; pktLength: RpcPrivate.DataLength ← 1; Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength]; [resPkt.anonP1id1871918] ← WhatAreTones[localConversation]; pktLength ← 1; RETURN[returnLength: pktLength]; END; -- WhatAreTonesStub. SetKeyTableStub: --PROCEDURE [shh: SHHH, table: KeyTable]-- RpcPrivate.Dispatcher = BEGIN table: KeyTable; pktLength: RpcPrivate.DataLength ← 1; BEGIN -- Unmarshal table: KeyTable from pkt.data[pktLength]. [table, pktLength] ← UnmarshalKeyTable[pkt, pktLength]; END; -- Unmarshal table. Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength]; SetKeyTable[localConversation, table]; pktLength ← 0; RETURN[returnLength: pktLength]; END; -- SetKeyTableStub. CommandStringStub: --PROCEDURE [shh: SHHH, device: Device, commands: -- ROPE]-- RpcPrivate.Dispatcher = BEGIN commands: ROPE; ArgumentOverlay: TYPE = MACHINE DEPENDENT RECORD [ transferIndex (0): RpcControl.ProcedureIndex, device (1): Device]; argPkt: LONG POINTER TO ArgumentOverlay = @pkt.data[0]; pktLength: RpcPrivate.DataLength ← 2; BEGIN -- Unmarshal commands: ROPE from pkt.data[pktLength]. [commands, pktLength] ← LupineRuntimeExtras.UnmarshalRope[pkt, pktLength]; END; -- Unmarshal commands. Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength]; CommandString[localConversation, argPkt.device, commands]; pktLength ← 0; RETURN[returnLength: pktLength]; END; -- CommandStringStub. PleaseLoginStub: --PROCEDURE [shh: SHHH] RETURNS [will: BOOL]-- RpcPrivate.Dispatcher = BEGIN ResultOverlay: TYPE = MACHINE DEPENDENT RECORD [ will (0): BOOL]; resPkt: LONG POINTER TO ResultOverlay = @pkt.data[0]; pktLength: RpcPrivate.DataLength ← 1; Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength]; [resPkt.will] ← PleaseLogin[localConversation]; pktLength ← 1; RETURN[returnLength: pktLength]; END; -- PleaseLoginStub. EchoSupressionStub: --PROCEDURE [shh: SHHH, echo: EchoParameters]-- RpcPrivate.Dispatcher = BEGIN echo: EchoParameters; pktLength: RpcPrivate.DataLength ← 1; BEGIN -- Unmarshal echo: EchoParameters from pkt.data[pktLength]. [echo, pktLength] ← UnmarshalEchoParameters[pkt, pktLength]; END; -- Unmarshal echo. Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength]; EchoSupression[localConversation, echo]; pktLength ← 0; RETURN[returnLength: pktLength]; END; -- EchoSupressionStub. SetHostNumberStub: --PROCEDURE [shh: SHHH, host: Machine]-- RpcPrivate.Dispatcher = BEGIN ArgumentOverlay: TYPE = MACHINE DEPENDENT RECORD [ transferIndex (0): RpcControl.ProcedureIndex, host (1): Machine]; argPkt: LONG POINTER TO ArgumentOverlay = @pkt.data[0]; pktLength: RpcPrivate.DataLength ← 2; Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength]; SetHostNumber[localConversation, argPkt.host]; pktLength ← 0; RETURN[returnLength: pktLength]; END; -- SetHostNumberStub. -- Marshall/Unmarshal procedures. UnmarshalEchoParameters: PROC[pkt: RpcPrivate.RPCPkt, pktLength: RpcPrivate.DataLength] RETURNS[value: Lark.EchoParameters, newLength: RpcPrivate.DataLength] = BEGIN isNIL: Lupine.NilHeader; isNIL ← pkt.data[pktLength]; pktLength ← pktLength+1; IF isNIL THEN value ← NIL ELSE BEGIN value ← (paramZones.gc.NEW[Lark.EchoParameterRecord]); BEGIN -- Unmarshal value↑: Lark.EchoParameterRecord from pkt.data[pktLength]. pktLength ← Lupine.CopyFromPkt[pkt: pkt, pktLength: pktLength, dataAdr: LOOPHOLE[value], dataLength: SIZE[Lark.EchoParameterRecord], alwaysOnePkt: TRUE]; END; -- Unmarshal value↑. END; -- IF isNIL. END; UnmarshalConnectionSpec: PROC[pkt: RpcPrivate.RPCPkt, pktLength: RpcPrivate.DataLength] RETURNS[value: Lark.ConnectionSpec, newLength: RpcPrivate.DataLength] = BEGIN isNIL: Lupine.NilHeader; isNIL ← pkt.data[pktLength]; pktLength ← pktLength+1; IF isNIL THEN value ← NIL ELSE BEGIN value ← (paramZones.gc.NEW[Lark.ConnectionSpecRec]); BEGIN -- Unmarshal value↑: Lark.ConnectionSpecRec from pkt.data[pktLength]. pktLength ← Lupine.CopyFromPkt[pkt: pkt, pktLength: pktLength, dataAdr: LOOPHOLE[value], dataLength: SIZE[Lark.ConnectionSpecRec], alwaysOnePkt: TRUE]; END; -- Unmarshal value↑. END; -- IF isNIL. END; UnmarshalKeyTable: PROC[pkt: RpcPrivate.RPCPkt, pktLength: RpcPrivate.DataLength] RETURNS[value: Lark.KeyTable, newLength: RpcPrivate.DataLength] = BEGIN BEGIN -- Unmarshal value↑: Lark.KeyTableBody from pkt.data[pktLength]. recordIsNIL: Lupine.NilHeader; recordIsNIL ← pkt.data[pktLength]; pktLength ← pktLength+1; IF recordIsNIL THEN value ← NIL ELSE BEGIN seqLength: Lupine.SequenceHeader; seqLength ← Lupine.RpcPktDoubleWord[pkt, pktLength]↑; pktLength ← pktLength + 2; value ← (paramZones.gc.NEW[Lark.KeyTableBody[Lupine.SHORT[seqLength]]]); pktLength ← Lupine.CopyFromPkt[pkt: pkt, pktLength: pktLength, dataAdr: LOOPHOLE[value], dataLength: SIZE[Lark.KeyTableBody[LENGTH[DESCRIPTOR[value↑]]]], alwaysOnePkt: TRUE]; END; -- IF recordIsNIL. END; -- Unmarshal value↑. END; UnmarshalCommandEvents: PROC[pkt: RpcPrivate.RPCPkt, pktLength: RpcPrivate.DataLength] RETURNS[value: Lark.CommandEvents, newLength: RpcPrivate.DataLength] = BEGIN BEGIN -- Unmarshal value↑: Lark.CommandEventSequence from pkt.data[pktLength]. recordIsNIL: Lupine.NilHeader; recordIsNIL ← pkt.data[pktLength]; pktLength ← pktLength+1; IF recordIsNIL THEN value ← NIL ELSE BEGIN seqLength: Lupine.SequenceHeader; seqLength ← Lupine.RpcPktDoubleWord[pkt, pktLength]↑; pktLength ← pktLength + 2; value ← (paramZones.gc.NEW[Lark.CommandEventSequence[Lupine.SHORT[seqLength]]]); pktLength ← Lupine.CopyFromPkt[pkt: pkt, pktLength: pktLength, dataAdr: LOOPHOLE[value], dataLength: SIZE[Lark.CommandEventSequence[LENGTH[DESCRIPTOR[value↑]]]], alwaysOnePkt: TRUE]; END; -- IF recordIsNIL. END; -- Unmarshal value↑. END; MarshalConnectionSpec: PROC[value: Lark.ConnectionSpec, pkt: RpcPrivate.RPCPkt, pktLength: RpcPrivate.DataLength] RETURNS[newLength: RpcPrivate.DataLength] = BEGIN pkt.data[pktLength] ← value=NIL; pktLength ← pktLength+1; IF value # NIL THEN BEGIN -- Marshal value↑: Lark.ConnectionSpecRec to pkt.data[pktLength]. pktLength ← Lupine.CopyToPkt[pkt: pkt, pktLength: pktLength, dataAdr: LOOPHOLE[value], dataLength: SIZE[Lark.ConnectionSpecRec], alwaysOnePkt: TRUE]; END; -- Marshal value↑. END; MarshalStatusEvents: PROC[value: Lark.StatusEvents, pkt: RpcPrivate.RPCPkt, pktLength: RpcPrivate.DataLength] RETURNS[newLength: RpcPrivate.DataLength] = BEGIN BEGIN -- Marshal value↑: Lark.StatusEventSequence to pkt.data[pktLength]. pkt.data[pktLength] ← value=NIL; pktLength ← pktLength+1; IF value # NIL THEN BEGIN -- Record has a sequence, put its length up front. Lupine.RpcPktDoubleWord[pkt, pktLength]↑ ← LENGTH[DESCRIPTOR[value↑]]; pktLength ← pktLength + 2; pktLength ← Lupine.CopyToPkt[pkt: pkt, pktLength: pktLength, dataAdr: LOOPHOLE[value], dataLength: SIZE[Lark.StatusEventSequence[LENGTH[DESCRIPTOR[value↑]]]], alwaysOnePkt: TRUE]; END; -- IF value # NIL. END; -- Marshal value↑. END; -- No module initialization. END. -- LarkRpcServerImpl.