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.

CSwingOffPermissionVariables.f90 1.4 KiB

2 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. module CSwingOffPermissionVariables
  2. use CVoidEventHandlerCollection
  3. implicit none
  4. logical :: SwingOffPermission = .false.
  5. public
  6. type(VoidEventHandlerCollection) :: OnSwingOffPermissionChange
  7. private :: SwingOffPermission
  8. contains
  9. subroutine Set_SwingOffPermission(v)
  10. implicit none
  11. logical , intent(in) :: v
  12. #ifdef ExcludeExtraChanges
  13. if(SwingOffPermission == v) return
  14. #endif
  15. SwingOffPermission = v
  16. #ifdef deb
  17. print*, 'SwingOffPermission=', SwingOffPermission
  18. #endif
  19. call OnSwingOffPermissionChange%RunAll()
  20. end subroutine
  21. logical function Get_SwingOffPermission()
  22. implicit none
  23. Get_SwingOffPermission = SwingOffPermission
  24. end function
  25. subroutine Set_SwingOffPermission_WN(v)
  26. !DEC$ ATTRIBUTES DLLEXPORT :: Set_SwingOffPermission_WN
  27. !DEC$ ATTRIBUTES ALIAS: 'Set_SwingOffPermission_WN' :: Set_SwingOffPermission_WN
  28. implicit none
  29. logical , intent(in) :: v
  30. call Set_SwingOffPermission(v)
  31. end subroutine
  32. logical function Get_SwingOffPermission_WN()
  33. !DEC$ ATTRIBUTES DLLEXPORT :: Get_SwingOffPermission_WN
  34. !DEC$ ATTRIBUTES ALIAS: 'Get_SwingOffPermission_WN' :: Get_SwingOffPermission_WN
  35. implicit none
  36. Get_SwingOffPermission_WN = SwingOffPermission
  37. end function
  38. end module CSwingOffPermissionVariables