-- Copyright (C) 1985 by Xerox Corporation.  All rights reserved.
-- Stub file  was translated on May 15, 1985 1:01:10 pm PDT by Lupine of March 15, 1985 2:49:13 pm PST
-- Source interface ComputeServerController came from file ComputeServerController.bcd, which was created on May 15, 1985 1:01:03 pm PDT with version stamp 322#313#10673645544 from source of May 7, 1985 2:46:31 pm PDT.

-- The RPC stub modules for ComputeServerController are:
--   ComputeServerControllerRpcControl.mesa;
--   ComputeServerControllerRpcClientImpl.mesa;
--   ComputeServerControllerRpcBinderImpl.mesa;
--   ComputeServerControllerRpcServerImpl.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 = FALSE
--   Warn about short POINTER ("MDS") allocations = TRUE
--   Maximum number of dynamic heap NEWs = 50, MDS NEWs = 50
--   Acceptable parameter protocols = VersionRange[1..1].


DIRECTORY
  BasicTime,
  ComputeServer,
  PrincOps,
  PupDefs,
  Rope,
  RPC,
  ComputeServerController,
  ComputeServerControllerRpcControl USING [InterfaceRecord, InterMdsCallsOnly,
      LupineProtocolVersion, ProcedureIndex, SignalIndex],
  RPCLupine --USING SOME OF [Alloc, Call, DataLength, DeAlloc, Dispatcher,
      -- GetPkt, GetStubPkt, ImportHandle, ImportInterface, maxDataLength,
      -- maxPrincipalLength, maxShortStringLength, pktOverhead, ReceiveExtraPkt,
      -- SendPrelimPkt, StartCall, StartSignal, StubPkt, UnimportInterface]--,
  LupineRuntime --USING SOME OF [BindingError, CheckPktLength, CopyFromPkt,
      -- CopyFromMultiplePkts, CopyToPkt, CopyToMultiplePkts, defaultZones,
      -- DispatchingError, FinishThisPkt, ListHeader, MarshalingError,
      -- MarshalingExprError, MarshalAtom, MarshalRope, NilHeader, ProtocolError,
      -- RopeHeader, RpcPktDoubleWord, RuntimeError, SequenceHeader, SHORT,
      -- StartNextPkt, StringHeader, StubPktDoubleWord, TranslationError,
      -- UnmarshalingError, UnmarshalingExprError, UnmarshalAtom, UnmarshalRope,
      -- WordsForChars]--,
  Atom --USING SOME OF [GetPName, MakeAtom]--,
  PrincOpsUtils --USING SOME OF [Enter, Exit]--,
  VM --USING SOME OF [AddressForPageNumber, PageCount, PageNumber,
      -- PageNumberForAddress, PagesForWords]--;


ComputeServerControllerRpcClientImpl: MONITOR
  IMPORTS ComputeServerController, RpcPrivate: RPCLupine, Lupine: LupineRuntime,
      Atom, PrincOpsUtils, Rope
  EXPORTS ComputeServerControllerRpcControl
  SHARES  ComputeServerController, ComputeServerControllerRpcControl,
      Rope
  = BEGIN OPEN ComputeServerController, RpcControl: ComputeServerControllerRpcControl,
      RpcPublic: RPC;


-- Standard remote binding routines.


  ImportInterface: PUBLIC ENTRY SAFE PROCEDURE [
        interface: RpcControl.InterfaceRecord,
        interfaceName: RpcPublic.InterfaceName,
        parameterStorage: RpcPublic.Zones ] =
    TRUSTED BEGIN ENABLE UNWIND => NULL;
    IsNull: PROCEDURE [string: Rope.ROPE] RETURNS [BOOLEAN] =
      INLINE {RETURN[string.Length[] = 0]};
    IF interface.bound THEN Lupine.BindingError;
    interface↑ ← [clientStubFindService: clientStubFindService, clientStubFindServiceWithQueueing:
        clientStubFindServiceWithQueueing, clientStubNewStats: clientStubNewStats,
        clientStubBestServerStats: clientStubBestServerStats, clientStubNoticeNewPackage:
        clientStubNoticeNewPackage, clientStubRemoveOldPackage: clientStubRemoveOldPackage,
        clientStubGetSomeInfo: clientStubGetSomeInfo, clientStubCommandUnavailable:
        clientStubCommandUnavailable, clientStubExtraCommandAvailable:
        clientStubExtraCommandAvailable, clientStubMightAcceptQueuedCommand:
        clientStubMightAcceptQueuedCommand];
    interface.myInterface ← RpcPrivate.ImportInterface [
      interface: [
        type: IF ~IsNull[interfaceName.type]
          THEN interfaceName.type ELSE "ComputeServerController~322#313#10673645544",
        instance: interfaceName.instance,
        version: interfaceName.version ],
      localOnly: RpcControl.InterMdsCallsOnly,
      stubProtocol: RpcControl.LupineProtocolVersion ];
    interface.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 ];
    interface.bound ← TRUE;
    END;



