Hot-keys on this page

r m x p   toggle line displays

j k   next/prev highlighted chunk

0   (zero) top of page

1   (one) first highlighted chunk

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

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

#! /usr/bin/env python3 

# -*- coding: utf-8 -*- 

 

#       Copyright 2011, Milan Boers 

#       Copyright 2011-2013, Marten de Vries 

# 

#       This file is part of OpenTeacher. 

# 

#       OpenTeacher 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. 

# 

#       OpenTeacher 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 OpenTeacher.  If not, see <http://www.gnu.org/licenses/>. 

 

class VTrainTxtLoaderModule: 

        def __init__(self, moduleManager, *args, **kwargs): 

                super().__init__(*args, **kwargs) 

 

                self.type = "load" 

                self.priorities = { 

                        "default": 432, 

                } 

                self._mm = moduleManager 

                self.uses = ( 

                        self._mm.mods(type="translator"), 

                ) 

                self.requires = ( 

                        self._mm.mods(type="wordsStringParser"), 

                ) 

                self.filesWithTranslations = ("vtrainTxt.py",) 

                #for test suite purposes 

                self.format = "vtrain" 

 

        @property 

        def _parse(self): 

                return self._modules.default("active", type="wordsStringParser").parse 

 

        def _retranslate(self): 

                try: 

                        translator = self._modules.default("active", type="translator") 

                except IndexError: 

                        _, ngettext = str, lambda a, b, n: a if n == 1 else b 

                else: 

                        _, ngettext = translator.gettextFunctions( 

                                self._mm.resourcePath("translations") 

                        ) 

                #TRANSLATORS: This is one of the file formats OpenTeacher 

                #TRANSLATORS: can read. It's named after the program that uses 

                #TRANSLATORS: it. See http://www.vtrain.net/ for more info on 

                #TRANSLATORS: the program. 

                self.name = _("VTrain") 

 

        def enable(self): 

                self.loads = { 

                        "txt": ["words"], 

                } 

                #no mime type: claiming .txt doesn't make sense. 

 

                self._modules = set(self._mm.mods(type="modules")).pop() 

                try: 

                        translator = self._modules.default("active", type="translator") 

                except IndexError: 

                        pass 

                else: 

                        translator.languageChanged.handle(self._retranslate) 

                self._retranslate() 

 

                self.active = True 

 

        def disable(self): 

                self.active = False 

 

                del self.name 

                del self.loads 

 

                del self._modules 

 

        def getFileTypeOf(self, path): 

exit                if path.endswith(".txt"): 

                        with open(path, "r", encoding="ISO-8859-1") as f: 

                                data = f.read() 

                                #A heuristic. Adapt as necessary. 

                                amountOfLineEnds = data.count("|") 

                                amountOfSeparators = data.count("=") 

exit                                if amountOfLineEnds and amountOfLineEnds == amountOfSeparators: 

                                        return "words" 

 

        def load(self, path): 

                """Tries to load .txt VTrain files. Based on observation of the 

                    file format, and the following description send by mail by 

                    the author of VTrain: 

 

                        'VTrain uses customizable separators after the front and 

                        after the back of each flashcard. By default, the 

                        separators are "=" and "|". You can use these separators to 

                        import and export flashcards (File menu). 

 

                        the horse=el caballo| 

                        the house=la casa| 

                        ...' 

 

                """ 

                items = [] 

 

                #read file 

                with open(path, "r", encoding="ISO-8859-1") as f: 

                        data = f.read() 

                        for i, line in enumerate(data.split(u"|")): 

                                try: 

                                        questions, answers = line.split(u"=") 

                                except ValueError: 

                                        #shouldn't happen, but just in case someone e.g. 

                                        #accidentally adds a newline at the end of the file. 

                                        continue 

                                items.append({ 

                                        "id": i, 

                                        "questions": self._parse(questions), 

                                        "answers": self._parse(answers), 

                                }) 

 

                return { 

                        "list": { 

                                "items": items, 

                                "results": [], 

                        }, 

                        "resources": {}, 

                } 

 

def init(moduleManager): 

        return VTrainTxtLoaderModule(moduleManager)