diff --git a/src/main.rs b/src/main.rs
index bcbda32..e76a145 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -69,39 +69,21 @@ fn parser(
 }
 
 fn main() {
-    println!("Hello, world!");
-
-    let src = "
-        morph_digit_as_char_to_uint8 (Radix:ℤ_16)
-            <Digit Radix> ~ Char ~ Ascii ~ Byte
-        --> <Digit Radix> ~ x86.UInt8 ~ Byte
-        @lib/libmorph_posint.so:src/posint.c
-
-        morph_string_as_nullterm_to_length_prefix ()
-            <Seq~<ValueDelim '\\0'> Char ~ Ascii>
-        --> <Seq~<LengthPrefix x86.UInt64> Char ~ Ascii>
-        @lib/libmorph_length-prefix.so:src/length_prefix.c
-
-        morph_string_as_length_prefix_to_nullterm ()
-            <Seq~<LengthPrefix x86.UInt64> Char ~ Ascii>
-        --> <Seq~<ValueDelim '\\0'> Char ~ Ascii>
-        @lib/libmorph_length-prefix.so:src/length_prefix.c
-    ";
-
     let type_dict = Arc::new(RwLock::new(BimapTypeDict::new()));
+    let src = std::fs::read_to_string(
+        std::env::args().nth(1).expect("expected file name")
+    ).expect("read");
 
-   let result = parser(type_dict.clone()).parse(src);
-
+    let result = parser(type_dict.clone()).parse(src.clone());
     match result {
         Ok(morphisms) => {
             println!("parse ok.");
-
             let mut dict = type_dict.write().unwrap();
 
             for m in morphisms {
                 println!("{}\n    {}\n---> \n    {}\n", m.symbol,
-                    m.src_type.normalize().sugar(&mut *dict).pretty(&mut *dict, 1),
-                    m.dst_type.normalize().sugar(&mut *dict).pretty(&mut *dict, 1),
+                    m.src_type.sugar(&mut *dict).pretty(&mut *dict, 1),
+                    m.dst_type.sugar(&mut *dict).pretty(&mut *dict, 1),
                 );
             }
         }