-- Remote public procedure stubs.

  clientStubFindService: PUBLIC SAFE PROCEDURE [interface: RpcControl.InterfaceRecord,
      service: Rope.ROPE] RETURNS [found: BOOL, instance: RPC.ShortROPE]
      =
    TRUSTED BEGIN
    ArgumentOverlay: TYPE = MACHINE DEPENDENT RECORD [
        transferIndex (0): RpcControl.ProcedureIndex ← FindService];
    ResultOverlay: TYPE = MACHINE DEPENDENT RECORD [
        found (0): BOOL];
    pkt: RpcPrivate.RPCPkt = RpcPrivate.GetPkt[space: RpcPrivate.Alloc[RpcPrivate.pktOverhead+254]];
    argPkt: LONG POINTER TO ArgumentOverlay = @pkt.data[0];
    resPkt: LONG POINTER TO ResultOverlay = @pkt.data[0];
    pktLength: RpcPrivate.DataLength ← 1;
    lastPkt: BOOLEAN;
    BEGIN ENABLE UNWIND => RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+254];
      RpcPrivate.StartCall[callPkt: pkt, interface: interface.myInterface];
      argPkt.transferIndex ← FindService;
      BEGIN  -- Marshal service: Rope.ROPE to pkt.data[pktLength].
        pktLength ← Lupine.MarshalRope[service, pkt, pktLength, FALSE];
        END;  -- Marshal service.
      [returnLength: , lastPkt: lastPkt] ←
        RpcPrivate.Call[ pkt: pkt, callLength: pktLength,
            maxReturnLength: 35, signalHandler: ClientDispatcher];
      pktLength ← 1;
      [found: found] ← resPkt↑;
      BEGIN  -- Unmarshal instance: RPC.ShortROPE from pkt.data[pktLength].
        [instance, pktLength] ← Lupine.UnmarshalRope[pkt, pktLength,
            TRUE];
        END;  -- Unmarshal instance.
      Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength];
      RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+254];
      RETURN[found, instance];
      END;  -- UNWIND.
    END;  -- FindService.

  clientStubFindServiceWithQueueing: PUBLIC SAFE PROCEDURE [interface:
      RpcControl.InterfaceRecord, service: Rope.ROPE, version: RPC.ShortROPE,
      timeToWait: INT, clientMachineName: RPC.ShortROPE, streamPupAddress:
      PupDefs.PupAddress, needListener: BOOL]
    RETURNS [found: ComputeServer.AskResponce, instance: RPC.ShortROPE,
        serverPupAddress: PupDefs.PupAddress, errMsg: Rope.ROPE] =
    TRUSTED BEGIN
    ArgumentOverlay: TYPE = MACHINE DEPENDENT RECORD [
        transferIndex (0): RpcControl.ProcedureIndex ← FindServiceWithQueueing,
        timeToWait (1): INT, streamPupAddress (3): PupDefs.PupAddress,
        needListener (6): BOOL];
    ResultOverlay: TYPE = MACHINE DEPENDENT RECORD [
        found (0): ComputeServer.AskResponce, serverPupAddress (1): PupDefs.PupAddress];
    pkt: RpcPrivate.RPCPkt = RpcPrivate.GetPkt[space: RpcPrivate.Alloc[RpcPrivate.pktOverhead+254]];
    argPkt: LONG POINTER TO ArgumentOverlay = @pkt.data[0];
    resPkt: LONG POINTER TO ResultOverlay = @pkt.data[0];
    pktLength: RpcPrivate.DataLength ← 7;
    lastPkt: BOOLEAN;
    BEGIN ENABLE UNWIND => RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+254];
      RpcPrivate.StartCall[callPkt: pkt, interface: interface.myInterface];
      argPkt↑ ← [timeToWait: timeToWait, streamPupAddress: streamPupAddress,
          needListener: needListener];
      BEGIN  -- Marshal service: Rope.ROPE to pkt.data[pktLength].
        pktLength ← Lupine.MarshalRope[service, pkt, pktLength, FALSE];
        END;  -- Marshal service.
      BEGIN  -- Marshal version: RPC.ShortROPE to pkt.data[pktLength].
        pktLength ← Lupine.MarshalRope[version, pkt, pktLength, TRUE];
        END;  -- Marshal version.
      BEGIN  -- Marshal clientMachineName: RPC.ShortROPE to pkt.data[pktLength].
        pktLength ← Lupine.MarshalRope[clientMachineName, pkt, pktLength,
            TRUE];
        END;  -- Marshal clientMachineName.
      [returnLength: , lastPkt: lastPkt] ←
        RpcPrivate.Call[ pkt: pkt, callLength: pktLength,
            maxReturnLength: 254, signalHandler: ClientDispatcher];
      pktLength ← 4;
      BEGIN  -- OnePkt.
        -- Move statics from pkt now.
        [found: found, serverPupAddress: serverPupAddress] ← resPkt↑;
      BEGIN  -- Unmarshal instance: RPC.ShortROPE from pkt.data[pktLength].
        [instance, pktLength] ← Lupine.UnmarshalRope[pkt, pktLength,
            TRUE];
        END;  -- Unmarshal instance.
      BEGIN  -- Unmarshal errMsg: Rope.ROPE from pkt.data[pktLength].
        [errMsg, pktLength] ← Lupine.UnmarshalRope[pkt, pktLength,
            FALSE];
        END;  -- Unmarshal errMsg.
      Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength];
      RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+254];
