squawk-ide 2.50.0

Linter for Postgres migrations & SQL
Documentation
#[cfg(not(target_arch = "wasm32"))]
use etcetera::BaseStrategy;
use salsa::Database as Db;
#[cfg(not(target_arch = "wasm32"))]
use url::Url;

use crate::db::File;

const BUILTINS_SQL: &str = include_str!("generated/builtins.sql");

#[salsa::tracked]
pub fn builtins_file(db: &dyn Db) -> File {
    File::new(db, BUILTINS_SQL.into())
}

#[cfg(not(target_arch = "wasm32"))]
#[salsa::tracked]
pub fn builtins_url(db: &dyn Db) -> Option<Url> {
    let strategy = etcetera::base_strategy::choose_base_strategy().ok()?;
    let config_dir = strategy.config_dir();
    let cache_dir = config_dir.join("squawk/stubs");
    let path = cache_dir.join("builtins.sql");
    std::fs::create_dir_all(&cache_dir).ok()?;
    let builtins = builtins_file(db);
    let builtins_sql = builtins.content(db);
    std::fs::write(&path, builtins_sql.as_ref()).ok()?;
    Url::from_file_path(path).ok()
}

#[cfg(test)]
mod test {
    use squawk_syntax::ast;

    use crate::builtins::BUILTINS_SQL;

    #[test]
    fn no_errors() {
        let parse = ast::SourceFile::parse(BUILTINS_SQL);
        assert_eq!(parse.errors(), vec![]);
    }
}