mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
[if vfmt] function attribute for skipping functions for performance
This commit is contained in:
parent
ee51313e2c
commit
ef022c2326
@ -113,6 +113,7 @@ pub mut:
|
|||||||
// This is on by default, since a vast majority of users do not
|
// This is on by default, since a vast majority of users do not
|
||||||
// work on the builtin module itself.
|
// work on the builtin module itself.
|
||||||
//generating_vh bool
|
//generating_vh bool
|
||||||
|
comptime_define string // -D vfmt for `if $vfmt {`
|
||||||
}
|
}
|
||||||
|
|
||||||
// Should be called by main at the end of the compilation process, to cleanup
|
// Should be called by main at the end of the compilation process, to cleanup
|
||||||
@ -279,7 +280,7 @@ pub fn (v mut V) compile() {
|
|||||||
// parse generated V code (str() methods etc)
|
// parse generated V code (str() methods etc)
|
||||||
mut vgen_parser := v.new_parser_from_string(v.vgen_buf.str())
|
mut vgen_parser := v.new_parser_from_string(v.vgen_buf.str())
|
||||||
// free the string builder which held the generated methods
|
// free the string builder which held the generated methods
|
||||||
vgen_parser.is_vgen = true
|
vgen_parser.is_vgen = true
|
||||||
v.vgen_buf.free()
|
v.vgen_buf.free()
|
||||||
vgen_parser.parse(.main)
|
vgen_parser.parse(.main)
|
||||||
// v.parsers.add(vgen_parser)
|
// v.parsers.add(vgen_parser)
|
||||||
@ -765,6 +766,7 @@ pub 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', '')
|
||||||
|
comptime_define := get_arg(joined_args, 'd', '')
|
||||||
mut out_name := get_arg(joined_args, 'o', 'a.out')
|
mut out_name := get_arg(joined_args, 'o', 'a.out')
|
||||||
|
|
||||||
mut dir := args.last()
|
mut dir := args.last()
|
||||||
@ -922,6 +924,7 @@ pub fn new_v(args[]string) &V {
|
|||||||
cflags: cflags
|
cflags: cflags
|
||||||
ccompiler: find_c_compiler()
|
ccompiler: find_c_compiler()
|
||||||
building_v: !is_repl && (rdir_name == 'compiler' || rdir_name == 'v.v' || dir.contains('vlib'))
|
building_v: !is_repl && (rdir_name == 'compiler' || rdir_name == 'v.v' || dir.contains('vlib'))
|
||||||
|
comptime_define: comptime_define
|
||||||
}
|
}
|
||||||
if pref.is_verbose || pref.is_debug {
|
if pref.is_verbose || pref.is_debug {
|
||||||
println('C compiler=$pref.ccompiler')
|
println('C compiler=$pref.ccompiler')
|
||||||
|
@ -3872,7 +3872,13 @@ fn (p mut Parser) js_decode() string {
|
|||||||
|
|
||||||
fn (p mut Parser) attribute() {
|
fn (p mut Parser) attribute() {
|
||||||
p.check(.lsbr)
|
p.check(.lsbr)
|
||||||
p.attr = p.check_name()
|
if p.tok == .key_if {
|
||||||
|
// [if vfmt]
|
||||||
|
p.next()
|
||||||
|
p.attr = 'if ' + p.check_name()
|
||||||
|
} else {
|
||||||
|
p.attr = p.check_name()
|
||||||
|
}
|
||||||
attr_token_idx := p.cur_tok_index()
|
attr_token_idx := p.cur_tok_index()
|
||||||
if p.tok == .colon {
|
if p.tok == .colon {
|
||||||
p.check(.colon)
|
p.check(.colon)
|
||||||
|
@ -7,6 +7,7 @@ module compiler
|
|||||||
import strings
|
import strings
|
||||||
|
|
||||||
// fmt helpers
|
// fmt helpers
|
||||||
|
//[if vfmt]
|
||||||
fn (scanner mut Scanner) fgen(s_ string) {
|
fn (scanner mut Scanner) fgen(s_ string) {
|
||||||
mut s := s_
|
mut s := s_
|
||||||
if scanner.fmt_line_empty {
|
if scanner.fmt_line_empty {
|
||||||
|
Loading…
Reference in New Issue
Block a user