RETURN[found, instance, serverPupAddress, errMsg];
      END;  -- OnePkt.
      END;  -- UNWIND.
    END;  -- FindServiceWithQueueing.

  clientStubNewStats: PUBLIC SAFE PROCEDURE [interface: RpcControl.InterfaceRecord,
      serverMachineName: RPC.ShortROPE, serverMachinePupAddress: RPC.ShortROPE,
      serverUP: BOOL, firstCall: BOOL, machineType: PrincOps.MachineType,
      mainMemory: CARDINAL, numberCPUs: CARDINAL, diskPartionSize: INT,
      freePagesOnDisk: INT, freeboard: INT, freeGFI: CARDINAL, freeMDS:
      CARDINAL, freeVM: CARDINAL, oldestLRUFileDate: BasicTime.GMT, CPULoad:
      REAL, reclamationRate: REAL, freeProcesses: CARDINAL]
    RETURNS [terminateService: BOOL, newPackage: BOOL, queueingCommands:
        LIST OF Rope.ROPE] =
    TRUSTED BEGIN
    ArgumentOverlay: TYPE = MACHINE DEPENDENT RECORD [
        transferIndex (0): RpcControl.ProcedureIndex ← NewStats, serverUP
        (1): BOOL, firstCall (2): BOOL, machineType (3): PrincOps.MachineType,
        mainMemory (4): CARDINAL, numberCPUs (5): CARDINAL, diskPartionSize
        (6): INT, freePagesOnDisk (8): INT, freeboard (10): INT, freeGFI
        (12): CARDINAL, freeMDS (13): CARDINAL, freeVM (14): CARDINAL,
        oldestLRUFileDate (15): BasicTime.GMT, CPULoad (17): REAL, reclamationRate
        (19): REAL, freeProcesses (21): CARDINAL];
    ResultOverlay: TYPE = MACHINE DEPENDENT RECORD [
        terminateService (0): BOOL, newPackage (1): BOOL];
    pkt: RpcPrivate.RPCPkt = RpcPrivate.GetPkt[space: RpcPrivate.Alloc[RpcPrivate.pktOverhead+254]];
    argPkt: LONG POINTER TO ArgumentOverlay = @pkt.data[0];
    resPkt: LONG POINTER TO ResultOverlay = @pkt.data[0];
    pktLength: RpcPrivate.DataLength ← 22;
    lastPkt: BOOLEAN;
    BEGIN ENABLE UNWIND => RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+254];
      RpcPrivate.StartCall[callPkt: pkt, interface: interface.myInterface];
      argPkt↑ ← [serverUP: serverUP, firstCall: firstCall, machineType:
          machineType, mainMemory: mainMemory, numberCPUs: numberCPUs,
          diskPartionSize: diskPartionSize, freePagesOnDisk: freePagesOnDisk,
          freeboard: freeboard, freeGFI: freeGFI, freeMDS: freeMDS, freeVM:
          freeVM, oldestLRUFileDate: oldestLRUFileDate, CPULoad: CPULoad,
          reclamationRate: reclamationRate, freeProcesses: freeProcesses];
      BEGIN  -- Marshal serverMachineName: RPC.ShortROPE to pkt.data[pktLength].
        pktLength ← Lupine.MarshalRope[serverMachineName, pkt, pktLength,
            TRUE];
        END;  -- Marshal serverMachineName.
      BEGIN  -- Marshal serverMachinePupAddress: RPC.ShortROPE to pkt.data[pktLength].
        pktLength ← Lupine.MarshalRope[serverMachinePupAddress, pkt,
            pktLength, TRUE];
        END;  -- Marshal serverMachinePupAddress.
      [returnLength: , lastPkt: lastPkt] ←
        RpcPrivate.Call[ pkt: pkt, callLength: pktLength,
            maxReturnLength: 254, signalHandler: ClientDispatcher];
      pktLength ← 2;
      BEGIN  -- OnePkt.
        -- Move statics from pkt now.
        [terminateService: terminateService, newPackage: newPackage]
            ← resPkt↑;
      BEGIN  -- Unmarshal queueingCommands: LIST OF Rope.ROPE from
          -- pkt.data[pktLength].
        lastNode: LIST OF Rope.ROPE ← (queueingCommands ← NIL);
        listLength: Lupine.ListHeader;
        IF pktLength+2 > RpcPrivate.maxDataLength
          THEN pktLength ← Lupine.FinishThisPkt[pkt: pkt, pktLength:
              pktLength];
        listLength ← Lupine.RpcPktDoubleWord[pkt, pktLength]↑;
        pktLength ← pktLength + 2;
        WHILE listLength > 0 DO
          thisNode1: LIST OF Rope.ROPE = interface.paramZones.gc.CONS[--DefaultValue--,NIL];
          BEGIN  -- Unmarshal thisNode1.first: Rope.ROPE from pkt.data[pktLength].
            [thisNode1.first, pktLength] ← Lupine.UnmarshalRope[pkt,
                pktLength, FALSE];
            END;  -- Unmarshal thisNode1.first.
          IF lastNode # NIL
            THEN lastNode ← (lastNode.rest ← thisNode1)
            ELSE lastNode ← (queueingCommands ← thisNode1);
          listLength ← listLength - 1;
          ENDLOOP;  -- WHILE listLength > 0.
        END;  -- Unmarshal queueingCommands.
      Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength];
      RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+254];
