KIM API V2
kim_length_unit_module.f90
Go to the documentation of this file.
1 !
2 ! CDDL HEADER START
3 !
4 ! The contents of this file are subject to the terms of the Common Development
5 ! and Distribution License Version 1.0 (the "License").
6 !
7 ! You can obtain a copy of the license at
8 ! http://www.opensource.org/licenses/CDDL-1.0. See the License for the
9 ! specific language governing permissions and limitations under the License.
10 !
11 ! When distributing Covered Code, include this CDDL HEADER in each file and
12 ! include the License file in a prominent location with the name LICENSE.CDDL.
13 ! If applicable, add the following below this CDDL HEADER, with the fields
14 ! enclosed by brackets "[]" replaced with your own identifying information:
15 !
16 ! Portions Copyright (c) [yyyy] [name of copyright owner]. All rights reserved.
17 !
18 ! CDDL HEADER END
19 !
20 
21 !
22 ! Copyright (c) 2016--2018, Regents of the University of Minnesota.
23 ! All rights reserved.
24 !
25 ! Contributors:
26 ! Ryan S. Elliott
27 !
28 
29 !
30 ! Release: This file is part of the kim-api-v2.0.0-beta.0 package.
31 !
32 
33 
35  use, intrinsic :: iso_c_binding
36  implicit none
37  private
38 
39  public &
40  kim_length_unit_type, &
41  kim_length_unit_from_string, &
42  operator (.eq.), &
43  operator (.ne.), &
44  kim_length_unit_string, &
45 
52 
53  kim_length_unit_get_number_of_length_units, &
54  kim_length_unit_get_length_unit
55 
56 
57  type, bind(c) :: kim_length_unit_type
58  integer(c_int) length_unit_id
59  end type kim_length_unit_type
60 
61  type(kim_length_unit_type), protected, &
62  bind(c, name="KIM_LENGTH_UNIT_unused") &
64  type(kim_length_unit_type), protected, &
65  bind(c, name="KIM_LENGTH_UNIT_A") &
67  type(kim_length_unit_type), protected, &
68  bind(c, name="KIM_LENGTH_UNIT_Bhor") &
70  type(kim_length_unit_type), protected, &
71  bind(c, name="KIM_LENGTH_UNIT_cm") &
73  type(kim_length_unit_type), protected, &
74  bind(c, name="KIM_LENGTH_UNIT_m") &
76  type(kim_length_unit_type), protected, &
77  bind(c, name="KIM_LENGTH_UNIT_nm") &
79 
80  interface operator (.eq.)
81  logical function kim_length_unit_equal(left, right)
82  use, intrinsic :: iso_c_binding
83  import kim_length_unit_type
84  implicit none
85  type(kim_length_unit_type), intent(in) :: left
86  type(kim_length_unit_type), intent(in) :: right
87  end function kim_length_unit_equal
88  end interface operator (.eq.)
89 
90  interface operator (.ne.)
91  logical function kim_length_unit_not_equal(left, right)
92  use, intrinsic :: iso_c_binding
93  import kim_length_unit_type
94  implicit none
95  type(kim_length_unit_type), intent(in) :: left
96  type(kim_length_unit_type), intent(in) :: right
97  end function kim_length_unit_not_equal
98  end interface operator (.ne.)
99 
100  interface
101  subroutine kim_length_unit_from_string(string, length_unit)
102  use, intrinsic :: iso_c_binding
103  import kim_length_unit_type
104  implicit none
105  character(len=*, kind=c_char), intent(in) :: string
106  type(kim_length_unit_type), intent(out) :: length_unit
107  end subroutine kim_length_unit_from_string
108 
109  subroutine kim_length_unit_string(length_unit, string)
110  use, intrinsic :: iso_c_binding
111  import kim_length_unit_type
112  implicit none
113  type(kim_length_unit_type), intent(in), value :: length_unit
114  character(len=*, kind=c_char), intent(out) :: string
115  end subroutine kim_length_unit_string
116 
117  subroutine kim_length_unit_get_number_of_length_units( &
118  number_of_length_units)
119  use, intrinsic :: iso_c_binding
120  implicit none
121  integer(c_int), intent(out) :: number_of_length_units
122  end subroutine kim_length_unit_get_number_of_length_units
123 
124  subroutine kim_length_unit_get_length_unit(index, length_unit, ierr)
125  use, intrinsic :: iso_c_binding
126  import kim_length_unit_type
127  implicit none
128  integer(c_int), intent(in), value :: index
129  type(kim_length_unit_type), intent(out) :: length_unit
130  integer(c_int), intent(out) :: ierr
131  end subroutine kim_length_unit_get_length_unit
132  end interface
133 end module kim_length_unit_module
type(kim_length_unit_type), public, protected kim_length_unit_nm
type(kim_length_unit_type), public, protected kim_length_unit_cm
type(kim_length_unit_type), public, protected kim_length_unit_a
type(kim_length_unit_type), public, protected kim_length_unit_unused
type(kim_length_unit_type), public, protected kim_length_unit_bohr
type(kim_length_unit_type), public, protected kim_length_unit_m