1
0
mirror of https://github.com/vlang/v.git synced 2023-08-10 21:13:21 +03:00

cgen: fix fixed array of threads (#15086)

This commit is contained in:
yuyi 2022-07-15 19:19:11 +08:00 committed by GitHub
parent f2961ec862
commit 560afac5d5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 26 additions and 6 deletions

View File

@ -60,6 +60,7 @@ mut:
alias_definitions strings.Builder // alias fixed array of non-builtin alias_definitions strings.Builder // alias fixed array of non-builtin
hotcode_definitions strings.Builder // -live declarations & functions hotcode_definitions strings.Builder // -live declarations & functions
channel_definitions strings.Builder // channel related code channel_definitions strings.Builder // channel related code
thread_definitions strings.Builder // thread defines
comptime_definitions strings.Builder // custom defines, given by -d/-define flags on the CLI comptime_definitions strings.Builder // custom defines, given by -d/-define flags on the CLI
cleanup strings.Builder cleanup strings.Builder
cleanups map[string]strings.Builder // contents of `void _vcleanup(){}` cleanups map[string]strings.Builder // contents of `void _vcleanup(){}`
@ -249,6 +250,7 @@ pub fn gen(files []&ast.File, table &ast.Table, pref &pref.Preferences) string {
alias_definitions: strings.new_builder(100) alias_definitions: strings.new_builder(100)
hotcode_definitions: strings.new_builder(100) hotcode_definitions: strings.new_builder(100)
channel_definitions: strings.new_builder(100) channel_definitions: strings.new_builder(100)
thread_definitions: strings.new_builder(100)
comptime_definitions: strings.new_builder(100) comptime_definitions: strings.new_builder(100)
definitions: strings.new_builder(100) definitions: strings.new_builder(100)
gowrappers: strings.new_builder(100) gowrappers: strings.new_builder(100)
@ -344,6 +346,7 @@ pub fn gen(files []&ast.File, table &ast.Table, pref &pref.Preferences) string {
global_g.json_forward_decls.write(g.json_forward_decls) or { panic(err) } global_g.json_forward_decls.write(g.json_forward_decls) or { panic(err) }
global_g.enum_typedefs.write(g.enum_typedefs) or { panic(err) } global_g.enum_typedefs.write(g.enum_typedefs) or { panic(err) }
global_g.channel_definitions.write(g.channel_definitions) or { panic(err) } global_g.channel_definitions.write(g.channel_definitions) or { panic(err) }
global_g.thread_definitions.write(g.thread_definitions) or { panic(err) }
global_g.sql_buf.write(g.sql_buf) or { panic(err) } global_g.sql_buf.write(g.sql_buf) or { panic(err) }
global_g.cleanups[g.file.mod.name].write(g.cleanup) or { panic(err) } // strings.Builder.write never fails; it is like that in the source global_g.cleanups[g.file.mod.name].write(g.cleanup) or { panic(err) } // strings.Builder.write never fails; it is like that in the source
@ -450,6 +453,8 @@ pub fn gen(files []&ast.File, table &ast.Table, pref &pref.Preferences) string {
b.write_string(g.includes.str()) b.write_string(g.includes.str())
b.writeln('\n// Enum definitions:') b.writeln('\n// Enum definitions:')
b.write_string(g.enum_typedefs.str()) b.write_string(g.enum_typedefs.str())
b.writeln('\n// Thread definitions:')
b.write_string(g.thread_definitions.str())
b.writeln('\n// V type definitions:') b.writeln('\n// V type definitions:')
b.write_string(g.type_definitions.str()) b.write_string(g.type_definitions.str())
b.writeln('\n// V alias definitions:') b.writeln('\n// V alias definitions:')
@ -557,6 +562,7 @@ fn cgen_process_one_file_cb(p &pool.PoolProcessor, idx int, wid int) &Gen {
shared_types: strings.new_builder(100) shared_types: strings.new_builder(100)
shared_functions: strings.new_builder(100) shared_functions: strings.new_builder(100)
channel_definitions: strings.new_builder(100) channel_definitions: strings.new_builder(100)
thread_definitions: strings.new_builder(100)
json_forward_decls: strings.new_builder(100) json_forward_decls: strings.new_builder(100)
enum_typedefs: strings.new_builder(100) enum_typedefs: strings.new_builder(100)
sql_buf: strings.new_builder(100) sql_buf: strings.new_builder(100)
@ -609,6 +615,7 @@ pub fn (mut g Gen) free_builders() {
g.shared_types.free() g.shared_types.free()
g.shared_functions.free() g.shared_functions.free()
g.channel_definitions.free() g.channel_definitions.free()
g.thread_definitions.free()
g.options.free() g.options.free()
g.out_results.free() g.out_results.free()
g.json_forward_decls.free() g.json_forward_decls.free()
@ -4943,18 +4950,18 @@ fn (mut g Gen) write_types(symbols []&ast.TypeSymbol) {
ast.Thread { ast.Thread {
if g.pref.os == .windows { if g.pref.os == .windows {
if name == '__v_thread' { if name == '__v_thread' {
g.type_definitions.writeln('typedef HANDLE $name;') g.thread_definitions.writeln('typedef HANDLE $name;')
} else { } else {
// Windows can only return `u32` (no void*) from a thread, so the // Windows can only return `u32` (no void*) from a thread, so the
// V gohandle must maintain a pointer to the return value // V gohandle must maintain a pointer to the return value
g.type_definitions.writeln('typedef struct {') g.thread_definitions.writeln('typedef struct {')
g.type_definitions.writeln('\tvoid* ret_ptr;') g.thread_definitions.writeln('\tvoid* ret_ptr;')
g.type_definitions.writeln('\tHANDLE handle;') g.thread_definitions.writeln('\tHANDLE handle;')
g.type_definitions.writeln('} $name;') g.thread_definitions.writeln('} $name;')
} }
} else { } else {
if !g.pref.is_bare && !g.pref.no_builtin { if !g.pref.is_bare && !g.pref.no_builtin {
g.type_definitions.writeln('typedef pthread_t $name;') g.thread_definitions.writeln('typedef pthread_t $name;')
} }
} }
} }

View File

@ -0,0 +1,13 @@
module main
fn test_fixed_array_of_threads() {
mut avar := [8]thread string{}
avar[0] = go printme()
ret := avar[0].wait()
assert ret == 'me'
}
fn printme() string {
println('me')
return 'me'
}