update code format

This commit is contained in:
Konarak 2022-07-19 22:57:14 +05:30
parent f6811aeade
commit d0835a9314
5 changed files with 94 additions and 95 deletions

View File

@ -1,2 +1,2 @@
profile = janestreet
version = 0.23.0
version = 0.24.1

View File

@ -3,17 +3,17 @@ open Hack
let read_file file =
let not_empty str = not (String.is_empty str) in
List.filter (In_channel.read_lines file) ~f:(not_empty)
List.filter (In_channel.read_lines file) ~f:not_empty
;;
let outfile file = String.concat [Filename.chop_extension file; ".hack"];;
let outfile file = String.concat [ Filename.chop_extension file; ".hack" ]
let gen_hack file =
let assembly = read_file file in
let binary = Translate.translate assembly in
let outchan = Out_channel.create (outfile file) in
Out_channel.output_lines outchan binary;
Out_channel.close outchan;
Out_channel.close outchan
;;
let param =
@ -25,8 +25,7 @@ let command =
Command.basic
~summary:"Translate <filename>.asm to <filename>.hack"
~readme:(fun () -> "Assembler for project 6 of Nand2Tetris")
(Command.Param.map param ~f:(fun filename ->
(fun () -> gen_hack filename)))
(Command.Param.map param ~f:(fun filename () -> gen_hack filename))
;;
let () = Command_unix.run command;;
let () = Command_unix.run command

View File

@ -1,29 +1,33 @@
open Base
let symbols = Map.of_alist_exn (module String) [
"R0", 0;
"R1", 1;
"R2", 2;
"R3", 3;
"R4", 4;
"R5", 5;
"R6", 6;
"R7", 7;
"R8", 8;
"R9", 9;
"R10", 10;
"R11", 11;
"R12", 12;
"R13", 13;
"R14", 14;
"R15", 15;
"SP", 0;
"LCL", 1;
"ARG", 2;
"THIS", 3;
"THAT", 4;
"SCREEN", 16384;
"KBD", 24576;
let symbols =
Map.of_alist_exn
(module String)
[ "R0", 0
; "R1", 1
; "R2", 2
; "R3", 3
; "R4", 4
; "R5", 5
; "R6", 6
; "R7", 7
; "R8", 8
; "R9", 9
; "R10", 10
; "R11", 11
; "R12", 12
; "R13", 13
; "R14", 14
; "R15", 15
; "SP", 0
; "LCL", 1
; "ARG", 2
; "THIS", 3
; "THAT", 4
; "SCREEN", 16384
; "KBD", 24576
]
;;
let comp c =
match c with

View File

@ -2,61 +2,59 @@ open Base
open Ast
open Predef
(* Check if symbol(k) exists in map(map), add it if it does not. *)
let add_symbol map k d =
if Map.mem map k then map
else Map.add_exn map ~key:k ~data:d
;;
let add_symbol map k d = if Map.mem map k then map else Map.add_exn map ~key:k ~data:d
(* First Pass. FIXME *)
let rec first_pass exprs st loc =
match exprs with
| [] -> st
| (Ginstr s)::t -> first_pass t (add_symbol st s loc) loc
| Ginstr s :: t -> first_pass t (add_symbol st s loc) loc
| (Ainstr _ | Cinstr _) :: t -> first_pass t st (loc + 1)
| _ :: t -> first_pass t st loc
;;
(* Second Pass. FIXME *)
let rec second_pass exprs st loc =
let is_new s =
try Int.of_string s |> ignore; false
with Failure _ -> not (Map.mem st s) in
try
Int.of_string s |> ignore;
false
with
| Failure _ -> not (Map.mem st s)
in
match exprs with
| [] -> st
| (Ainstr a)::t when (is_new a) -> second_pass t (add_symbol st a loc) (loc + 1)
| Ainstr a :: t when is_new a -> second_pass t (add_symbol st a loc) (loc + 1)
| _ :: t -> second_pass t st loc
;;
(* Decimal to Binary . FIXME *)
let translate_ainstr addr st =
let to_int addr =
try Map.find_exn st addr
with Not_found_s _ -> Int.of_string addr in
try Map.find_exn st addr with
| Not_found_s _ -> Int.of_string addr
in
let pad binary =
let length = 16 - String.length binary in
let prefix = String.init length ~f:(fun _ -> '0') in
String.concat [prefix; binary] in
String.concat [ prefix; binary ]
in
let rec to_binary a =
match a with
| 0 -> ""
| _ ->
let rem = a % 2 in
match rem with
(match rem with
| 0 -> to_binary (a / 2) ^ "0"
| _ -> to_binary (a / 2) ^ "1" in
| _ -> to_binary (a / 2) ^ "1")
in
pad (to_binary (to_int addr))
;;
let translate_cinstr (d, c, j) =
String.concat ["111"; comp c; dest d; jump j]
;;
let translate_cinstr (d, c, j) = String.concat [ "111"; comp c; dest d; jump j ]
let rec _translate exprs st tt =
match exprs with
| [] -> tt
| (Ainstr a)::t -> translate_ainstr a st :: _translate t st tt
| (Cinstr (d, c, j))::t -> translate_cinstr (d, c, j) :: _translate t st tt
| Ainstr a :: t -> translate_ainstr a st :: _translate t st tt
| Cinstr (d, c, j) :: t -> translate_cinstr (d, c, j) :: _translate t st tt
| _ :: t -> _translate t st tt
;;
@ -66,9 +64,7 @@ let parse s =
ast
;;
let generate_exprs lines =
List.map lines ~f:parse
;;
let generate_exprs lines = List.map lines ~f:parse
let generate_st exprs =
let _st = first_pass exprs symbols 0 in

View File

@ -5,4 +5,4 @@
(library
(name hack)
(libraries base core))
(libraries base))