diff options
author | Araq <rumpf_a@web.de> | 2013-07-25 08:37:37 +0200 |
---|---|---|
committer | Araq <rumpf_a@web.de> | 2013-07-25 08:37:37 +0200 |
commit | 3e0899359be8bd962fd673f2530ba4d285cc28ae (patch) | |
tree | b5985ce4062799d1ccdc21df68f032fe03518fa5 | |
parent | bdbf0f863d9e9d891d299fc7932e3714bd1ba8ca (diff) | |
download | Nim-3e0899359be8bd962fd673f2530ba4d285cc28ae.tar.gz |
new evaluation engine: next steps
-rw-r--r-- | compiler/types.nim | 4 | ||||
-rw-r--r-- | compiler/vm.nim | 4 | ||||
-rw-r--r-- | compiler/vmgen.nim | 15 |
3 files changed, 11 insertions, 12 deletions
diff --git a/compiler/types.nim b/compiler/types.nim index 9dad958b8..6c4249b83 100644 --- a/compiler/types.nim +++ b/compiler/types.nim @@ -1028,9 +1028,9 @@ proc typeAllowedAux(marker: var TIntSet, typ: PType, kind: TSymKind): bool = result = kind == skParam of tyGenericInst, tyDistinct: result = typeAllowedAux(marker, lastSon(t), kind) - of tyRange: + of tyRange: result = skipTypes(t.sons[0], abstractInst-{tyTypeDesc}).kind in - {tyChar, tyEnum, tyInt..tyFloat128} + {tyChar, tyEnum, tyInt..tyUInt64} of tyOpenArray, tyVarargs: result = (kind == skParam) and typeAllowedAux(marker, t.sons[0], skVar) of tySequence: diff --git a/compiler/vm.nim b/compiler/vm.nim index 72e0cb5b1..97c870051 100644 --- a/compiler/vm.nim +++ b/compiler/vm.nim @@ -197,14 +197,10 @@ proc execute(c: PCtx, start: int) = of opcYldYoid: assert false of opcYldVal: assert false of opcAsgnInt: - echo ra, " ", instr.regB, " ", regs.len, tos.prc.name.s decodeB(nkIntLit) regs[ra].intVal = regs[rb].intVal of opcAsgnStr: decodeB(nkStrLit) - debug regs[rb] - echo rb - Message(c.debug[pc], warnUser, " here") regs[ra].strVal = regs[rb].strVal of opcAsgnFloat: decodeB(nkFloatLit) diff --git a/compiler/vmgen.nim b/compiler/vmgen.nim index 048a89b8c..baa38e05a 100644 --- a/compiler/vmgen.nim +++ b/compiler/vmgen.nim @@ -40,19 +40,22 @@ proc gABC(ctx: PCtx; n: PNode; opc: TOpcode; a, b, c: TRegister = 0) = ctx.debug.add(n.info) proc gABI(c: PCtx; n: PNode; opc: TOpcode; a, b: TRegister; imm: biggestInt) = - let ins = (opc.ord or a shl 8 or b shl 16 or (imm+byteExcess) shl 24).TInstr + let ins = (opc.uint32 or (a.uint32 shl 8'u32) or + (b.uint32 shl 16'u32) or + (imm+byteExcess).uint32 shl 24'u32).TInstr c.code.add(ins) c.debug.add(n.info) proc gABx(c: PCtx; n: PNode; opc: TOpcode; a: TRegister = 0; bx: int) = - let ins = (opc.ord or a shl 8 or (bx+wordExcess) shl 16).TInstr + let ins = (opc.uint32 or a.uint32 shl 8'u32 or + (bx+wordExcess).uint32 shl 16'u32).TInstr c.code.add(ins) c.debug.add(n.info) proc xjmp(c: PCtx; n: PNode; opc: TOpcode; a: TRegister = 0): TPosition = #assert opc in {opcJmp, opcFJmp, opcTJmp} - gABx(c, n, opc, a, 0) result = TPosition(c.code.len) + gABx(c, n, opc, a, 0) proc genLabel(c: PCtx): TPosition = result = TPosition(c.code.len) @@ -71,7 +74,8 @@ proc patch(c: PCtx, p: TPosition) = InternalAssert(-0x7fff < diff and diff < 0x7fff) let oldInstr = c.code[p] # opcode and regA stay the same: - c.code[p] = ((oldInstr.int and 0xffff) or (diff+wordExcess)).TInstr + c.code[p] = ((oldInstr.uint32 and 0xffff'u32) or + uint32(diff+wordExcess) shr 16'u32).TInstr proc getSlotKind(t: PType): TSlotKind = case t.skipTypes(abstractRange).kind @@ -704,7 +708,7 @@ proc genAsgn(c: PCtx; le, ri: PNode; requiresCopy: bool) = let dest = c.genx(le.sons[0]) let idx = c.genx(le.sons[1]) let tmp = c.genx(ri) - if le.typ.skipTypes(abstractVarRange).kind in {tyString, tyCString}: + if le.sons[0].typ.skipTypes(abstractVarRange).kind in {tyString, tyCString}: c.gABC(le, opcWrStrIdx, dest, idx, tmp) else: c.gABC(le, whichAsgnOpc(le, opcWrArr), dest, idx, tmp) @@ -820,7 +824,6 @@ proc setSlot(c: PCtx; v: PSym) = v.position = c.prc.maxSlots c.prc.slots[v.position] = (inUse: true, kind: slotFixed) inc c.prc.maxSlots - echo v.name.s, " has position ", v.position proc genVarSection(c: PCtx; n: PNode) = for a in n: |