|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 |
- module CHoisting
- use SimulationVariables
- use json_module
- implicit none
- public
- contains
-
- subroutine HoistingFromJson(parent)
-
- use json_module,IK =>json_ik
- type(json_value),pointer :: parent
- type(json_core) :: json
- type(json_value),pointer :: p,pitem,pval
- logical::is_found
- integer::i,n_children
- CHARACTER(KIND=JSON_CK, LEN=:), ALLOCATABLE :: val
-
- call json%get(parent,'Hoisting',p)
- call json%get(p,'DriveType',pval)
- call json%get(pval,data%Configuration%Hoisting%DriveType)
- call json%get(p,'TravelingBlockWeight',pval)
- call json%get(pval,data%Configuration%Hoisting%TravelingBlockWeight)
- call json%get(p,'TopDriveWeight',pval)
- call json%get(pval,data%Configuration%Hoisting%TopDriveWeight)
- call json%get(p,'KellyWeight',pval)
- call json%get(pval,data%Configuration%Hoisting%KellyWeight)
- call json%get(p,'NumberOfLine',pval)
- call json%get(pval,data%Configuration%Hoisting%NumberOfLine)
- call json%get(p,'DrillingLineBreakingLoad',pval)
- call json%get(pval,data%Configuration%Hoisting%DrillingLineBreakingLoad)
- end subroutine
-
- subroutine HoistingToJson(parent)
- type(json_value),pointer :: parent
- type(json_core) :: json
- type(json_value),pointer :: p
-
- ! 1. create new node
- call json%create_object(p,'Hoisting')
-
- ! 2. add member of data type to new node
- ! call StringConfigurationToJson(p)
- ! call FormationToJson(p)
- call json%add(p,"DrillingLineBreakingLoad",data%Configuration%Hoisting%DrillingLineBreakingLoad)
- call json%add(p,"DriveType",data%Configuration%Hoisting%DriveType)
- call json%add(p,"KellyWeight",data%Configuration%Hoisting%KellyWeight)
- call json%add(p,"NumberOfLine",data%Configuration%Hoisting%NumberOfLine)
- call json%add(p,"TopDriveWeight",data%Configuration%Hoisting%TopDriveWeight)
- call json%add(p,"TravelingBlockWeight",data%Configuration%Hoisting%TravelingBlockWeight)
- ! 3. add new node to parent
- call json%add(parent,p)
- end subroutine
-
- end module CHoisting
|