parser: register #flags

pull/4321/head
Alexander Medvednikov 2020-04-09 16:39:53 +02:00
parent 2b685fc80a
commit 6ac64c8586
2 changed files with 53 additions and 23 deletions

View File

@ -1,3 +1,6 @@
// Copyright (c) 2019-2020 Alexander Medvednikov. All rights reserved.
// Use of this source code is governed by an MIT license
// that can be found in the LICENSE file.
module parser module parser
import ( import (
@ -6,10 +9,54 @@ import (
) )
const ( const (
supported_platforms = ['windows', 'mac', 'macos', 'darwin', 'linux', 'freebsd', 'openbsd', 'netbsd', supported_platforms = ['windows', 'mac', 'macos', 'darwin', 'linux', 'freebsd', 'openbsd',
'dragonfly', 'android', 'js', 'solaris', 'haiku', 'linux_or_macos'] 'netbsd', 'dragonfly', 'android', 'js', 'solaris', 'haiku', 'linux_or_macos']
) )
// // #include, #flag, #v
fn (p mut Parser) hash() ast.HashStmt {
val := p.tok.lit
p.next()
if val.starts_with('flag') {
// #flag linux -lm
mut flag := val[5..]
// expand `@VROOT` to its absolute path
/*
if flag.contains('@VROOT') {
vmod_file_location := p.v.mod_file_cacher.get( p.file_path_dir )
if vmod_file_location.vmod_file.len == 0 {
// There was no actual v.mod file found.
p.error_with_token_index('To use @VROOT, you need' +
' to have a "v.mod" file in ${p.file_path_dir},' +
' or in one of its parent folders.',
p.cur_tok_index() - 1)
}
flag = flag.replace('@VROOT', vmod_file_location.vmod_folder )
}
*/
for deprecated in ['@VMOD', '@VMODULE', '@VPATH', '@VLIB_PATH'] {
if flag.contains(deprecated) {
p.error('${deprecated} had been deprecated, use @VROOT instead.')
}
}
// println('adding flag "$flag"')
p.table.parse_cflag(flag, p.mod, p.pref.compile_defines_all) or {
p.error(err)
}
/*
words := val.split(' ')
if words.len > 1 && words[1] in supported_platforms {
if p.pref.os == .mac && words[1] == 'darwin' {
p.pref.cflags += val.after('darwin')
}
}
*/
}
return ast.HashStmt{
val: val
}
}
fn (p mut Parser) comp_if() ast.CompIf { fn (p mut Parser) comp_if() ast.CompIf {
pos := p.tok.position() pos := p.tok.position()
p.next() p.next()
@ -31,14 +78,13 @@ fn (p mut Parser) comp_if() ast.CompIf {
p.check(.lcbr) p.check(.lcbr)
// p.warn('skipping $if $val os=$os p.pref.os=$p.pref.os') // p.warn('skipping $if $val os=$os p.pref.os=$p.pref.os')
mut stack := 1 mut stack := 1
for { for {
if p.tok.kind == .key_return { if p.tok.kind == .key_return {
p.returns = true p.returns = true
} }
if p.tok.kind == .lcbr { if p.tok.kind == .lcbr {
stack++ stack++
} } else if p.tok.kind == .rcbr {
else if p.tok.kind == .rcbr {
stack-- stack--
} }
if p.tok.kind == .eof { if p.tok.kind == .eof {
@ -74,8 +120,9 @@ fn (p mut Parser) comp_if() ast.CompIf {
return node return node
} }
// TODO import warning bug
const ( const (
todo_delete_me = pref.OS.linux // TODO import warning bug todo_delete_me = pref.OS.linux
) )
fn os_from_string(os string) pref.OS { fn os_from_string(os string) pref.OS {

View File

@ -1716,23 +1716,6 @@ fn (p mut Parser) assign_stmt() ast.Stmt {
} }
} }
fn (p mut Parser) hash() ast.HashStmt {
val := p.tok.lit
p.next()
if val.starts_with('flag') {
// #flag linux -lm
words := val.split(' ')
if words.len > 1 && words[1] in supported_platforms {
if p.pref.os == .mac && words[1] == 'darwin' {
p.pref.cflags += val.after('darwin')
}
}
}
return ast.HashStmt{
val: val
}
}
fn (p mut Parser) global_decl() ast.GlobalDecl { fn (p mut Parser) global_decl() ast.GlobalDecl {
if !p.pref.translated && !p.pref.is_live && !p.builtin_mod && !p.pref.building_v && p.mod != if !p.pref.translated && !p.pref.is_live && !p.builtin_mod && !p.pref.building_v && p.mod !=
'ui' && p.mod != 'gg2' && p.mod != 'uiold' && !os.getwd().contains('/volt') && !p.pref.enable_globals { 'ui' && p.mod != 'gg2' && p.mod != 'uiold' && !os.getwd().contains('/volt') && !p.pref.enable_globals {