RETURN[terminateService, newPackage, queueingCommands];
      END;  -- OnePkt.
      END;  -- UNWIND.
    END;  -- NewStats.

  clientStubBestServerStats: PUBLIC SAFE PROCEDURE [interface: RpcControl.InterfaceRecord]RETURNS
      [instance: RPC.ShortROPE, FOM: REAL] =
    TRUSTED BEGIN
    ArgumentOverlay: TYPE = MACHINE DEPENDENT RECORD [
        transferIndex (0): RpcControl.ProcedureIndex ← BestServerStats];
    ResultOverlay: TYPE = MACHINE DEPENDENT RECORD [
        FOM (0): REAL];
    pkt: RpcPrivate.RPCPkt = RpcPrivate.GetPkt[space: RpcPrivate.Alloc[RpcPrivate.pktOverhead+36]];
    argPkt: LONG POINTER TO ArgumentOverlay = @pkt.data[0];
    resPkt: LONG POINTER TO ResultOverlay = @pkt.data[0];
    pktLength: RpcPrivate.DataLength ← 1;
    lastPkt: BOOLEAN;
    BEGIN ENABLE UNWIND => RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+36];
      RpcPrivate.StartCall[callPkt: pkt, interface: interface.myInterface];
      argPkt.transferIndex ← BestServerStats;
      [returnLength: , lastPkt: lastPkt] ←
        RpcPrivate.Call[ pkt: pkt, callLength: pktLength,
            maxReturnLength: 36, signalHandler: ClientDispatcher];
      pktLength ← 2;
      [FOM: FOM] ← resPkt↑;
      BEGIN  -- Unmarshal instance: RPC.ShortROPE from pkt.data[pktLength].
        [instance, pktLength] ← Lupine.UnmarshalRope[pkt, pktLength,
            TRUE];
        END;  -- Unmarshal instance.
      Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength];
      RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+36];
      RETURN[instance, FOM];
      END;  -- UNWIND.
    END;  -- BestServerStats.

  clientStubNoticeNewPackage: PUBLIC SAFE PROCEDURE [interface: RpcControl.InterfaceRecord,
      package: RPC.ShortROPE] RETURNS [error: BOOL, tryDifferentController:
      BOOL, msg: Rope.ROPE] =
    TRUSTED BEGIN
    ArgumentOverlay: TYPE = MACHINE DEPENDENT RECORD [
        transferIndex (0): RpcControl.ProcedureIndex ← NoticeNewPackage];
    ResultOverlay: TYPE = MACHINE DEPENDENT RECORD [
        error (0): BOOL, tryDifferentController (1): BOOL];
    pkt: RpcPrivate.RPCPkt = RpcPrivate.GetPkt[space: RpcPrivate.Alloc[RpcPrivate.pktOverhead+254]];
    argPkt: LONG POINTER TO ArgumentOverlay = @pkt.data[0];
    resPkt: LONG POINTER TO ResultOverlay = @pkt.data[0];
    pktLength: RpcPrivate.DataLength ← 1;
    lastPkt: BOOLEAN;
    BEGIN ENABLE UNWIND => RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+254];
      RpcPrivate.StartCall[callPkt: pkt, interface: interface.myInterface];
      argPkt.transferIndex ← NoticeNewPackage;
      BEGIN  -- Marshal package: RPC.ShortROPE to pkt.data[pktLength].
        pktLength ← Lupine.MarshalRope[package, pkt, pktLength, TRUE];
        END;  -- Marshal package.
      [returnLength: , lastPkt: lastPkt] ←
        RpcPrivate.Call[ pkt: pkt, callLength: pktLength,
            maxReturnLength: 254, signalHandler: ClientDispatcher];
      pktLength ← 2;
      BEGIN  -- OnePkt.
        -- Move statics from pkt now.
        [error: error, tryDifferentController: tryDifferentController]
            ← resPkt↑;
      BEGIN  -- Unmarshal msg: Rope.ROPE from pkt.data[pktLength].
        [msg, pktLength] ← Lupine.UnmarshalRope[pkt, pktLength, FALSE];
        END;  -- Unmarshal msg.
      Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength];
      RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+254];
