Here you can find the source of tokenizeQuotes(String f1)
public static ArrayList<String> tokenizeQuotes(String f1)
//package com.java2s; /*/*from w w w . j a v a 2 s . co m*/ * Copyright (C) 2014 Sheng Cao <sca6096@gmail.com>. All rights reserved. * * The file is part of English-Semantics-Extraction. * * English-Semantics-Extraction 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/>. * * Please contact sca6096@gmail.com if you need additional information * or have any questions. */ import java.util.*; public class Main { public static ArrayList<String> tokenizeQuotes(String f1) { ArrayList<String> fin = new ArrayList(); StringBuilder temp = new StringBuilder(); boolean inQuote = false; for (int i = 0; i < f1.length(); i++) { if (!inQuote) if (Character.isWhitespace(f1.charAt(i))) continue; boolean enter = false; boolean exit = false; if (f1.charAt(i) == '"') { if (i == 0) { inQuote = true; } else { if (!inQuote) { enter = true; inQuote = true; } else { if (f1.charAt(i - 1) != '\\') { exit = true; inQuote = false; } } } } if (enter) { fin.add(temp.toString()); temp = new StringBuilder(); } temp.append(f1.charAt(i)); if (exit) { fin.add(temp.toString()); temp = new StringBuilder(); } } if (temp.length() != 0) fin.add(temp.toString()); return fin; } }