all: introduce `isize` and `usize` (#11437)

pull/11441/head
Enzo 2021-09-08 04:53:39 +02:00 committed by GitHub
parent 577fedfce1
commit cc8ee5fb84
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
13 changed files with 213 additions and 130 deletions

View File

@ -1,3 +1,7 @@
-## V 0.2.5
-*Not yet released, changelog is not full*
- Introduce `isize` and `usize` types, deprecate `size_t` in favor of `usize`
-## V 0.2.4 -## V 0.2.4
-*Not yet released, changelog is not full* -*Not yet released, changelog is not full*
- Bare metal support. Vinix OS kernel is now being developed in V. - Bare metal support. Vinix OS kernel is now being developed in V.

View File

@ -419,6 +419,8 @@ rune // represents a Unicode code point
f32 f64 f32 f64
isize, usize // platform-dependent, the size is how many bytes it takes to reference any location in memory
voidptr, size_t // these are mostly used for C interoperability voidptr, size_t // these are mostly used for C interoperability
any // similar to C's void* and Go's interface{} any // similar to C's void* and Go's interface{}

View File

@ -15,6 +15,15 @@ pub fn ptr_str(ptr voidptr) string {
return buf1 return buf1
} }
// TODO uncomment to have string representation of i/usize
// pub fn (x isize) str() string {
// return u64(x).str()
// }
//
// pub fn (x usize) str() string {
// return u64(x).str()
// }
pub fn (x size_t) str() string { pub fn (x size_t) str() string {
return u64(x).str() return u64(x).str()
} }

View File

@ -1,26 +1,38 @@
module orm module orm
import time import time
import v.ast
pub const ( pub const (
num64 = [8, 12] num64 = [ast.i64_type_idx, ast.u64_type_idx]
nums = [5, 6, 7, 9, 10, 11, 16] nums = [
float = [13, 14] ast.i8_type_idx,
string = 18 ast.i16_type_idx,
ast.int_type_idx,
ast.byte_type_idx,
ast.u16_type_idx,
ast.u32_type_idx,
ast.bool_type_idx,
]
float = [
ast.f32_type_idx,
ast.f64_type_idx,
]
string = ast.string_type_idx
time = -2 time = -2
type_idx = { type_idx = {
'i8': 5 'i8': ast.i8_type_idx
'i16': 6 'i16': ast.i16_type_idx
'int': 7 'int': ast.int_type_idx
'i64': 8 'i64': ast.i64_type_idx
'byte': 9 'byte': ast.byte_type_idx
'u16': 10 'u16': ast.u16_type_idx
'u32': 11 'u32': ast.u32_type_idx
'u64': 12 'u64': ast.u64_type_idx
'f32': 13 'f32': ast.f32_type_idx
'f64': 14 'f64': ast.f64_type_idx
'bool': 16 'bool': ast.bool_type_idx
'string': 18 'string': ast.string_type_idx
} }
string_max_len = 2048 string_max_len = 2048
) )

View File

