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
mod file_utils;
mod plagiarism_database;
mod result_output_html;
mod result_printer;
mod string_compare;
mod text_utils;
use file_utils::get_file_contents_from_dir;
use plagiarism_database::{PlagiarismDatabase, PlagiarismResult};
#[derive(Copy, Clone, PartialEq, Debug)]
pub enum Metric {
Equal,
Lev,
}
pub struct AppSettings {
pub n: usize,
pub s: usize,
pub metric: Metric,
pub udir: String,
pub tdir: Option<String>,
pub idir: Option<String>,
pub output_cli: bool,
pub output_html: bool,
pub open_html_after: bool,
}
pub fn run_plagiarism_checks(appsettings: &AppSettings) {
let untrusted_contents = get_file_contents_from_dir(&appsettings.udir);
let mut ignored_texts: Vec<String> = Vec::new();
if let Some(idir) = &appsettings.idir {
let ignore_contents = get_file_contents_from_dir(&idir);
for (_, val) in ignore_contents {
ignored_texts.push(val);
}
}
let mut db = PlagiarismDatabase::new(
appsettings.n,
appsettings.s,
appsettings.metric,
ignored_texts,
);
for (id, val) in untrusted_contents {
db.add_untrusted_text(&id, &val);
}
if let Some(tdir) = &appsettings.tdir {
let trusted_contents = get_file_contents_from_dir(&tdir);
for (id, val) in trusted_contents {
db.add_trusted_text(&id, &val);
}
}
let mut ut_result: Vec<PlagiarismResult> = db.check_untrusted_plagiarism();
let mut t_result: Vec<PlagiarismResult> = db.check_trusted_plagiarism();
if appsettings.output_cli {
result_printer::print_results_ut(&mut ut_result);
result_printer::print_results_t(&mut t_result);
}
if appsettings.output_html {
ut_result.append(&mut t_result);
result_output_html::output_results(
&mut ut_result,
db.get_all_cleantext(),
appsettings.open_html_after,
);
}
}