strafe-client-jed/src/roblox_legacy.rs

93 lines
2.8 KiB
Rust
Raw Normal View History

2024-02-13 00:13:04 -08:00
use std::io::Read;
use std::collections::HashMap;
2024-02-14 23:45:16 -08:00
use crate::texture::{Texture,RenderConfigs};
use strafesnet_common::model::{TextureId,RenderConfigId,RenderConfig};
2024-02-13 00:13:04 -08:00
2024-02-13 00:48:30 -08:00
#[derive(Hash,Eq,PartialEq)]
struct RobloxAssetId(u64);
#[derive(Debug)]
pub struct RobloxAssetIdParseErr(String);
impl std::str::FromStr for RobloxAssetId{
type Err=RobloxAssetIdParseErr;
fn from_str(s:&str)->Result<Self,Self::Err>{
let regman=lazy_regex::regex!(r"(\d+)$");
if let Some(captures)=regman.captures(s){
if captures.len()==2{//captures[0] is all captures concatenated, and then each individual capture
if let Ok(id)=captures[0].parse::<u64>(){
return Ok(Self(id));
}
}
}
Err(RobloxAssetIdParseErr(s.to_owned()))
}
}
impl std::fmt::Display for RobloxAssetIdParseErr{
fn fmt(&self,f:&mut std::fmt::Formatter<'_>)->std::fmt::Result{
write!(f,"{self:?}")
}
}
impl std::error::Error for RobloxAssetIdParseErr{}
2024-02-13 19:48:47 -08:00
pub struct Loader{
2024-02-14 23:45:16 -08:00
texture_count:u32,
render_configs:Vec<RenderConfig>,
render_config_id_from_asset_id:HashMap<Option<RobloxAssetId>,RenderConfigId>,
2024-02-13 00:13:04 -08:00
}
2024-02-13 19:48:47 -08:00
impl Loader{
2024-02-13 00:13:04 -08:00
pub fn new()->Self{
Self{
2024-02-14 23:45:16 -08:00
texture_count:0,
render_configs:Vec::new(),
render_config_id_from_asset_id:HashMap::new(),
2024-02-13 00:13:04 -08:00
}
}
}
2024-02-13 19:48:47 -08:00
impl Loader{
2024-02-14 23:45:16 -08:00
pub fn acquire_render_config_id(&mut self,name:Option<&str>)->RenderConfigId{
let render_id=RenderConfigId::new(self.render_config_id_from_asset_id.len() as u32);
let index=name.and_then(|name|{
match name.parse::<RobloxAssetId>(){
Ok(asset_id)=>Some(asset_id),
Err(e)=>{
println!("Failed to parse AssetId: {e}");
None
},
}
});
*self.render_config_id_from_asset_id.entry(index).or_insert_with(||{
//create the render config.
let render_config=if name.is_some(){
let render_config=RenderConfig::texture(TextureId::new(self.texture_count));
self.texture_count+=1;
render_config
}else{
RenderConfig::default()
};
self.render_configs.push(render_config);
render_id
})
2024-02-13 00:13:04 -08:00
}
2024-02-14 23:45:16 -08:00
pub fn into_render_configs(mut self)->Result<RenderConfigs,std::io::Error>{
let mut sorted_textures=vec![None;self.texture_count as usize];
for (asset_id,render_config_id) in self.render_config_id_from_asset_id{
let render_config=self.render_configs.get_mut(render_config_id.get() as usize).unwrap();
if let (Some(asset_id),Some(texture_id))=(asset_id,render_config.texture){
let path=std::path::PathBuf::from(format!("textures/{}.dds",asset_id.0));
if let Ok(mut file)=std::fs::File::open(path){
//TODO: parallel
let mut data=Vec::<u8>::new();
file.read_to_end(&mut data)?;
sorted_textures[texture_id.get() as usize]=Some(Texture::ImageDDS(data));
}else{
//texture failed to load
render_config.texture=None;
}
2024-02-13 00:13:04 -08:00
}
}
2024-02-14 23:45:16 -08:00
Ok(RenderConfigs::new(
sorted_textures,
self.render_configs,
))
2024-02-13 00:13:04 -08:00
}
}