@ -1,4 +1,5 @@
import orm import orm
import v.ast
fn test_orm_stmt_gen_update() { fn test_orm_stmt_gen_update() {
query := orm.orm_stmt_gen('Test', "'", .update, true, '?', 0, orm.QueryData{ query := orm.orm_stmt_gen('Test', "'", .update, true, '?', 0, orm.QueryData{
@ -120,7 +121,7 @@ fn test_orm_table_gen() {
query := orm.orm_table_gen('test_table', "'", true, 0, [ query := orm.orm_table_gen('test_table', "'", true, 0, [
orm.TableField{ orm.TableField{
name: 'id' name: 'id'
typ: 7 typ: ast.int_type_idx
default_val: '10' default_val: '10'
attrs: [ attrs: [
StructAttribute{ StructAttribute{
@ -136,11 +137,11 @@ fn test_orm_table_gen() {
}, },
orm.TableField{ orm.TableField{
name: 'test' name: 'test'
typ: 18 typ: ast.string_type_idx
}, },
orm.TableField{ orm.TableField{
name: 'abc' name: 'abc'
typ: 8 typ: ast.i64_type_idx
default_val: '6754' default_val: '6754'
}, },
], sql_type_from_v, false) or { panic(err) } ], sql_type_from_v, false) or { panic(err) }
@ -149,7 +150,7 @@ fn test_orm_table_gen() {
alt_query := orm.orm_table_gen('test_table', "'", true, 0, [ alt_query := orm.orm_table_gen('test_table', "'", true, 0, [
orm.TableField{ orm.TableField{
name: 'id' name: 'id'
typ: 7 typ: ast.int_type_idx
default_val: '10' default_val: '10'
attrs: [ attrs: [
StructAttribute{ StructAttribute{
@ -165,11 +166,11 @@ fn test_orm_table_gen() {
}, },
orm.TableField{ orm.TableField{
name: 'test' name: 'test'
typ: 18 typ: ast.string_type_idx
}, },
orm.TableField{ orm.TableField{
name: 'abc' name: 'abc'
typ: 8 typ: ast.i64_type_idx
default_val: '6754' default_val: '6754'
}, },
], sql_type_from_v, true) or { panic(err) } ], sql_type_from_v, true) or { panic(err) }
@ -178,7 +179,7 @@ fn test_orm_table_gen() {
unique_query := orm.orm_table_gen('test_table', "'", true, 0, [ unique_query := orm.orm_table_gen('test_table', "'", true, 0, [
orm.TableField{ orm.TableField{
name: 'id' name: 'id'
typ: 7 typ: ast.int_type_idx
default_val: '10' default_val: '10'
attrs: [ attrs: [
StructAttribute{ StructAttribute{
@ -194,7 +195,7 @@ fn test_orm_table_gen() {
}, },
orm.TableField{ orm.TableField{
name: 'test' name: 'test'
typ: 18 typ: ast.string_type_idx
attrs: [ attrs: [
StructAttribute{ StructAttribute{
name: 'unique' name: 'unique'
@ -203,7 +204,7 @@ fn test_orm_table_gen() {
}, },
orm.TableField{ orm.TableField{
name: 'abc' name: 'abc'
typ: 8 typ: ast.i64_type_idx
default_val: '6754' default_val: '6754'
}, },
], sql_type_from_v, false) or { panic(err) } ], sql_type_from_v, false) or { panic(err) }
@ -212,7 +213,7 @@ fn test_orm_table_gen() {
mult_unique_query := orm.orm_table_gen('test_table', "'", true, 0, [ mult_unique_query := orm.orm_table_gen('test_table', "'", true, 0, [
orm.TableField{ orm.TableField{
name: 'id' name: 'id'
typ: 7 typ: ast.int_type_idx
default_val: '10' default_val: '10'
attrs: [ attrs: [
StructAttribute{ StructAttribute{
@ -228,7 +229,7 @@ fn test_orm_table_gen() {
}, },
orm.TableField{ orm.TableField{
name: 'test' name: 'test'
typ: 18 typ: ast.string_type_idx
attrs: [ attrs: [
StructAttribute{ StructAttribute{
name: 'unique' name: 'unique'
@ -240,7 +241,7 @@ fn test_orm_table_gen() {
}, },
orm.TableField{ orm.TableField{
name: 'abc' name: 'abc'
typ: 8 typ: ast.i64_type_idx
default_val: '6754' default_val: '6754'
attrs: [ attrs: [
StructAttribute{ StructAttribute{

View File

@ -1,5 +1,6 @@
import orm import orm
import sqlite import sqlite
import v.ast
fn test_sqlite_orm() { fn test_sqlite_orm() {
sdb := sqlite.connect(':memory:') or { panic(err) } sdb := sqlite.connect(':memory:') or { panic(err) }
@ -7,7 +8,7 @@ fn test_sqlite_orm() {
db.create('Test', [ db.create('Test', [
orm.TableField{ orm.TableField{
name: 'id' name: 'id'
typ: 7 typ: ast.int_type_idx
attrs: [ attrs: [
StructAttribute{ StructAttribute{
name: 'primary' name: 'primary'
@ -22,12 +23,12 @@ fn test_sqlite_orm() {
}, },
orm.TableField{ orm.TableField{
name: 'name' name: 'name'
typ: 18 typ: ast.string_type_idx
attrs: [] attrs: []
}, },
orm.TableField{ orm.TableField{
name: 'age' name: 'age'
typ: 8 typ: ast.i64_type_idx
}, },
]) or { panic(err) } ]) or { panic(err) }
@ -40,11 +41,11 @@ fn test_sqlite_orm() {
table: 'Test' table: 'Test'
has_where: true has_where: true
fields: ['id', 'name', 'age'] fields: ['id', 'name', 'age']
types: [7, 18, 8] types: [ast.int_type_idx, ast.string_type_idx, ast.i64_type_idx]
}, orm.QueryData{}, orm.QueryData{ }, orm.QueryData{}, orm.QueryData{
fields: ['name', 'age'] fields: ['name', 'age']
data: [orm.Primitive('Louis'), i64(100)] data: [orm.Primitive('Louis'), i64(100)]
types: [18, 8] types: [ast.string_type_idx, ast.i64_type_idx]
is_and: [true, true] is_and: [true, true]
kinds: [.eq, .eq] kinds: [.eq, .eq]
}) or { panic(err) } }) or { panic(err) }

View File

@ -378,40 +378,45 @@ pub const (
i16_type_idx = 6 i16_type_idx = 6
int_type_idx = 7 int_type_idx = 7
i64_type_idx = 8 i64_type_idx = 8
byte_type_idx = 9 isize_type_idx = 9
u16_type_idx = 10 byte_type_idx = 10
u32_type_idx = 11 u16_type_idx = 11
u64_type_idx = 12 u32_type_idx = 12
f32_type_idx = 13 u64_type_idx = 13
f64_type_idx = 14 usize_type_idx = 14
char_type_idx = 15 f32_type_idx = 15
bool_type_idx = 16 f64_type_idx = 16
none_type_idx = 17 char_type_idx = 17
string_type_idx = 18 bool_type_idx = 18
rune_type_idx = 19 none_type_idx = 19
array_type_idx = 20 string_type_idx = 20
map_type_idx = 21 rune_type_idx = 21
chan_type_idx = 22 array_type_idx = 22
size_t_type_idx = 23 map_type_idx = 23
any_type_idx = 24 chan_type_idx = 24
float_literal_type_idx = 25 size_t_type_idx = 25
int_literal_type_idx = 26 any_type_idx = 26
thread_type_idx = 27 float_literal_type_idx = 27
error_type_idx = 28 int_literal_type_idx = 28
u8_type_idx = 29 thread_type_idx = 29
error_type_idx = 30
u8_type_idx = 31
) )
pub const ( pub const (
integer_type_idxs = [i8_type_idx, i16_type_idx, int_type_idx, i64_type_idx, integer_type_idxs = [i8_type_idx, i16_type_idx, int_type_idx, i64_type_idx,
byte_type_idx, u8_type_idx, u16_type_idx, u32_type_idx, u64_type_idx, int_literal_type_idx, byte_type_idx, u8_type_idx, u16_type_idx, u32_type_idx, u64_type_idx, isize_type_idx,
rune_type_idx, usize_type_idx, int_literal_type_idx, rune_type_idx]
signed_integer_type_idxs = [i8_type_idx, i16_type_idx, int_type_idx, i64_type_idx,
isize_type_idx,
]
unsigned_integer_type_idxs = [byte_type_idx, u16_type_idx, u32_type_idx, u64_type_idx,
usize_type_idx,
] ]
signed_integer_type_idxs = [i8_type_idx, i16_type_idx, int_type_idx, i64_type_idx]
unsigned_integer_type_idxs = [byte_type_idx, u16_type_idx, u32_type_idx, u64_type_idx]
float_type_idxs = [f32_type_idx, f64_type_idx, float_literal_type_idx] float_type_idxs = [f32_type_idx, f64_type_idx, float_literal_type_idx]
number_type_idxs = [i8_type_idx, i16_type_idx, int_type_idx, i64_type_idx, number_type_idxs = [i8_type_idx, i16_type_idx, int_type_idx, i64_type_idx,
byte_type_idx, u16_type_idx, u32_type_idx, u64_type_idx, f32_type_idx, f64_type_idx, byte_type_idx, u16_type_idx, u32_type_idx, u64_type_idx, isize_type_idx, usize_type_idx,
int_literal_type_idx, float_literal_type_idx, rune_type_idx] f32_type_idx, f64_type_idx, int_literal_type_idx, float_literal_type_idx, rune_type_idx]
pointer_type_idxs = [voidptr_type_idx, byteptr_type_idx, charptr_type_idx] pointer_type_idxs = [voidptr_type_idx, byteptr_type_idx, charptr_type_idx]
string_type_idxs = [string_type_idx] string_type_idxs = [string_type_idx]
) )
@ -426,11 +431,13 @@ pub const (
int_type = new_type(int_type_idx) int_type = new_type(int_type_idx)
i16_type = new_type(i16_type_idx) i16_type = new_type(i16_type_idx)
i64_type = new_type(i64_type_idx) i64_type = new_type(i64_type_idx)
isize_type = new_type(isize_type_idx)
byte_type = new_type(byte_type_idx) byte_type = new_type(byte_type_idx)
u8_type = new_type(u8_type_idx) u8_type = new_type(u8_type_idx)
u16_type = new_type(u16_type_idx) u16_type = new_type(u16_type_idx)
u32_type = new_type(u32_type_idx) u32_type = new_type(u32_type_idx)
u64_type = new_type(u64_type_idx) u64_type = new_type(u64_type_idx)
usize_type = new_type(usize_type_idx)
f32_type = new_type(f32_type_idx) f32_type = new_type(f32_type_idx)
f64_type = new_type(f64_type_idx) f64_type = new_type(f64_type_idx)
char_type = new_type(char_type_idx) char_type = new_type(char_type_idx)
@ -498,11 +505,13 @@ pub enum Kind {
i16 i16
int int
i64 i64
isize
byte byte
u8 u8
u16 u16
u32 u32
u64 u64
usize
f32 f32
f64 f64
char char
@ -632,10 +641,12 @@ pub fn (mut t Table) register_builtin_type_symbols() {
t.register_type_symbol(kind: .i16, name: 'i16', cname: 'i16', mod: 'builtin') t.register_type_symbol(kind: .i16, name: 'i16', cname: 'i16', mod: 'builtin')
t.register_type_symbol(kind: .int, name: 'int', cname: 'int', mod: 'builtin') t.register_type_symbol(kind: .int, name: 'int', cname: 'int', mod: 'builtin')
t.register_type_symbol(kind: .i64, name: 'i64', cname: 'i64', mod: 'builtin') t.register_type_symbol(kind: .i64, name: 'i64', cname: 'i64', mod: 'builtin')
t.register_type_symbol(kind: .isize, name: 'isize', cname: 'isize', mod: 'builtin')
t.register_type_symbol(kind: .byte, name: 'byte', cname: 'byte', mod: 'builtin') t.register_type_symbol(kind: .byte, name: 'byte', cname: 'byte', mod: 'builtin')
t.register_type_symbol(kind: .u16, name: 'u16', cname: 'u16', mod: 'builtin') t.register_type_symbol(kind: .u16, name: 'u16', cname: 'u16', mod: 'builtin')
t.register_type_symbol(kind: .u32, name: 'u32', cname: 'u32', mod: 'builtin') t.register_type_symbol(kind: .u32, name: 'u32', cname: 'u32', mod: 'builtin')
t.register_type_symbol(kind: .u64, name: 'u64', cname: 'u64', mod: 'builtin') t.register_type_symbol(kind: .u64, name: 'u64', cname: 'u64', mod: 'builtin')
t.register_type_symbol(kind: .usize, name: 'usize', cname: 'usize', mod: 'builtin')
t.register_type_symbol(kind: .f32, name: 'f32', cname: 'f32', mod: 'builtin') t.register_type_symbol(kind: .f32, name: 'f32', cname: 'f32', mod: 'builtin')
t.register_type_symbol(kind: .f64, name: 'f64', cname: 'f64', mod: 'builtin') t.register_type_symbol(kind: .f64, name: 'f64', cname: 'f64', mod: 'builtin')
t.register_type_symbol(kind: .char, name: 'char', cname: 'char', mod: 'builtin') t.register_type_symbol(kind: .char, name: 'char', cname: 'char', mod: 'builtin')
@ -680,7 +691,9 @@ pub fn (t &TypeSymbol) is_pointer() bool {
[inline] [inline]
pub fn (t &TypeSymbol) is_int() bool { pub fn (t &TypeSymbol) is_int() bool {
res := t.kind in [.i8, .i16, .int, .i64, .byte, .u16, .u32, .u64, .int_literal, .rune] res := t.kind in [.i8, .i16, .int, .i64, .isize, .byte, .u16, .u32, .u64, .usize, .int_literal,
.rune,
]
if !res && t.kind == .alias { if !res && t.kind == .alias {
return (t.info as Alias).parent_type.is_number() return (t.info as Alias).parent_type.is_number()
} }
@ -725,11 +738,13 @@ pub fn (k Kind) str() string {
.i8 { 'i8' } .i8 { 'i8' }
.i16 { 'i16' } .i16 { 'i16' }
.i64 { 'i64' } .i64 { 'i64' }
.isize { 'isize' }
.byte { 'byte' } .byte { 'byte' }
.u8 { 'u8' } .u8 { 'u8' }
.u16 { 'u16' } .u16 { 'u16' }
.u32 { 'u32' } .u32 { 'u32' }
.u64 { 'u64' } .u64 { 'u64' }
.usize { 'usize' }
.int_literal { 'int_literal' } .int_literal { 'int_literal' }
.f32 { 'f32' } .f32 { 'f32' }
.f64 { 'f64' } .f64 { 'f64' }
@ -927,16 +942,16 @@ pub fn (t &Table) type_to_str_using_aliases(typ Type, import_aliases map[string]
.int_literal, .float_literal { .int_literal, .float_literal {
res = sym.name res = sym.name
} }
.i8, .i16, .int, .i64, .byte, .u8, .u16, .u32, .u64, .f32, .f64, .char, .rune, .string, .byteptr {
.bool, .none_, .byteptr, .voidptr, .charptr {
// primitive types
if sym.kind == .byteptr {
res = '&byte' res = '&byte'
} else if sym.kind == .charptr {
res = '&char'
} else {
res = sym.kind.str()
} }
.charptr {
res = '&char'
}
.i8, .i16, .int, .i64, .isize, .byte, .u8, .u16, .u32, .u64, .usize, .f32, .f64, .char,
.rune, .string, .bool, .none_, .voidptr {
// primitive types
res = sym.kind.str()
} }
.array { .array {
if typ == ast.array_type { if typ == ast.array_type {

View File

@ -254,7 +254,7 @@ fn (c &Checker) promote_num(left_type ast.Type, right_type ast.Type) ast.Type {
} else if idx_lo >= ast.byte_type_idx { // both operands are unsigned } else if idx_lo >= ast.byte_type_idx { // both operands are unsigned
return type_hi return type_hi
} else if idx_lo >= ast.i8_type_idx } else if idx_lo >= ast.i8_type_idx
&& (idx_hi <= ast.i64_type_idx || idx_hi == ast.rune_type_idx) { // both signed && (idx_hi <= ast.isize_type_idx || idx_hi == ast.rune_type_idx) { // both signed
return if idx_lo == ast.i64_type_idx { type_lo } else { type_hi } return if idx_lo == ast.i64_type_idx { type_lo } else { type_hi }
} else if idx_hi - idx_lo < (ast.byte_type_idx - ast.i8_type_idx) { } else if idx_hi - idx_lo < (ast.byte_type_idx - ast.i8_type_idx) {
return type_lo // conversion unsigned -> signed if signed type is larger return type_lo // conversion unsigned -> signed if signed type is larger

View File

@ -416,7 +416,8 @@ pub fn (mut g Gen) init() {
#endif' #endif'
g.cheaders.writeln(tcc_undef_has_include) g.cheaders.writeln(tcc_undef_has_include)
g.includes.writeln(tcc_undef_has_include) g.includes.writeln(tcc_undef_has_include)
g.cheaders.writeln(get_guarded_include_text('<inttypes.h>', 'The C compiler can not find <inttypes.h> . Please install build-essentials')) // int64_t etc g.cheaders.writeln(get_guarded_include_text('<inttypes.h>', 'The C compiler can not find <inttypes.h>. Please install build-essentials')) // int64_t etc
g.cheaders.writeln(get_guarded_include_text('<stddef.h>', 'The C compiler can not find <stddef.h>. Please install build-essentials')) // size_t, ptrdiff_t
g.cheaders.writeln(c_builtin_types) g.cheaders.writeln(c_builtin_types)
if g.pref.is_bare { if g.pref.is_bare {
g.cheaders.writeln(c_bare_headers) g.cheaders.writeln(c_bare_headers)

View File

@ -512,6 +512,8 @@ typedef uint8_t u8;
typedef uint16_t u16; typedef uint16_t u16;
typedef uint8_t byte; typedef uint8_t byte;
typedef uint32_t rune; typedef uint32_t rune;
typedef size_t usize;
typedef ptrdiff_t isize;
typedef float f32; typedef float f32;
typedef double f64; typedef double f64;
typedef int64_t int_literal; typedef int64_t int_literal;

View File

@ -132,8 +132,8 @@ pub fn (mut g JsGen) typ(t ast.Type) string {
.byteptr, .charptr { .byteptr, .charptr {
styp = '${g.sym_to_js_typ(sym)}' styp = '${g.sym_to_js_typ(sym)}'
} }
.i8, .i16, .int, .i64, .byte, .u8, .u16, .u32, .u64, .f32, .f64, .int_literal, .i8, .i16, .int, .i64, .isize, .byte, .u8, .u16, .u32, .u64, .usize, .f32, .f64,
.float_literal, .size_t { .int_literal, .float_literal, .size_t {
styp = '${g.sym_to_js_typ(sym)}' styp = '${g.sym_to_js_typ(sym)}'
} }
.bool { .bool {

View File

@ -54,52 +54,52 @@ pub fn mark_used(mut table ast.Table, pref &pref.Preferences, ast_files []&ast.F
'4.vstring_with_len', '4.vstring_with_len',
'4.vstring_literal', '4.vstring_literal',
// byte. methods // byte. methods
'9.str_escaped', '10.str_escaped',
// string. methods // string. methods
'18.add', '20.add',
'18.trim_space', '20.trim_space',
'18.repeat', '20.repeat',
'18.replace', '20.replace',
'18.clone', '20.clone',
'18.clone_static', '20.clone_static',
'18.trim', '20.trim',
'18.substr', '20.substr',
'18.at', '20.at',
'18.at_with_check', '20.at_with_check',
'18.index_kmp', '20.index_kmp',
// string. ==, !=, etc... // string. ==, !=, etc...
'18.eq', '20.eq',
'18.ne', '20.ne',
'18.lt', '20.lt',
'18.gt', '20.gt',
'18.le', '20.le',
'18.ge', '20.ge',
'fast_string_eq', 'fast_string_eq',
// other array methods // other array methods
'20.get', '22.get',
'20.set', '22.set',
'20.get_unsafe', '22.get_unsafe',
'20.set_unsafe', '22.set_unsafe',
'20.get_with_check' /* used for `x := a[i] or {}` */, '22.get_with_check' /* used for `x := a[i] or {}` */,
'20.clone_static_to_depth', '22.clone_static_to_depth',
'20.clone_to_depth', '22.clone_to_depth',
'20.first', '22.first',
'20.last', '22.last',
'20.pointers' /* TODO: handle generic methods calling array primitives more precisely in pool_test.v */, '22.pointers' /* TODO: handle generic methods calling array primitives more precisely in pool_test.v */,
'20.reverse', '22.reverse',
'20.repeat_to_depth', '22.repeat_to_depth',
'20.slice', '22.slice',
'20.slice2', '22.slice2',
'59.get', '61.get',
'59.set', '61.set',
'65556.last', '65558.last',
'65556.pop', '65558.pop',
'65556.push', '65558.push',
'65556.insert_many', '65558.insert_many',
'65556.prepend_many', '65558.prepend_many',
'65556.reverse', '65558.reverse',
'65556.set', '65558.set',
'65556.set_unsafe', '65558.set_unsafe',
// TODO: process the _vinit const initializations automatically too // TODO: process the _vinit const initializations automatically too
'json.decode_string', 'json.decode_string',
'json.decode_int', 'json.decode_int',
@ -136,20 +136,20 @@ pub fn mark_used(mut table ast.Table, pref &pref.Preferences, ast_files []&ast.F
'__new_array_with_default_noscan', '__new_array_with_default_noscan',
'__new_array_with_array_default_noscan', '__new_array_with_array_default_noscan',
'new_array_from_c_array_noscan', 'new_array_from_c_array_noscan',
'20.clone_static_to_depth_noscan', '22.clone_static_to_depth_noscan',
'20.clone_to_depth_noscan', '22.clone_to_depth_noscan',
'20.reverse_noscan', '22.reverse_noscan',
'20.repeat_to_depth_noscan', '22.repeat_to_depth_noscan',
'65556.pop_noscan', '65558.pop_noscan',
'65556.push_noscan', '65558.push_noscan',
'65556.push_many_noscan', '65558.push_many_noscan',
'65556.insert_noscan', '65558.insert_noscan',
'65556.insert_many_noscan', '65558.insert_many_noscan',
'65556.prepend_noscan', '65558.prepend_noscan',
'65556.prepend_many_noscan', '65558.prepend_many_noscan',
'65556.reverse_noscan', '65558.reverse_noscan',
'65556.grow_cap_noscan', '65558.grow_cap_noscan',
'65556.grow_len_noscan', '65558.grow_len_noscan',
] ]
} }

View File

@ -0,0 +1,36 @@
fn f(u usize) usize
fn g(i isize) isize
// TODO refactor once `str` method is implemented
fn test_usize() {
mut u := usize(3)
u += u32(1)
// assert u == 4
if u != 4 {
assert false
}
u = 4
u++
// assert u == 5
if u != 5 {
assert false
}
// assert u.str() == '5'
}
fn test_isize() {
mut i := isize(-3)
i -= int(1)
// assert i == -4
if i != -4 {
assert false
}
i = -5
i += 2
// assert i == -3
if i != -3 {
assert false
}
// assert i.str() == '-2'
}