mirror of
https://github.com/aljazceru/cdk.git
synced 2025-12-18 13:14:59 +01:00
fix(build): use OUT_DIR for migration files (#1088)
- write generated migration files to OUT_DIR instead of source directory - copy migration SQL files to OUT_DIR for inclusion in build artifacts - use absolute paths from OUT_DIR in include_str! macros - update consumer modules to include from OUT_DIR using concat! macro these changes enable cdk to support nix sandbox builds
This commit is contained in:
@@ -1,4 +1,5 @@
|
||||
use std::cmp::Ordering;
|
||||
use std::env;
|
||||
use std::fs::{self, File};
|
||||
use std::io::Write;
|
||||
use std::path::{Path, PathBuf};
|
||||
@@ -7,11 +8,22 @@ fn main() {
|
||||
// Step 1: Find `migrations/` folder recursively
|
||||
let root = Path::new("src");
|
||||
|
||||
// Get the OUT_DIR from Cargo - this is writable
|
||||
let out_dir = PathBuf::from(env::var("OUT_DIR").expect("OUT_DIR is set by Cargo"));
|
||||
|
||||
for migration_path in find_migrations_dirs(root) {
|
||||
// Step 3: Output file path (e.g., `src/db/migrations.rs`)
|
||||
// Step 3: Output file path to OUT_DIR instead of source directory
|
||||
let parent = migration_path.parent().unwrap();
|
||||
let skip_path = parent.to_str().unwrap_or_default().len();
|
||||
let dest_path = parent.join("migrations.rs");
|
||||
|
||||
// Create a unique filename based on the migration path to avoid conflicts
|
||||
let migration_name = parent
|
||||
.strip_prefix("src")
|
||||
.unwrap_or(parent)
|
||||
.to_str()
|
||||
.unwrap_or("default")
|
||||
.replace("/", "_")
|
||||
.replace("\\", "_");
|
||||
let dest_path = out_dir.join(format!("migrations_{}.rs", migration_name));
|
||||
let mut out_file = File::create(&dest_path).expect("Failed to create migrations.rs");
|
||||
|
||||
let skip_name = migration_path.to_str().unwrap_or_default().len();
|
||||
@@ -89,10 +101,22 @@ fn main() {
|
||||
};
|
||||
|
||||
let rel_name = &path.file_name().unwrap().to_str().unwrap();
|
||||
let rel_path = &path.to_str().unwrap().replace("\\", "/")[skip_path..]; // for Windows
|
||||
|
||||
// Copy migration file to OUT_DIR
|
||||
let relative_path = path.strip_prefix(root).unwrap();
|
||||
let dest_migration_file = out_dir.join(relative_path);
|
||||
if let Some(parent) = dest_migration_file.parent() {
|
||||
fs::create_dir_all(parent)
|
||||
.expect("Failed to create migration directory in OUT_DIR");
|
||||
}
|
||||
fs::copy(path, &dest_migration_file).expect("Failed to copy migration file to OUT_DIR");
|
||||
|
||||
// Use path relative to OUT_DIR for include_str
|
||||
let relative_to_out_dir = relative_path.to_str().unwrap().replace("\\", "/");
|
||||
writeln!(
|
||||
out_file,
|
||||
" (\"{prefix}\", \"{rel_name}\", include_str!(r#\".{rel_path}\"#)),"
|
||||
" (\"{prefix}\", \"{rel_name}\", include_str!(r#\"{}\"#)),",
|
||||
relative_to_out_dir
|
||||
)
|
||||
.unwrap();
|
||||
println!("cargo:rerun-if-changed={}", path.display());
|
||||
|
||||
@@ -54,8 +54,9 @@ where
|
||||
}
|
||||
|
||||
#[rustfmt::skip]
|
||||
mod migrations;
|
||||
|
||||
mod migrations {
|
||||
include!(concat!(env!("OUT_DIR"), "/migrations_mint_auth.rs"));
|
||||
}
|
||||
|
||||
#[async_trait]
|
||||
impl<RM> MintAuthTransaction<database::Error> for SQLTransaction<RM>
|
||||
|
||||
@@ -51,8 +51,9 @@ use crate::{
|
||||
mod auth;
|
||||
|
||||
#[rustfmt::skip]
|
||||
mod migrations;
|
||||
|
||||
mod migrations {
|
||||
include!(concat!(env!("OUT_DIR"), "/migrations_mint.rs"));
|
||||
}
|
||||
|
||||
#[cfg(feature = "auth")]
|
||||
pub use auth::SQLMintAuthDatabase;
|
||||
|
||||
@@ -28,7 +28,9 @@ use crate::{
|
||||
};
|
||||
|
||||
#[rustfmt::skip]
|
||||
mod migrations;
|
||||
mod migrations {
|
||||
include!(concat!(env!("OUT_DIR"), "/migrations_wallet.rs"));
|
||||
}
|
||||
|
||||
/// Wallet SQLite Database
|
||||
#[derive(Debug, Clone)]
|
||||
|
||||
Reference in New Issue
Block a user