Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Ps 4 #107

Merged
merged 59 commits into from
Oct 24, 2011
Merged

Ps 4 #107

Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
59 commits
Select commit Hold shift + click to select a range
3ee676d
Initial commit
awatanabe Oct 14, 2011
f237fe0
Merge branch 'master' of github.com:spartango/CS153 into ps_4
awatanabe Oct 14, 2011
b8df54f
Added ps3 compile code to ps4
awatanabe Oct 14, 2011
ab66aba
Added utility file.
awatanabe Oct 14, 2011
2e4acd4
Allows compilation with old compile code
awatanabe Oct 14, 2011
e622b93
Implemented load and store
awatanabe Oct 14, 2011
fef3576
Implemented load and store
awatanabe Oct 14, 2011
a9761fd
minor changes
spartango Oct 14, 2011
2aa6ed6
unmessed up merging lol
spartango Oct 14, 2011
966adb6
Merge branch 'ps_4' of github.com:spartango/CS153 into ps_4
awatanabe Oct 19, 2011
4ce5010
added description of env
spartango Oct 19, 2011
96db18c
Pulling env into its own nice file
spartango Oct 19, 2011
35ef913
moving things around to create a coherent flow in the logic
spartango Oct 19, 2011
8f94119
moving stuff around still...adding lookup
spartango Oct 19, 2011
12cfff8
moving to a mode where i dont build asts by hand, cause that sucks
spartango Oct 19, 2011
5f33b4e
adding env push
spartango Oct 19, 2011
233c2ff
fixed up stuff so it actually compiles
spartango Oct 19, 2011
be74062
starting to fill in compile unit
spartango Oct 22, 2011
6e9db33
added real stubs
spartango Oct 22, 2011
0e680d4
Added int compile
awatanabe Oct 22, 2011
85c95a5
added virtual stack for code gen
spartango Oct 22, 2011
1a20699
Merge branch 'ps_4_env' of github.com:spartango/CS153 into ps_4_call
awatanabe Oct 22, 2011
cfda67e
minor change
spartango Oct 22, 2011
558be9c
Updated changes from ps_4_env
awatanabe Oct 22, 2011
71de648
Re-implemented int
awatanabe Oct 22, 2011
efea561
pseudocode
spartango Oct 22, 2011
cda0f97
Added lookup calls
spartango Oct 22, 2011
4d6bfba
Put in integer junk
spartango Oct 22, 2011
240e2eb
moving toward proper stack use, intermediate commit
spartango Oct 22, 2011
9d6c452
moivng toward closure
spartango Oct 22, 2011
448b7b9
implemented closure
spartango Oct 22, 2011
a88d5bc
Helpers for PrimApp
awatanabe Oct 22, 2011
8744e26
Put in if code, untested
spartango Oct 22, 2011
0d65816
Fixed int
awatanabe Oct 22, 2011
32c5fec
Merge branch 'ps_4_call' of github.com:spartango/CS153 into ps_4_env
spartango Oct 22, 2011
37ee24c
merge effects
spartango Oct 22, 2011
eabde1c
compiles
spartango Oct 22, 2011
caa3ab5
Implementation of Cons
awatanabe Oct 22, 2011
dd4c79e
Fixed bugs in PrimApp code to allow for compile
awatanabe Oct 22, 2011
56e956b
Compling code and works for single integers
awatanabe Oct 23, 2011
5119b6f
Allowing for binop compilation
awatanabe Oct 23, 2011
388368d
Gave temps and function their own counters
awatanabe Oct 23, 2011
41a9b50
Binops compiling and running
awatanabe Oct 23, 2011
111c536
Continued code cleanup
awatanabe Oct 23, 2011
a635e02
Fixed stack overflow for closure creation
awatanabe Oct 23, 2011
cee8652
Changed compile_exp so main is appended onto function list
awatanabe Oct 23, 2011
7743f93
Changed implementation of init_env/result
awatanabe Oct 23, 2011
2f1c69d
Reorganized location of some functions
awatanabe Oct 23, 2011
cfaa121
Compiles and runs correctly
awatanabe Oct 23, 2011
dd27273
cleaned up code in compile
awatanabe Oct 23, 2011
0fb04db
Added some comments
awatanabe Oct 23, 2011
c10bf8e
fixed a cons bug and added tests
spartango Oct 24, 2011
d54bb01
Fixed error in access_mem
awatanabe Oct 24, 2011
234ab57
Merge branch 'ps_4_call' of github.com:spartango/CS153 into ps_4_call
awatanabe Oct 24, 2011
93d7733
added a fancier test
spartango Oct 24, 2011
3c228cc
Added guard for length of exps list for primaps
awatanabe Oct 24, 2011
fc0fde9
Merge branch 'ps_4_call' of github.com:spartango/CS153 into ps_4_call
awatanabe Oct 24, 2011
dd6602e
minor test stuff
spartango Oct 24, 2011
643a119
Merge pull request #106 from spartango/ps_4_call
spartango Oct 24, 2011
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
fixed a cons bug and added tests
  • Loading branch information
spartango committed Oct 24, 2011
commit c10bf8e430180543f3b3d720d9b9860192ddaac2
13 changes: 11 additions & 2 deletions ps4/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
# change to a different ocamlc if you prefer (e.g., ocamlopt)
COMPILER=ocamlc

all: clean cish scish
all: clean cish cish_stdin scish scish_stdin

mips:
$(COMPILER) -c word32.ml
Expand All @@ -23,6 +23,10 @@ cish: mips
$(COMPILER) -c cish.ml
$(COMPILER) -o ps4_cish cish_ast.cmo cish_parse.cmo cish_lex.cmo cish_eval.cmo word32.cmo mips.cmo utility.cmo cish_compile.cmo cish.cmo

