]> cloudbase.mooo.com Git - ddt180.git/blobdiff - ddt180.z80
optimize mainloop; cmd_H: remove +- expression2
[ddt180.git] / ddt180.z80
index 5c1349255e83b86bd71d57a9a777eec7384b1760..da5cfe6c3134079ea81f06facabc5a881332236f 100644 (file)
@@ -120,7 +120,6 @@ reg.iff:
        db      0c3h\r
 reg.pc:        dw      TPA\r
 var.$: dw      0000h\r
-var.@: dw      0\r
 \r
 cmd_rpt:dw     mainloop\r
 \r
@@ -132,9 +131,7 @@ conbuf:
        ld sp,stack\r
        exx\r
        ld de,ddtz_base\r
-       or a\r
-       sbc hl,de\r
-       add hl,de\r
+       call cp_hl_de\r
        jr c,l0079h\r
        ex de,hl\r
 l0079h:\r
@@ -171,7 +168,7 @@ l0093h:
 ;-------------------------------------------------------------------------------\r
 \r
 CMDTAB:\r
-       dw      cmd_@           ;examine/substitute the displacement register @\r
+       dw      ERROR ;cmd_@    ;examine/substitute the displacement register @\r
        dw      ERROR ;cmd_A    ;Assemble\r
        dw      cmd_B           ;Breakpoints display/set/clear\r
        dw      cmd_C           ;trace over Calls\r
@@ -211,6 +208,7 @@ mainloop:
        call bp_clr_temporary\r
        ld hl,(cmd_rpt)\r
        ld de,mainloop\r
+       push de\r
        call cp_hl_de\r
        ld a,'>'\r
        call outchar\r
@@ -219,7 +217,8 @@ mainloop:
        call get_line\r
        call skipbl\r
        jr z,exe_hl\r
-       ld hl,mainloop\r
+       pop hl\r
+       push hl\r
        ld (cmd_rpt),hl\r
        inc de\r
        sub '@'\r
@@ -235,8 +234,7 @@ mainloop:
        ld l,a\r
 \r
 exe_hl:\r
-       call CALL_HL\r
-       jr mainloop\r
+       jp (hl)\r
 \r
 ;-------------------------------------------------------------------------------\r
 \r
@@ -249,25 +247,6 @@ crlf:
        jr c,mainloop\r
        ret\r
 \r
-out.hl.@:\r
-       call out_hl\r
-       push de\r
-       push hl\r
-       ld de,(var.@)\r
-       ld a,d\r
-       or e\r
-       jr z,l01bfh\r
-       call outbl\r
-       call    pstr_inl\r
-       dc      '@'\r
-       and a\r
-       sbc hl,de\r
-       call out_hl\r
-l01bfh:\r
-       pop hl\r
-       pop de\r
-       ret\r
-\r
 sub_01d9h:\r
        call    pstr_inl\r
        dc      '-'\r
@@ -557,10 +536,6 @@ l0300h:
 sub_0303h:\r
        ld hl,t_reg_names\r
        ld b,07fh\r
-       jr l030ch\r
-\r
-sub_030ah:\r
-       ld b,0ffh\r
 l030ch:\r
        inc b\r
        ld a,(hl)\r
@@ -571,10 +546,6 @@ l030ch:
        res 7,b\r
        ret\r
 \r
-sub_0318h:\r
-       push bc\r
-       res 7,b\r
-       defb 03eh               ;ld a,nn\r
 sub_031ch:\r
        push bc\r
        push de\r
@@ -988,9 +959,6 @@ do_factor:
        ld hl,TPA\r
        cp 'L'\r
        ret z\r
-       ld hl,(var.@)\r
-       cp '@'\r
-       ret z\r
        ld hl,(var.$)\r
        cp '$'\r
        ret z\r
@@ -1222,6 +1190,7 @@ p_cpustat:
 l063eh:\r
        call p_regs\r
        djnz l063eh\r
+       call outbl6\r
        push hl\r
        push de\r
        ld iy,(reg.pc)\r
@@ -1238,8 +1207,6 @@ l065bh:
        djnz l065bh\r
        pop af\r
        pop hl\r
-       call nz,outbl6\r
-       call nz,p_offset\r
        jp crlf\r
 \r
 p_f:\r
@@ -1296,12 +1263,6 @@ p_regs:
        inc hl\r
        ld d,(hl)\r
        ex de,hl\r
-       dec a\r
-       jr z,l06d9h\r
-       call out.hl.@\r
-       call z,outbl6\r
-       jr l06e2h\r
-l06d9h:\r
        call out_hl\r
        jr l06e2h\r
 l06deh:\r
@@ -1482,7 +1443,7 @@ l07cdh:
        call outbl\r
        ld l,(ix+002h)\r
        ld h,(ix+003h)\r
-       call out.hl.@\r
+       call out_hl\r
        call    pstr_inl\r
        dc      '  :'\r
        ld l,(ix+004h)\r
@@ -1906,7 +1867,7 @@ cmd_X:
        call sel_dc_string\r
 l0c12h:\r
        call l0c33h\r
-l0c15h:\r
+\r
        call outbl\r
        push de\r
        push bc\r
@@ -1940,9 +1901,7 @@ l0c33h:
        ld a,(de)\r
        dec de\r
        ld h,a\r
-       bit 1,c\r
-       jp z,out_hl\r
-       jp out.hl.@\r
+       jp out_hl\r
 \r
 l0c4fh:\r
        call p_f\r
@@ -2125,7 +2084,7 @@ cmd_S:
        call get_lastarg_def\r
 l0d60h:\r
        ld (last_S),hl\r
-       call out.hl.@\r
+       call out_hl\r
        call outbl\r
        ld a,(hl)\r
        call out_hex\r
@@ -2160,22 +2119,13 @@ l0d8ah:
 ; > @\r
 ;      examine (substitute) displacement register @\r
 \r
-cmd_@:\r
-       call assert_eol\r
-       ld hl,msg_@\r
-       ld de,var.@\r
-       ld c,001h\r
-       jp l0c12h\r
-\r
-msg_@:\r
-       dc      '@'\r
+;cmd_@:\r
 \r
 ;-------------------------------------------------------------------------------\r
 ; >>I [port]\r
 ;      Input a byte from port\r
 \r
 cmd_I:\r
-       ld hl,cmd_I\r
        ld (cmd_rpt),hl\r
        ld hl,(last_I)\r
        call get_lastarg_def\r
@@ -2195,7 +2145,6 @@ cmd_I:
 ;      Output a byte to a port\r
 \r
 cmd_O:\r
-       ld hl,cmd_O\r
        ld (cmd_rpt),hl\r
        ld hl,(last_O_val)\r
        call get_arg_def\r
@@ -2225,7 +2174,7 @@ l0dedh:
        cp b\r
        jr z,l0e10h\r
        ld c,a\r
-       call out.hl.@\r
+       call out_hl\r
        call outbl\r
        ld a,b\r
        call out_hex\r
@@ -2234,7 +2183,7 @@ l0dedh:
        call out_hex\r
        call outbl\r
        ex de,hl\r
-       call out.hl.@\r
+       call out_hl\r
        ex de,hl\r
        call crlf\r
 l0e10h:\r
@@ -2287,30 +2236,11 @@ cmdm_up:
 ;      off all loaded files, and Top address of available memory\r
 ; > H expression\r
 ;      evaluate expression and display result in hex, decimal and other formats\r
-; > H expression expression\r
-;      display sum und difference of expressions\r
 \r
 cmd_H:\r
        call expr\r
        jp c,p_max_high0\r
-       call next_arg\r
-       push hl\r
-       call expr\r
-       push af\r
        call assert_eol\r
-       pop af\r
-       ex de,hl\r
-       pop hl\r
-       jr c,l0e5eh\r
-       push hl\r
-       push de\r
-       add hl,de\r
-       call l0e5eh\r
-       pop de\r
-       pop hl\r
-       and a\r
-       sbc hl,de\r
-l0e5eh:\r
        call out_hl\r
        call outbl2\r
        call out_hl_neg\r
@@ -2490,7 +2420,6 @@ l0f42h:
 ;      Display memory in hex and ASCII\r
 \r
 cmd_D:\r
-       ld hl,cmd_D\r
        ld (cmd_rpt),hl\r
        ld hl,(last_D)\r
        ld bc,128\r
@@ -2502,7 +2431,7 @@ sub_0f58h:
        push hl\r
        push af\r
 l0f5ch:\r
-       call out.hl.@\r
+       call out_hl\r
        call z,outbl2\r
        call outbl\r
        ld de,0\r
@@ -3004,7 +2933,6 @@ l1773h:
 ;      List disassembled code\r
 \r
 cmd_L:\r
-       ld hl,cmd_L\r
        ld (cmd_rpt),hl\r
        call expr\r
        jr nc,l18dbh\r
@@ -3051,7 +2979,7 @@ cmdl_p_line:
 \r
 p_disas_line:\r
        call outbl2\r
-       call out.hl.@\r
+       call out_hl\r
        call z,outbl\r
        call outbl\r
        sub a\r
@@ -3065,19 +2993,7 @@ p_disas_line:
        call    p_goto_col\r
        ; fall thru\r
 ;-------------------------------------------------------------------------------\r
-\r
-p_offset:\r
-       ld de,(var.@)\r
-       ld a,d\r
-       or e\r
-       ret z\r
-       call    pstr_inl\r
-       dc      '(@'\r
-       and a\r
-       sbc hl,de\r
-       call out_hl\r
-       add     hl,de\r
-       jp out_rparen\r
+       ret\r
 \r
 ;-------------------------------------------------------------------------------\r
 \r
@@ -4249,7 +4165,6 @@ l2113h:
 ;     trace over Calls [No list] [Jumps only] /.While./.Until.\r
 \r
 cmd_C:\r
-       ld hl,cmd_C\r
        ld a,1\r
        jr cmd_tc\r
 \r
@@ -4261,7 +4176,6 @@ cmd_C:
 \r
 cmd_T:\r
        xor a\r
-       ld hl,cmd_T\r
 cmd_tc:\r
        ld (cmd_rpt),hl\r
        ld (trace_call_flag),a\r