File: clAnagram.cpp

package info (click to toggle)
codelite 17.0.0%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 136,204 kB
  • sloc: cpp: 491,547; ansic: 280,393; php: 10,259; sh: 8,930; lisp: 7,664; vhdl: 6,518; python: 6,020; lex: 4,920; yacc: 3,123; perl: 2,385; javascript: 1,715; cs: 1,193; xml: 1,110; makefile: 804; cobol: 741; sql: 709; ruby: 620; f90: 566; ada: 534; asm: 464; fortran: 350; objc: 289; tcl: 258; java: 157; erlang: 61; pascal: 51; ml: 49; awk: 44; haskell: 36
file content (69 lines) | stat: -rw-r--r-- 1,872 bytes parent folder | download | duplicates (4)
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
#include "clAnagram.h"
#include <algorithm>
#include <wx/wxcrt.h>

#define IS_WHITESPACE(ch) (ch == ' ' || ch == '\t' || ch == '\n' || ch == '\r')

clAnagram::clAnagram(const wxString& needle, size_t flags)
    : m_flags(flags)
{
    Reset(needle, m_flags);
}

clAnagram::~clAnagram() {}

bool clAnagram::Matches(const wxString& haystack) const
{
    std::unordered_map<wxChar, int> charsCount = m_charCounts;
    for(size_t i = 0; i < haystack.size(); ++i) {
        wxChar ch = haystack[i];
        ch = wxTolower(ch);
        if(charsCount.count(ch)) {
            int& counter = charsCount[ch];
            counter--;
            if(counter == 0) { charsCount.erase(ch); }
            if(charsCount.empty()) { return true; }
        }
    }
    return false;
}

bool clAnagram::MatchesInOrder(const wxString& haystack) const
{
    if(m_needle.IsEmpty()) { return true; }
    size_t index = 0;
    size_t maxIndex = m_needle.size();
    for(size_t i = 0; i < haystack.size(); ++i) {
        wxChar ch = haystack[i];
        ch = wxTolower(ch);
        if(ch == m_needle[index]) { ++index; }
        if(maxIndex == index) { return true; }
    }
    return false;
}

void clAnagram::Reset(const wxString& needle, size_t flags)
{
    m_flags = flags;
    m_needle.Clear();
    if(HasFlag(eAnagramFlag::kIgnoreWhitespace)) {
        for(size_t i = 0; i < needle.size(); ++i) {
            wxChar ch = needle[i];
            if(IS_WHITESPACE(ch)) { continue; }
            m_needle.Append(wxTolower(ch));
        }
    } else {
        m_needle = needle.Lower();
    }

    m_charCounts.clear();
    std::for_each(m_needle.begin(), m_needle.end(), [&](wxChar ch) {
        if(m_charCounts.count(ch) == 0) {
            m_charCounts[ch] = 1;
        } else {
            m_charCounts[ch]++;
        }
    });
}

bool clAnagram::IsEmpty() const { return m_needle.IsEmpty(); }