All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.languagetool.rules.ga.DhaNoBeirtRule Maven / Gradle / Ivy

/* LanguageTool, a natural language style checker
 * Copyright (C) 2005 Daniel Naber (http://www.danielnaber.de)
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library 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
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301
 * USA
 */
package org.languagetool.rules.ga;

import org.languagetool.AnalyzedSentence;
import org.languagetool.AnalyzedToken;
import org.languagetool.AnalyzedTokenReadings;
import org.languagetool.rules.*;

import java.util.ArrayList;
import java.util.List;
import java.util.ResourceBundle;

import static org.languagetool.rules.ga.DhaNoBeirtData.getNumberReplacements;
import static org.languagetool.rules.ga.DhaNoBeirtData.getDaoine;

public class DhaNoBeirtRule extends Rule {
  public DhaNoBeirtRule(ResourceBundle messages) {
    super.setCategory(Categories.MISC.getCategory(messages));
    setLocQualityIssueType(ITSIssueType.Misspelling);
    addExamplePair(Example.wrong("Tá dhá dheartháireacha agam."),
                   Example.fixed("Tá beirt dheartháireacha agam."));
  }

  @Override
  public String getId() {
    return "GA_DHA_NO_BEIRT";
  }

  @Override
  public String getDescription() {
    return "'dhá' nó 'beirt'";
  }

  @Override
  public RuleMatch[] match(AnalyzedSentence sentence) {
    List ruleMatches = new ArrayList<>();
    AnalyzedTokenReadings[] tokens = sentence.getTokensWithoutWhitespace();
    int markDeag = 1;
    int prevTokenIndex = 0;
    String replacement = null;
    String msg = null;
    for (int i = 1; i < tokens.length; i++) {  // ignoring token 0, i.e., SENT_START
      if (isNumber(tokens[i]) && (i < tokens.length - 2 && isPerson(tokens[i + 1]))) {
        if ("dhá".equalsIgnoreCase(tokens[i].getToken()) && (i < tokens.length - 2)) {
          for (int j = i + 2; j < tokens.length; j++) {
            if ("déag".equalsIgnoreCase(tokens[j].getToken())) {
              markDeag = j;
              replacement = "dháréag";
              msg = "Ba chóir duit " + replacement + " a scríobh";
              RuleMatch match = new RuleMatch(
                this, sentence, tokens[prevTokenIndex+1].getStartPos(), tokens[prevTokenIndex+1].getEndPos(), msg, "Uimhir phearsanta");
              ruleMatches.add(match);
              msg = "Ba chóir duit \"déag\" a scriosadh.";
              RuleMatch match2 = new RuleMatch(
                this, sentence, tokens[markDeag].getStartPos(), tokens[markDeag].getEndPos(), msg, "Uimhir phearsanta");
              ruleMatches.add(match2);
              msg = null;
            }
          }
        }
        if (replacement == null) {
          replacement = getNumberReplacements().get(tokens[i].getToken());
          if (msg == null) {
            msg = "Ba chóir duit " + replacement + " " + tokens[i + 1].getToken() + " a scríobh";
          }
        }
      }
      if (msg != null) {
        RuleMatch match = new RuleMatch(
          this, sentence, tokens[prevTokenIndex+1].getStartPos(), tokens[prevTokenIndex+1 ].getEndPos(), msg, "Uimhir phearsanta");
        ruleMatches.add(match);
        msg = null;
      }
      prevTokenIndex = i;
    }
    return toRuleMatchArray(ruleMatches);
  }

  private boolean isNumber(AnalyzedTokenReadings tok) {
    for (String num : getNumberReplacements().keySet()) {
      if (num.equalsIgnoreCase(tok.getToken())) {
        return true;
      }
    }
    return false;
  }
  private boolean isPerson(AnalyzedTokenReadings tok) {
    if (getDaoine().contains(tok.getToken().toLowerCase())) {
      return true;
    }
    for (AnalyzedToken reading : tok.getReadings()) {
      if (getDaoine().contains(reading.getLemma())) {
        return true;
      }
    }
    return false;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy