KIM API V2
kim_language_name_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_language_name_type, &
41  kim_language_name_from_string, &
42  operator (.eq.), &
43  operator (.ne.), &
44  kim_language_name_string, &
45 
49 
50  kim_language_name_get_number_of_language_names, &
51  kim_language_name_get_language_name
52 
53 
54  type, bind(c) :: kim_language_name_type
55  integer(c_int) :: language_name_id
56  end type kim_language_name_type
57 
58  type(kim_language_name_type), protected, &
59  bind(c, name="KIM_LANGUAGE_NAME_cpp") &
61  type(kim_language_name_type), protected, &
62  bind(c, name="KIM_LANGUAGE_NAME_c") &
64  type(kim_language_name_type), protected, &
65  bind(c, name="KIM_LANGUAGE_NAME_fortran") &
67 
68  interface operator (.eq.)
69  logical function kim_language_name_equal(left, right)
70  use, intrinsic :: iso_c_binding
71  import kim_language_name_type
72  implicit none
73  type(kim_language_name_type), intent(in) :: left
74  type(kim_language_name_type), intent(in) :: right
75  end function kim_language_name_equal
76  end interface operator (.eq.)
77 
78  interface operator (.ne.)
79  logical function kim_language_name_not_equal(left, right)
80  use, intrinsic :: iso_c_binding
81  import kim_language_name_type
82  implicit none
83  type(kim_language_name_type), intent(in) :: left
84  type(kim_language_name_type), intent(in) :: right
85  end function kim_language_name_not_equal
86  end interface operator (.ne.)
87 
88  interface
89  subroutine kim_language_name_from_string(string, language_name)
90  use, intrinsic :: iso_c_binding
91  import kim_language_name_type
92  implicit none
93  character(len=*, kind=c_char), intent(in) :: string
94  type(kim_language_name_type), intent(out) :: language_name
95  end subroutine kim_language_name_from_string
96 
97  subroutine kim_language_name_string(language_name, string)
98  use, intrinsic :: iso_c_binding
99  import kim_language_name_type
100  implicit none
101  type(kim_language_name_type), intent(in), value :: language_name
102  character(len=*, kind=c_char), intent(out) :: string
103  end subroutine kim_language_name_string
104 
105  subroutine kim_language_name_get_number_of_language_names( &
106  number_of_language_names)
107  use, intrinsic :: iso_c_binding
108  implicit none
109  integer(c_int), intent(out) :: number_of_language_names
110  end subroutine kim_language_name_get_number_of_language_names
111 
112  subroutine kim_language_name_get_language_name(index, language_name, ierr)
113  use, intrinsic :: iso_c_binding
114  import kim_language_name_type
115  implicit none
116  integer(c_int), intent(in), value :: index
117  type(kim_language_name_type), intent(out) :: language_name
118  integer(c_int), intent(out) :: ierr
119  end subroutine kim_language_name_get_language_name
120  end interface
121 end module kim_language_name_module
type(kim_language_name_type), public, protected kim_language_name_fortran
type(kim_language_name_type), public, protected kim_language_name_cpp
type(kim_language_name_type), public, protected kim_language_name_c