working on pass 2
This commit is contained in:
parent
7810346819
commit
f79aa96359
4 changed files with 83 additions and 7 deletions
30
ass3/zbirnik/lib/encoder.ml
Normal file
30
ass3/zbirnik/lib/encoder.ml
Normal file
|
|
@ -0,0 +1,30 @@
|
|||
(*naloga encoderja je, da pretvarja iz lineSemantic tipa v stringe ki jih appendamo v object file*)
|
||||
|
||||
open SemanticAnalyzer
|
||||
(*vrne H vrstico*)
|
||||
let getZaglavje (prviUkaz : lineSemantic) (lenProg : int) : string list =
|
||||
let name = match prviUkaz.label with
|
||||
| None -> "MOJPROG" (*default ime*)
|
||||
| Some s -> if String.length s > 6 then "MOJPROG" else String.make (6 - String.length s) '0' ^ s (*paddamo z 0 če je < 6*)
|
||||
in
|
||||
let startAddr = match prviUkaz.mnem with
|
||||
| MnemonicDn s -> (*preverimo ali je pravilne dolzine in naredimo string dolzine 6*)
|
||||
let n = int_of_string s in
|
||||
if n < 0 || n > 0xFFFFFF then
|
||||
invalid_arg "getZaglavje: zacetni naslov out of range"
|
||||
else
|
||||
Printf.sprintf "%06X" n
|
||||
| _ -> failwith "getZaglavje: invalid mnemonic_type"
|
||||
in
|
||||
let lenObjectCode = Printf.sprintf "%06X" lenProg in
|
||||
["H" ^ name ^ startAddr ^ lenObjectCode] (*vrnemo concatiniran string in startAddr*)
|
||||
|
||||
|
||||
(*vrne T vrstico*)
|
||||
let instructionList_to_objectCode (instructionList : string list) (startAddr : int) : string =
|
||||
|
||||
let startAddr = Printf.sprintf "%06X" startAddr in
|
||||
let objectCode = String.concat "" instructionList in
|
||||
let len = (String.length objectCode) / 2 in (*delimo z dva ker hočemo dolžino v bytih ne nibblih*)
|
||||
let lenString = Printf.sprintf "%02X" len in
|
||||
"T" ^ startAddr ^ lenString ^ objectCode (*vrnemo concatiniran T zapis*)
|
||||
Loading…
Add table
Add a link
Reference in a new issue