Skip to content

Commit

Permalink
refactor: make hax-engine-names depends on hax-frontend-exporter,…
Browse files Browse the repository at this point in the history
… w/o `full`

This get rids of the `#[path]` introduced
#703 by using the disabling the new
`full` feature of `hax-frontend-exporter`.
  • Loading branch information
W95Psp committed Jun 12, 2024
1 parent f9370ac commit ddc0f93
Show file tree
Hide file tree
Showing 4 changed files with 13 additions and 31 deletions.
1 change: 1 addition & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions engine/names/extract/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ description = "Helper binary generating an OCaml module"

[build-dependencies]
hax-cli-options-engine.workspace = true
hax-frontend-exporter.workspace = true
serde.workspace = true
serde_json.workspace = true
cargo_metadata.workspace = true
Expand Down
9 changes: 1 addition & 8 deletions engine/names/extract/build.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,14 +2,7 @@ use serde_json;
use serde_json::Value;
use std::process::{Command, Stdio};

/// Instead of depending on `hax_frontend_exporter` (that links to
/// rustc and exposes a huge number of type definitions and their
/// impls), we just inline a small module here that contains the three
/// type definition we need. See the module for complementary
/// informations.
#[path = "../../../frontend/exporter/src/types/def_id.rs"]
mod hax_frontend_exporter_def_id;
use hax_frontend_exporter_def_id::*;
use hax_frontend_exporter::{DefId, DefPathItem, DisambiguatedDefPathItem};

/// Name of the current crate
const HAX_ENGINE_NAMES_CRATE: &str = "hax_engine_names";
Expand Down
33 changes: 10 additions & 23 deletions frontend/exporter/src/types/def_id.rs
Original file line number Diff line number Diff line change
@@ -1,37 +1,23 @@
//! This module contains the type definition for `DefId` and the types
//! `DefId` depends on.
//!
//! This is purposely a very small isolated module:
//! `hax-engine-names-extract` uses those types, but we don't want
//! `hax-engine-names-extract` to have a build dependency on the whole
//! frontend, that double the build times for the Rust part of hax.
//!
//! The feature `extract_names_mode` exists only in the crate
//! `hax-engine-names-extract`, and is used to turn off the derive
//! attributes `AdtInto` and `JsonSchema`.
pub use serde::{Deserialize, Serialize};

#[cfg(not(feature = "extract_names_mode"))]
use crate::{AdtInto, JsonSchema};
pub use serde::{Deserialize, Serialize};

#[cfg(feature = "full")]
use crate::{BaseState, SInto};

pub type Symbol = String;

#[derive(Clone, Debug, Serialize, Deserialize, Hash, PartialEq, Eq, PartialOrd, Ord)]
#[cfg_attr(not(feature = "extract_names_mode"), derive(AdtInto, JsonSchema))]
#[cfg_attr(not(feature = "extract_names_mode"), args(<'a, S: BaseState<'a>>, from: rustc_hir::definitions::DisambiguatedDefPathData, state: S as s))]
#[derive(
Clone, Debug, Serialize, Deserialize, Hash, PartialEq, Eq, PartialOrd, Ord, AdtInto, JsonSchema,
)]
#[args(<'a, S: BaseState<'a>>, from: rustc_hir::definitions::DisambiguatedDefPathData, state: S as s)]
/// Reflects [`rustc_hir::definitions::DisambiguatedDefPathData`]
pub struct DisambiguatedDefPathItem {
pub data: DefPathItem,
pub disambiguator: u32,
}

/// Reflects [`rustc_hir::def_id::DefId`]
#[derive(Clone, Debug, Serialize, Deserialize, PartialEq, Eq, PartialOrd, Ord)]
#[cfg_attr(not(feature = "extract_names_mode"), derive(JsonSchema))]
#[derive(Clone, Debug, Serialize, Deserialize, PartialEq, Eq, PartialOrd, Ord, JsonSchema)]
pub struct DefId {
pub krate: String,
pub path: Vec<DisambiguatedDefPathItem>,
Expand All @@ -47,9 +33,10 @@ pub struct DefId {
}

/// Reflects [`rustc_hir::definitions::DefPathData`]
#[derive(Clone, Debug, Serialize, Deserialize, Hash, PartialEq, Eq, PartialOrd, Ord)]
#[cfg_attr(not(feature = "extract_names_mode"), derive(AdtInto, JsonSchema))]
#[cfg_attr(not(feature = "extract_names_mode"), args(<'ctx, S: BaseState<'ctx>>, from: rustc_hir::definitions::DefPathData, state: S as state))]
#[derive(
Clone, Debug, AdtInto, JsonSchema, Serialize, Deserialize, Hash, PartialEq, Eq, PartialOrd, Ord,
)]
#[args(<'ctx, S: BaseState<'ctx>>, from: rustc_hir::definitions::DefPathData, state: S as state)]
pub enum DefPathItem {
CrateRoot,
Impl,
Expand Down

0 comments on commit ddc0f93

Please sign in to comment.