replace *Foo with &Foo everywhere

pull/1819/head
Alexander Medvednikov 2019-09-01 22:51:16 +03:00
parent aaab24dcf8
commit 0e2c41e0f9
12 changed files with 52 additions and 50 deletions

View File

@ -39,7 +39,7 @@ mut:
cut_pos int cut_pos int
} }
fn new_cgen(out_name_c string) *CGen { fn new_cgen(out_name_c string) &CGen {
path := out_name_c path := out_name_c
out := os.create(path) or { out := os.create(path) or {
println('failed to create $path') println('failed to create $path')

View File

@ -103,7 +103,7 @@ fn (p mut Parser) is_sig() bool {
(p.file_path.contains(ModPath)) (p.file_path.contains(ModPath))
} }
fn new_fn(mod string, is_public bool) *Fn { fn new_fn(mod string, is_public bool) &Fn {
return &Fn { return &Fn {
mod: mod mod: mod
local_vars: [Var{} ; MaxLocalVars] local_vars: [Var{} ; MaxLocalVars]
@ -756,7 +756,7 @@ fn (p mut Parser) fn_args(f mut Fn) {
} }
// foo *(1, 2, 3, mut bar)* // foo *(1, 2, 3, mut bar)*
fn (p mut Parser) fn_call_args(f mut Fn) *Fn { fn (p mut Parser) fn_call_args(f mut Fn) &Fn {
// p.gen('(') // p.gen('(')
// println('fn_call_args() name=$f.name args.len=$f.args.len') // println('fn_call_args() name=$f.name args.len=$f.args.len')
// C func. # of args is not known // C func. # of args is not known
@ -977,7 +977,7 @@ fn (f Fn) typ_str() string {
} }
// f.args => "int a, string b" // f.args => "int a, string b"
fn (f &Fn) str_args(table *Table) string { fn (f &Fn) str_args(table &Table) string {
mut s := '' mut s := ''
for i, arg in f.args { for i, arg in f.args {
// Interfaces are a special case. We need to pass the object + pointers // Interfaces are a special case. We need to pass the object + pointers

View File

@ -62,9 +62,9 @@ mut:
out_name_c string // name of the temporary C file out_name_c string // name of the temporary C file
files []string // all V files that need to be parsed and compiled files []string // all V files that need to be parsed and compiled
dir string // directory (or file) being compiled (TODO rename to path?) dir string // directory (or file) being compiled (TODO rename to path?)
table *Table // table with types, vars, functions etc table &Table // table with types, vars, functions etc
cgen *CGen // C code generator cgen &CGen // C code generator
pref *Preferences // all the prefrences and settings extracted to a struct for reusability pref &Preferences // all the prefrences and settings extracted to a struct for reusability
lang_dir string // "~/code/v" lang_dir string // "~/code/v"
out_name string // "program.exe" out_name string // "program.exe"
vroot string vroot string
@ -651,7 +651,7 @@ fn (v &V) log(s string) {
println(s) println(s)
} }
fn new_v(args[]string) *V { fn new_v(args[]string) &V {
joined_args := args.join(' ') joined_args := args.join(' ')
target_os := get_arg(joined_args, 'os', '') target_os := get_arg(joined_args, 'os', '')
mut out_name := get_arg(joined_args, 'o', 'a.out') mut out_name := get_arg(joined_args, 'o', 'a.out')

View File

@ -4,7 +4,7 @@
module main module main
import os import os
struct ModDepGraphNode { struct ModDepGraphNode {
mut: mut:
@ -21,7 +21,7 @@ pub:
} }
struct DepSet { struct DepSet {
mut: mut:
items []string items []string
} }
@ -43,7 +43,7 @@ pub fn(dset &DepSet) size() int {
return dset.items.len return dset.items.len
} }
pub fn new_mod_dep_graph() *ModDepGraph { pub fn new_mod_dep_graph() &ModDepGraph {
return &ModDepGraph{ return &ModDepGraph{
acyclic: true acyclic: true
} }
@ -66,9 +66,9 @@ pub fn(graph mut ModDepGraph) add(mod string, deps []string) {
} }
} }
pub fn(graph &ModDepGraph) resolve() *ModDepGraph { pub fn(graph &ModDepGraph) resolve() &ModDepGraph {
mut node_names := map[string]ModDepGraphNode mut node_names := map[string]ModDepGraphNode
mut node_deps := map[string]DepSet mut node_deps := map[string]DepSet
for _, node in graph.nodes { for _, node in graph.nodes {
node_names[node.name] = node node_names[node.name] = node
@ -148,24 +148,24 @@ pub fn(graph &ModDepGraph) display() {
} }
} }
// 'strings' => 'VROOT/vlib/strings' // 'strings' => 'VROOT/vlib/strings'
// 'installed_mod' => '~/.vmodules/installed_mod' // 'installed_mod' => '~/.vmodules/installed_mod'
// 'local_mod' => '/path/to/current/dir/local_mod' // 'local_mod' => '/path/to/current/dir/local_mod'
fn (v &V) find_module_path(mod string) string { fn (v &V) find_module_path(mod string) string {
mod_path := v.module_path(mod) mod_path := v.module_path(mod)
// First check for local modules in the same directory // First check for local modules in the same directory
mut import_path := os.getwd() + '/$mod_path' mut import_path := os.getwd() + '/$mod_path'
// Now search in vlib/ // Now search in vlib/
if !os.dir_exists(import_path) { if !os.dir_exists(import_path) {
import_path = '$v.lang_dir/vlib/$mod_path' import_path = '$v.lang_dir/vlib/$mod_path'
} }
//println('ip=$import_path') //println('ip=$import_path')
// Finally try modules installed with vpm (~/.vmodules) // Finally try modules installed with vpm (~/.vmodules)
if !os.dir_exists(import_path) { if !os.dir_exists(import_path) {
import_path = '$ModPath/$mod_path' import_path = '$ModPath/$mod_path'
if !os.dir_exists(import_path){ if !os.dir_exists(import_path){
cerror('module "$mod" not found') cerror('module "$mod" not found')
} }
} }
return import_path return import_path
} }

View File

@ -18,17 +18,17 @@ struct Parser {
// C ifdef guard clause that must be put before // C ifdef guard clause that must be put before
// the #include directives in the parsed .v file // the #include directives in the parsed .v file
mut: mut:
v *V v &V
scanner *Scanner scanner &Scanner
// tokens []Token // TODO cache all tokens, right now they have to be scanned twice // tokens []Token // TODO cache all tokens, right now they have to be scanned twice
token_idx int token_idx int
tok Token tok Token
prev_tok Token prev_tok Token
prev_tok2 Token // TODO remove these once the tokens are cached prev_tok2 Token // TODO remove these once the tokens are cached
lit string lit string
cgen *CGen cgen &CGen
table *Table table &Table
import_table *FileImportTable // Holds imports for just the file being parsed import_table &FileImportTable // Holds imports for just the file being parsed
pass Pass pass Pass
os OS os OS
mod string mod string
@ -40,7 +40,7 @@ mut:
expected_type string expected_type string
tmp_cnt int tmp_cnt int
is_script bool is_script bool
pref *Preferences // Setting and Preferences shared from V struct pref &Preferences // Setting and Preferences shared from V struct
builtin_mod bool builtin_mod bool
vh_lines []string vh_lines []string
inside_if_expr bool inside_if_expr bool
@ -50,7 +50,7 @@ mut:
for_expr_cnt int // to detect whether `continue` can be used for_expr_cnt int // to detect whether `continue` can be used
ptr_cast bool ptr_cast bool
calling_c bool calling_c bool
cur_fn *Fn cur_fn &Fn
returns bool returns bool
vroot string vroot string
is_c_struct_init bool is_c_struct_init bool
@ -867,7 +867,9 @@ fn (p mut Parser) get_type() string {
} }
// //
for p.tok == .mul { for p.tok == .mul {
p.warn('use `&Foo` instead of `*Foo`') if p.first_pass() {
p.warn('use `&Foo` instead of `*Foo`')
}
mul = true mul = true
nr_muls++ nr_muls++
p.check(.mul) p.check(.mul)

View File

@ -26,7 +26,7 @@ mut:
prev_tok Token prev_tok Token
} }
fn new_scanner(file_path string) *Scanner { fn new_scanner(file_path string) &Scanner {
if !os.file_exists(file_path) { if !os.file_exists(file_path) {
cerror('"$file_path" doesn\'t exist') cerror('"$file_path" doesn\'t exist')
} }

View File

@ -211,7 +211,7 @@ fn is_primitive_type(typ string) bool {
return is_number_type(typ) || typ == 'string' return is_number_type(typ) || typ == 'string'
} }
fn new_table(obfuscate bool) *Table { fn new_table(obfuscate bool) &Table {
mut t := &Table { mut t := &Table {
obfuscate: obfuscate obfuscate: obfuscate
} }
@ -857,7 +857,7 @@ fn (table &Table) qualify_module(mod string, file_path string) string {
return mod return mod
} }
fn new_file_import_table(file_path string) *FileImportTable { fn new_file_import_table(file_path string) &FileImportTable {
return &FileImportTable{ return &FileImportTable{
file_path: file_path file_path: file_path
imports: map[string]string imports: map[string]string

View File

@ -260,7 +260,7 @@ pub fn copy(dst, src []byte) int {
return 0 return 0
} }
fn compare_ints(a, b *int) int { fn compare_ints(a, b &int) int {
if a < b { if a < b {
return -1 return -1
} }

View File

@ -8,14 +8,14 @@ import strings
struct map { struct map {
element_size int element_size int
root *mapnode root &mapnode
pub: pub:
size int size int
} }
struct mapnode { struct mapnode {
left *mapnode left &mapnode
right *mapnode right &mapnode
is_empty bool is_empty bool
key string key string
val voidptr val voidptr
@ -30,7 +30,7 @@ fn new_map(cap, elm_size int) map {
} }
// `m := { 'one': 1, 'two': 2 }` // `m := { 'one': 1, 'two': 2 }`
fn new_map_init(cap, elm_size int, keys *string, vals voidptr) map { fn new_map_init(cap, elm_size int, keys &string, vals voidptr) map {
mut res := map { mut res := map {
element_size: elm_size element_size: elm_size
root: 0 root: 0
@ -41,7 +41,7 @@ fn new_map_init(cap, elm_size int, keys *string, vals voidptr) map {
return res return res
} }
fn new_node(key string, val voidptr, element_size int) *mapnode { fn new_node(key string, val voidptr, element_size int) &mapnode {
new_e := &mapnode { new_e := &mapnode {
key: key key: key
val: malloc(element_size) val: malloc(element_size)

View File

@ -639,7 +639,7 @@ pub fn (s string) trim_right(cutset string) string {
// fn print_cur_thread() { // fn print_cur_thread() {
// //C.printf("tid = %08x \n", pthread_self()); // //C.printf("tid = %08x \n", pthread_self());
// } // }
fn compare_strings(a, b *string) int { fn compare_strings(a, b &string) int {
if a.lt(b) { if a.lt(b) {
return -1 return -1
} }
@ -649,7 +649,7 @@ fn compare_strings(a, b *string) int {
return 0 return 0
} }
fn compare_strings_by_len(a, b *string) int { fn compare_strings_by_len(a, b &string) int {
if a.len < b.len { if a.len < b.len {
return -1 return -1
} }
@ -659,7 +659,7 @@ fn compare_strings_by_len(a, b *string) int {
return 0 return 0
} }
fn compare_lower_strings(a, b *string) int { fn compare_lower_strings(a, b &string) int {
aa := a.to_lower() aa := a.to_lower()
bb := b.to_lower() bb := b.to_lower()
return compare_strings(aa, bb) return compare_strings(aa, bb)

View File

@ -34,7 +34,7 @@ struct C.FILE {
} }
struct File { struct File {
cfile *FILE cfile &FILE
} }
struct FileInfo { struct FileInfo {
@ -87,7 +87,7 @@ fn C.sigaction(int, voidptr, int)
fn todo_remove(){} fn todo_remove(){}
fn init_os_args(argc int, argv *byteptr) []string { fn init_os_args(argc int, argv &byteptr) []string {
mut args := []string mut args := []string
$if windows { $if windows {
mut args_list := &voidptr(0) mut args_list := &voidptr(0)
@ -308,7 +308,7 @@ pub fn (f File) close() {
// system starts the specified command, waits for it to complete, and returns its code. // system starts the specified command, waits for it to complete, and returns its code.
fn popen(path string) *FILE { fn popen(path string) &FILE {
$if windows { $if windows {
mode := 'rb' mode := 'rb'
wpath := path.to_wide() wpath := path.to_wide()
@ -320,7 +320,7 @@ fn popen(path string) *FILE {
} }
} }
fn pclose(f *FILE) int { fn pclose(f &FILE) int {
$if windows { $if windows {
return C._pclose(f) return C._pclose(f)
} }

View File

@ -24,7 +24,7 @@ pub:
} }
fn C.localtime(int) *C.tm fn C.localtime(int) &C.tm
fn remove_me_when_c_bug_is_fixed() { // TODO fn remove_me_when_c_bug_is_fixed() { // TODO
} }