Completed
Pull Request — master (#141)
by Chris
13:03
created

abydos.phonetic._phonetic   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 87
Duplicated Lines 0 %

Test Coverage

Coverage 87.5%

Importance

Changes 0
Metric Value
wmc 3
eloc 20
dl 0
loc 87
ccs 14
cts 16
cp 0.875
rs 10
c 0
b 0
f 0

3 Methods

Rating   Name   Duplication   Size   Complexity  
A Phonetic.encode_alpha() 0 11 1
A Phonetic.encode() 0 8 1
A Phonetic._delete_consecutive_repeats() 0 21 1
1
# -*- coding: utf-8 -*-
2
3
# Copyright 2018 by Christopher C. Little.
4
# This file is part of Abydos.
5
#
6
# Abydos is free software: you can redistribute it and/or modify
7
# it under the terms of the GNU General Public License as published by
8
# the Free Software Foundation, either version 3 of the License, or
9
# (at your option) any later version.
10
#
11
# Abydos is distributed in the hope that it will be useful,
12
# but WITHOUT ANY WARRANTY; without even the implied warranty of
13
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
# GNU General Public License for more details.
15
#
16
# You should have received a copy of the GNU General Public License
17
# along with Abydos. If not, see <http://www.gnu.org/licenses/>.
18
19 1
"""abydos.phonetic._phonetic.
20
21
The phonetic._phonetic module implements abstract class Phonetic.
22
"""
23
24 1
from __future__ import unicode_literals
25
26 1
from itertools import groupby
27
28
29 1
class Phonetic(object):
0 ignored issues
show
Unused Code introduced by
The variable __class__ seems to be unused.
Loading history...
30
    """Abstract Phonetic class."""
31
32 1
    _uc_set = set('ABCDEFGHIJKLMNOPQRSTUVWXYZ')
33 1
    _lc_set = set('abcdefghijklmnopqrstuvwxyz')
34 1
    _uc_v_set = set('AEIOU')
35 1
    _lc_v_set = set('aeiou')
36 1
    _uc_vy_set = set('AEIOUY')
37 1
    _lc_vy_set = set('aeiouy')
38
39 1
    def _delete_consecutive_repeats(self, word):
0 ignored issues
show
Coding Style introduced by
This method could be written as a function/class method.

If a method does not access any attributes of the class, it could also be implemented as a function or static method. This can help improve readability. For example

class Foo:
    def some_method(self, x, y):
        return x + y;

could be written as

class Foo:
    @classmethod
    def some_method(cls, x, y):
        return x + y;
Loading history...
40
        """Delete consecutive repeated characters in a word.
41
42
        Args:
43
            word (str): The word to transform
44
45
        Returns:
46
            str: Word with consecutive repeating characters collapsed to a
47
                single instance
48
49
        Examples:
50
            >>> pe = Phonetic()
51
            >>> pe._delete_consecutive_repeats('REDDEE')
52
            'REDE'
53
            >>> pe._delete_consecutive_repeats('AEIOU')
54
            'AEIOU'
55
            >>> pe._delete_consecutive_repeats('AAACCCTTTGGG')
56
            'ACTG'
57
58
        """
59 1
        return ''.join(char for char, _ in groupby(word))
60
61 1
    def encode(self, word):
62
        """Encode phonetically.
63
64
        Args:
65
            word (str): The word to transform
66
67
        """
68
        pass
69
70 1
    def encode_alpha(self, word):
71
        """Encode phonetically using alphabetic characters.
72
73
        Args:
74
            word (str): The word to transform
75
76
        Returns:
77
            str: The word transformed
78
79
        """
80
        return self.encode(word)
81
82
83
if __name__ == '__main__':
84
    import doctest
85
86
    doctest.testmod()
87