From edabd57e8aa0c4948cc96a889e5e3226a879b3f3 Mon Sep 17 00:00:00 2001 From: Alexander Medvednikov Date: Fri, 22 May 2020 02:45:11 +0200 Subject: [PATCH] parser: use parallel only on macos for now --- vlib/v/parser/parser.v | 36 +++++++++++++++++++----------------- vlib/v/table/table.v | 2 +- 2 files changed, 20 insertions(+), 18 deletions(-) diff --git a/vlib/v/parser/parser.v b/vlib/v/parser/parser.v index 81633cdd3c..f143c0a838 100644 --- a/vlib/v/parser/parser.v +++ b/vlib/v/parser/parser.v @@ -171,24 +171,26 @@ fn (mut q Queue) run() { pub fn parse_files(paths []string, table &table.Table, pref &pref.Preferences, global_scope &ast.Scope) []ast.File { // println('nr_cpus= $nr_cpus') - if pref.is_parallel && paths[0].contains('/array.v') { - println('\n\n\nparse_files() nr_files=$paths.len') - println(paths) - nr_cpus := runtime.nr_cpus() - mut q := &Queue{ - paths: paths - table: table - pref: pref - global_scope: global_scope - mu: sync.new_mutex() - mu2: sync.new_mutex() + $if macos { + if pref.is_parallel && paths[0].contains('/array.v') { + println('\n\n\nparse_files() nr_files=$paths.len') + println(paths) + nr_cpus := runtime.nr_cpus() + mut q := &Queue{ + paths: paths + table: table + pref: pref + global_scope: global_scope + mu: sync.new_mutex() + mu2: sync.new_mutex() + } + for _ in 0 .. nr_cpus - 1 { + go q.run() + } + time.sleep_ms(1000) + println('all done') + return q.parsed_ast_files } - for _ in 0 .. nr_cpus - 1 { - go q.run() - } - time.sleep_ms(1000) - println('all done') - return q.parsed_ast_files } // /////////////// mut files := []ast.File{} diff --git a/vlib/v/table/table.v b/vlib/v/table/table.v index 46d6948ca2..6a14037d61 100644 --- a/vlib/v/table/table.v +++ b/vlib/v/table/table.v @@ -15,7 +15,7 @@ pub mut: modules []string // List of all modules registered by the application cflags []cflag.CFlag redefined_fns []string - fn_gen_types map[string][]Type + fn_gen_types map[string][]Type // for generic functions } pub struct Fn {