FtsUtils.java

 1/*
 2 * Copyright (c) 2018, Daniel Gultsch All rights reserved.
 3 *
 4 * Redistribution and use in source and binary forms, with or without modification,
 5 * are permitted provided that the following conditions are met:
 6 *
 7 * 1. Redistributions of source code must retain the above copyright notice, this
 8 * list of conditions and the following disclaimer.
 9 *
10 * 2. Redistributions in binary form must reproduce the above copyright notice,
11 * this list of conditions and the following disclaimer in the documentation and/or
12 * other materials provided with the distribution.
13 *
14 * 3. Neither the name of the copyright holder nor the names of its contributors
15 * may be used to endorse or promote products derived from this software without
16 * specific prior written permission.
17 *
18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
19 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
20 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
21 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
22 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
23 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
24 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
25 * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
27 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 */
29
30package eu.siacs.conversations.utils;
31
32import java.util.ArrayList;
33import java.util.Arrays;
34import java.util.List;
35import java.util.Locale;
36
37public class FtsUtils {
38
39	private static List<String> KEYWORDS = Arrays.asList("OR", "AND");
40
41	public static List<String> parse(String input) {
42		List<String> term = new ArrayList<>();
43		for (String part : input.split("\\s+")) {
44			if (part.isEmpty()) {
45				continue;
46			}
47			final String cleaned = part.substring(getStartIndex(part), getEndIndex(part) +1);
48			if (isKeyword(cleaned)) {
49				term.add(part);
50			} else {
51				term.add(cleaned);
52			}
53		}
54		return term;
55	}
56
57	public static String toMatchString(List<String> terms) {
58		StringBuilder builder = new StringBuilder();
59		for (String term : terms) {
60			if (builder.length() != 0) {
61				builder.append(' ');
62			}
63			if (isKeyword(term)) {
64				builder.append(term.toUpperCase(Locale.ENGLISH));
65			} else if (term.contains("*") || term.startsWith("-")) {
66				builder.append(term);
67			} else {
68				builder.append('*').append(term).append('*');
69			}
70		}
71		return builder.toString();
72	}
73
74	public static boolean isKeyword(String term) {
75		return KEYWORDS.contains(term.toUpperCase(Locale.ENGLISH));
76	}
77
78	private static int getStartIndex(String term) {
79		int index = 0;
80		while (term.charAt(index) == '*') {
81			++index;
82		}
83		return index;
84	}
85
86	private static int getEndIndex(String term) {
87		int index = term.length() - 1;
88		while (term.charAt(index) == '*') {
89			--index;
90		}
91		return index;
92	}
93
94}