Simulation Core
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

120 lines
6.5 KiB

  1. # 1 "/mnt/c/Projects/VSIM/SimulationCore2/CSharp/BasicInputs/Bha/CStringConfiguration.f90"
  2. module CStringConfiguration
  3. use CStringConfigurationVariables
  4. use SimulationVariables
  5. use json_module
  6. implicit none
  7. public
  8. contains
  9. subroutine StringConfigurationFromJson(parent)
  10. use json_module,IK =>json_ik
  11. type(json_value),pointer :: parent
  12. type(json_core) :: json
  13. type(json_value),pointer :: p,pitems,pitem,pval,pbit
  14. logical::is_found
  15. type(CStringItem) :: item
  16. integer::i,n_children
  17. CHARACTER(KIND=JSON_CK, LEN=:), ALLOCATABLE :: val
  18. call json%get(parent,'StringConfiguration',p)
  19. call json%get(p,'StringConfigurationItems',pitems)
  20. call json%info(pitems, n_children=n_children)
  21. if (.not. allocated(data%Configuration%StringConfiguration%StringConfigurations) .or. size(data%Configuration%StringConfiguration%StringConfigurations)/=n_children) then
  22. ALLOCATE(data%Configuration%StringConfiguration%StringConfigurations(n_children))
  23. endif
  24. do i=1,n_children
  25. call json%get_child(pitems, i, pitem, found=is_found)
  26. call json%get(pitem,"ComponentType",pval)
  27. call json%get(pval,data%Configuration%StringConfiguration%StringConfigurations(i)%ComponentType)
  28. call json%get(pitem,"NumberOfJoint",pval)
  29. call json%get(pval,data%Configuration%StringConfiguration%StringConfigurations(i)%NumberOfJoint)
  30. call json%get(pitem,"LengthPerJoint",pval)
  31. call json%get(pval,data%Configuration%StringConfiguration%StringConfigurations(i)%LengthPerJoint)
  32. call json%get(pitem,"NominalOd",pval)
  33. call json%get(pval,data%Configuration%StringConfiguration%StringConfigurations(i)%NominalOd)
  34. call json%get(pitem,"NominalId",pval)
  35. call json%get(pval,data%Configuration%StringConfiguration%StringConfigurations(i)%NominalId)
  36. call json%get(pitem,"WeightPerLength",pval)
  37. call json%get(pval,data%Configuration%StringConfiguration%StringConfigurations(i)%WeightPerLength)
  38. call json%get(pitem,"ComponentLength",pval)
  39. call json%get(pval,data%Configuration%StringConfiguration%StringConfigurations(i)%ComponentLength)
  40. call json%get(pitem,"NominalToolJointOd",pval)
  41. call json%get(pval,data%Configuration%StringConfiguration%StringConfigurations(i)%NominalToolJointOd)
  42. call json%get(pitem,"Grade",pval)
  43. call json%get(pval,val)
  44. data%Configuration%StringConfiguration%StringConfigurations(i)%Grade = val
  45. end do
  46. call json%get(p,'BitDefenition',pbit)
  47. call json%get(pbit,'BitType',pval)
  48. call json%get(pval,data%Configuration%StringConfiguration%BitDefinition%BitType)
  49. call json%get(pbit,'BitSize',pval)
  50. call json%get(pval,data%Configuration%StringConfiguration%BitDefinition%BitSize)
  51. call json%get(pbit,'BitCodeHundreds',pval)
  52. call json%get(pval,data%Configuration%StringConfiguration%BitDefinition%BitCodeHundreds)
  53. call json%get(pbit,'BitCodeTens',pval)
  54. call json%get(pval,data%Configuration%StringConfiguration%BitDefinition%BitCodeTens)
  55. call json%get(pbit,'BitCodeOnes',pval)
  56. call json%get(pval,data%Configuration%StringConfiguration%BitDefinition%BitCodeOnes)
  57. call json%get(pbit,'BitNozzleSize',pval)
  58. call json%get(pval,data%Configuration%StringConfiguration%BitDefinition%BitNozzleSize)
  59. call json%get(pbit,'BitLength',pval)
  60. call json%get(pval,data%Configuration%StringConfiguration%BitDefinition%BitLength)
  61. call json%get(pbit,'BitWeightPerLength',pval)
  62. call json%get(pval,data%Configuration%StringConfiguration%BitDefinition%BitWeightPerLength)
  63. call json%get(pbit,'BitNozzleNo',pval)
  64. call json%get(pval,data%Configuration%StringConfiguration%BitDefinition%BitNozzleNo)
  65. call json%get(pbit,'FloatValve',pval)
  66. call json%get(pval,data%Configuration%StringConfiguration%BitDefinition%FloatValve)
  67. end subroutine
  68. subroutine StringConfigurationToJson(parent)
  69. type(json_value),pointer :: parent
  70. type(json_core) :: json
  71. type(json_value),pointer :: pitems,pitem,pbit,p
  72. integer:: i,n
  73. ! 1. create new node
  74. call json%create_object(p,'StringConfiguration')
  75. call json%create_array(pitems,'StringConfigurationItems')
  76. ! 2. add member of data type to new node
  77. n = data%Configuration%StringConfiguration%StringConfigurationCount
  78. do i=1,n
  79. call json%create_object(pitem,'')
  80. call json%add(pitem,"ComponentLength",data%Configuration%StringConfiguration%StringConfigurations(i)%ComponentLength)
  81. call json%add(pitem,"ComponentType",data%Configuration%StringConfiguration%StringConfigurations(i)%ComponentType)
  82. call json%add(pitem,"Grade",data%Configuration%StringConfiguration%StringConfigurations(i)%Grade)
  83. call json%add(pitem,"LengthPerJoint",data%Configuration%StringConfiguration%StringConfigurations(i)%LengthPerJoint)
  84. call json%add(pitem,"NominalId",data%Configuration%StringConfiguration%StringConfigurations(i)%NominalId)
  85. call json%add(pitem,"NominalOd",data%Configuration%StringConfiguration%StringConfigurations(i)%NominalOd)
  86. call json%add(pitem,"NominalToolJointOd",data%Configuration%StringConfiguration%StringConfigurations(i)%NominalToolJointOd)
  87. call json%add(pitem,"NumberOfJoint",data%Configuration%StringConfiguration%StringConfigurations(i)%NumberOfJoint)
  88. call json%add(pitem,"WeightPerLength",data%Configuration%StringConfiguration%StringConfigurations(i)%WeightPerLength)
  89. call json%add(pitems,pitem)
  90. end do
  91. call json%create_object(pbit,"BitDefenition")
  92. call json%add(pbit,"BitCodeHundreds",data%Configuration%StringConfiguration%BitDefinition%BitCodeHundreds)
  93. call json%add(pbit,"BitCodeOnes",data%Configuration%StringConfiguration%BitDefinition%BitCodeOnes)
  94. call json%add(pbit,"BitCodeTens",data%Configuration%StringConfiguration%BitDefinition%BitCodeTens)
  95. call json%add(pbit,"BitLength",data%Configuration%StringConfiguration%BitDefinition%BitLength)
  96. call json%add(pbit,"BitNozzleNo",data%Configuration%StringConfiguration%BitDefinition%BitNozzleNo)
  97. call json%add(pbit,"BitNozzleSize",data%Configuration%StringConfiguration%BitDefinition%BitNozzleSize)
  98. call json%add(pbit,"BitSize",data%Configuration%StringConfiguration%BitDefinition%BitSize)
  99. call json%add(pbit,"BitType",data%Configuration%StringConfiguration%BitDefinition%BitType)
  100. call json%add(pbit,"BitWeightPerLength",data%Configuration%StringConfiguration%BitDefinition%BitWeightPerLength)
  101. call json%add(pbit,"FloatValve",data%Configuration%StringConfiguration%BitDefinition%FloatValve)
  102. ! call json%add(p,"StringConfigurationCount",dat%Configuration%StringConfiguration%StringConfigurationCount)
  103. ! 3. add new node to parent
  104. call json%add(p,pitems)
  105. call json%add(p,pbit)
  106. call json%add(parent,p)
  107. end subroutine
  108. end module CStringConfiguration