compiler: support integer convert in interpreter

Этот коммит содержится в:
Ayke van Laethem 2018-09-15 18:47:15 +02:00
родитель 1d2e0cd259
коммит 94b18e2d79
Не найден ключ, соответствующий данной подписи
Идентификатор ключа GPG: E97FF5335DFDFDED

Просмотреть файл

@ -134,18 +134,29 @@ func (p *Program) interpret(instrs []ssa.Instruction, paramKeys []*ssa.Parameter
if err != nil { if err != nil {
return i, err return i, err
} }
switch typ := instr.Type().Underlying().(type) { typeFrom := instr.X.Type().Underlying()
switch typeTo := instr.Type().Underlying().(type) {
case *types.Basic: case *types.Basic:
if _, ok := instr.X.Type().Underlying().(*types.Pointer); ok && typ.Kind() == types.UnsafePointer { if typeTo.Kind() == types.String {
locals[instr] = &PointerBitCastValue{typ, x} return i, errors.New("todo: init: cannot convert string")
} else if xtyp, ok := instr.X.Type().Underlying().(*types.Basic); ok && xtyp.Kind() == types.UnsafePointer && typ.Kind() == types.Uintptr { }
if _, ok := typeFrom.(*types.Pointer); ok && typeTo.Kind() == types.UnsafePointer {
locals[instr] = &PointerBitCastValue{typeTo, x}
} else if typeFrom, ok := typeFrom.(*types.Basic); ok {
if typeFrom.Kind() == types.UnsafePointer && typeTo.Kind() == types.Uintptr {
locals[instr] = &PointerToUintptrValue{x} locals[instr] = &PointerToUintptrValue{x}
} else if typeFrom.Info()&types.IsInteger != 0 && typeTo.Info()&types.IsInteger != 0 {
locals[instr] = &ConstValue{Expr: ssa.NewConst(x.(*ConstValue).Expr.Value, typeTo)}
} else {
return i, errors.New("todo: init: unknown basic-to-basic convert: " + instr.String())
}
} else { } else {
return i, errors.New("todo: init: unknown basic convert: " + instr.String()) return i, errors.New("todo: init: unknown basic convert: " + instr.String())
} }
case *types.Pointer: case *types.Pointer:
if xtyp, ok := instr.X.Type().Underlying().(*types.Basic); ok && xtyp.Kind() == types.UnsafePointer { if typeFrom, ok := typeFrom.(*types.Basic); ok && typeFrom.Kind() == types.UnsafePointer {
locals[instr] = &PointerBitCastValue{typ, x} locals[instr] = &PointerBitCastValue{typeTo, x}
} else { } else {
panic("expected unsafe pointer conversion") panic("expected unsafe pointer conversion")
} }