1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
use serde::{Serialize, Deserialize};

use shm_rs::static_scheme::generator::RustCode;
use shm_rs::static_scheme::init;
use shm_rs::dynamic_scheme::environment;
use shm_rs::serializator::serializator;


#[derive(Clone, Debug, Serialize, Deserialize)]
pub struct LdActionExec 
{ 
    pub executable: String
}


#[derive(Clone, Debug, Serialize, Deserialize)]
pub struct LdGrep 
{ 
    pub regex_str: String
}


#[derive(Clone, Debug, Serialize, Deserialize)]
pub struct LdActionBlock 
{ 
    pub exec_pipeline: Vec<LdActionExec>,
    pub grep_pipe: Option<LdGrep>
}


#[derive(Clone, Debug, Serialize, Deserialize)]
pub struct LdAction 
{ 
    pub action_block: Option<LdActionBlock>,
    pub action_unblock: Option<LdActionBlock>
}

fn main()
{
    let control_inst = 
        LdAction
        {
            action_block: 
                Some(
                    LdActionBlock
                    {
                        exec_pipeline: 
                            vec![
                                LdActionExec { executable: "test1".to_string() },
                                LdActionExec { executable: "test2".to_string() },
                            ],
                        grep_pipe:
                            Some(
                                LdGrep { regex_str: "grep1".to_string() }
                            ),
                    }
                ),
            action_unblock: 
                Some(
                    LdActionBlock 
                    { 
                        exec_pipeline: 
                            vec![
                                LdActionExec { executable: "unblock_test".to_string() },
                            ], 
                        grep_pipe: None 
                    }
                ),
        };

    let curdir = std::env::current_dir().unwrap();

    println!("{}", curdir.display());

    let schm = init::SchemeInit::new_with_path(curdir).unwrap();

    let res = schm.run_from_file("examples/scheme_common_struct/schm_init.shm", None).unwrap();

    let resser = res.get("test_common").unwrap().clone();

    let mut curdir = std::env::current_dir().unwrap();

    curdir.push("examples/scheme_common_struct/schm_dyn.shm");

   // let lex = lexer::Lexer::from_file(curdir).unwrap();
    let (_dynenv, dyn_res) = 
        environment::DynEnvironment::from_file(curdir, resser.clone()).unwrap();
   // let dynenv = environment::DynEnvironment::new_root(resser.clone());

    //let dyn_res = environment::DynEnvironment::run(&lex, dynenv).unwrap();

    let ret = serializator::Serialization::serialize(resser.clone(), dyn_res.clone()).unwrap();

    let serialized = serde_json::to_string(&ret).unwrap();

    println!("Serialized:\n{}", serialized);

    let ctrl_ser = serde_json::to_string(&control_inst).unwrap();

    if ctrl_ser == serialized
    {
        println!("matched!");
    }
    else
    {
        panic!("unmatched");
    }

    let _: LdAction = serde_json::from_str(&ctrl_ser).unwrap();

    let mut rc = RustCode::new(&["Clone", "Debug", "Serialize", "Deserialize"], &["Clone", "Debug", "Serialize", "Deserialize"]);
    println!("Structures: ");
    match resser.generate_rust_structs(&mut rc)
    {
        Ok(_) => 
        {
            println!("{}", rc);
        },
        Err(e) => 
        {
            println!("{}", e);
        }
    }
}