cish_stdin: cish
$(COMPILER) -c cish_stdin.ml
$(COMPILER) -o ps4_cish_stdin cish_ast.cmo cish_parse.cmo cish_lex.cmo cish_eval.cmo word32.cmo mips.cmo utility.cmo cish_compile.cmo cish_stdin.cmo

scish: cish mips
$(COMPILER) -c cish_ast.ml
$(COMPILER) -c scish_ast.ml
Expand All @@ -37,6 +41,11 @@ scish: cish mips
$(COMPILER) -c scish.ml
$(COMPILER) -o ps4_scish cish_ast.cmo cish_parse.cmo cish_lex.cmo scish_ast.cmo scish_parse.cmo scish_lex.cmo scish_eval.cmo utility.cmo word32.cmo mips.cmo environment.cmo scish_compile.cmo scish.cmo

scish_stdin: scish
$(COMPILER) -c scish_stdin.ml
$(COMPILER) -o ps4_scish_stdin cish_ast.cmo cish_parse.cmo cish_lex.cmo scish_ast.cmo scish_parse.cmo scish_lex.cmo scish_eval.cmo utility.cmo word32.cmo mips.cmo environment.cmo scish_compile.cmo scish_stdin.cmo


clean:
rm -rf *.cmo *.cmi ps4_cish ps4_scish cish_parse.ml cish_parse.mli cish_lex.ml scish_parse.ml scish_parse.mli scish_lex.ml
rm -rf *.cmo *.cmi ps4_cish ps4_scish ps4_cish_stdin ps4_scish_stdin cish_parse.ml cish_parse.mli cish_lex.ml scish_parse.ml scish_parse.mli scish_lex.ml

27 changes: 27 additions & 0 deletions ps4/cish_stdin.ml
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
open Cish_ast
open Cish_eval

(* This magic is used to glue the generated lexer and parser together.
* Expect one command-line argument, a file to parse.
* You do not need to understand this interaction with the system. *)
let parse_file() =
let argv = Sys.argv in
let _ =
if Array.length argv != 2
then (prerr_string ("usage: " ^ argv.(0) ^ " [file-to-parse]\n");
exit 1) in
let ch = open_in argv.(1) in
Cish_parse.program Cish_lex.lexer (Lexing.from_channel ch)

let parse_stdin() =
Cish_parse.program Cish_lex.lexer (Lexing.from_channel stdin)

let compile_prog prog =
Cish_compile.result2string (Cish_compile.compile prog )

(* Reads in cish code and evaluates it *)
let _ =
let prog = parse_stdin() in
let ans = eval prog in
print_string ("answer = "^(val2string ans)^"\n")
(* print_string (compile_prog prog) *)
5 changes: 3 additions & 2 deletions ps4/scish_compile.ml
Original file line number Diff line number Diff line change
Expand Up @@ -72,9 +72,10 @@ let rec compile_exp_r ( t_expr : Scish_ast.exp )
let store_stmt1 = cish_stmt_from_str ("*(" ^ tuple_address ^ ") = " ^ result_name ^ ";") in
(* Compile second expression, placing result in result *)
let (f_list2, scope2, stmt2) = compile_exp_r (List.nth exps 1) f_list1 scope1 in
(* Store result in second word at tupele's address *)
(* Store result in second word at tuple's address *)
let store_stmt2 = cish_stmt_from_str ("*(" ^ tuple_address ^ "+4) = " ^ result_name ^ ";") in
(f_list2, scope2, (init_var tuple_address (seqs [init_stmt; stmt1; store_stmt1; stmt2; store_stmt2])))
let mv_result = cish_stmt_from_str (result_name^" = "^tuple_address^";") in
(f_list2, scope2, (init_var tuple_address (seqs [init_stmt; stmt1; store_stmt1; stmt2; store_stmt2; mv_result])))
(* create a pair *)
| Fst -> access_mem (List.hd exps) f_list scope 0
| Snd -> access_mem (List.hd exps) f_list scope 4
Expand Down
31 changes: 31 additions & 0 deletions ps4/scish_stdin.ml
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
open Scish_ast
open Scish_eval

(* This magic is used to glue the generated lexer and parser together.
* Expect one command-line argument, a file to parse.
* You do not need to understand this interaction with the system. *)
let parse_file () =
let argv = Sys.argv in
let _ =
if Array.length argv != 2
then (prerr_string ("usage: " ^ argv.(0) ^ " [file-to-parse]\n");
exit 1) in
let ch = open_in argv.(1) in
Scish_parse.program Scish_lex.lexer (Lexing.from_channel ch)

let parse_stdin () =
Scish_parse.program Scish_lex.lexer (Lexing.from_channel stdin)

let compile_prog prog = Scish_compile.compile_exp prog

let run_prog prog = Scish_eval.run prog

let dump p = print_string (Cish_ast.prog2string p)

let _ =
let prog = parse_stdin() in
(*
let _ = print_string ("answer = "^(string_of_int ans)^"\n") in
*)

dump (compile_prog prog)
1 change: 1 addition & 0 deletions ps4/test/if.scish
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
((lambda (x) (if (< x 5) (* x 5) (* x 2))) 10)
1 change: 1 addition & 0 deletions ps4/test/sample_add.scish
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
(+ 5 4)
1 change: 1 addition & 0 deletions ps4/test/sample_cons.scish
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
(fst (cons 5 4))
1 change: 1 addition & 0 deletions ps4/test/shadow.scish
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
(((lambda (x) (lambda (x) (+ x x))) 42) 3)
1 change: 1 addition & 0 deletions ps4/test/square.scish
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
((lambda (x) (* x x)) 5)