RETURN[error, tryDifferentController, msg];
      END;  -- OnePkt.
      END;  -- UNWIND.
    END;  -- NoticeNewPackage.

  clientStubRemoveOldPackage: PUBLIC SAFE PROCEDURE [interface: RpcControl.InterfaceRecord,
      package: RPC.ShortROPE] RETURNS [error: BOOL, tryDifferentController:
      BOOL, msg: Rope.ROPE] =
    TRUSTED BEGIN
    ArgumentOverlay: TYPE = MACHINE DEPENDENT RECORD [
        transferIndex (0): RpcControl.ProcedureIndex ← RemoveOldPackage];
    ResultOverlay: TYPE = MACHINE DEPENDENT RECORD [
        error (0): BOOL, tryDifferentController (1): BOOL];
    pkt: RpcPrivate.RPCPkt = RpcPrivate.GetPkt[space: RpcPrivate.Alloc[RpcPrivate.pktOverhead+254]];
    argPkt: LONG POINTER TO ArgumentOverlay = @pkt.data[0];
    resPkt: LONG POINTER TO ResultOverlay = @pkt.data[0];
    pktLength: RpcPrivate.DataLength ← 1;
    lastPkt: BOOLEAN;
    BEGIN ENABLE UNWIND => RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+254];
      RpcPrivate.StartCall[callPkt: pkt, interface: interface.myInterface];
      argPkt.transferIndex ← RemoveOldPackage;
      BEGIN  -- Marshal package: RPC.ShortROPE to pkt.data[pktLength].
        pktLength ← Lupine.MarshalRope[package, pkt, pktLength, TRUE];
        END;  -- Marshal package.
      [returnLength: , lastPkt: lastPkt] ←
        RpcPrivate.Call[ pkt: pkt, callLength: pktLength,
            maxReturnLength: 254, signalHandler: ClientDispatcher];
      pktLength ← 2;
      BEGIN  -- OnePkt.
        -- Move statics from pkt now.
        [error: error, tryDifferentController: tryDifferentController]
            ← resPkt↑;
      BEGIN  -- Unmarshal msg: Rope.ROPE from pkt.data[pktLength].
        [msg, pktLength] ← Lupine.UnmarshalRope[pkt, pktLength, FALSE];
        END;  -- Unmarshal msg.
      Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength];
      RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+254];
