#![doc = include_str!("../README.md")]
#![deny(rust_2018_idioms, unsafe_code, missing_docs)]
pub use psl_core::builtin_connectors;
use psl_core::parser_database::{ExtensionTypes, Files, NoExtensionTypes};
pub use psl_core::{
ALL_PREVIEW_FEATURES,
Configuration,
ConnectorRegistry,
Datasource,
DatasourceConnectorData,
DatasourceUrls,
FeatureMapWithProvider,
Generator,
GeneratorConfigValue,
PreviewFeature,
PreviewFeatures,
StringFromEnvVar,
ValidatedSchema,
builtin_connectors::{can_have_capability, can_support_relation_load_strategy, has_capability},
datamodel_connector,
diagnostics::{self, Diagnostics},
generators,
is_reserved_type_name,
mcf::config_to_mcf_json_value as get_config,
mcf::{generators_to_json, render_sources_to_json}, parser_database::{self, SourceFile},
reachable_only_with_capability,
reformat,
reformat_multiple,
reformat_validated_schema_into_single,
schema_ast,
set_config_dir,
};
pub mod get_config {
pub use psl_core::mcf::{config_to_mcf_json_value as get_config, *};
}
pub fn parse_configuration(schema: &str) -> Result<Configuration, Diagnostics> {
psl_core::parse_configuration(schema, builtin_connectors::BUILTIN_CONNECTORS)
}
pub fn parse_configuration_multi_file(
files: &[(String, SourceFile)],
) -> Result<(Files, Configuration), (Files, Diagnostics)> {
psl_core::parse_configuration_multi_file(files, builtin_connectors::BUILTIN_CONNECTORS)
}
pub fn error_tolerant_parse_configuration(files: &[(String, SourceFile)]) -> (Files, Configuration, Diagnostics) {
psl_core::error_tolerant_parse_configuration(files, builtin_connectors::BUILTIN_CONNECTORS)
}
pub fn parse_schema(
file: impl Into<SourceFile>,
extension_types: &dyn ExtensionTypes,
) -> Result<ValidatedSchema, String> {
let mut schema = validate(file.into(), extension_types);
schema
.diagnostics
.to_result()
.map_err(|err| err.to_pretty_string("schema.prisma", schema.db.source_assert_single()))?;
Ok(schema)
}
pub fn parse_schema_without_extensions(file: impl Into<SourceFile>) -> Result<ValidatedSchema, String> {
parse_schema(file, &NoExtensionTypes)
}
pub fn parse_schema_multi(
files: &[(String, SourceFile)],
extension_types: &dyn ExtensionTypes,
) -> Result<ValidatedSchema, String> {
let mut schema = validate_multi_file(files, extension_types);
schema
.diagnostics
.to_result()
.map_err(|err| schema.db.render_diagnostics(&err))?;
Ok(schema)
}
pub fn parse_schema_multi_without_extensions(files: &[(String, SourceFile)]) -> Result<ValidatedSchema, String> {
parse_schema_multi(files, &NoExtensionTypes)
}
pub fn validate(file: SourceFile, extension_types: &dyn ExtensionTypes) -> ValidatedSchema {
psl_core::validate(file, builtin_connectors::BUILTIN_CONNECTORS, extension_types)
}
pub fn validate_without_extensions(file: SourceFile) -> ValidatedSchema {
validate(file, &NoExtensionTypes)
}
pub fn parse_without_validation(
file: SourceFile,
connector_registry: ConnectorRegistry<'_>,
extension_types: &dyn ExtensionTypes,
) -> ValidatedSchema {
psl_core::parse_without_validation(file, connector_registry, extension_types)
}
pub fn validate_multi_file(files: &[(String, SourceFile)], extension_types: &dyn ExtensionTypes) -> ValidatedSchema {
psl_core::validate_multi_file(files, builtin_connectors::BUILTIN_CONNECTORS, extension_types)
}
pub fn validate_multi_file_without_extensions(files: &[(String, SourceFile)]) -> ValidatedSchema {
validate_multi_file(files, &NoExtensionTypes)
}