/* * Created by Angel Leon (@gubatron), Alden Torres (aldenml) * Copyright (c) 2011-2014, FrostWire(R). All rights reserved. * * This program 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. * * 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ package com.frostwire.search; import com.google.code.regexp.Matcher; /** * <strong>A memory conscious Matcher</strong><br/> * Instead of using the groups() that reference the original HTML strings, * we just make copies of those substrings with this search matcher everytime * we invoke group(), this way the original HTML can be dereferenced and garbage collected. * * @author gubatron * @author aldenml * */ public final class SearchMatcher { private final Matcher matcher; public static SearchMatcher from(Matcher matcher) { return new SearchMatcher(matcher); } private SearchMatcher(Matcher matcher) { this.matcher = matcher; } public boolean find() { return matcher.find(); } public String group(int group) { return copy(matcher.group(group)); } public String group(String group) { return copy(matcher.group(group)); } private String copy(String str) { return new String(str.toCharArray()); } }