aboutsummaryrefslogtreecommitdiff
path: root/stdlib/source/lux/locale.lux
blob: 69920aba9e75bad94dced52526b1f98f537680ae (plain)
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
(.module:
  [lux #*
   [abstract
    [equivalence (#+ Equivalence)]
    [hash (#+ Hash)]]
   [data
    ["." maybe ("#@." functor)]
    ["." text
     ["%" format (#+ format)]
     ["." encoding (#+ Encoding)]]]
   [type
    abstract]
   ["." macro]]
  [/
   ["." language (#+ Language)]
   ["." territory (#+ Territory)]])

(abstract: #export Locale
  {}

  Text

  (def: territory-separator "_")
  (def: encoding-separator ".")

  (def: #export (locale language territory encoding)
    (-> Language (Maybe Territory) (Maybe Encoding) Locale)
    (:abstraction (format (language.code language)
                          (|> territory
                              (maybe@map (|>> territory.long-code (format ..territory-separator)))
                              (maybe.default ""))
                          (|> encoding
                              (maybe@map (|>> encoding.name (format ..encoding-separator)))
                              (maybe.default "")))))

  (def: #export code
    (-> Locale Text)
    (|>> :representation))

  (structure: #export equivalence
    (Equivalence Locale)
    
    (def: (= reference sample)
      (:: text.equivalence = (:representation reference) (:representation sample))))

  (structure: #export hash
    (Hash Locale)
    
    (def: &equivalence ..equivalence)
    
    (def: hash
      (|>> :representation
           (:: text.hash hash))))
  )