Skip to content

Commit

Permalink
make geode package new auto-detect binaries and auto-name the output
Browse files Browse the repository at this point in the history
  • Loading branch information
HJfod committed Apr 16, 2023
1 parent c2e4e97 commit 17a621d
Show file tree
Hide file tree
Showing 3 changed files with 44 additions and 20 deletions.
2 changes: 1 addition & 1 deletion Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[package]
name = "geode"
version = "2.2.4"
version = "2.3.0"
authors = ["HJfod <[email protected]>", "Camila314 <[email protected]>"]
edition = "2021"
build = "build.rs"
Expand Down
60 changes: 42 additions & 18 deletions src/package.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@

use std::fs;
use std::fs::{self, read_dir};
use std::io::{Read, Write, Seek};
use std::path::{Path, PathBuf};

Expand All @@ -13,7 +13,7 @@ use crate::util::cache::CacheBundle;
use crate::util::mod_file::{ModFileInfo, parse_mod_info};
use crate::util::spritesheet;
use crate::{cache, project};
use crate::{done, fail, info, warn, fatal};
use crate::{done, info, warn, fatal};

#[derive(Subcommand, Debug)]
#[clap(rename_all = "kebab-case")]
Expand All @@ -29,13 +29,16 @@ pub enum Package {
/// Location of mod's folder
root_path: PathBuf,

/// Add binary file
/// Add an external binary file. By default, all known binary files
/// (.dll, .lib, .dylib, .so) named after the mod ID in the root path
/// are included
#[clap(short, long, num_args(1..))]
binary: Vec<PathBuf>,

/// Location of output file
/// Location of output file. If not provided, the resulting file is named
/// {mod.id}.geode and placed at the root path
#[clap(short, long)]
output: PathBuf,
output: Option<PathBuf>,

/// Whether to install the generated package after creation
#[clap(short, long)]
Expand Down Expand Up @@ -255,35 +258,30 @@ fn create_package(
config: &mut Config,
root_path: &Path,
binaries: Vec<PathBuf>,
mut output: PathBuf,
raw_output: Option<PathBuf>,
do_install: bool,
) {
// Parse mod.json
let mod_file_info = parse_mod_info(root_path);

let mut output = raw_output.unwrap_or(root_path.join(format!("{}.geode", mod_file_info.id)));

// If it's a directory, add file path to it
if output.is_dir() {
output.push(root_path.file_name().unwrap());
output.push(&mod_file_info.id);
output.set_extension("geode");
warn!(
"Specified output is a directory. Creating package at {}",
output.display()
);
}

// Ensure at least one binary
if binaries.is_empty() {
fail!("No binaries added");
info!("Help: Add a binary with `--binary <bin_path>`");
return;
}

// Test if possible to create file
if !output.exists() || output.is_dir() {
fs::write(&output, "").expect("Could not create package");
fs::remove_file(&output).unwrap();
}

// Parse mod.json
let mod_file_info = parse_mod_info(root_path);

// Setup working directory
let working_dir = get_working_dir(&mod_file_info.id);

Expand Down Expand Up @@ -329,7 +327,26 @@ fn create_package(
}
}

// Copy binaries
let mut binaries_added = false;
for file in read_dir(root_path).expect("Unable to read root directory") {
let Ok(file) = file else { continue; };
let path = file.path();
let Some(name) = path.file_stem() else { continue; };
let Some(ext) = path.extension() else { continue; };
if name.to_string_lossy() == mod_file_info.id
&& matches!(
ext.to_string_lossy().as_ref(),
"ios.dylib" | "dylib" | "dll" | "lib" | "so"
)
{
let binary = name.to_string_lossy().to_string() + "." + ext.to_string_lossy().as_ref();
std::fs::copy(path, working_dir.join(&binary))
.expect(&format!("Unable to copy binary '{}'", binary));
binaries_added = true;
}
}

// Copy other binaries
for binary in &binaries {
let mut binary_name = binary.file_name().unwrap().to_str().unwrap().to_string();
if let Some(ext) = [".ios.dylib", ".dylib", ".dll", ".lib", ".so"].iter().find(|x| binary_name.contains(**x)) {
Expand All @@ -338,6 +355,13 @@ fn create_package(

std::fs::copy(binary, working_dir.join(binary_name))
.expect(&format!("Unable to copy binary at '{}'", binary.display()));
binaries_added = true;
}

// Ensure at least one binary
if !binaries_added {
warn!("No binaries added to the resulting package");
info!("Help: Add a binary with `--binary <bin_path>`");
}

new_cache.save(&working_dir);
Expand Down

0 comments on commit 17a621d

Please sign in to comment.