RETURN[error, tryDifferentController, msg];
      END;  -- OnePkt.
      END;  -- UNWIND.
    END;  -- RemoveOldPackage.

  clientStubGetSomeInfo: PUBLIC SAFE PROCEDURE [interface: RpcControl.InterfaceRecord]RETURNS
      [error: BOOL, tryDifferentController: BOOL, msg: Rope.ROPE, serverList:
      LIST OF Rope.ROPE, bestFOM: REAL] =
    TRUSTED BEGIN
    ArgumentOverlay: TYPE = MACHINE DEPENDENT RECORD [
        transferIndex (0): RpcControl.ProcedureIndex ← GetSomeInfo];
    ResultOverlay: TYPE = MACHINE DEPENDENT RECORD [
        error (0): BOOL, tryDifferentController (1): BOOL, bestFOM (2):
        REAL];
    pkt: RpcPrivate.RPCPkt = RpcPrivate.GetPkt[space: RpcPrivate.Alloc[RpcPrivate.pktOverhead+254]];
    argPkt: LONG POINTER TO ArgumentOverlay = @pkt.data[0];
    resPkt: LONG POINTER TO ResultOverlay = @pkt.data[0];
    pktLength: RpcPrivate.DataLength ← 1;
    lastPkt: BOOLEAN;
    BEGIN ENABLE UNWIND => RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+254];
      RpcPrivate.StartCall[callPkt: pkt, interface: interface.myInterface];
      argPkt.transferIndex ← GetSomeInfo;
      [returnLength: , lastPkt: lastPkt] ←
        RpcPrivate.Call[ pkt: pkt, callLength: pktLength,
            maxReturnLength: 254, signalHandler: ClientDispatcher];
      pktLength ← 4;
      BEGIN  -- OnePkt.
        -- Move statics from pkt now.
        [error: error, tryDifferentController: tryDifferentController,
            bestFOM: bestFOM] ← resPkt↑;
      BEGIN  -- Unmarshal msg: Rope.ROPE from pkt.data[pktLength].
        [msg, pktLength] ← Lupine.UnmarshalRope[pkt, pktLength, FALSE];
        END;  -- Unmarshal msg.
      BEGIN  -- Unmarshal serverList: LIST OF Rope.ROPE from pkt.data[pktLength].
        lastNode: LIST OF Rope.ROPE ← (serverList ← NIL);
        listLength: Lupine.ListHeader;
        IF pktLength+2 > RpcPrivate.maxDataLength
          THEN pktLength ← Lupine.FinishThisPkt[pkt: pkt, pktLength:
              pktLength];
        listLength ← Lupine.RpcPktDoubleWord[pkt, pktLength]↑;
        pktLength ← pktLength + 2;
        WHILE listLength > 0 DO
          thisNode1: LIST OF Rope.ROPE = interface.paramZones.gc.CONS[--DefaultValue--,NIL];
          BEGIN  -- Unmarshal thisNode1.first: Rope.ROPE from pkt.data[pktLength].
            [thisNode1.first, pktLength] ← Lupine.UnmarshalRope[pkt,
                pktLength, FALSE];
            END;  -- Unmarshal thisNode1.first.
          IF lastNode # NIL
            THEN lastNode ← (lastNode.rest ← thisNode1)
            ELSE lastNode ← (serverList ← thisNode1);
          listLength ← listLength - 1;
          ENDLOOP;  -- WHILE listLength > 0.
        END;  -- Unmarshal serverList.
      Lupine.CheckPktLength[pkt: pkt, pktLength: pktLength];
      RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+254];
