Split repos in their own modules
also start working on collections Signed-off-by: Luca Fulchir <luca.fulchir@runesauth.com>
This commit is contained in:
parent
081d0ecbc1
commit
2e75c8a8f9
@ -257,6 +257,7 @@ pub(crate) fn deps_build(
|
|||||||
let vis = local.vis;
|
let vis = local.vis;
|
||||||
|
|
||||||
let pkg_trait = quote::format_ident!("BokDeps{}", ident);
|
let pkg_trait = quote::format_ident!("BokDeps{}", ident);
|
||||||
|
let pkg_builder_trait = quote::format_ident!("BokBuilderDeps{}", ident);
|
||||||
|
|
||||||
use ::convert_case::{Case, Casing};
|
use ::convert_case::{Case, Casing};
|
||||||
let deps = packages
|
let deps = packages
|
||||||
@ -280,6 +281,11 @@ pub(crate) fn deps_build(
|
|||||||
#(fn #deps(&self) -> ::std::boxed::Box<dyn ::bok::Pkg>;)
|
#(fn #deps(&self) -> ::std::boxed::Box<dyn ::bok::Pkg>;)
|
||||||
*
|
*
|
||||||
}
|
}
|
||||||
|
#[::macro_magic::export_tokens(#pkg_builder_trait)]
|
||||||
|
pub trait #pkg_builder_trait {
|
||||||
|
#(fn #deps(&self) -> ::std::boxed::Box<dyn ::bok::PkgBuilder>;)
|
||||||
|
*
|
||||||
|
}
|
||||||
}
|
}
|
||||||
.into()
|
.into()
|
||||||
}
|
}
|
||||||
@ -988,6 +994,12 @@ pub(crate) fn derive_package(input: TokenStream) -> TokenStream {
|
|||||||
use ::bok::Pkg;
|
use ::bok::Pkg;
|
||||||
#name::<R>::default().version()
|
#name::<R>::default().version()
|
||||||
}
|
}
|
||||||
|
fn as_any(&self) -> &dyn ::std::any::Any {
|
||||||
|
self
|
||||||
|
}
|
||||||
|
fn as_any_mut(&mut self) -> &mut dyn ::std::any::Any {
|
||||||
|
self
|
||||||
|
}
|
||||||
fn default_unused(&mut self) -> &mut dyn ::bok::PkgBuilder {
|
fn default_unused(&mut self) -> &mut dyn ::bok::PkgBuilder {
|
||||||
let def = #name::<R>::default();
|
let def = #name::<R>::default();
|
||||||
#(if self.#non_opt_fields5.is_none() {
|
#(if self.#non_opt_fields5.is_none() {
|
||||||
|
@ -193,14 +193,26 @@ pub(crate) fn derive_repository(input: TokenStream) -> TokenStream {
|
|||||||
}
|
}
|
||||||
// holds the list of all package names, snake case
|
// holds the list of all package names, snake case
|
||||||
let mut all_pkgs = Vec::<::syn::Ident>::with_capacity(items.fields.len());
|
let mut all_pkgs = Vec::<::syn::Ident>::with_capacity(items.fields.len());
|
||||||
|
let mut all_deps_builder =
|
||||||
|
Vec::<::syn::Path>::with_capacity(items.fields.len());
|
||||||
|
|
||||||
for it in items.fields.iter() {
|
for it in items.fields.iter() {
|
||||||
let Some(id) = &it.ident else { continue };
|
let Some(id) = &it.ident else { continue };
|
||||||
let id_str = id.to_string();
|
let id_str = id.to_string();
|
||||||
if id_str.starts_with("_p_") {
|
if !id_str.starts_with("_p_") {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
let ::syn::Type::Path(raw_path) = &it.ty else {
|
||||||
|
continue;
|
||||||
|
};
|
||||||
let name = id_str.strip_prefix("_p_").unwrap().to_owned();
|
let name = id_str.strip_prefix("_p_").unwrap().to_owned();
|
||||||
all_pkgs.push(::quote::format_ident!("{}", name));
|
all_pkgs.push(::quote::format_ident!("{}", name));
|
||||||
}
|
|
||||||
|
let mut dep_builder_trait = raw_path.path.clone();
|
||||||
|
let pkg_t = &mut dep_builder_trait.segments.last_mut().unwrap();
|
||||||
|
pkg_t.ident = ::quote::format_ident!("BokBuilderDeps{}", pkg_t.ident);
|
||||||
|
|
||||||
|
all_deps_builder.push(dep_builder_trait);
|
||||||
}
|
}
|
||||||
all_pkgs.sort_by(|a, b| a.to_string().cmp(&b.to_string()));
|
all_pkgs.sort_by(|a, b| a.to_string().cmp(&b.to_string()));
|
||||||
let pkgs_num: usize = all_pkgs.len();
|
let pkgs_num: usize = all_pkgs.len();
|
||||||
@ -231,6 +243,14 @@ pub(crate) fn derive_repository(input: TokenStream) -> TokenStream {
|
|||||||
self
|
self
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
//#[::bok_macro::collection(#(#all_deps_builder,)*)]
|
||||||
|
struct Collection {
|
||||||
|
repo: ::std::sync::Arc<#name>,
|
||||||
|
pkgs: ::std::sync::RwLock<
|
||||||
|
::std::vec::Vec<
|
||||||
|
::std::sync::Arc<
|
||||||
|
dyn ::bok::PkgBuilder>>>,
|
||||||
|
}
|
||||||
}.into()
|
}.into()
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -413,6 +433,8 @@ pub(crate) fn repo_impl(
|
|||||||
let reponame = &local.self_ty;
|
let reponame = &local.self_ty;
|
||||||
|
|
||||||
quote! {
|
quote! {
|
||||||
|
use ::bok_macro::repo_impl_methods;
|
||||||
|
use ::bok_macro::repo_impl_pkg_deps;
|
||||||
#[::bok_macro::repo_impl_methods(#reponame)]
|
#[::bok_macro::repo_impl_methods(#reponame)]
|
||||||
#local
|
#local
|
||||||
}
|
}
|
||||||
|
@ -18,32 +18,26 @@
|
|||||||
mod conf;
|
mod conf;
|
||||||
mod repos;
|
mod repos;
|
||||||
|
|
||||||
/*
|
|
||||||
trait TP {
|
|
||||||
fn p(r: &impl TR);
|
|
||||||
}
|
|
||||||
trait TR {
|
|
||||||
fn r();
|
|
||||||
}
|
|
||||||
|
|
||||||
struct R {}
|
|
||||||
impl TR for R {
|
|
||||||
fn r() {}
|
|
||||||
}
|
|
||||||
struct P {}
|
|
||||||
impl TP for P {
|
|
||||||
fn p(r: &impl TR) {}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
//let one = repos::pkgs::one::One::default();
|
//let one = repos::pkgs::one::One::default();
|
||||||
|
|
||||||
let pkgs1 = repos::Pkgs1::default();
|
use ::std::sync::Arc;
|
||||||
let pkgs2 = repos::Pkgs2::default();
|
let pkgs1 = Arc::new(repos::R1::default());
|
||||||
|
let pkgs2 = Arc::new(repos::R2::default());
|
||||||
use ::bok::Repository;
|
use ::bok::Repository;
|
||||||
println!("pkgs1: {}", pkgs1.name());
|
println!("pkgs1: {}", pkgs1.name());
|
||||||
println!("pkgs2: {}", pkgs2.name());
|
println!("pkgs2: {}", pkgs2.name());
|
||||||
|
let build_deps = ::bok::deps::Build(::bok::Collection::new());
|
||||||
|
let run_deps = ::bok::deps::Runtime(::bok::Collection::new());
|
||||||
|
|
||||||
|
let one = pkgs1.one();
|
||||||
|
use ::bok::Pkg;
|
||||||
|
let res = one.dependencies_set(pkgs1, &build_deps, &run_deps);
|
||||||
|
println!("{:?}", res);
|
||||||
|
|
||||||
|
let two = pkgs2.two();
|
||||||
|
let res = two.dependencies_set(pkgs2, &build_deps, &run_deps);
|
||||||
|
println!("{:?}", res);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
let mut pb: pkgs::one::OneBuilder = pkgs1.one();
|
let mut pb: pkgs::one::OneBuilder = pkgs1.one();
|
||||||
|
@ -19,56 +19,11 @@
|
|||||||
//! Example of two package repositories, where one
|
//! Example of two package repositories, where one
|
||||||
//! extends ancd changes another
|
//! extends ancd changes another
|
||||||
|
|
||||||
|
// all packages we have
|
||||||
pub mod pkgs;
|
pub mod pkgs;
|
||||||
|
|
||||||
// FIXME: why?
|
pub mod r1;
|
||||||
use ::bok_macro::repo_impl_methods;
|
pub mod r2;
|
||||||
use ::bok_macro::repo_impl_pkg_deps;
|
|
||||||
// Export multiple packages in this module
|
|
||||||
use ::bok::repository;
|
|
||||||
|
|
||||||
///
|
pub use r1::R1;
|
||||||
/// Base repository with some packages
|
pub use r2::R2;
|
||||||
#[::bok::repository(::bok::RepositoryEmpty)]
|
|
||||||
#[::bok::repo_packages(pkgs::one::One)]
|
|
||||||
#[derive(::std::default::Default)]
|
|
||||||
pub struct Pkgs1 {
|
|
||||||
r1: i32,
|
|
||||||
}
|
|
||||||
|
|
||||||
#[::bok::repo_impl]
|
|
||||||
impl Pkgs1 {}
|
|
||||||
|
|
||||||
///
|
|
||||||
/// This repository extends and changes Pkgs1
|
|
||||||
#[::bok::repository(Pkgs1)]
|
|
||||||
#[::bok::repo_packages(pkgs::two::Two)]
|
|
||||||
#[derive(::std::default::Default)]
|
|
||||||
pub struct Pkgs2 {
|
|
||||||
r2: i32,
|
|
||||||
}
|
|
||||||
|
|
||||||
#[::bok::repo_impl]
|
|
||||||
impl Pkgs2 {}
|
|
||||||
|
|
||||||
/*
|
|
||||||
impl Pkgs2 {
|
|
||||||
/// override the package `two` options from the base repostiory (Pkgs1)
|
|
||||||
pub fn two(&self) -> Two {
|
|
||||||
use ::bok::PkgBuilder;
|
|
||||||
let pkg: Box<dyn ::bok::Pkg> = Two::builder()
|
|
||||||
.my_attr(42)
|
|
||||||
.build()
|
|
||||||
.expect("Can't build package Two");
|
|
||||||
|
|
||||||
let two = pkg.as_any().downcast_ref::<Two>().unwrap();
|
|
||||||
two.clone()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// This repository extends both Pkgs1 and Pkgs2
|
|
||||||
#[::bok::repository(Pkgs2)]
|
|
||||||
#[::bok::repository(Pkgs1)]
|
|
||||||
#[derive(::std::default::Default)]
|
|
||||||
pub struct Pkgs3 {}
|
|
||||||
*/
|
|
||||||
|
@ -52,6 +52,11 @@ impl ::bok::Pkg for One {
|
|||||||
_build: &::bok::deps::Build,
|
_build: &::bok::deps::Build,
|
||||||
_runtime: &::bok::deps::Runtime,
|
_runtime: &::bok::deps::Runtime,
|
||||||
) -> Result<(), ()> {
|
) -> Result<(), ()> {
|
||||||
|
//TODO: automatically add repo type conversion via macro
|
||||||
|
let repo_any = repo.as_any();
|
||||||
|
let Some(actual_repo) = repo_any.downcast_ref::<R>() else {
|
||||||
|
return Err(());
|
||||||
|
};
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -46,14 +46,15 @@ impl ::bok::Pkg for Two {
|
|||||||
fn dependencies_set(
|
fn dependencies_set(
|
||||||
&self,
|
&self,
|
||||||
repo: ::std::sync::Arc<dyn ::bok::Repository>,
|
repo: ::std::sync::Arc<dyn ::bok::Repository>,
|
||||||
_build: &::bok::deps::Build,
|
build: &::bok::deps::Build,
|
||||||
_runtime: &::bok::deps::Runtime,
|
_runtime: &::bok::deps::Runtime,
|
||||||
) -> Result<(), ()> {
|
) -> Result<(), ()> {
|
||||||
|
//TODO: automatically add repo type conversion via macro
|
||||||
let repo_any = repo.as_any();
|
let repo_any = repo.as_any();
|
||||||
let Some(actual_repo) = repo_any.downcast_ref::<R>() else {
|
let Some(actual_repo) = repo_any.downcast_ref::<R>() else {
|
||||||
return Err(());
|
return Err(());
|
||||||
};
|
};
|
||||||
let _ = actual_repo.one();
|
let one = actual_repo.one();
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
44
bok-utils/src/repos/r1/mod.rs
Normal file
44
bok-utils/src/repos/r1/mod.rs
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2024 Luca Fulchir <luca.fulchir@runesauth.com>
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 with LLVM exception (the
|
||||||
|
* "License"); you may not use this file except in compliance with the
|
||||||
|
* License. You may obtain a copy of the License and of the exception at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
* https://spdx.org/licenses/LLVM-exception.html
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
//!
|
||||||
|
//! Example of a simple repository of packages
|
||||||
|
|
||||||
|
// get the 'pkgs' from somewhere
|
||||||
|
use crate::repos::pkgs;
|
||||||
|
|
||||||
|
/* or you can create and export your own packages
|
||||||
|
pub mod pkgs {
|
||||||
|
pub mod one {
|
||||||
|
pub use crate::repos::pkgs::one::*;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
use ::bok::repository;
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Base repository with some packages
|
||||||
|
#[::bok::repository(::bok::RepositoryEmpty)]
|
||||||
|
#[::bok::repo_packages(pkgs::one::One)]
|
||||||
|
#[derive(::std::default::Default)]
|
||||||
|
pub struct R1 {
|
||||||
|
r1: i32,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[::bok::repo_impl]
|
||||||
|
impl R1 {}
|
58
bok-utils/src/repos/r2/mod.rs
Normal file
58
bok-utils/src/repos/r2/mod.rs
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2024 Luca Fulchir <luca.fulchir@runesauth.com>
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 with LLVM exception (the
|
||||||
|
* "License"); you may not use this file except in compliance with the
|
||||||
|
* License. You may obtain a copy of the License and of the exception at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
* https://spdx.org/licenses/LLVM-exception.html
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
//!
|
||||||
|
//! Example of a repository extending another
|
||||||
|
///
|
||||||
|
/// This repository extends and changes R1
|
||||||
|
// FIXME: why?
|
||||||
|
use ::bok::repository;
|
||||||
|
|
||||||
|
pub mod pkgs {
|
||||||
|
pub mod one {
|
||||||
|
pub use crate::repos::pkgs::one::*;
|
||||||
|
}
|
||||||
|
pub mod two {
|
||||||
|
pub use crate::repos::pkgs::two::*;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[::bok::repository(super::r1::R1)]
|
||||||
|
#[::bok::repo_packages(pkgs::two::Two)]
|
||||||
|
#[derive(::std::default::Default)]
|
||||||
|
pub struct R2 {
|
||||||
|
r2: i32,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[::bok::repo_impl]
|
||||||
|
impl R2 {}
|
||||||
|
|
||||||
|
/*
|
||||||
|
impl Pkgs2 {
|
||||||
|
/// override the package `two` options from the base repostiory (Pkgs1)
|
||||||
|
pub fn two(&self) -> Two {
|
||||||
|
use ::bok::PkgBuilder;
|
||||||
|
let pkg: Box<dyn ::bok::Pkg> = Two::builder()
|
||||||
|
.my_attr(42)
|
||||||
|
.build()
|
||||||
|
.expect("Can't build package Two");
|
||||||
|
|
||||||
|
let two = pkg.as_any().downcast_ref::<Two>().unwrap();
|
||||||
|
two.clone()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
@ -126,6 +126,8 @@ pub trait PkgBuilder: ::core::fmt::Debug + ::std::any::Any {
|
|||||||
fn name(&self) -> crate::PkgName;
|
fn name(&self) -> crate::PkgName;
|
||||||
fn path(&self) -> crate::Path<crate::PkgName>;
|
fn path(&self) -> crate::Path<crate::PkgName>;
|
||||||
fn version(&self) -> crate::Version;
|
fn version(&self) -> crate::Version;
|
||||||
|
fn as_any(&self) -> &dyn ::std::any::Any;
|
||||||
|
fn as_any_mut(&mut self) -> &mut dyn ::std::any::Any;
|
||||||
fn default_unused(&mut self) -> &mut dyn crate::PkgBuilder;
|
fn default_unused(&mut self) -> &mut dyn crate::PkgBuilder;
|
||||||
fn build(
|
fn build(
|
||||||
&mut self,
|
&mut self,
|
||||||
|
Loading…
Reference in New Issue
Block a user