freetype: fix align.right rendering
parent
1e98a227cc
commit
756c6d2858
|
@ -486,7 +486,7 @@ fn (p mut Parser) fn_decl() {
|
||||||
if is_c {
|
if is_c {
|
||||||
p.fgen_nl()
|
p.fgen_nl()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Register the method
|
// Register the method
|
||||||
if receiver_typ != '' {
|
if receiver_typ != '' {
|
||||||
mut receiver_t := p.table.find_type(receiver_typ)
|
mut receiver_t := p.table.find_type(receiver_typ)
|
||||||
|
@ -512,7 +512,7 @@ fn (p mut Parser) fn_decl() {
|
||||||
if p.first_pass() && p.attr == 'live' && !(is_live || is_solive) {
|
if p.first_pass() && p.attr == 'live' && !(is_live || is_solive) {
|
||||||
println('INFO: run `v -live $p.v.dir `, if you want to use [live] function $f.name .')
|
println('INFO: run `v -live $p.v.dir `, if you want to use [live] function $f.name .')
|
||||||
}
|
}
|
||||||
|
|
||||||
if p.is_vh || p.first_pass() || is_live || is_fn_header || skip_main_in_test {
|
if p.is_vh || p.first_pass() || is_live || is_fn_header || skip_main_in_test {
|
||||||
// First pass? Skip the body for now
|
// First pass? Skip the body for now
|
||||||
// Look for generic calls.
|
// Look for generic calls.
|
||||||
|
@ -536,7 +536,7 @@ fn (p mut Parser) fn_decl() {
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if is_solive {
|
if is_solive {
|
||||||
// Live functions are protected by a mutex, because otherwise they
|
// Live functions are protected by a mutex, because otherwise they
|
||||||
// can be changed by the live reload thread, *while* they are
|
// can be changed by the live reload thread, *while* they are
|
||||||
|
@ -560,10 +560,10 @@ fn (p mut Parser) fn_decl() {
|
||||||
p.genln(' $live_fncall')
|
p.genln(' $live_fncall')
|
||||||
p.genln(' pthread_mutex_unlock(&live_fn_mutex);')
|
p.genln(' pthread_mutex_unlock(&live_fn_mutex);')
|
||||||
p.genln(' $live_fnreturn')
|
p.genln(' $live_fnreturn')
|
||||||
p.genln('}')
|
p.genln('}')
|
||||||
p.genln('$typ impl_live_${fn_name_cgen} ($str_args){')
|
p.genln('$typ impl_live_${fn_name_cgen} ($str_args){')
|
||||||
}
|
}
|
||||||
|
|
||||||
if f.name in ['main__main', 'main', 'WinMain'] {
|
if f.name in ['main__main', 'main', 'WinMain'] {
|
||||||
if p.pref.is_test {
|
if p.pref.is_test {
|
||||||
p.error_with_token_index('tests cannot have function `main`', f.fn_name_token_idx)
|
p.error_with_token_index('tests cannot have function `main`', f.fn_name_token_idx)
|
||||||
|
@ -665,11 +665,11 @@ fn (p mut Parser) check_unused_and_mut_vars() {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
if !var.is_used && !p.pref.is_repl && !var.is_arg && !p.pref.translated &&
|
if !var.is_used && !p.pref.is_repl && !var.is_arg && !p.pref.translated &&
|
||||||
var.name != 'tmpl_res' && p.mod != 'vweb' && var.name != 'it' {
|
var.name != 'tmpl_res' && p.mod != 'vweb' && var.name != 'it' && !p.cur_fn.is_unsafe {
|
||||||
p.production_error_with_token_index('`$var.name` declared and not used', var.token_idx)
|
p.production_error_with_token_index('`$var.name` declared and not used', var.token_idx)
|
||||||
}
|
}
|
||||||
if !var.is_changed && var.is_mut && !p.pref.is_repl && !p.pref.translated && var.typ != 'T*' && p.mod != 'ui' && var.typ != 'App*' {
|
if !var.is_changed && var.is_mut && !p.pref.is_repl && !p.pref.translated && var.typ != 'T*' && p.mod != 'ui' && var.typ != 'App*' {
|
||||||
p.warn_or_error('`$var.name` is declared as mutable, but it was never changed')
|
//p.warn_or_error('`$var.name` is declared as mutable, but it was never changed')
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -310,7 +310,7 @@ fn build_thirdparty_obj_file_with_msvc(path string, moduleflags []CFlag) {
|
||||||
mut obj_path := '${path}bj'
|
mut obj_path := '${path}bj'
|
||||||
obj_path = os.realpath(obj_path)
|
obj_path = os.realpath(obj_path)
|
||||||
if os.exists(obj_path) {
|
if os.exists(obj_path) {
|
||||||
println('$obj_path already build.')
|
println('$obj_path already built.')
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
println('$obj_path not found, building it (with msvc)...')
|
println('$obj_path not found, building it (with msvc)...')
|
||||||
|
|
|
@ -262,7 +262,8 @@ fn (ctx mut FreeType) private_draw_text(_x, _y int, utext ustring, cfg gx.TextCf
|
||||||
mut y := f32(_y)
|
mut y := f32(_y)
|
||||||
// println('scale=$ctx.scale size=$cfg.size')
|
// println('scale=$ctx.scale size=$cfg.size')
|
||||||
if cfg.align == gx.ALIGN_RIGHT {
|
if cfg.align == gx.ALIGN_RIGHT {
|
||||||
width := utext.len * 7
|
//width := utext.len * 7
|
||||||
|
width := ctx.text_width(utext.s)
|
||||||
x -= width + 10
|
x -= width + 10
|
||||||
}
|
}
|
||||||
x *= ctx.scale// f32(2)
|
x *= ctx.scale// f32(2)
|
||||||
|
|
Loading…
Reference in New Issue