Compare commits
No commits in common. "49464a58a542fa3bbe492d2a4ee43ec57171eb09" and "bf3ed7ff2472dadcea411ec0d824e1fcadc7aea2" have entirely different histories.
49464a58a5
...
bf3ed7ff24
|
@ -1,5 +1,5 @@
|
||||||
[alias]
|
[alias]
|
||||||
xtask = "run -q --package xtask --"
|
xtask = "run --package xtask --"
|
||||||
|
|
||||||
[profile.dev]
|
[profile.dev]
|
||||||
opt-level = 1
|
opt-level = 1
|
||||||
|
|
1240
Cargo.lock
generated
1240
Cargo.lock
generated
File diff suppressed because it is too large
Load diff
|
@ -6,7 +6,7 @@ resolver = "2"
|
||||||
[workspace.dependencies]
|
[workspace.dependencies]
|
||||||
log = "0.4.22"
|
log = "0.4.22"
|
||||||
env_logger = "0.11.5"
|
env_logger = "0.11.5"
|
||||||
thiserror = "1.0.65"
|
thiserror = "1.0.63"
|
||||||
raw-window-handle = "0.6.2"
|
raw-window-handle = "0.6.2"
|
||||||
gb-emu-lib = { path = "./lib", features = ["config"] }
|
gb-emu-lib = { path = "./lib", features = ["config"] }
|
||||||
frontend-common = { path = "./frontend-common" }
|
frontend-common = { path = "./frontend-common" }
|
||||||
|
|
|
@ -16,8 +16,8 @@ vulkan = ["frontend-common/vulkan"]
|
||||||
[dependencies]
|
[dependencies]
|
||||||
frontend-common = { workspace = true }
|
frontend-common = { workspace = true }
|
||||||
gb-emu-lib = { workspace = true }
|
gb-emu-lib = { workspace = true }
|
||||||
clap = { version = "4.5.20", features = ["derive"] }
|
clap = { version = "4.5.15", features = ["derive"] }
|
||||||
ctrlc = "3.4.5"
|
ctrlc = "3.4.4"
|
||||||
log = { workspace = true }
|
log = { workspace = true }
|
||||||
env_logger = { workspace = true }
|
env_logger = { workspace = true }
|
||||||
anyhow = { version = "1.0.91", features = ["backtrace"] }
|
anyhow = { version = "1.0.86", features = ["backtrace"] }
|
||||||
|
|
|
@ -89,7 +89,9 @@ struct Args {
|
||||||
/// Run debug console
|
/// Run debug console
|
||||||
#[arg(long)]
|
#[arg(long)]
|
||||||
debug: bool,
|
debug: bool,
|
||||||
|
// /// Use webcam as Pocket Camera emulation
|
||||||
|
// #[arg(short, long)]
|
||||||
|
// camera: bool,
|
||||||
/// Record frames to image sequence
|
/// Record frames to image sequence
|
||||||
#[arg(long)]
|
#[arg(long)]
|
||||||
record: bool,
|
record: bool,
|
||||||
|
|
|
@ -13,16 +13,16 @@ wgpu = ["gb-emu-lib/wgpu-renderer"]
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
gb-emu-lib = { workspace = true }
|
gb-emu-lib = { workspace = true }
|
||||||
gilrs = "0.11.0"
|
gilrs = "0.10.9"
|
||||||
cpal = { version = "0.15.3", features = ["jack"] }
|
cpal = { version = "0.15.3", features = ["jack"] }
|
||||||
futures = "0.3.31"
|
futures = "0.3.30"
|
||||||
send_wrapper = { version = "0.6.0", optional = true }
|
send_wrapper = { version = "0.6.0", optional = true }
|
||||||
winit = { version = "0.29.15", features = ["rwh_05"] }
|
winit = { version = "0.29.15", features = ["rwh_05"] }
|
||||||
winit_input_helper = "0.16.0"
|
winit_input_helper = "0.16.0"
|
||||||
raw-window-handle = { workspace = true }
|
raw-window-handle = { workspace = true }
|
||||||
serde = { version = "1.0.213", features = ["derive"] }
|
serde = { version = "1.0.205", features = ["derive"] }
|
||||||
image = { version = "0.25.4", default-features = false, features = ["png"] }
|
image = { version = "0.25.2", default-features = false, features = ["png"] }
|
||||||
bytemuck = "1.19.0"
|
bytemuck = "1.16.3"
|
||||||
chrono = "0.4.38"
|
chrono = "0.4.38"
|
||||||
log = { workspace = true }
|
log = { workspace = true }
|
||||||
anyhow = "1.0.91"
|
anyhow = "1.0.86"
|
||||||
|
|
102
frontend-common/src/camera.rs
Normal file
102
frontend-common/src/camera.rs
Normal file
|
@ -0,0 +1,102 @@
|
||||||
|
use gb_emu_lib::connect::PocketCamera;
|
||||||
|
use nokhwa::{
|
||||||
|
pixel_format,
|
||||||
|
utils::{CameraIndex, RequestedFormat, RequestedFormatType},
|
||||||
|
Camera,
|
||||||
|
};
|
||||||
|
use send_wrapper::SendWrapper;
|
||||||
|
|
||||||
|
pub struct Webcam {
|
||||||
|
camera: SendWrapper<Camera>,
|
||||||
|
scaled_buffer: [u8; 128 * 128],
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Webcam {
|
||||||
|
pub fn new() -> Self {
|
||||||
|
let format = RequestedFormat::new::<pixel_format::RgbFormat>(
|
||||||
|
RequestedFormatType::AbsoluteHighestResolution,
|
||||||
|
);
|
||||||
|
|
||||||
|
let mut camera = SendWrapper::new(
|
||||||
|
Camera::new(CameraIndex::Index(0), format).expect("Couldn't open camera"),
|
||||||
|
);
|
||||||
|
camera
|
||||||
|
.set_frame_format(nokhwa::utils::FrameFormat::YUYV)
|
||||||
|
.expect("couldnt set frame format to yuyv");
|
||||||
|
|
||||||
|
if let Ok(formats) = camera.compatible_fourcc() {
|
||||||
|
if formats.is_empty() {
|
||||||
|
println!("no compatible frame formats listed");
|
||||||
|
}
|
||||||
|
for f in formats {
|
||||||
|
println!("compatible frame format: {f:?}");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
println!("couldnt get frame formats")
|
||||||
|
}
|
||||||
|
|
||||||
|
println!("current camera format: {:?}", camera.camera_format());
|
||||||
|
|
||||||
|
if let Ok(formats) = camera.compatible_camera_formats() {
|
||||||
|
if formats.is_empty() {
|
||||||
|
println!("camera formats is empty");
|
||||||
|
}
|
||||||
|
for f in formats {
|
||||||
|
println!("supports camera format {f:?}");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
println!("couldnt get camera formats");
|
||||||
|
}
|
||||||
|
|
||||||
|
Self {
|
||||||
|
camera,
|
||||||
|
scaled_buffer: [0; 128 * 128],
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl PocketCamera for Webcam {
|
||||||
|
fn get_image(&mut self) -> [u8; 128 * 128] {
|
||||||
|
self.scaled_buffer
|
||||||
|
}
|
||||||
|
|
||||||
|
fn begin_capture(&mut self) {
|
||||||
|
let _height = self.camera.resolution().height() as usize;
|
||||||
|
let width = self.camera.resolution().width() as usize;
|
||||||
|
// let frame = self.camera.frame_raw().expect("couldn't get frame");
|
||||||
|
self.camera
|
||||||
|
.set_frame_format(nokhwa::utils::FrameFormat::RAWRGB)
|
||||||
|
.unwrap();
|
||||||
|
let frame = self.camera.frame().expect("couldn't get frame");
|
||||||
|
println!("source format: {:?}", frame.source_frame_format());
|
||||||
|
|
||||||
|
let decoded = frame
|
||||||
|
.decode_image::<pixel_format::RgbFormat>()
|
||||||
|
.expect("couldn't decode image");
|
||||||
|
let pixels = decoded.pixels().collect::<Vec<_>>();
|
||||||
|
|
||||||
|
for y in 0..128 {
|
||||||
|
for x in 0..128 {
|
||||||
|
self.scaled_buffer[y * 128 + x] = pixels[((y * width) + x) * 2][0];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn init(&mut self) {
|
||||||
|
self.camera.open_stream().expect("couldn't open stream");
|
||||||
|
self.camera
|
||||||
|
.set_frame_format(nokhwa::utils::FrameFormat::YUYV)
|
||||||
|
.unwrap();
|
||||||
|
|
||||||
|
println!(
|
||||||
|
"opened stream! current format: {:?}",
|
||||||
|
self.camera.camera_format()
|
||||||
|
);
|
||||||
|
// let format = RequestedFormat::new::<pixel_format::LumaFormat>(
|
||||||
|
// RequestedFormatType::AbsoluteHighestResolution,
|
||||||
|
// );
|
||||||
|
// self.camera
|
||||||
|
// .set_camera_requset(format)
|
||||||
|
// .expect("couldn't set format again");
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,5 +1,8 @@
|
||||||
#![feature(let_chains, if_let_guard, iter_array_chunks)]
|
#![feature(let_chains, if_let_guard, iter_array_chunks)]
|
||||||
|
|
||||||
|
#[cfg(feature = "camera")]
|
||||||
|
use camera::Webcam;
|
||||||
|
|
||||||
use gb_emu_lib::{
|
use gb_emu_lib::{
|
||||||
config::{NamedConfig, CONFIG_MANAGER},
|
config::{NamedConfig, CONFIG_MANAGER},
|
||||||
connect::{
|
connect::{
|
||||||
|
@ -16,6 +19,8 @@ use std::{
|
||||||
use window::{RendererChannel, WindowManager, WindowType};
|
use window::{RendererChannel, WindowManager, WindowType};
|
||||||
|
|
||||||
pub mod audio;
|
pub mod audio;
|
||||||
|
#[cfg(feature = "camera")]
|
||||||
|
mod camera;
|
||||||
pub mod debug;
|
pub mod debug;
|
||||||
pub mod window;
|
pub mod window;
|
||||||
|
|
||||||
|
|
|
@ -27,8 +27,8 @@ nih_plug = { workspace = true, features = [
|
||||||
"vst3",
|
"vst3",
|
||||||
], optional = true }
|
], optional = true }
|
||||||
baseview = { workspace = true, optional = true }
|
baseview = { workspace = true, optional = true }
|
||||||
async-ringbuf = { version = "0.3.1", optional = true }
|
async-ringbuf = { version = "0.2.1", optional = true }
|
||||||
futures = { version = "0.3.31", optional = true }
|
futures = { version = "0.3.30", optional = true }
|
||||||
keyboard-types = { version = "0.7.0", optional = true }
|
keyboard-types = { version = "0.6.2", optional = true }
|
||||||
raw-window-handle = { workspace = true }
|
raw-window-handle = { workspace = true }
|
||||||
serde = { version = "1.0.213", features = ["derive"] }
|
serde = { version = "1.0.205", features = ["derive"] }
|
||||||
|
|
|
@ -69,6 +69,7 @@ impl Editor for TwincEditor {
|
||||||
title: String::from("gb-emu"),
|
title: String::from("gb-emu"),
|
||||||
size,
|
size,
|
||||||
scale: baseview::WindowScalePolicy::SystemScaleFactor,
|
scale: baseview::WindowScalePolicy::SystemScaleFactor,
|
||||||
|
gl_config: Default::default(),
|
||||||
},
|
},
|
||||||
move |window| {
|
move |window| {
|
||||||
let manager = Arc::new(
|
let manager = Arc::new(
|
||||||
|
|
|
@ -24,7 +24,7 @@ adw = { version = "0.7.0", package = "libadwaita", features = [
|
||||||
], optional = true }
|
], optional = true }
|
||||||
frontend-common = { workspace = true }
|
frontend-common = { workspace = true }
|
||||||
gb-emu-lib = { workspace = true }
|
gb-emu-lib = { workspace = true }
|
||||||
gtk = { version = "0.9.2", package = "gtk4", features = [
|
gtk = { version = "0.9.0", package = "gtk4", features = [
|
||||||
"v4_12",
|
"v4_12",
|
||||||
], optional = true }
|
], optional = true }
|
||||||
twinc_emu_vst = { path = "../gb-vst", default-features = false }
|
twinc_emu_vst = { path = "../gb-vst", default-features = false }
|
||||||
|
@ -33,13 +33,13 @@ cpal = "0.15.3"
|
||||||
log = { workspace = true }
|
log = { workspace = true }
|
||||||
env_logger = { workspace = true }
|
env_logger = { workspace = true }
|
||||||
thiserror = { workspace = true }
|
thiserror = { workspace = true }
|
||||||
serde = { version = "1.0.213", features = ["derive"] }
|
serde = { version = "1.0.205", features = ["derive"] }
|
||||||
anyhow = "1.0.91"
|
anyhow = "1.0.86"
|
||||||
|
|
||||||
[target.'cfg(any(target_os = "macos"))'.dependencies]
|
[target.'cfg(any(target_os = "macos"))'.dependencies]
|
||||||
cacao = { git = "https://git.alexjanka.com/alex/cacao", optional = true }
|
cacao = { git = "https://git.alexjanka.com/alex/cacao", optional = true }
|
||||||
objc = { version = "0.5.2", package = "objc2", optional = true }
|
objc = { version = "=0.3.0-beta.3", package = "objc2", optional = true }
|
||||||
uuid = { version = "1.11.0", features = ["v4", "fast-rng"], optional = true }
|
uuid = { version = "1.10.0", features = ["v4", "fast-rng"], optional = true }
|
||||||
|
|
||||||
[build-dependencies]
|
[build-dependencies]
|
||||||
glib-build-tools = { version = "0.20.0", optional = true }
|
glib-build-tools = { version = "0.20.0", optional = true }
|
||||||
|
|
|
@ -34,12 +34,12 @@ error-colour = []
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
rand = "0.8.5"
|
rand = "0.8.5"
|
||||||
async-ringbuf = "0.3.1"
|
async-ringbuf = "0.2.1"
|
||||||
futures = "0.3.31"
|
futures = "0.3.30"
|
||||||
itertools = "0.13.0"
|
itertools = "0.13.0"
|
||||||
serde = { version = "1.0.213", features = ["derive"] }
|
serde = { version = "1.0.205", features = ["derive"] }
|
||||||
serde_with = "3.11.0"
|
serde_with = "3.9.0"
|
||||||
bytemuck = "1.19.0"
|
bytemuck = "1.16.3"
|
||||||
num-traits = "0.2.19"
|
num-traits = "0.2.19"
|
||||||
pixels = { git = "https://git.alexjanka.com/alex/pixels", optional = true }
|
pixels = { git = "https://git.alexjanka.com/alex/pixels", optional = true }
|
||||||
ash = { workspace = true, features = ["linked"], optional = true }
|
ash = { workspace = true, features = ["linked"], optional = true }
|
||||||
|
@ -54,7 +54,7 @@ lazy_static = "1.5.0"
|
||||||
wgpu = { version = "22.1.0", optional = true }
|
wgpu = { version = "22.1.0", optional = true }
|
||||||
thiserror = { workspace = true }
|
thiserror = { workspace = true }
|
||||||
log = { workspace = true }
|
log = { workspace = true }
|
||||||
anyhow = "1.0.91"
|
anyhow = "1.0.86"
|
||||||
|
|
||||||
[build-dependencies]
|
[build-dependencies]
|
||||||
naga = { version = "22.1.0", optional = true, features = [
|
naga = { version = "22.1.0", optional = true, features = [
|
||||||
|
@ -63,4 +63,4 @@ naga = { version = "22.1.0", optional = true, features = [
|
||||||
] }
|
] }
|
||||||
|
|
||||||
[target.'cfg(any(target_os = "macos", target_os = "ios"))'.dependencies]
|
[target.'cfg(any(target_os = "macos", target_os = "ios"))'.dependencies]
|
||||||
ash-molten = { version = "0.20.0", optional = true }
|
ash-molten = { version = "0.19.0", optional = true }
|
||||||
|
|
|
@ -2,30 +2,28 @@ use librashader_presets::ShaderPreset;
|
||||||
|
|
||||||
pub fn default_preset() -> ShaderPreset {
|
pub fn default_preset() -> ShaderPreset {
|
||||||
ShaderPreset {
|
ShaderPreset {
|
||||||
pass_count: 1,
|
shader_count: 1,
|
||||||
passes: vec![librashader_presets::PassConfig {
|
shaders: vec![librashader_presets::ShaderPassConfig {
|
||||||
storage: librashader_common::StorageType::String(
|
id: 0,
|
||||||
|
name: librashader_common::ShaderStorage::String(
|
||||||
include_str!("./stock.slang").to_string(),
|
include_str!("./stock.slang").to_string(),
|
||||||
),
|
),
|
||||||
meta: librashader_presets::PassMeta {
|
alias: None,
|
||||||
id: 0,
|
filter: librashader::FilterMode::Nearest,
|
||||||
alias: None,
|
wrap_mode: librashader::WrapMode::ClampToBorder,
|
||||||
filter: librashader::FilterMode::Nearest,
|
frame_count_mod: 0,
|
||||||
wrap_mode: librashader::WrapMode::ClampToBorder,
|
srgb_framebuffer: false,
|
||||||
frame_count_mod: 0,
|
float_framebuffer: false,
|
||||||
srgb_framebuffer: false,
|
mipmap_input: false,
|
||||||
float_framebuffer: false,
|
scaling: librashader_presets::Scale2D {
|
||||||
mipmap_input: false,
|
valid: false,
|
||||||
scaling: librashader_presets::Scale2D {
|
x: librashader_presets::Scaling {
|
||||||
valid: false,
|
scale_type: librashader_presets::ScaleType::Input,
|
||||||
x: librashader_presets::Scaling {
|
factor: librashader_presets::ScaleFactor::Float(1.0),
|
||||||
scale_type: librashader_presets::ScaleType::Input,
|
},
|
||||||
factor: librashader_presets::ScaleFactor::Float(1.0),
|
y: librashader_presets::Scaling {
|
||||||
},
|
scale_type: librashader_presets::ScaleType::Input,
|
||||||
y: librashader_presets::Scaling {
|
factor: librashader_presets::ScaleFactor::Float(1.0),
|
||||||
scale_type: librashader_presets::ScaleType::Input,
|
|
||||||
factor: librashader_presets::ScaleFactor::Float(1.0),
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
}],
|
}],
|
||||||
|
|
|
@ -472,7 +472,6 @@ impl VulkanWindowInner {
|
||||||
size: self.swapchain.surface_resolution.into(),
|
size: self.swapchain.surface_resolution.into(),
|
||||||
format: self.swapchain.format.format,
|
format: self.swapchain.format.format,
|
||||||
},
|
},
|
||||||
size: self.swapchain.surface_resolution.into(),
|
|
||||||
},
|
},
|
||||||
self.vulkan_data.draw_command_buffer,
|
self.vulkan_data.draw_command_buffer,
|
||||||
self.frame_counter,
|
self.frame_counter,
|
||||||
|
|
|
@ -252,7 +252,6 @@ impl RendererBackend for WgpuBackend {
|
||||||
filter_output.size().into(),
|
filter_output.size().into(),
|
||||||
filter_output.format(),
|
filter_output.format(),
|
||||||
),
|
),
|
||||||
size: filter_output.size().into(),
|
|
||||||
},
|
},
|
||||||
&mut encoder,
|
&mut encoder,
|
||||||
self.frame_num,
|
self.frame_num,
|
||||||
|
|
|
@ -6,13 +6,13 @@ edition = "2021"
|
||||||
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
clap = { version = "4.5.20", features = ["derive"] }
|
clap = { version = "4.5.15", features = ["derive"] }
|
||||||
strum = { version = "0.26.3", features = ["derive"] }
|
strum = { version = "0.26.3", features = ["derive"] }
|
||||||
duct = "0.13.7"
|
duct = "0.13.7"
|
||||||
cargo_metadata = "0.18.1"
|
cargo_metadata = "0.18.1"
|
||||||
cfg-expr = "0.17.0"
|
cfg-expr = "0.16.0"
|
||||||
pbr = "1.1.1"
|
pbr = "1.1.1"
|
||||||
serde_json = "1.0.132"
|
serde_json = "1.0.125"
|
||||||
nih_plug_xtask = { workspace = true }
|
nih_plug_xtask = { workspace = true }
|
||||||
log = { workspace = true }
|
log = { workspace = true }
|
||||||
env_logger = { workspace = true }
|
env_logger = { workspace = true }
|
||||||
|
|
|
@ -9,7 +9,11 @@ mod types;
|
||||||
static METADATA: std::sync::OnceLock<cargo_metadata::Metadata> = std::sync::OnceLock::new();
|
static METADATA: std::sync::OnceLock<cargo_metadata::Metadata> = std::sync::OnceLock::new();
|
||||||
static OUTPUT_DIR: std::sync::OnceLock<std::path::PathBuf> = std::sync::OnceLock::new();
|
static OUTPUT_DIR: std::sync::OnceLock<std::path::PathBuf> = std::sync::OnceLock::new();
|
||||||
|
|
||||||
fn executable_dir(binary: Binary, triple: impl std::fmt::Display, renderer: Renderer) -> String {
|
fn executable_dir(
|
||||||
|
binary: Binary,
|
||||||
|
triple: &cfg_expr::targets::Triple,
|
||||||
|
renderer: Renderer,
|
||||||
|
) -> String {
|
||||||
format!("{}_{}_{}", binary.name(), triple, renderer.as_feature())
|
format!("{}_{}_{}", binary.name(), triple, renderer.as_feature())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -294,7 +298,7 @@ fn cargo_exec(
|
||||||
|
|
||||||
println!("Building {package} with {renderer} renderer for target {triple}");
|
println!("Building {package} with {renderer} renderer for target {triple}");
|
||||||
|
|
||||||
let args=format!("{verb} -q -p {package} --target {triple} {release} --no-default-features -F {renderer} --message-format=json-render-diagnostics");
|
let args=format!("{verb} -q -p {package} --target {triple} {release} --no-default-features -F {renderer} --message-format=json");
|
||||||
let args = args.split_whitespace().map(|s| s.to_string());
|
let args = args.split_whitespace().map(|s| s.to_string());
|
||||||
let args = if let Some(additional_flags) = additional_flags {
|
let args = if let Some(additional_flags) = additional_flags {
|
||||||
args.chain(additional_flags).collect::<Vec<_>>()
|
args.chain(additional_flags).collect::<Vec<_>>()
|
||||||
|
@ -337,18 +341,14 @@ fn cargo_exec(
|
||||||
|
|
||||||
Ok(
|
Ok(
|
||||||
cargo_metadata::Message::parse_stream(std::io::BufReader::new(output)).inspect(move |v| {
|
cargo_metadata::Message::parse_stream(std::io::BufReader::new(output)).inspect(move |v| {
|
||||||
match v {
|
if let Some(pb) = pb.as_mut() {
|
||||||
Ok(cargo_metadata::Message::BuildScriptExecuted(_))
|
match v {
|
||||||
| Ok(cargo_metadata::Message::CompilerArtifact(_)) => {
|
Ok(cargo_metadata::Message::BuildScriptExecuted(_))
|
||||||
if let Some(pb) = pb.as_mut() {
|
| Ok(cargo_metadata::Message::CompilerArtifact(_)) => {
|
||||||
pb.inc();
|
pb.inc();
|
||||||
}
|
}
|
||||||
|
_ => {}
|
||||||
}
|
}
|
||||||
Ok(cargo_metadata::Message::CompilerMessage(message)) => {
|
|
||||||
eprintln!("{message}");
|
|
||||||
}
|
|
||||||
|
|
||||||
_ => {}
|
|
||||||
}
|
}
|
||||||
}),
|
}),
|
||||||
)
|
)
|
||||||
|
@ -368,92 +368,22 @@ fn build_vst(
|
||||||
renderer: Renderer,
|
renderer: Renderer,
|
||||||
debug: bool,
|
debug: bool,
|
||||||
) -> Result<(), Box<dyn std::error::Error>> {
|
) -> Result<(), Box<dyn std::error::Error>> {
|
||||||
|
let triple_str = triple.map(|t| t.to_string());
|
||||||
let mut args = if platform == Platform::Mac {
|
let mut args = if platform == Platform::Mac {
|
||||||
vec!["bundle-universal"]
|
vec!["bundle-universal"]
|
||||||
} else {
|
} else {
|
||||||
vec!["bundle"]
|
vec!["bundle", "--target", triple_str.as_ref().unwrap().as_str()]
|
||||||
};
|
};
|
||||||
let more_args = "twinc_emu_vst --no-default-features -F plugin";
|
|
||||||
for arg in more_args.split_whitespace() {
|
|
||||||
args.push(arg);
|
|
||||||
}
|
|
||||||
if !debug {
|
if !debug {
|
||||||
args.push("--release");
|
args.push("--release");
|
||||||
}
|
}
|
||||||
|
let more_args = "-p twinc_emu_vst --no-default-features -F plugin";
|
||||||
// we need the &str to live for this whole function
|
for arg in more_args.split_whitespace() {
|
||||||
let triple_str = triple.map(|t| t.to_string());
|
args.push(arg);
|
||||||
if platform != Platform::Mac {
|
|
||||||
args.push("--target");
|
|
||||||
args.push(triple_str.as_ref().unwrap().as_str());
|
|
||||||
}
|
}
|
||||||
args.push("-F");
|
args.push("-F");
|
||||||
let renderer = renderer.as_feature();
|
args.push(renderer.as_feature());
|
||||||
args.push(renderer);
|
|
||||||
let target_dir = METADATA
|
|
||||||
.get()
|
|
||||||
.unwrap()
|
|
||||||
.target_directory
|
|
||||||
.join(format!("xtargets/{renderer}"));
|
|
||||||
std::fs::create_dir_all(&target_dir)?;
|
|
||||||
std::env::set_var("CARGO_TARGET_DIR", target_dir.as_str());
|
|
||||||
|
|
||||||
let build_plan =
|
|
||||||
nih_plug_xtask::get_build_plan("cargo xtask", args.clone().into_iter().map(String::from))?;
|
|
||||||
let mut build_plan_iter = build_plan.into_iter();
|
|
||||||
let mut pb = build_plan_iter.next().map(|(arch, num)| {
|
|
||||||
let mut pb = pbr::ProgressBar::new(num.try_into().unwrap());
|
|
||||||
if let Some(arch) = arch {
|
|
||||||
pb.message(format!("({arch}) Building crate ").as_str());
|
|
||||||
} else {
|
|
||||||
pb.message("Building crate ");
|
|
||||||
}
|
|
||||||
pb.show_time_left = false;
|
|
||||||
pb.show_speed = false;
|
|
||||||
pb
|
|
||||||
});
|
|
||||||
|
|
||||||
let args = ["xtask"]
|
|
||||||
.into_iter()
|
|
||||||
.chain(args)
|
|
||||||
.chain(["--message-format=json-render-diagnostics"])
|
|
||||||
.collect::<Vec<_>>();
|
|
||||||
|
|
||||||
// nih_plug_xtask::ch
|
|
||||||
let output = duct::cmd("cargo", args)
|
|
||||||
.env("CARGO_TARGET_DIR", target_dir)
|
|
||||||
.stdout_capture()
|
|
||||||
.stderr_capture()
|
|
||||||
.reader()?;
|
|
||||||
|
|
||||||
for v in cargo_metadata::Message::parse_stream(std::io::BufReader::new(output)) {
|
|
||||||
match v {
|
|
||||||
Ok(cargo_metadata::Message::BuildScriptExecuted(_))
|
|
||||||
| Ok(cargo_metadata::Message::CompilerArtifact(_)) => {
|
|
||||||
if pb.as_ref().is_some_and(|pb| pb.is_finish) {
|
|
||||||
pb = build_plan_iter.next().map(|(arch, num)| {
|
|
||||||
let mut pb = pbr::ProgressBar::new(num.try_into().unwrap());
|
|
||||||
if let Some(arch) = arch {
|
|
||||||
pb.message(format!("({arch}) Building crate ").as_str());
|
|
||||||
} else {
|
|
||||||
pb.message("Building crate ");
|
|
||||||
}
|
|
||||||
pb.show_time_left = false;
|
|
||||||
pb.show_speed = false;
|
|
||||||
pb
|
|
||||||
});
|
|
||||||
}
|
|
||||||
if let Some(pb) = pb.as_mut() {
|
|
||||||
pb.inc();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Ok(cargo_metadata::Message::CompilerMessage(message)) => {
|
|
||||||
eprintln!("{message}");
|
|
||||||
}
|
|
||||||
|
|
||||||
_ => {}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
nih_plug_xtask::main_with_args("cargo xtask", args.into_iter().map(String::from))?;
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue