Expand description
Public Rust entry point for the ferrocat workspace.
This crate re-exports the primary API surface from the lower-level
ferrocat-po and ferrocat-icu crates so application code can depend on a
single package.
§Examples
use ferrocat::{parse_icu, parse_po};
let po = parse_po("msgid \"Hello\"\nmsgstr \"Hallo\"\n")?;
let icu = parse_icu("Hello {name}")?;
assert_eq!(po.items[0].msgid, "Hello");
assert_eq!(icu.nodes.len(), 2);use ferrocat::{
CompileSelectedCatalogArtifactOptions, CompiledCatalogIdIndex, CompiledKeyStrategy,
ParseCatalogOptions, compile_catalog_artifact_selected, parse_catalog,
};
let source = parse_catalog(ParseCatalogOptions {
content: "msgid \"Hello\"\nmsgstr \"Hello\"\n",
source_locale: "en",
locale: Some("en"),
..ParseCatalogOptions::default()
})?
.into_normalized_view()?;
let requested = parse_catalog(ParseCatalogOptions {
content: "msgid \"Hello\"\nmsgstr \"Hallo\"\n",
source_locale: "en",
locale: Some("de"),
..ParseCatalogOptions::default()
})?
.into_normalized_view()?;
let index = CompiledCatalogIdIndex::new(&[&requested, &source], CompiledKeyStrategy::FerrocatV1)?;
let compiled_ids = index.iter().map(|(id, _)| id.to_owned()).collect::<Vec<_>>();
let compiled = compile_catalog_artifact_selected(
&[&requested, &source],
&index,
&CompileSelectedCatalogArtifactOptions {
requested_locale: "de",
source_locale: "en",
compiled_ids: &compiled_ids,
..CompileSelectedCatalogArtifactOptions::default()
},
)?;
assert_eq!(compiled.messages.len(), 1);use ferrocat::{CatalogAuditOptions, ParseCatalogOptions, audit_catalogs, parse_catalog};
let source = parse_catalog(ParseCatalogOptions {
content: "msgid \"Checkout\"\nmsgstr \"Checkout\"\n",
source_locale: "en",
locale: Some("en"),
..ParseCatalogOptions::default()
})?
.into_normalized_view()?;
let target = parse_catalog(ParseCatalogOptions {
content: "",
source_locale: "en",
locale: Some("de"),
..ParseCatalogOptions::default()
})?
.into_normalized_view()?;
let report = audit_catalogs(&[&source, &target], &CatalogAuditOptions::new("en"))?;
assert!(report.has_errors());Structs§
- Borrowed
Header - Borrowed header entry from the PO header block.
- Borrowed
PoFile - Borrowed PO document that reuses slices from the original input whenever possible.
- Borrowed
PoItem - Borrowed gettext message entry.
- Catalog
Audit Checks - Enables or disables individual catalog audit checks.
- Catalog
Audit Diagnostic - One machine-readable catalog audit diagnostic.
- Catalog
Audit Message Ref - Catalog message reference attached to audit diagnostics.
- Catalog
Audit Options - Options controlling catalog audit checks.
- Catalog
Audit Report - Report returned by
audit_catalogs. - Catalog
Audit Summary - Summary counters for a catalog audit report.
- Catalog
Combine Input - One catalog input passed to
super::combine_catalogs. - Catalog
Combine Result - Result returned by catalog combine operations.
- Catalog
Combine Stats - Basic counters describing a catalog combine operation.
- Catalog
Message - Public message representation returned by
super::parse_catalog. - Catalog
Message Extra - Extra translator-facing metadata preserved on a catalog message.
- Catalog
Message Key - Stable lookup key for catalog messages.
- Catalog
Origin - File and line information for an extracted message origin.
- Catalog
Stats - Basic counters describing an update operation.
- Catalog
Update Result - Result returned by catalog update operations.
- Combine
Catalog Options - Options for combining multiple catalogs into one deterministic catalog.
- Compile
Catalog Artifact Options - Options controlling high-level compiled catalog artifact generation.
- Compile
Catalog Options - Options controlling runtime catalog compilation.
- Compile
Selected Catalog Artifact Options - Options controlling selected-subset compiled catalog artifact generation.
- Compiled
Catalog - Runtime-oriented lookup structure compiled from a normalized catalog.
- Compiled
Catalog Artifact - Host-neutral compiled runtime artifact for one requested locale.
- Compiled
Catalog Diagnostic - Diagnostic emitted by
super::compile_catalog_artifact. - Compiled
Catalog IdDescription - Metadata describing one compiled runtime ID for a specific catalog set.
- Compiled
Catalog IdIndex - Stable compiled runtime ID index built from one or more normalized catalogs.
- Compiled
Catalog Missing Message - Missing-message record emitted by
super::compile_catalog_artifact. - Compiled
Catalog Unavailable Id - Known compiled runtime ID that was not present in the provided catalog set.
- Compiled
Message - A compiled runtime message keyed by a derived lookup key.
- Describe
Compiled IdsReport - Report returned by
CompiledCatalogIdIndex::describe_compiled_ids. - Diagnostic
- Non-fatal issue collected while parsing or updating catalogs.
- Extracted
Plural Message - Structured plural message input used by catalog update operations.
- Extracted
Singular Message - Structured singular message input used by catalog update operations.
- Header
- A single header entry from the PO header block.
- IcuAnalysis
- Structural summary of a parsed ICU message.
- IcuArgument
- One data argument reference discovered in an ICU message.
- IcuCompatibility
Options - Options controlling ICU source/translation compatibility checks.
- IcuCompatibility
Report - Report returned by
compare_icu_messages. - IcuDiagnostic
- One diagnostic emitted by an ICU compatibility check.
- IcuFormatter
- One formatter reference discovered in an ICU message.
- IcuMessage
- Parsed ICU message.
- IcuOption
- A selector branch inside a plural or select expression.
- IcuParse
Error - Error returned when parsing ICU messages fails.
- IcuParser
Options - Options controlling ICU parsing behavior.
- IcuPlural
Summary - One cardinal or ordinal plural expression discovered in an ICU message.
- IcuPosition
- Byte offset plus line/column location inside the original input.
- IcuSelect
Summary - One select expression discovered in an ICU message.
- IcuTag
Summary - One rich-text tag discovered in an ICU message.
- Merge
Extracted Message - Borrowed extracted message input for the lightweight merge helper.
- Message
Argument Format Metadata - Formatter metadata attached to an argument.
- Message
Argument Metadata - Normalized semantic metadata for one message argument.
- Message
Metadata - Normalized semantic metadata for one source message.
- Message
Metadata Diagnostic - One diagnostic emitted while validating semantic message metadata.
- Message
Metadata Input - Authoring input for semantic message metadata.
- Message
Metadata Validation Report - Report returned by
validate_message_metadata. - Message
Origin Metadata - Extraction origin attached to semantic message metadata.
- Message
Selector Metadata - Selector metadata attached to a selecting argument.
- MsgStr
Iter - Iterator over
MsgStrvalues. - Normalized
Parsed Catalog - Parsed catalog with fast key-based lookup helpers.
- Parse
Catalog Options - Options for parsing a catalog into the higher-level message model.
- Parse
Error - Error returned when parsing or unescaping PO content fails.
- Parsed
Catalog - Parsed catalog plus diagnostics and normalized headers.
- Plural
Source - Source-side plural forms for structured catalog messages.
- PoFile
- An owned PO document.
- PoItem
- A single gettext message entry.
- Serialize
Options - Options controlling PO serialization.
- Source
Extracted Message - Source-first extractor input that lets
ferrocatinfer plural structure. - Update
Catalog File Options - Options for updating a catalog file on disk.
- Update
Catalog Options - Options for in-memory catalog updates.
Enums§
- ApiError
- Error returned by catalog parsing and update APIs.
- Borrowed
MsgStr - Borrowed translation payload for a PO item.
- Catalog
Combine Selection - Selection rule used after definitions from all inputs have been counted.
- Catalog
Conflict Strategy - Strategy used when multiple catalogs define conflicting translations for one identity.
- Catalog
Storage Format - Storage format used by the high-level catalog API.
- Catalog
Update Input - Input payload accepted by catalog update operations.
- Compiled
Catalog Translation Kind - High-level translation kind associated with a compiled runtime ID.
- Compiled
KeyStrategy - Built-in key strategy used when compiling runtime catalogs.
- Compiled
Translation - Translation value stored in a compiled runtime catalog.
- Diagnostic
Severity - Severity level attached to a
Diagnostic. - Effective
Translation - Owned translation value materialized from a parsed catalog.
- Effective
Translation Ref - Borrowed view over a message translation.
- Extracted
Message - Structured extractor input accepted by
super::update_catalogandsuper::update_catalog_file. - IcuArgument
Kind - Broad role of an ICU argument in a parsed message.
- IcuDiagnostic
Severity - Severity level attached to ICU authoring diagnostics.
- IcuError
Kind - High-level classification of ICU parse failures.
- IcuNode
- AST node emitted by the ICU parser.
- IcuPlural
Kind - Distinguishes cardinal and ordinal plural forms.
- IcuStyle
Kind - Classification of an optional formatter style segment.
- Message
Argument Kind - Broad argument kind used by semantic message metadata.
- Message
Argument Metadata Input - Progressive authoring input for one argument.
- Message
Format Style Kind - Classification of a message formatter style.
- Message
Selector Kind - Selector kind used by semantic message metadata.
- MsgStr
- Message translation payload for a PO item.
- Obsolete
Strategy - Strategy used for messages that disappear from the extracted input.
- OrderBy
- Sort order used when writing output catalogs.
- Placeholder
Comment Mode - Controls whether placeholder hints are emitted as extracted comments.
- Plural
Encoding - Encoding used for plural messages in PO files.
- Translation
Shape - Public translation shape returned from parsed catalogs.
Functions§
- analyze_
icu - Produces a structural summary of a parsed ICU message.
- audit_
catalogs - Audits a normalized catalog set for catalog QA and authoring issues.
- combine_
catalogs - Combines multiple catalogs into one deterministic catalog.
- compare_
icu_ messages - Compares source and translation ICU messages for authoring compatibility.
- compile_
catalog_ artifact - Compiles one requested-locale runtime artifact from one or more normalized catalogs.
- compile_
catalog_ artifact_ selected - Compiles one requested-locale runtime artifact for a selected subset of compiled IDs.
- compiled_
key - Derives the default stable runtime lookup key for
msgidandmsgctxt. - derive_
message_ metadata_ from_ icu - Derives normalized semantic metadata from an ICU MessageFormat v1
msgid. - escape_
string - Escapes a PO string literal payload.
- extract_
argument_ names - Extracts data argument names in first-seen order, excluding rich-text tags.
- extract_
quoted - Extracts and unescapes the first quoted PO string from
line. - extract_
quoted_ cow - Extracts and unescapes the first quoted PO string from
line, borrowing from the input when no escapes are present. - extract_
tag_ names - Extracts rich-text tag names in first-seen order.
- extract_
variables - Extracts variable names in first-seen order.
- has_
plural - Returns
truewhen the message contains a cardinal plural expression. - has_
select - Returns
truewhen the message contains a select expression. - has_
select_ ordinal - Returns
truewhen the message contains an ordinal plural expression. - has_
selectordinal - Returns
truewhen the message contains an ordinal plural expression. - has_tag
- Returns
truewhen the message contains rich-text style tags. - merge_
catalog - Merges extracted messages into an existing PO catalog while preserving the existing translation payload.
- normalize_
message_ metadata - Normalizes progressive semantic message metadata into canonical object form.
- parse_
catalog - Parses catalog content into the higher-level representation used by
ferrocat’s catalog APIs. - parse_
icu - Parses ICU
MessageFormatinput with the default parser options. - parse_
icu_ with_ options - Parses ICU
MessageFormatinput with explicit parser options. - parse_
po - Parses PO content into the owned
PoFilerepresentation. - parse_
po_ borrowed - Parses PO content into a borrowed representation.
- stringify_
po - Serializes a
PoFileback into gettext PO text. - unescape_
string - Unescapes a PO string literal payload.
- update_
catalog - Merges extracted messages into an existing catalog and returns updated catalog content.
- update_
catalog_ file - Updates a catalog on disk and only writes the file when the rendered output changes.
- validate_
icu - Validates ICU
MessageFormatinput without returning the parsed AST. - validate_
message_ metadata - Validates progressive semantic message metadata against its
msgid.