Remove unneeded stuff from image-converter

This commit is contained in:
Gwilym Inzani 2023-04-13 22:14:44 +01:00
parent f53cd9b25a
commit 875a0fbb65
11 changed files with 14 additions and 194 deletions

View file

@ -12,8 +12,6 @@ proc-macro = true
[dependencies] [dependencies]
image = { version = "0.23", default-features = false, features = [ "png", "bmp" ] } image = { version = "0.23", default-features = false, features = [ "png", "bmp" ] }
toml = "0.7"
serde = { version = "1", features = ["derive"] }
syn = { version = "2", features = ["full"] } syn = { version = "2", features = ["full"] }
proc-macro2 = "1" proc-macro2 = "1"
quote = "1" quote = "1"

View file

@ -1,25 +1,7 @@
use serde::Deserialize;
use std::collections::HashMap; use std::collections::HashMap;
use std::fs;
use crate::{Colour, Colours, TileSize}; use crate::{Colour, Colours, TileSize};
pub(crate) fn parse(filename: &str) -> Box<dyn Config> {
let config_toml =
fs::read_to_string(filename).unwrap_or_else(|_| panic!("Failed to read file {filename}"));
let config: ConfigV1 = toml::from_str(&config_toml).expect("Failed to parse file");
if config.version != "1.0" {
panic!(
"Expected version of {} to be 1.0, got {}",
filename, config.version
);
}
Box::new(config)
}
pub(crate) trait Config { pub(crate) trait Config {
fn crate_prefix(&self) -> String; fn crate_prefix(&self) -> String;
fn images(&self) -> HashMap<String, &dyn Image>; fn images(&self) -> HashMap<String, &dyn Image>;
@ -31,96 +13,3 @@ pub(crate) trait Image {
fn tile_size(&self) -> TileSize; fn tile_size(&self) -> TileSize;
fn colours(&self) -> Colours; fn colours(&self) -> Colours;
} }
#[derive(Deserialize)]
pub struct ConfigV1 {
version: String,
crate_prefix: Option<String>,
transparent_colour: Option<String>,
image: HashMap<String, ImageV1>,
}
impl Config for ConfigV1 {
fn crate_prefix(&self) -> String {
self.crate_prefix
.clone()
.unwrap_or_else(|| "agb".to_owned())
}
fn images(&self) -> HashMap<String, &dyn Image> {
self.image
.iter()
.map(|(filename, image)| (filename.clone(), image as &dyn Image))
.collect()
}
fn transparent_colour(&self) -> Option<Colour> {
if let Some(colour) = &self
.transparent_colour
.as_ref()
.map(|colour| colour.parse().unwrap())
{
return Some(*colour);
}
self.image
.values()
.flat_map(|image| image.transparent_colour())
.next()
}
}
#[derive(Deserialize)]
pub struct ImageV1 {
filename: String,
transparent_colour: Option<String>,
tile_size: TileSizeV1,
colours: Option<u32>,
}
impl Image for ImageV1 {
fn filename(&self) -> String {
self.filename.clone()
}
fn tile_size(&self) -> TileSize {
self.tile_size.into()
}
fn colours(&self) -> Colours {
match self.colours {
None | Some(16) => Colours::Colours16,
Some(256) => Colours::Colours256,
_ => panic!("colours must either not be set or 16 or 256"),
}
}
}
impl ImageV1 {
fn transparent_colour(&self) -> Option<Colour> {
self.transparent_colour
.as_ref()
.map(|colour| colour.parse().unwrap())
}
}
#[derive(Deserialize, Clone, Copy)]
pub enum TileSizeV1 {
#[serde(rename = "8x8")]
Tile8,
#[serde(rename = "16x16")]
Tile16,
#[serde(rename = "32x32")]
Tile32,
}
impl From<TileSizeV1> for TileSize {
fn from(item: TileSizeV1) -> Self {
match item {
TileSizeV1::Tile8 => TileSize::Tile8,
TileSizeV1::Tile16 => TileSize::Tile16,
TileSizeV1::Tile32 => TileSize::Tile32,
}
}
}

View file

@ -29,8 +29,6 @@ use colour::Colour;
#[derive(Debug, Clone, Copy)] #[derive(Debug, Clone, Copy)]
pub(crate) enum TileSize { pub(crate) enum TileSize {
Tile8, Tile8,
Tile16,
Tile32,
} }
#[derive(Debug, Clone, Copy)] #[derive(Debug, Clone, Copy)]
@ -43,8 +41,6 @@ impl TileSize {
fn to_size(self) -> usize { fn to_size(self) -> usize {
match self { match self {
TileSize::Tile8 => 8, TileSize::Tile8 => 8,
TileSize::Tile16 => 16,
TileSize::Tile32 => 32,
} }
} }
} }
@ -176,31 +172,6 @@ pub fn include_background_gfx(input: TokenStream) -> TokenStream {
include_gfx_from_config(config, module_name, Path::new(&root)) include_gfx_from_config(config, module_name, Path::new(&root))
} }
#[proc_macro]
pub fn include_gfx(input: TokenStream) -> TokenStream {
let input = parse_macro_input!(input as syn::LitStr);
let filename = input.value();
let root = std::env::var("CARGO_MANIFEST_DIR").expect("Failed to get cargo manifest dir");
let path = Path::new(&root).join(&*filename);
let config = config::parse(&path.to_string_lossy());
let parent = path
.parent()
.expect("Expected a parent directory for the path");
let module_name = format_ident!(
"{}",
path.file_stem()
.expect("Expected a file stem")
.to_string_lossy()
);
include_gfx_from_config(config, module_name, parent)
}
fn include_gfx_from_config( fn include_gfx_from_config(
config: Box<dyn config::Config>, config: Box<dyn config::Config>,
module_name: syn::Ident, module_name: syn::Ident,

View file

@ -1,22 +0,0 @@
version = "1.0"
transparent_colour = "121105"
[image.stars]
filename = "stars.png"
tile_size = "8x8"
[image.title]
filename = "title-screen.png"
tile_size = "8x8"
[image.help]
filename = "help-text.png"
tile_size = "8x8"
[image.descriptions1]
filename = "descriptions1.png"
tile_size = "8x8"
[image.descriptions2]
filename = "descriptions2.png"
tile_size = "8x8"

View file

@ -1,11 +1,17 @@
use agb::{ use agb::{
display::tiled::{RegularMap, TileFormat, TileSet, TileSetting, TiledMap, VRamManager}, display::tiled::{RegularMap, TileFormat, TileSet, TileSetting, TiledMap, VRamManager},
include_gfx, rng, include_background_gfx, rng,
}; };
use crate::sfx::Sfx; use crate::sfx::Sfx;
include_gfx!("gfx/backgrounds.toml"); include_background_gfx!(backgrounds, "121105",
stars => "gfx/stars.png",
title => "gfx/title-screen.png",
help => "gfx/help-text.png",
descriptions1 => "gfx/descriptions1.png",
descriptions2 => "gfx/descriptions2.png",
);
pub fn load_palettes(vram: &mut VRamManager) { pub fn load_palettes(vram: &mut VRamManager) {
vram.set_background_palettes(backgrounds::PALETTES); vram.set_background_palettes(backgrounds::PALETTES);

View file

@ -1,11 +0,0 @@
version = "1.0"
transparent_colour = "2ce8f4"
[image.thanks_for_playing]
filename = "thanks_for_playing.png"
tile_size = "8x8"
[image.splash]
filename = "splash.png"
tile_size = "8x8"

View file

@ -1,7 +0,0 @@
version = "1.0"
transparent_colour = "2ce8f4"
[image.background]
filename = "tile_sheet.png"
tile_size = "8x8"

View file

@ -101,7 +101,7 @@ mod map_tiles {
} }
} }
agb::include_gfx!("gfx/tile_sheet.toml"); agb::include_background_gfx!(tile_sheet, "2ce8f4", background => "gfx/tile_sheet.png");
const GRAPHICS: &Graphics = agb::include_aseprite!("gfx/sprites.aseprite"); const GRAPHICS: &Graphics = agb::include_aseprite!("gfx/sprites.aseprite");
const TAG_MAP: &TagMap = GRAPHICS.tags(); const TAG_MAP: &TagMap = GRAPHICS.tags();

View file

@ -1,7 +1,10 @@
use super::sfx::SfxPlayer; use super::sfx::SfxPlayer;
use agb::display::tiled::{RegularMap, TileFormat, TileSet, TileSetting, TiledMap, VRamManager}; use agb::display::tiled::{RegularMap, TileFormat, TileSet, TileSetting, TiledMap, VRamManager};
agb::include_gfx!("gfx/splash_screens.toml"); agb::include_background_gfx!(splash_screens,
splash => "gfx/splash.png",
thanks_for_playing => "gfx/thanks_for_playing.png",
);
pub enum SplashScreen { pub enum SplashScreen {
Start, Start,

View file

@ -1,7 +0,0 @@
version = "1.0"
transparent_colour = "53269a"
[image.background]
filename = "background.png"
tile_size = "8x8"

View file

@ -57,7 +57,7 @@ const SWORDLESS_JUMP: &Tag = TAG_MAP.get("jump swordless");
const SWORDLESS_ATTACK: &Tag = KNIFE_ATTACK; const SWORDLESS_ATTACK: &Tag = KNIFE_ATTACK;
const SWORDLESS_JUMP_ATTACK: &Tag = KNIFE_JUMP_ATTACK; const SWORDLESS_JUMP_ATTACK: &Tag = KNIFE_JUMP_ATTACK;
agb::include_gfx!("gfx/background.toml"); agb::include_background_gfx!(background, "53269a", background => "gfx/background.png");
type Number = FixedNum<8>; type Number = FixedNum<8>;