-
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathConjugations.py
65 lines (55 loc) · 2.07 KB
/
Conjugations.py
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
# This script is part of the Contextualize Add-on for Anki.
# Source: https://github.com/Eltaurus-Lt/Anki-Contextualize
#
# Copyright © 2024-2025 Eltaurus
# Contact:
# Email: Eltaurus@inbox.lt
# GitHub: github.com/Eltaurus-Lt
# Anki Forums: forums.ankiweb.net/u/Eltaurus
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
# See the GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
import os, json, re
def installedPacks():
files = os.listdir(os.path.join(os.path.dirname(__file__), 'ConjugationPacks'))
return [os.path.splitext(file)[0] for file in files if file.endswith('.json')]
def formMatch(word, dictForm):
regex = dictForm.replace("_", "(.*?)")
match = re.fullmatch(regex, word)
if match:
wordStems = match.groups()
return True, wordStems
else:
return False, ()
def formReplace(wordStems, conj):
wordConjugation = ""
for i in range(len(conj)):
if conj[i] == '_':
wordConjugation += wordStems[i]
else:
wordConjugation += conj[i]
return wordConjugation
def conjugate(word, dict, pos = ""):
wordForms = []
with open(os.path.join(os.path.dirname(__file__), "ConjugationPacks", f"{dict}.json"), "r", encoding="utf-8") as file:
dictionary = json.load(file)
for posCandidate in dictionary: # if posCandidate == pos or not pos (non-blind match)
for form in posCandidate['forms']:
match, wordStems = formMatch(word, form['dict'])
if match:
wordForms.append({
"PoS": posCandidate['PoS'],
"dict": form['dict'],
"conjs": [formReplace(wordStems, conj['conj']) for conj in form['conjs']]
})
return wordForms