1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153
|
(*
** For writing ATS code
** that translates into Python
*)
(* ****** ****** *)
//
// HX-2014-08:
// prefix for external names
//
#define
ATS_EXTERN_PREFIX "ats2pypre_"
//
(* ****** ****** *)
typedef strchr = string(1)
(* ****** ****** *)
//
fun
strchr_chr : int -> strchr = "mac#%"
//
fun
strchr_ord : strchr -> int = "mac#%"
//
(* ****** ****** *)
//
fun
string_get_at
{n:int}{i:nat | i < n}
(
str: string(n), i: int(i)
) : strchr = "mac#%" // end-of-fun
//
overload [] with string_get_at of 100
//
(* ****** ****** *)
//
fun
string_fset_at
{n:int}
{i:nat | i < n}
(
str: string(n), i0: int(i), c0: strchr
) : string(n) = "mac#%" // end-of-fun
//
(* ****** ****** *)
//
fun
string_substring_beg_end
{n:int}
{i,j:int |
0 <= i; i <= j; j <= n}
(
str: string(n), i0: int(i), j0: int(j)
) : string(j-i) = "mac#%" // end-of-fun
//
//
fun
string_substring_beg_len
{n:int}
{i,len:nat | i + len <= n}
(
str: string(n), i0: int(i), len: int(len)
) : string(len) = "mac#%" // end-of-fun
//
(* ****** ****** *)
//
fun
string_length
{n:int}(string(n)): int(n) = "mac#%"
//
overload length with string_length of 100
//
(* ****** ****** *)
//
fun lt_string_string
: (string, string) -> bool = "mac#%"
fun lte_string_string
: (string, string) -> bool = "mac#%"
fun gt_string_string
: (string, string) -> bool = "mac#%"
fun gte_string_string
: (string, string) -> bool = "mac#%"
//
fun eq_string_string
: (string, string) -> bool = "mac#%"
fun neq_string_string
: (string, string) -> bool = "mac#%"
//
(* ****** ****** *)
//
overload < with lt_string_string of 100
overload <= with lte_string_string of 100
overload > with gt_string_string of 100
overload >= with gte_string_string of 100
//
overload = with eq_string_string of 100
overload != with neq_string_string of 100
overload <> with neq_string_string of 100
//
(* ****** ****** *)
//
fun
compare_string_string:
(string, string) -> intBtwe(~1, 1) = "mac#%"
//
overload
compare with compare_string_string of 100
//
(* ****** ****** *)
//
fun
string_isalnum : string -> bool = "mac#%"
fun
string_isalpha : string -> bool = "mac#%"
fun
string_isdecimal : string -> bool = "mac#%"
//
(* ****** ****** *)
//
fun string_lower(string): string = "mac#%"
fun string_upper(string): string = "mac#%"
//
(* ****** ****** *)
//`
fun
string_append_2
(string, string): string = "mac#%"
//
fun
string_append_3
(
x1: string, x2: string, x3: string
) : string = "mac#%" // end-of-fun
fun
string_append_4
(
x1: string, x2: string, x3: string, x4: string
) : string = "mac#%" // end-of-fun
//
overload + with string_append_2 of 100
//
overload
string_append with string_append_2 of 100
overload
string_append with string_append_3 of 100
overload
string_append with string_append_4 of 100
//
(* ****** ****** *)
(* end of [string.sats] *)
|