mirror of
https://github.com/astral-sh/ruff.git
synced 2025-09-30 22:01:47 +00:00
100 lines
3 KiB
Rust
100 lines
3 KiB
Rust
use crate::python_version::PythonVersion;
|
|
use anyhow::Context;
|
|
use salsa::Durability;
|
|
use salsa::Setter;
|
|
|
|
use ruff_db::system::{SystemPath, SystemPathBuf};
|
|
|
|
use crate::module_resolver::SearchPaths;
|
|
use crate::Db;
|
|
|
|
#[salsa::input(singleton)]
|
|
pub struct Program {
|
|
pub target_version: PythonVersion,
|
|
|
|
#[return_ref]
|
|
pub(crate) search_paths: SearchPaths,
|
|
}
|
|
|
|
impl Program {
|
|
pub fn from_settings(db: &dyn Db, settings: &ProgramSettings) -> anyhow::Result<Self> {
|
|
let ProgramSettings {
|
|
target_version,
|
|
search_paths,
|
|
} = settings;
|
|
|
|
tracing::info!("Target version: Python {target_version}");
|
|
|
|
let search_paths = SearchPaths::from_settings(db, search_paths)
|
|
.with_context(|| "Invalid search path settings")?;
|
|
|
|
Ok(Program::builder(settings.target_version, search_paths)
|
|
.durability(Durability::HIGH)
|
|
.new(db))
|
|
}
|
|
|
|
pub fn update_search_paths(
|
|
self,
|
|
db: &mut dyn Db,
|
|
search_path_settings: &SearchPathSettings,
|
|
) -> anyhow::Result<()> {
|
|
let search_paths = SearchPaths::from_settings(db, search_path_settings)?;
|
|
|
|
if self.search_paths(db) != &search_paths {
|
|
tracing::debug!("Update search paths");
|
|
self.set_search_paths(db).to(search_paths);
|
|
}
|
|
|
|
Ok(())
|
|
}
|
|
|
|
pub fn custom_stdlib_search_path(self, db: &dyn Db) -> Option<&SystemPath> {
|
|
self.search_paths(db).custom_stdlib()
|
|
}
|
|
}
|
|
|
|
#[derive(Clone, Debug, Eq, PartialEq)]
|
|
pub struct ProgramSettings {
|
|
pub target_version: PythonVersion,
|
|
pub search_paths: SearchPathSettings,
|
|
}
|
|
|
|
/// Configures the search paths for module resolution.
|
|
#[derive(Eq, PartialEq, Debug, Clone)]
|
|
pub struct SearchPathSettings {
|
|
/// List of user-provided paths that should take first priority in the module resolution.
|
|
/// Examples in other type checkers are mypy's MYPYPATH environment variable,
|
|
/// or pyright's stubPath configuration setting.
|
|
pub extra_paths: Vec<SystemPathBuf>,
|
|
|
|
/// The root of the workspace, used for finding first-party modules.
|
|
pub src_root: SystemPathBuf,
|
|
|
|
/// Optional path to a "custom typeshed" directory on disk for us to use for standard-library types.
|
|
/// If this is not provided, we will fallback to our vendored typeshed stubs for the stdlib,
|
|
/// bundled as a zip file in the binary
|
|
pub custom_typeshed: Option<SystemPathBuf>,
|
|
|
|
/// The path to the user's `site-packages` directory, where third-party packages from ``PyPI`` are installed.
|
|
pub site_packages: SitePackages,
|
|
}
|
|
|
|
impl SearchPathSettings {
|
|
pub fn new(src_root: SystemPathBuf) -> Self {
|
|
Self {
|
|
src_root,
|
|
extra_paths: vec![],
|
|
custom_typeshed: None,
|
|
site_packages: SitePackages::Known(vec![]),
|
|
}
|
|
}
|
|
}
|
|
|
|
#[derive(Debug, Clone, Eq, PartialEq)]
|
|
pub enum SitePackages {
|
|
Derived {
|
|
venv_path: SystemPathBuf,
|
|
},
|
|
/// Resolved site packages paths
|
|
Known(Vec<SystemPathBuf>),
|
|
}
|