1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
use std::borrow::Borrow;
use fluent_syntax::ast;
use crate::bundle::{FluentArgs, FluentBundle};
use crate::resource::FluentResource;
use crate::types::FluentValue;
pub type FluentFunction =
Box<dyn for<'a> Fn(&[FluentValue<'a>], &FluentArgs) -> FluentValue<'a> + Send + Sync>;
pub enum Entry {
Message([usize; 2]),
Term([usize; 2]),
Function(FluentFunction),
}
pub trait GetEntry {
fn get_entry_message(&self, id: &str) -> Option<&ast::Message>;
fn get_entry_term(&self, id: &str) -> Option<&ast::Term>;
fn get_entry_function(&self, id: &str) -> Option<&FluentFunction>;
}
impl<'bundle, R: Borrow<FluentResource>> GetEntry for FluentBundle<R> {
fn get_entry_message(&self, id: &str) -> Option<&ast::Message> {
self.entries.get(id).and_then(|entry| match *entry {
Entry::Message(pos) => {
let res = self.resources.get(pos[0])?.borrow();
if let Some(ast::ResourceEntry::Entry(ast::Entry::Message(ref msg))) =
res.ast().body.get(pos[1])
{
return Some(msg);
} else {
return None;
}
}
_ => None,
})
}
fn get_entry_term(&self, id: &str) -> Option<&ast::Term> {
self.entries.get(id).and_then(|entry| match *entry {
Entry::Term(pos) => {
let res = self.resources.get(pos[0])?.borrow();
if let Some(ast::ResourceEntry::Entry(ast::Entry::Term(ref msg))) =
res.ast().body.get(pos[1])
{
return Some(msg);
} else {
return None;
}
}
_ => None,
})
}
fn get_entry_function(&self, id: &str) -> Option<&FluentFunction> {
self.entries.get(id).and_then(|entry| match entry {
Entry::Function(function) => Some(function),
_ => None,
})
}
}