|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202 |
- module CDrillingConsole
- use CDrillingConsoleVariables
- use SimulationVariables
- ! use CSimulationVariables
- use CLog4
- use CLog3
- implicit none
- public
- contains
-
-
- subroutine DrillingConsoleFromJson(jsonfile)
- type(json_value),pointer :: parent
- type(json_core) :: json
- type(json_value),pointer :: p,pval
- type(json_file)::jsonfile
- logical::found
- integer :: i
-
- call jsonfile%get('Equipments.Drilling.AssignmentSwitch',data%Equipments%DrillingConsole%AssignmentSwitch,found)
- if ( .not. found ) call logg(4,"Not found: AssignmentSwitch")
- call jsonfile%get('Equipments.Drilling.EmergencySwitch',data%Equipments%DrillingConsole%EmergencySwitch,found)
- if ( .not. found ) call logg(4,"Not found: EmergencySwitch")
- call jsonfile%get('Equipments.Drilling.RTTorqueLimitKnob',data%Equipments%DrillingConsole%RTTorqueLimitKnob,found)
- if ( .not. found ) call logg(4,"Not found: RTTorqueLimitKnob")
- call jsonfile%get('Equipments.Drilling.MP1CPSwitch',data%Equipments%DrillingConsole%MP1CPSwitch,found)
- if ( .not. found ) call logg(4,"Not found: MP1CPSwitch")
- call jsonfile%get('Equipments.Drilling.MP1ThrottleUpdate',data%Equipments%DrillingConsole%MP1ThrottleUpdate,found)
- if ( .not. found ) call logg(4,"Not found: MP1ThrottleUpdate")
- call jsonfile%get('Equipments.Drilling.MP1Throttle',data%Equipments%DrillingConsole%MP1Throttle,found)
- if ( .not. found ) then
- call logg(4,"Not found: MP1Throttle")
- endif
- call jsonfile%get('Equipments.Drilling.MP2Switch',data%Equipments%DrillingConsole%MP2Switch,found)
- if ( .not. found ) call logg(4,"Not found: MP2Switch")
- call jsonfile%get('Equipments.Drilling.MP2ThrottleUpdate',data%Equipments%DrillingConsole%MP2ThrottleUpdate,found)
- if ( .not. found ) call logg(4,"Not found: MP2ThrottleUpdate")
- call jsonfile%get('Equipments.Drilling.MP2Throttle',data%Equipments%DrillingConsole%MP2Throttle,found)
- if ( .not. found ) then
- call logg(4,"Not found: MP2Throttle")
- endif
- call jsonfile%get('Equipments.Drilling.DWSwitch',data%Equipments%DrillingConsole%DWSwitch,found)
- if ( .not. found ) call logg(4,"Not found: DWSwitch")
- call jsonfile%get('Equipments.Drilling.DWThrottle',data%Equipments%DrillingConsole%DWThrottle,found)
- if ( .not. found ) call logg(4,"Not found: DWThrottle")
- call jsonfile%get('Equipments.Drilling.RTSwitch',data%Equipments%DrillingConsole%RTSwitch,found)
- if ( .not. found ) call logg(4,"Not found: RTSwitch")
- call jsonfile%get('Equipments.Drilling.RTThrottle',i,found)
- data%Equipments%DrillingConsole%RTThrottle = real(i)
- if ( .not. found ) then
- call logg(4,"Not found: RTThrottle")
- endif
- call jsonfile%get('Equipments.Drilling.DWBreak',data%Equipments%DrillingConsole%DWBreak,found)
- if ( .not. found ) call logg(4,"Not found: DWBreak")
- call jsonfile%get('Equipments.Drilling.PreviousDWBreak',data%Equipments%DrillingConsole%PreviousDWBreak,found)
- if ( .not. found ) call logg(4,"Not found: PreviousDWBreak")
- call jsonfile%get('Equipments.Drilling.ForceBreak',data%Equipments%DrillingConsole%ForceBreak,found)
- if ( .not. found ) call logg(4,"Not found: ForceBreak")
- call jsonfile%get('Equipments.Drilling.DWAcceleretor',data%Equipments%DrillingConsole%DWAcceleretor,found)
- if ( .not. found ) call logg(4,"Not found: DWAcceleretor")
- call jsonfile%get('Equipments.Drilling.DWTransmisionLever',data%Equipments%DrillingConsole%DWTransmisionLever,found)
- if ( .not. found ) call logg(4,"Not found: DWTransmisionLever")
- call jsonfile%get('Equipments.Drilling.DWPowerLever',data%Equipments%DrillingConsole%DWPowerLever,found)
- if ( .not. found ) call logg(4,"Not found: DWPowerLever")
- ! call jsonfile%get('Equipments.Drilling.TongLever',data%Equipments%DrillingConsole%TongLever,found)
- ! if ( .not. found ) call logg(4,"Not found: TongLever")
- call jsonfile%get('Equipments.Drilling.RTTransmissionLever',data%Equipments%DrillingConsole%RTTransmissionLever,found)
- if ( .not. found ) call logg(4,"Not found: RTTransmissionLever")
- call jsonfile%get('Equipments.Drilling.DWClutchLever',data%Equipments%DrillingConsole%DWClutchLever,found)
- if ( .not. found ) call logg(4,"Not found: DWClutchLever")
- call jsonfile%get('Equipments.Drilling.EddyBreakLever',data%Equipments%DrillingConsole%EddyBreakLever,found)
- if ( .not. found ) call logg(4,"Not found: EddyBreakLever")
- call jsonfile%get('Equipments.Drilling.AutoDW',data%Equipments%DrillingConsole%AutoDW,found)
- if ( .not. found ) call logg(4,"Not found: AutoDW")
- call jsonfile%get('Equipments.Drilling.GEN1',data%Equipments%DrillingConsole%GEN1,found)
- if ( .not. found ) call logg(4,"Not found: GEN1")
- call jsonfile%get('Equipments.Drilling.GEN2',data%Equipments%DrillingConsole%GEN2,found)
- if ( .not. found ) call logg(4,"Not found: GEN2")
- call jsonfile%get('Equipments.Drilling.GEN3',data%Equipments%DrillingConsole%GEN3,found)
- if ( .not. found ) call logg(4,"Not found: GEN3")
- call jsonfile%get('Equipments.Drilling.GEN4',data%Equipments%DrillingConsole%GEN4,found)
- if ( .not. found ) call logg(4,"Not found: GEN4")
- call jsonfile%get('Equipments.Drilling.Permission_OpenKellyCock',data%Equipments%DrillingConsole%Permission_OpenKellyCock,found)
- if ( .not. found ) call logg(4,"Not found: Permission_OpenKellyCock")
- call jsonfile%get('Equipments.Drilling.OpenKellyCock',data%Equipments%DrillingConsole%OpenKellyCock,found)
- if ( .not. found ) call logg(4,"Not found: OpenKellyCock")
- call jsonfile%get('Equipments.Drilling.Permission_CloseKellyCock',data%Equipments%DrillingConsole%Permission_CloseKellyCock,found)
- if ( .not. found ) call logg(4,"Not found: Permission_CloseKellyCock")
- call jsonfile%get('Equipments.Drilling.CloseKellyCock',data%Equipments%DrillingConsole%CloseKellyCock,found)
- if ( .not. found ) call logg(4,"Not found: CloseKellyCock")
- call jsonfile%get('Equipments.Drilling.Permission_OpenSafetyValve',data%Equipments%DrillingConsole%Permission_OpenSafetyValve,found)
- if ( .not. found ) call logg(4,"Not found: Permission_OpenSafetyValve")
- call jsonfile%get('Equipments.Drilling.OpenSafetyValve',data%Equipments%DrillingConsole%OpenSafetyValve,found)
- if ( .not. found ) call logg(4,"Not found: OpenSafetyValve")
- call jsonfile%get('Equipments.Drilling.Permission_CloseSafetyValve',data%Equipments%DrillingConsole%Permission_CloseSafetyValve,found)
- if ( .not. found ) call logg(4,"Not found: Permission_CloseSafetyValve")
- call jsonfile%get('Equipments.Drilling.CloseSafetyValve',data%Equipments%DrillingConsole%CloseSafetyValve,found)
- if ( .not. found ) call logg(4,"Not found: CloseSafetyValve")
- call jsonfile%get('Equipments.Drilling.Permission_IRSafetyValve',data%Equipments%DrillingConsole%Permission_IRSafetyValve,found)
- if ( .not. found ) call logg(4,"Not found: Permission_IRSafetyValve")
- call jsonfile%get('Equipments.Drilling.IRSafetyValve',data%Equipments%DrillingConsole%IRSafetyValve,found)
- if ( .not. found ) call logg(4,"Not found: IRSafetyValve")
- call jsonfile%get('Equipments.Drilling.Permission_IRIBop',data%Equipments%DrillingConsole%Permission_IRIBop,found)
- if ( .not. found ) call logg(4,"Not found: Permission_IRIBop")
- call jsonfile%get('Equipments.Drilling.IRIBop',data%Equipments%DrillingConsole%IRIBop,found)
- if ( .not. found ) call logg(4,"Not found: IRIBop")
- call jsonfile%get('Equipments.Drilling.LatchPipe',data%Equipments%DrillingConsole%LatchPipe,found)
- if ( .not. found ) call logg(4,"Not found: LatchPipe")
- call jsonfile%get('Equipments.Drilling.UnlatchPipe',data%Equipments%DrillingConsole%UnlatchPipe,found)
- if ( .not. found ) call logg(4,"Not found: UnlatchPipe")
- call jsonfile%get('Equipments.Drilling.Swing',data%Equipments%DrillingConsole%Swing,found)
- if ( .not. found ) call logg(4,"Not found: Swing")
- call jsonfile%get('Equipments.Drilling.FillMouseHole',data%Equipments%DrillingConsole%FillMouseHole,found)
- if ( .not. found ) call logg(4,"Not found: FillMouseHole")
- call jsonfile%get('Equipments.Drilling.Slips',data%Equipments%DrillingConsole%Slips,found)
- if ( .not. found ) call logg(4,"Not found: Slips")
- call jsonfile%get('Equipments.Drilling.BrakeLeverCoefficient',data%Equipments%DrillingConsole%BrakeLeverCoefficient,found)
- if ( .not. found ) call logg(4,"Not found: BrakeLeverCoefficient")
- call jsonfile%get('Equipments.Drilling.HideDrillingBrake',data%Equipments%DrillingConsole%HideDrillingBrake,found)
- if ( .not. found ) call logg(4,"Not found: HideDrillingBrake")
- call jsonfile%get('Equipments.Drilling.ParkingBrakeBtn',data%Equipments%DrillingConsole%ParkingBrakeBtn,found)
- if ( .not. found ) call logg(4,"Not found: ParkingBrakeBtn")
-
- ! call jsonfile%destroy()
-
- ! data%Equipments%DrillingConsole%DWSwitch = -1
- data%Equipments%DrillingConsole%AssignmentSwitch = 1
- ! data%Equipments%DrillingConsole%MP1CPSwitch = -1
- ! data%Equipments%DrillingConsole%MP2Switch = -1
- ! data%Equipments%DrillingConsole%RTSwitch = -1
- end subroutine
-
- subroutine DrillingConsoleToJson(parent)
-
- type(json_value),pointer :: parent
- type(json_core) :: json
- type(json_value),pointer :: p
-
- ! 1. create new node
- call json%create_object(p,'Drilling')
-
- call json%add(p,"ParkingBrakeLed",data%Equipments%DrillingConsole%ParkingBrakeLed)
- call json%add(p,"GEN1LED",data%Equipments%DrillingConsole%GEN1LED)
- call json%add(p,"GEN2LED",data%Equipments%DrillingConsole%GEN2LED)
- call json%add(p,"GEN3LED",data%Equipments%DrillingConsole%GEN3LED)
- call json%add(p,"GEN4LED",data%Equipments%DrillingConsole%GEN4LED)
- call json%add(p,"SCR1LED",data%Equipments%DrillingConsole%SCR1LED)
- call json%add(p,"SCR2LED",data%Equipments%DrillingConsole%SCR2LED)
- call json%add(p,"SCR3LED",data%Equipments%DrillingConsole%SCR3LED)
- call json%add(p,"SCR4LED",data%Equipments%DrillingConsole%SCR4LED)
- call json%add(p,"MP1BLWR",data%Equipments%DrillingConsole%MP1BLWR)
- call json%add(p,"MP2BLWR",data%Equipments%DrillingConsole%MP2BLWR)
- call json%add(p,"DWBLWR",data%Equipments%DrillingConsole%DWBLWR)
- call json%add(p,"RTBLWR",data%Equipments%DrillingConsole%RTBLWR)
- call json%add(p,"PWRLIM",data%Equipments%DrillingConsole%PWRLIM)
- call json%add(p,"PWRLIMMTR",data%Equipments%DrillingConsole%PWRLIMMTR)
- call json%add(p,"RTTorqueLimitGauge",data%Equipments%DrillingConsole%RTTorqueLimitGauge)
- call json%add(p,"AutoDWLED",data%Equipments%DrillingConsole%AutoDWLED)
- call json%add(p,"GEN1BTNLED",data%Equipments%DrillingConsole%GEN1BTNLED)
- call json%add(p,"GEN2BTNLED",data%Equipments%DrillingConsole%GEN2BTNLED)
- call json%add(p,"GEN3BTNLED",data%Equipments%DrillingConsole%GEN3BTNLED)
- call json%add(p,"GEN4BTNLED",data%Equipments%DrillingConsole%GEN4BTNLED)
- call json%add(p,"OpenKellyCockLed",data%Equipments%DrillingConsole%OpenKellyCockLed)
- call json%add(p,"CloseKellyCockLed",data%Equipments%DrillingConsole%CloseKellyCockLed)
- call json%add(p,"OpenSafetyValveLed",data%Equipments%DrillingConsole%OpenSafetyValveLed)
- call json%add(p,"CloseSafetyValveLed",data%Equipments%DrillingConsole%CloseSafetyValveLed)
- call json%add(p,"IRSafetyValveLed",data%Equipments%DrillingConsole%IRSafetyValveLed)
- call json%add(p,"IRIBopLed",data%Equipments%DrillingConsole%IRIBopLed)
- call json%add(p,"LatchPipeLED",data%Equipments%DrillingConsole%LatchPipeLED)
- call json%add(p,"UnlatchPipeLED",data%Equipments%DrillingConsole%UnlatchPipeLED)
- call json%add(p,"SwingLed",data%Equipments%DrillingConsole%SwingLed)
- call json%add(p,"FillMouseHoleLed",data%Equipments%DrillingConsole%FillMouseHoleLed)
- call json%add(p,"MP1CPSwitch",data%Equipments%DrillingConsole%MP1CPSwitch)
- call json%add(p,"MP2Switch",data%Equipments%DrillingConsole%MP2Switch)
- call json%add(p,"DWSwitch",data%Equipments%DrillingConsole%DWSwitch)
- call json%add(p,"RTSwitch",data%Equipments%DrillingConsole%RTSwitch)
-
- call json%add(p,"RTSwitch",data%Equipments%DrillingConsole%RTSwitch)
-
- ! Trottle -------------
- call json%add(p,"MP1Throttle",data%Equipments%DrillingConsole%MP1Throttle)
- call json%add(p,"MP2Throttle",data%Equipments%DrillingConsole%MP2Throttle)
- call json%add(p,"RTThrottle",data%Equipments%DrillingConsole%RTThrottle)
- call json%add(p,"DWThrottle",data%Equipments%DrillingConsole%DWThrottle)
- call json%add(parent,p)
- end subroutine
-
- subroutine SetTongLever(v) bind(C,name="setTongLever")
- use CTongEnum
- use ISO_C_BINDING, only:c_int
- integer(c_int), intent(in) :: v
- if(v == 1) then
- call ButtonPress_Breakout_TongNotification()
- if(print_log) print*, 'BreakoutLeverPress'
- endif
- if(v == -1) then
- call ButtonPress_Makeup_TongNotification()
- if(print_log) print*, 'MakeupLeverPress'
- endif
- if(print_log) print*, 'TongLever=', v
- end subroutine
- end module CDrillingConsole
|