lokit-python 0.1.0__cp313-cp313-win_amd64.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (97) hide show
  1. 821d8b73c2a02cb7980f__mypyc.cp313-win_amd64.pyd +0 -0
  2. lokit/__init__.cp313-win_amd64.pyd +0 -0
  3. lokit/__init__.py +128 -0
  4. lokit/core/__init__.cp313-win_amd64.pyd +0 -0
  5. lokit/core/__init__.py +0 -0
  6. lokit/core/logger.cp313-win_amd64.pyd +0 -0
  7. lokit/core/logger.py +20 -0
  8. lokit/data/__init__.cp313-win_amd64.pyd +0 -0
  9. lokit/data/__init__.py +0 -0
  10. lokit/data/lang_codes.cp313-win_amd64.pyd +0 -0
  11. lokit/data/lang_codes.py +455 -0
  12. lokit/data/structure.cp313-win_amd64.pyd +0 -0
  13. lokit/data/structure.py +118 -0
  14. lokit/data/tag_types.cp313-win_amd64.pyd +0 -0
  15. lokit/data/tag_types.py +78 -0
  16. lokit/exporters/__init__.cp313-win_amd64.pyd +0 -0
  17. lokit/exporters/__init__.py +34 -0
  18. lokit/exporters/csv.cp313-win_amd64.pyd +0 -0
  19. lokit/exporters/csv.py +32 -0
  20. lokit/exporters/html.cp313-win_amd64.pyd +0 -0
  21. lokit/exporters/html.py +217 -0
  22. lokit/exporters/idml.cp313-win_amd64.pyd +0 -0
  23. lokit/exporters/idml.py +178 -0
  24. lokit/exporters/json_i18n.cp313-win_amd64.pyd +0 -0
  25. lokit/exporters/json_i18n.py +47 -0
  26. lokit/exporters/po.cp313-win_amd64.pyd +0 -0
  27. lokit/exporters/po.py +162 -0
  28. lokit/exporters/tmx.cp313-win_amd64.pyd +0 -0
  29. lokit/exporters/tmx.py +247 -0
  30. lokit/exporters/xliff.cp313-win_amd64.pyd +0 -0
  31. lokit/exporters/xliff.py +152 -0
  32. lokit/exporters/xlsx.cp313-win_amd64.pyd +0 -0
  33. lokit/exporters/xlsx.py +39 -0
  34. lokit/format_detection.cp313-win_amd64.pyd +0 -0
  35. lokit/format_detection.py +115 -0
  36. lokit/importers.py +321 -0
  37. lokit/io/__init__.cp313-win_amd64.pyd +0 -0
  38. lokit/io/__init__.py +3 -0
  39. lokit/io/json.cp313-win_amd64.pyd +0 -0
  40. lokit/io/json.py +194 -0
  41. lokit/logic.cp313-win_amd64.pyd +0 -0
  42. lokit/logic.py +324 -0
  43. lokit/parsers/__init__.cp313-win_amd64.pyd +0 -0
  44. lokit/parsers/__init__.py +1 -0
  45. lokit/parsers/csv/__init__.cp313-win_amd64.pyd +0 -0
  46. lokit/parsers/csv/__init__.py +1 -0
  47. lokit/parsers/csv/extraction.cp313-win_amd64.pyd +0 -0
  48. lokit/parsers/csv/extraction.py +164 -0
  49. lokit/parsers/html/__init__.cp313-win_amd64.pyd +0 -0
  50. lokit/parsers/html/__init__.py +3 -0
  51. lokit/parsers/html/extraction.cp313-win_amd64.pyd +0 -0
  52. lokit/parsers/html/extraction.py +365 -0
  53. lokit/parsers/idml/__init__.cp313-win_amd64.pyd +0 -0
  54. lokit/parsers/idml/__init__.py +3 -0
  55. lokit/parsers/idml/extraction.cp313-win_amd64.pyd +0 -0
  56. lokit/parsers/idml/extraction.py +264 -0
  57. lokit/parsers/json_i18n/__init__.cp313-win_amd64.pyd +0 -0
  58. lokit/parsers/json_i18n/__init__.py +3 -0
  59. lokit/parsers/json_i18n/extraction.cp313-win_amd64.pyd +0 -0
  60. lokit/parsers/json_i18n/extraction.py +163 -0
  61. lokit/parsers/po/__init__.cp313-win_amd64.pyd +0 -0
  62. lokit/parsers/po/__init__.py +3 -0
  63. lokit/parsers/po/extraction.cp313-win_amd64.pyd +0 -0
  64. lokit/parsers/po/extraction.py +236 -0
  65. lokit/parsers/tmx/__init__.cp313-win_amd64.pyd +0 -0
  66. lokit/parsers/tmx/__init__.py +0 -0
  67. lokit/parsers/tmx/base.cp313-win_amd64.pyd +0 -0
  68. lokit/parsers/tmx/base.py +145 -0
  69. lokit/parsers/tmx/extraction.cp313-win_amd64.pyd +0 -0
  70. lokit/parsers/tmx/extraction.py +170 -0
  71. lokit/parsers/tmx/header.cp313-win_amd64.pyd +0 -0
  72. lokit/parsers/tmx/header.py +55 -0
  73. lokit/parsers/tmx/helpers.cp313-win_amd64.pyd +0 -0
  74. lokit/parsers/tmx/helpers.py +9 -0
  75. lokit/parsers/tmx/models.cp313-win_amd64.pyd +0 -0
  76. lokit/parsers/tmx/models.py +10 -0
  77. lokit/parsers/tmx/props.cp313-win_amd64.pyd +0 -0
  78. lokit/parsers/tmx/props.py +201 -0
  79. lokit/parsers/tmx/tags.cp313-win_amd64.pyd +0 -0
  80. lokit/parsers/tmx/tags.py +59 -0
  81. lokit/parsers/tmx/xml_utils.cp313-win_amd64.pyd +0 -0
  82. lokit/parsers/tmx/xml_utils.py +46 -0
  83. lokit/parsers/xliff/__init__.cp313-win_amd64.pyd +0 -0
  84. lokit/parsers/xliff/__init__.py +3 -0
  85. lokit/parsers/xliff/extraction.cp313-win_amd64.pyd +0 -0
  86. lokit/parsers/xliff/extraction.py +229 -0
  87. lokit/parsers/xliff/tags.cp313-win_amd64.pyd +0 -0
  88. lokit/parsers/xliff/tags.py +128 -0
  89. lokit/parsers/xlsx/__init__.cp313-win_amd64.pyd +0 -0
  90. lokit/parsers/xlsx/__init__.py +1 -0
  91. lokit/parsers/xlsx/extraction.cp313-win_amd64.pyd +0 -0
  92. lokit/parsers/xlsx/extraction.py +198 -0
  93. lokit/py.typed +1 -0
  94. lokit_python-0.1.0.dist-info/METADATA +149 -0
  95. lokit_python-0.1.0.dist-info/RECORD +97 -0
  96. lokit_python-0.1.0.dist-info/WHEEL +5 -0
  97. lokit_python-0.1.0.dist-info/top_level.txt +2 -0
@@ -0,0 +1,149 @@
1
+ Metadata-Version: 2.4
2
+ Name: lokit-python
3
+ Version: 0.1.0
4
+ Summary: Add your description here
5
+ Requires-Python: >=3.12
6
+ Description-Content-Type: text/markdown
7
+ Requires-Dist: lxml>=6.1.1
8
+ Requires-Dist: openpyxl>=3.1.0
9
+ Requires-Dist: polib>=1.2.0
10
+
11
+ # lokit
12
+
13
+ > [!WARNING]
14
+ > **Beta Release:** lokit is currently in Beta. The API is volatile and subject to rapid, breaking changes prior to the official V1 release.
15
+
16
+ lokit is a high-performance, strictly type-safe, and highly memory-efficient localization toolkit for Python.
17
+ Supports Python 3.12+.
18
+
19
+ Unlike legacy tools that wrap around XML DOM element trees in-memory, lokit represents a shift away from XML-based localization interchange formats towards native language parsing. It ingests localization formats (TMX, XLIFF, PO, XLSX, CSV, JSON, HTML, IDML) and compiles them into a strict, unified structural data model. This enables not just parsing, but robust data manipulation, semantic extraction, and advanced translation memory features out-of-the-box. Lokit focuses on streaming and asynchronous processing rather than synchronous events using in-memory files.
20
+
21
+ This format type can be easily converted to JSON for interchange with other systems. I've made parsing and data transfers as native as possible by capturing all elements of traditional interchange formats in a common format structure. This allows for much better compatibility, especially in terms of segment matching and leveraging as it uses flattened strings as standard. Tags are preserved but as a common format, meaning the structure parsed from XLIFF will be the same as the structure parsed from HTML.
22
+
23
+ These legacy file formats have supported vendor-lock in for many year, making it difficult for any client to move to another system. Seeing that this is a major issue across the domain, something new is needed where vendors do not use hidden, legacy technology to lock in their clients. Localization deserves innovation.
24
+
25
+ Note: SDKs in other languages are coming soon.
26
+
27
+ ## Core Features
28
+
29
+ lokit provides a comprehensive suite of tools for managing localization data:
30
+
31
+ * **Native Structural Modeling:** Converts disjointed interchange formats into a strict, unified Python Data class, ensuring complete type safety across your entire localization pipeline.
32
+ * **Advanced Matching Engine:** Provides Exact Matching, Fuzzy Matching (via SequenceMatcher), and In-Context Exact (ICE) Matching leveraging previous and next segment context, as well as inline tag signatures.
33
+ * **Deep Sub-segment Extraction:** Automatically parses and isolates inline tags, properties, and formatting markers, allowing for safe manipulation of text without corrupting code.
34
+ * **Semantic Querying:** Easily traverse and filter translation units using complex predicates, exact ID lookups, or deep nested JSON path querying (`where()`).
35
+ * **Plural Support:** Native extraction and structuring of pluralized translation units.
36
+ * **Universal Format Conversion:** Instantly import and export between any supported format (e.g., TMX to JSON, HTML to XLIFF) with zero data loss.
37
+ * **Synchronous and Asynchronous Streaming:** Process massive enterprise files natively using Python async generators to keep memory overhead to an absolute minimum.
38
+
39
+ ## Parsing Performance vs Translate-Toolkit
40
+
41
+ When dealing with enterprise-scale localization environments, parsing performance and memory efficiency are paramount. lokit is designed to be significantly leaner and faster than the industry standard.
42
+
43
+ In a stress-test benchmark on a **612 MB TMX** file containing **557,058 segments**, parsing to XLIFF and back into TMX over 3 consecutive iterations, lokit yielded the following comparative averages:
44
+
45
+ | Library | Avg Duration (s) | Peak Memory (MB) | Memory Efficiency |
46
+ |---------|------------------|------------------|-------------------|
47
+ | **lokit (async)** | **57.5s** | **213.8 MB** | **~10.6x Less RAM** |
48
+ | **translate-toolkit** | 60.0s | 2,275.7 MB | ~2.3 GB |
49
+
50
+ Because translate-toolkit loads whole files into string buffers and C-level DOM trees synchronously, its memory spikes to over 2.2 Gigabytes. lokit leverages generator-based async streaming, allowing it to complete the exact same workload using **10.6x less RAM**, while operating slightly faster overall.
51
+
52
+ This memory safety allows for parallel processing of events, making it suitable for large-scale localization workflows and backend systems.
53
+
54
+ ## SDK Usage Reference
55
+
56
+ Lokit operates around a central `BaseStructure` dataclass model, which standardizes localization units and segments. This instructs better standardization and branching in a more language native way compared to XML based file formats. Parsing SDKs are added for both extraction and export tasks for localization interchange formats along with common file types.
57
+
58
+ ### Installation
59
+
60
+ Install lokit via pip:
61
+
62
+ ```bash
63
+ pip install lokit-python
64
+ ```
65
+
66
+ ### Basic Parsing and Conversion
67
+
68
+ Converting files synchronously is straightforward using the modular importers and exporters APIs.
69
+
70
+ ```python
71
+ from lokit.importers import import_tmx
72
+ from lokit.exporters import export_xliff
73
+
74
+ # Parse a localization file into a BaseStructure
75
+ document = import_tmx("path/to/source.tmx")
76
+
77
+ print(f"Loaded {len(document.data)} units")
78
+ print(f"Source Locale: {document.source_locale}")
79
+ print(f"Target Locale: {document.target_locale}")
80
+
81
+ # Export the BaseStructure out to a new format
82
+ export_xliff(document, "path/to/target.xliff")
83
+ ```
84
+
85
+ ### Asynchronous Streaming for Massive Files
86
+
87
+ For files spanning hundreds of megabytes, parsing the entire DOM structure into memory is inefficient. Lokit supports stream-parsing natively.
88
+
89
+ ```python
90
+ import asyncio
91
+ from lokit.importers import import_tmx_async
92
+ from lokit.exporters.xliff import export_xliff_async
93
+ from lokit.data.structure import BaseStructure
94
+
95
+ async def process_large_file():
96
+ units = {}
97
+
98
+ # Stream the file in an asynchronous generator
99
+ async for unit_id, unit_data in import_tmx_async("massive_file.tmx"):
100
+ units[unit_id] = unit_data
101
+
102
+ # Reconstruct the document safely
103
+ doc = BaseStructure(
104
+ source_locale="en_US",
105
+ target_locale="de_DE",
106
+ data=units
107
+ )
108
+
109
+ # Export asynchronously
110
+ await export_xliff_async(doc, "massive_output.xliff")
111
+
112
+ asyncio.run(process_large_file())
113
+ ```
114
+
115
+ ### Advanced Querying and Matching
116
+
117
+ The `Lokit` logic wrapper provides access to the powerful matching engine and data manipulation features.
118
+
119
+ ```python
120
+ from lokit.logic import Lokit
121
+
122
+ # Wrap a parsed document or path in the Lokit logic engine
123
+ engine = Lokit.parse("path/to/source.xliff")
124
+
125
+ # Query specific nested data structures
126
+ button_units = engine.where("extensions.component", "checkout_button")
127
+
128
+ # Perform fuzzy matching against translation memory
129
+ results = engine.fuzzy_find("Complete your purchase", limit=5, threshold=0.75)
130
+ for match in results:
131
+ print(f"Match found: {match.unit_id} (Score: {match.score})")
132
+
133
+ # Perform strict In-Context Exact (ICE) matching
134
+ ice_match = engine.match(
135
+ source="Submit",
136
+ target_unit_id="submit_btn_1",
137
+ previous_source="Enter your email",
138
+ require_context=True
139
+ )
140
+ ```
141
+
142
+ ## Supported Formats
143
+ * TMX (Translation Memory eXchange)
144
+ * XLIFF (XML Localization Interchange File Format)
145
+ * PO/POT (Gettext Portable Object)
146
+ * XLSX / CSV (Spreadsheets)
147
+ * JSON (Key-Value nested localization trees)
148
+ * HTML (Hypertext Markup)
149
+ * IDML (InDesign Markup Language)
@@ -0,0 +1,97 @@
1
+ 821d8b73c2a02cb7980f__mypyc.cp313-win_amd64.pyd,sha256=OZeVtknGA7z7HvYkyUX4Y23CgB1SR_teitbfinPBcLM,1430016
2
+ lokit/__init__.cp313-win_amd64.pyd,sha256=A7_FcVluqfyy72C-kpDvnXRfaGmzec_LvP22VLMRYCA,11264
3
+ lokit/__init__.py,sha256=YhZSX5QrEkFxaogw0N7eLf0TZMdJp97kBjTXGIPrK68,3043
4
+ lokit/format_detection.cp313-win_amd64.pyd,sha256=NqiapDgbj6hKbdlN6GqoK2FK5MslhrEZe6lamxqB4bo,11264
5
+ lokit/format_detection.py,sha256=CqoAQf8_V5iZtMzoY5W_nQmWLYo8Ko3wIlVTM8RlKJg,3775
6
+ lokit/importers.py,sha256=w3CrT2F0USyfRC0natLV27ksyrhGpkK8a3qM717rpvE,10485
7
+ lokit/logic.cp313-win_amd64.pyd,sha256=WnIbIdn_bnl8HmGbgPPMeYjOhLn8UOmeOO_8uZFSR_I,11264
8
+ lokit/logic.py,sha256=Mj5cIE2Dkc9geAFmd6EFwMJy-OWj_XQB1TIGjd04lXk,11705
9
+ lokit/py.typed,sha256=frcCV1k9oG9oKj3dpUqdJg1PxRT2RSN_XKdLCPjaYaY,2
10
+ lokit/core/__init__.cp313-win_amd64.pyd,sha256=NjQ8titXkOvxZ3yMKbp3iSrjVGURNFN2zu9YGmA2LdE,11264
11
+ lokit/core/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
12
+ lokit/core/logger.cp313-win_amd64.pyd,sha256=Gr0dSETcueq1wpZIXej6eLW3yhF4FUqEcBBNBFRXOeA,11264
13
+ lokit/core/logger.py,sha256=yjbitZCKBW25pewWZ83YChNnKj4duWD9JAGjRrvE_xk,580
14
+ lokit/data/__init__.cp313-win_amd64.pyd,sha256=lrMub1sNJc_JP1nJlrLgNKGt8fAnqaiC_ucg_A6qr9c,11264
15
+ lokit/data/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
16
+ lokit/data/lang_codes.cp313-win_amd64.pyd,sha256=t3A2TB5etk2Jpk5RJIi_eskampBN3bXB4k__iOInaBE,11264
17
+ lokit/data/lang_codes.py,sha256=BY0MhUKeAd-P9IeoEJNi-dkUEklJVaWpQxVq-iAFfO0,10259
18
+ lokit/data/structure.cp313-win_amd64.pyd,sha256=OkESoa-TFg1DAHB_Cm8T70SvW7CpBnu0B_UL290FFmg,11264
19
+ lokit/data/structure.py,sha256=bEnSWe8whhfUcqt9qTf9LVF9z-KQrS2hHNLERyWXhH8,3105
20
+ lokit/data/tag_types.cp313-win_amd64.pyd,sha256=i5fITnpLqTtVRZioV_az2RGP-jNCFDM239VCzpNs1zQ,11264
21
+ lokit/data/tag_types.py,sha256=sjEQdsTzpJuXX3snq2m4o9wQXiNCS_dU0dtwgMHGfEQ,2116
22
+ lokit/exporters/__init__.cp313-win_amd64.pyd,sha256=u-vV_nsek9zaTuuJGNdsx6bNORcXvJVIiV7dhQvhE10,11264
23
+ lokit/exporters/__init__.py,sha256=dpPkL_ODO0XhqxhuExjvvuuGolSgGG66WNS0gpVPpGI,1072
24
+ lokit/exporters/csv.cp313-win_amd64.pyd,sha256=Dey-4yfq6IWoQ5TxyJstNy0mQPv8Ek3p-q1IlkjQaxU,11264
25
+ lokit/exporters/csv.py,sha256=2_E3956eX8nRTDEZue07JdQSoIVgMkHq5hfXJyCWJPE,1122
26
+ lokit/exporters/html.cp313-win_amd64.pyd,sha256=KVkvqnrXAxcyd87u8fcpZBemWVGO71dYOCMDJVewYd0,11264
27
+ lokit/exporters/html.py,sha256=Og23iToijlGNEy3IvM7DCKlKJT_enOlzTlNveb_6diw,6981
28
+ lokit/exporters/idml.cp313-win_amd64.pyd,sha256=n7FkS--R6C6jA47lAcYuGTiEtbyJQmmIrMDSsZXrXCw,11264
29
+ lokit/exporters/idml.py,sha256=QhscjqyhKvBEUUl1iqBIPF7dKNbfN17mmuQN9BV7qRg,5619
30
+ lokit/exporters/json_i18n.cp313-win_amd64.pyd,sha256=jqen_5mYoJpHn8kqIynuKhxy0wzGl1n5vmzS4mp2SLk,11264
31
+ lokit/exporters/json_i18n.py,sha256=UC3Osu6_uJMR497RtQr5DbGPvOmwy7BlFyPlU9wOO0k,1303
32
+ lokit/exporters/po.cp313-win_amd64.pyd,sha256=H7GzGkrKkPHBhi1cB_ZrRbhE9SM486MCNmNRdnOsQcw,11264
33
+ lokit/exporters/po.py,sha256=Leg6mcJITba6HQGXLuCQUVKfVX702r8ROxtpGsXWocs,5003
34
+ lokit/exporters/tmx.cp313-win_amd64.pyd,sha256=QZ2Llxfob5sva2iqh1WL3JH4WrjCIpE1THg3CBI7Ydg,11264
35
+ lokit/exporters/tmx.py,sha256=42qmdn3YKf4y3a7o4gZVrAt52hqmx8IWOSR6qv4N4_s,8531
36
+ lokit/exporters/xliff.cp313-win_amd64.pyd,sha256=_0y9-dixpd2tSpFQFHIsufTTG4xuFD2uRDRxFFyak7s,11264
37
+ lokit/exporters/xliff.py,sha256=kBvRZfQC7vn9QGdAwe2YdpY1yA-icQljGOZTb9zKicc,5404
38
+ lokit/exporters/xlsx.cp313-win_amd64.pyd,sha256=fEI9z3kR5vdz3y_0xtjerRk5JjJscDH9Gia5cxwwuCc,11264
39
+ lokit/exporters/xlsx.py,sha256=gGrrdf6zKUK9zsqPSKVRzUeX2U8m2Ej2ZrlCaQjnHrM,1059
40
+ lokit/io/__init__.cp313-win_amd64.pyd,sha256=I3XtbOpZoKBDl2-z8waq4_U7E7YlOHTDrvrVfTleLmo,11264
41
+ lokit/io/__init__.py,sha256=-hkm8PkCM216sFF7X8f8F5wxSheGQ9iIaVn5K553ZYU,124
42
+ lokit/io/json.cp313-win_amd64.pyd,sha256=_36bTbQw7USrMSe-xD109fakajmsVUtxqQ_VS1nA6rg,11264
43
+ lokit/io/json.py,sha256=kQKIB04lZ-b4CfL6xgYQ9hGfR6F5DIMiQ5DOSVkBMYA,6484
44
+ lokit/parsers/__init__.cp313-win_amd64.pyd,sha256=Rc2nXEBsGndEIkf62ch5RNRgYu5qFKduBakdh-aDM1M,11264
45
+ lokit/parsers/__init__.py,sha256=frcCV1k9oG9oKj3dpUqdJg1PxRT2RSN_XKdLCPjaYaY,2
46
+ lokit/parsers/csv/__init__.cp313-win_amd64.pyd,sha256=o3r6C22KQK6DVcCwFkDgFEeIwlpaxOIAo91WZPEpQMQ,11264
47
+ lokit/parsers/csv/__init__.py,sha256=frcCV1k9oG9oKj3dpUqdJg1PxRT2RSN_XKdLCPjaYaY,2
48
+ lokit/parsers/csv/extraction.cp313-win_amd64.pyd,sha256=mkaSGIGqcPO1_cyniHKGM3WzWnecwcm4nmPM4Q8fjV8,11776
49
+ lokit/parsers/csv/extraction.py,sha256=k5M9JZde9I8gkviDx9A2iHScbzw_05onPJz1YkkS8bM,5611
50
+ lokit/parsers/html/__init__.cp313-win_amd64.pyd,sha256=I8hiKGr-JitsTxst3q3GBSS6IrN3_RhLAdXlA84emao,11264
51
+ lokit/parsers/html/__init__.py,sha256=dqUcjn2YJzMlwuQJaB5qXLu1PJpv_uDNEOcIK2jKxI0,88
52
+ lokit/parsers/html/extraction.cp313-win_amd64.pyd,sha256=ZMFcLpWRswmTidUcdLptlBk5AcbETy53HrZcBjAuPac,11776
53
+ lokit/parsers/html/extraction.py,sha256=G9UQLqJP8i9iKzjc890TFgj3mccU4oi-zVUjFkbntqI,12671
54
+ lokit/parsers/idml/__init__.cp313-win_amd64.pyd,sha256=QGEQXf1DGEVvxkTIv1vvk7kxdgfRIH87iOcy7w0ddl8,11264
55
+ lokit/parsers/idml/__init__.py,sha256=RSQMEfdXJdmSH3MhtiwyrcojOzxxftvK1AgnhvFgB0Y,88
56
+ lokit/parsers/idml/extraction.cp313-win_amd64.pyd,sha256=HsFFaZtPW_yFfBFJKOqYvxnKLVEzGtYWdcMww-Z2-qY,11776
57
+ lokit/parsers/idml/extraction.py,sha256=SR9dKkg9p0rJe35ySl8s7IBFTMua5IiJwm8UO2xvpAc,8764
58
+ lokit/parsers/json_i18n/__init__.cp313-win_amd64.pyd,sha256=xieZQL1WTl-KuPWWcehmTurbB5YM8w7LU2aOkCG8wmI,11264
59
+ lokit/parsers/json_i18n/__init__.py,sha256=FVMKVux9FZGZ6SXquULU42GM71K5cFlpHoP4Dte2LV0,101
60
+ lokit/parsers/json_i18n/extraction.cp313-win_amd64.pyd,sha256=FE3p_lunmr2c63SmeNrWHkEUl09NJ0jkG1faQT_wGVY,11776
61
+ lokit/parsers/json_i18n/extraction.py,sha256=bgAZJmCwb6tmiWwW5TxhuvWFQUUYjhWxE1NkEQTXtg8,5663
62
+ lokit/parsers/po/__init__.cp313-win_amd64.pyd,sha256=skqlToms0JbGjHAqsWs0OAOfuuNpz1y9T1uBA17PfLY,11264
63
+ lokit/parsers/po/__init__.py,sha256=M5hdXd5VgGLDSJt7s3BT2IYZmGVm0zbB_BnHLGcnPtQ,82
64
+ lokit/parsers/po/extraction.cp313-win_amd64.pyd,sha256=YT6lZhPPMJiItDwaHMHHDA7ueDOidtZT5tIGsRiLaIQ,11776
65
+ lokit/parsers/po/extraction.py,sha256=gt43zg1kdjE_x8PDEbHs1Ksimfxhnmi7I6pho5dpHVQ,7787
66
+ lokit/parsers/tmx/__init__.cp313-win_amd64.pyd,sha256=pZ_qf1G341ZVuAsarrlTLTEha8-G0k5AuUReCtdY_oc,11264
67
+ lokit/parsers/tmx/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
68
+ lokit/parsers/tmx/base.cp313-win_amd64.pyd,sha256=1UJ5aKTLMZu5oKAGe5fdqmJTGm9Zd2Wa3FltzXWGVKw,11264
69
+ lokit/parsers/tmx/base.py,sha256=XYLX9hnj_DSrOXZRsGFzR1UD6NqsYtdxx6dTjW6uNNc,5443
70
+ lokit/parsers/tmx/extraction.cp313-win_amd64.pyd,sha256=weLCZ0apOb3E-QTYKCRjLYR6fH4D1chCWljXyjLLqtY,11776
71
+ lokit/parsers/tmx/extraction.py,sha256=l-9Begd82OeN9xRB-KewVpY4fCWjlyISZl8kIEGdRws,5916
72
+ lokit/parsers/tmx/header.cp313-win_amd64.pyd,sha256=ZlpuPEWxPPGCmKp8EfvLBqPTVZAFDGqjRlXB2p2ttgA,11264
73
+ lokit/parsers/tmx/header.py,sha256=8vwBGDHDZSkaAz4qIWrW8KErO8nmmyt7NEtIKXqmA-s,2261
74
+ lokit/parsers/tmx/helpers.cp313-win_amd64.pyd,sha256=fKbN00JbGomth6EMj29KCsp_K3PtRa3t-EzrDovMBRs,11776
75
+ lokit/parsers/tmx/helpers.py,sha256=UZRd0a99-mYOwYEMVkRVuFnrp1yC6vmTHuJE95d1HnI,241
76
+ lokit/parsers/tmx/models.cp313-win_amd64.pyd,sha256=WrVuv1dFwXtoZE1Emni1EU2jPyMGN0cAOVvnsQeZJyQ,11264
77
+ lokit/parsers/tmx/models.py,sha256=h28n0JQtg-QwG9UswZVn3qwyFK1BKmnYUlk8V9DQjx8,175
78
+ lokit/parsers/tmx/props.cp313-win_amd64.pyd,sha256=mTi4yRp7x1dyOmElqz6ZcUBtlODnTF9sj3X-xGNV9_E,11264
79
+ lokit/parsers/tmx/props.py,sha256=OOVzZ0-A9uC8kH7lHuedDMNdiXcLJIdACu1Wa-lZqY4,7666
80
+ lokit/parsers/tmx/tags.cp313-win_amd64.pyd,sha256=ntsGLbin_QOqgFMRNncBl0cjB1OuyXAeXrH74qzSvjk,11264
81
+ lokit/parsers/tmx/tags.py,sha256=cRen1mRokpL-qlb8A2zyNPm4f-nbNfHq6IuUfCB3IwA,1990
82
+ lokit/parsers/tmx/xml_utils.cp313-win_amd64.pyd,sha256=Mu_iMB2wWf3ikLzc0QBHZnV1QZr7K_ehy1PL2aUWIqc,11776
83
+ lokit/parsers/tmx/xml_utils.py,sha256=iCpC8-giF_tzn6XzrbEgVue0cDxGWu2o5A-0V-_cw0g,1142
84
+ lokit/parsers/xliff/__init__.cp313-win_amd64.pyd,sha256=_NuzigRmtBMYAkbW66MMdw6RSHfHMZU5pAVYxOagPKI,11264
85
+ lokit/parsers/xliff/__init__.py,sha256=IhYgtPIzVImD9PtPUR36TqD99riPoU0qFmy7ES08-lM,91
86
+ lokit/parsers/xliff/extraction.cp313-win_amd64.pyd,sha256=DhPT1EOlksFGmzOr6fbU9ZkZqOD78cVbTzmGDNqGEG4,11776
87
+ lokit/parsers/xliff/extraction.py,sha256=bo0XHuVlq8GZSxj6On87ludih6uEhex4lzyZkSplpmk,8493
88
+ lokit/parsers/xliff/tags.cp313-win_amd64.pyd,sha256=opWzcy2dlnF1q9IJw0Rmdcc6_GOZ_Is_dTCkophc6FY,11264
89
+ lokit/parsers/xliff/tags.py,sha256=gKkcqcjOcLi3OiGOVOGyQvYKDORAkcW-u5cvhyxNkxo,4153
90
+ lokit/parsers/xlsx/__init__.cp313-win_amd64.pyd,sha256=DxLLd8Wh_x5CKA888hXxXMZtg8AjK9tJ4CFUcurmfuo,11264
91
+ lokit/parsers/xlsx/__init__.py,sha256=frcCV1k9oG9oKj3dpUqdJg1PxRT2RSN_XKdLCPjaYaY,2
92
+ lokit/parsers/xlsx/extraction.cp313-win_amd64.pyd,sha256=3Yr0e3LDXwCx4VJPQAX_AfFfHjkVnPcBUVOirNaHYNA,11776
93
+ lokit/parsers/xlsx/extraction.py,sha256=rZZJmyu-vmpqfL5DDQJeIiRibh-Ga-L9SGpbk8Uj1tk,6582
94
+ lokit_python-0.1.0.dist-info/METADATA,sha256=HkbOnQeGAd8SQaM0snxdTAFw4AIQ4fOCIKSm-upA1KM,7541
95
+ lokit_python-0.1.0.dist-info/WHEEL,sha256=x5Wpw_tLx5PQKiWdxpqvs0e7Sg-SO0mTWdEADYDGPGA,101
96
+ lokit_python-0.1.0.dist-info/top_level.txt,sha256=4FQaCRBDbt-jLGbmkq51WX9Gesp7Y_RXcWontgzRQrE,34
97
+ lokit_python-0.1.0.dist-info/RECORD,,
@@ -0,0 +1,5 @@
1
+ Wheel-Version: 1.0
2
+ Generator: setuptools (82.0.1)
3
+ Root-Is-Purelib: false
4
+ Tag: cp313-cp313-win_amd64
5
+
@@ -0,0 +1,2 @@
1
+ 821d8b73c2a02cb7980f__mypyc
2
+ lokit