RETURN[error, tryDifferentController, msg, serverList, bestFOM];
      END;  -- OnePkt.
      END;  -- UNWIND.
    END;  -- GetSomeInfo.

  clientStubCommandUnavailable: PUBLIC SAFE PROCEDURE [interface: RpcControl.InterfaceRecord,
      serverMachineName: RPC.ShortROPE, commandName: Rope.ROPE, version:
      RPC.ShortROPE] =
    TRUSTED BEGIN
    ArgumentOverlay: TYPE = MACHINE DEPENDENT RECORD [
        transferIndex (0): RpcControl.ProcedureIndex ← CommandUnavailable];
    pkt: RpcPrivate.RPCPkt = RpcPrivate.GetPkt[space: RpcPrivate.Alloc[RpcPrivate.pktOverhead+254]];
    argPkt: LONG POINTER TO ArgumentOverlay = @pkt.data[0];
    pktLength: RpcPrivate.DataLength ← 1;
    lastPkt: BOOLEAN;
    BEGIN ENABLE UNWIND => RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+254];
      RpcPrivate.StartCall[callPkt: pkt, interface: interface.myInterface];
      argPkt.transferIndex ← CommandUnavailable;
      BEGIN  -- Marshal serverMachineName: RPC.ShortROPE to pkt.data[pktLength].
        pktLength ← Lupine.MarshalRope[serverMachineName, pkt, pktLength,
            TRUE];
        END;  -- Marshal serverMachineName.
      BEGIN  -- Marshal commandName: Rope.ROPE to pkt.data[pktLength].
        pktLength ← Lupine.MarshalRope[commandName, pkt, pktLength,
            FALSE];
        END;  -- Marshal commandName.
      BEGIN  -- Marshal version: RPC.ShortROPE to pkt.data[pktLength].
        pktLength ← Lupine.MarshalRope[version, pkt, pktLength, TRUE];
        END;  -- Marshal version.
      [returnLength: , lastPkt: lastPkt] ←
        RpcPrivate.Call[ pkt: pkt, callLength: pktLength,
            maxReturnLength: 0, signalHandler: ClientDispatcher];
      Lupine.CheckPktLength[pkt: pkt, pktLength: 0];
      RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+254];
      RETURN[];
      END;  -- UNWIND.
    END;  -- CommandUnavailable.

  clientStubExtraCommandAvailable: PUBLIC SAFE PROCEDURE [interface:
      RpcControl.InterfaceRecord, serverMachineName: RPC.ShortROPE, commandName:
      Rope.ROPE, version: RPC.ShortROPE] =
    TRUSTED BEGIN
    ArgumentOverlay: TYPE = MACHINE DEPENDENT RECORD [
        transferIndex (0): RpcControl.ProcedureIndex ← ExtraCommandAvailable];
    pkt: RpcPrivate.RPCPkt = RpcPrivate.GetPkt[space: RpcPrivate.Alloc[RpcPrivate.pktOverhead+254]];
    argPkt: LONG POINTER TO ArgumentOverlay = @pkt.data[0];
    pktLength: RpcPrivate.DataLength ← 1;
    lastPkt: BOOLEAN;
    BEGIN ENABLE UNWIND => RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+254];
      RpcPrivate.StartCall[callPkt: pkt, interface: interface.myInterface];
      argPkt.transferIndex ← ExtraCommandAvailable;
      BEGIN  -- Marshal serverMachineName: RPC.ShortROPE to pkt.data[pktLength].
        pktLength ← Lupine.MarshalRope[serverMachineName, pkt, pktLength,
            TRUE];
        END;  -- Marshal serverMachineName.
      BEGIN  -- Marshal commandName: Rope.ROPE to pkt.data[pktLength].
        pktLength ← Lupine.MarshalRope[commandName, pkt, pktLength,
            FALSE];
        END;  -- Marshal commandName.
      BEGIN  -- Marshal version: RPC.ShortROPE to pkt.data[pktLength].
        pktLength ← Lupine.MarshalRope[version, pkt, pktLength, TRUE];
        END;  -- Marshal version.
      [returnLength: , lastPkt: lastPkt] ←
        RpcPrivate.Call[ pkt: pkt, callLength: pktLength,
            maxReturnLength: 0, signalHandler: ClientDispatcher];
      Lupine.CheckPktLength[pkt: pkt, pktLength: 0];
      RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+254];
      RETURN[];
      END;  -- UNWIND.
    END;  -- ExtraCommandAvailable.

  clientStubMightAcceptQueuedCommand: PUBLIC SAFE PROCEDURE [interface:
      RpcControl.InterfaceRecord, serverMachineAddress: RPC.ShortROPE,
      commandName: Rope.ROPE] =
    TRUSTED BEGIN
    ArgumentOverlay: TYPE = MACHINE DEPENDENT RECORD [
        transferIndex (0): RpcControl.ProcedureIndex ← MightAcceptQueuedCommand];
    pkt: RpcPrivate.RPCPkt = RpcPrivate.GetPkt[space: RpcPrivate.Alloc[RpcPrivate.pktOverhead+254]];
    argPkt: LONG POINTER TO ArgumentOverlay = @pkt.data[0];
    pktLength: RpcPrivate.DataLength ← 1;
    lastPkt: BOOLEAN;
    BEGIN ENABLE UNWIND => RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+254];
      RpcPrivate.StartCall[callPkt: pkt, interface: interface.myInterface];
      argPkt.transferIndex ← MightAcceptQueuedCommand;
      BEGIN  -- Marshal serverMachineAddress: RPC.ShortROPE to pkt.data[pktLength].
        pktLength ← Lupine.MarshalRope[serverMachineAddress, pkt, pktLength,
            TRUE];
        END;  -- Marshal serverMachineAddress.
      BEGIN  -- Marshal commandName: Rope.ROPE to pkt.data[pktLength].
        pktLength ← Lupine.MarshalRope[commandName, pkt, pktLength,
            FALSE];
        END;  -- Marshal commandName.
      [returnLength: , lastPkt: lastPkt] ←
        RpcPrivate.Call[ pkt: pkt, callLength: pktLength,
            maxReturnLength: 0, signalHandler: ClientDispatcher];
      Lupine.CheckPktLength[pkt: pkt, pktLength: 0];
      RpcPrivate.DeAlloc[LOOPHOLE[pkt], RpcPrivate.pktOverhead+254];
      RETURN[];
      END;  -- UNWIND.
    END;  -- MightAcceptQueuedCommand.


--Remote public signals and errors are imported from the interface.


-- Public signal and error dispatcher.

  ClientDispatcher: --PROCEDURE [pkt: RPCPkt, callLength: DataLength,
      -- lastPkt: BOOLEAN, localConversation: Conversation] RETURNS [returnLength:
      -- DataLength]-- RpcPrivate.Dispatcher =
    BEGIN

    SELECT LOOPHOLE[pkt.data[0], RpcControl.SignalIndex] FROM
      ENDCASE => RETURN[Lupine.DispatchingError[]];

    END;  -- ClientDispatcher


-- Public signal and error dispatcher stubs.


-- Marshall/Unmarshal procedures.


-- No module initialization.

END.  -- ComputeServerControllerRpcClientImpl.