/* * This file is part of gwap, an open platform for games with a purpose * * Copyright (C) 2013 * Project play4science * Lehr- und Forschungseinheit für Programmier- und Modellierungssprachen * Ludwig-Maximilians-Universität München * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero 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 Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ package gwap.game; import gwap.action.TaggingBean; import gwap.model.resource.Resource; import gwap.tools.LevenshteinDistance; import gwap.tools.TagSemantics; import gwap.wrapper.MatchingTag; import gwap.wrapper.TagFrequency; import java.io.Serializable; import java.util.List; import javax.persistence.EntityManager; import javax.persistence.Query; import org.jboss.seam.ScopeType; import org.jboss.seam.annotations.Create; import org.jboss.seam.annotations.Destroy; import org.jboss.seam.annotations.In; import org.jboss.seam.annotations.Logger; import org.jboss.seam.annotations.Name; import org.jboss.seam.annotations.Scope; import org.jboss.seam.international.LocaleSelector; import org.jboss.seam.log.Log; @Name("spellCorrection") @Scope(ScopeType.CONVERSATION) public class SpellCorrection implements Serializable { @Create public void init() { log.info("Creating"); } @Destroy public void destroy() { log.info("Destroying"); } @Logger private Log log; @In private EntityManager entityManager; @In private LocaleSelector localeSelector; @In(required=false) private TaggingBean taggingBean; @In(required=false) private List<TagFrequency> tabooTags; public void findSpellCorrectedTags(Resource resource, MatchingTag matchingTag) { if (!matchingTag.isTagCorrectionCompleted()) { String originalTag = matchingTag.getTag(); int TagLength = originalTag.length(); if (TagLength>=3){ Query query1 = entityManager.createNamedQuery("tag.tagNamesByResource"); query1.setParameter("resource", resource); query1.setParameter("language", localeSelector.getLanguage()); query1.setParameter("minOccurrence", 2L); findAlternativeTags(matchingTag, query1.getResultList()); } } } private void findAlternativeTags(MatchingTag matchingTag, List<String> tagNames){ String originalTag = matchingTag.getTag(); int originalTagLength = originalTag.length(); for (int i=0; i<tagNames.size(); i++){ String tagName = tagNames.get(i); int lengthDiff = tagName.length()-originalTagLength; if (-2<=lengthDiff && lengthDiff<=2){ int levenshteinDiff = LevenshteinDistance.computeLevenshteinDistance(originalTag.toLowerCase(), tagName.toLowerCase()); if (levenshteinDiff<=1 ||(originalTag.length()>8 && levenshteinDiff<=2)){ if (tabooTags == null || TagSemantics.containsNotNormalized2(tabooTags, tagName) == null) { matchingTag.addAlternativeTag(tagName); i=tagNames.size(); } } } } } }