added c-main dependency

This commit is contained in:
Emma Tebibyte 2023-03-25 00:46:37 -04:00
parent 03e02b9882
commit 19e5f4e2f4
Signed by: emma
GPG Key ID: 6D661C738815E7DD
3 changed files with 19 additions and 9 deletions

10
Cargo.lock generated
View File

@ -30,6 +30,15 @@ version = "1.3.2"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a"
[[package]]
name = "c-main"
version = "1.0.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "797bbff8bd2bcddb7f0ee638b55398686adac15174689a86da5ffc0f51219f75"
dependencies = [
"libc",
]
[[package]] [[package]]
name = "cexpr" name = "cexpr"
version = "0.6.0" version = "0.6.0"
@ -205,6 +214,7 @@ dependencies = [
name = "tomcat" name = "tomcat"
version = "0.0.1" version = "0.0.1"
dependencies = [ dependencies = [
"c-main",
"toml", "toml",
"yacexits", "yacexits",
] ]

View File

@ -6,5 +6,6 @@ license = "AGPL-3.0-or-later"
authors = [ "Emma Tebibyte <emma@tebibyte.media>" ] authors = [ "Emma Tebibyte <emma@tebibyte.media>" ]
[dependencies] [dependencies]
c-main = "1.0.1"
toml = "0.5.9" toml = "0.5.9"
yacexits = "0.1.2" yacexits = "0.1.2"

View File

@ -16,8 +16,9 @@
* along with this program. If not, see https://www.gnu.org/licenses/. * along with this program. If not, see https://www.gnu.org/licenses/.
*/ */
#![no_main]
use std::{ use std::{
env,
fs::File, fs::File,
io::Read, io::Read,
iter::Peekable, iter::Peekable,
@ -26,6 +27,7 @@ use std::{
str::FromStr, str::FromStr,
}; };
use c_main::Args;
use toml::Value; use toml::Value;
use yacexits::*; use yacexits::*;
@ -97,8 +99,9 @@ fn parse_toml(
Ok(out) Ok(out)
} }
fn main() { #[no_mangle]
let argv: Vec<String> = env::args().collect(); fn rust_main(args: Args) {
let argv: Vec<&str> = args.into_iter().collect();
let usage_info = format!("Usage: {} [table.]key[[index]] [file...]", argv[0]); let usage_info = format!("Usage: {} [table.]key[[index]] [file...]", argv[0]);
if argv.len() <= 1 { if argv.len() <= 1 {
@ -106,15 +109,11 @@ fn main() {
exit(EX_USAGE); exit(EX_USAGE);
} }
let input: &str; let input = argv.get(2).unwrap_or(&"");
if let Some(arg) = argv.get(2) {
input = arg;
} else { input = &""; }
let mut content = Vec::new(); let mut content = Vec::new();
match input { match input.to_owned() {
"-" | "" => unsafe { File::from_raw_fd(0) }, "-" | "" => unsafe { File::from_raw_fd(0) },
_ => { _ => {
File::open(Path::new(&input)).unwrap_or_else(|_| { File::open(Path::new(&input)).unwrap_or_else(|_| {