Moving search suggestions into their own package

This commit is contained in:
anthony restaino 2017-06-23 23:31:22 -04:00
parent cf94963255
commit 58dac82e7a
5 changed files with 43 additions and 31 deletions

View File

@ -10,6 +10,9 @@ import com.anthonycr.bonsai.SingleSubscriber;
import java.util.List; import java.util.List;
import acr.browser.lightning.database.HistoryItem; import acr.browser.lightning.database.HistoryItem;
import acr.browser.lightning.search.suggestions.BaiduSuggestionsModel;
import acr.browser.lightning.search.suggestions.DuckSuggestionsModel;
import acr.browser.lightning.search.suggestions.GoogleSuggestionsModel;
class SuggestionsManager { class SuggestionsManager {
@ -26,7 +29,7 @@ class SuggestionsManager {
@Override @Override
public void onSubscribe(@NonNull final SingleSubscriber<List<HistoryItem>> subscriber) { public void onSubscribe(@NonNull final SingleSubscriber<List<HistoryItem>> subscriber) {
sIsTaskExecuting = true; sIsTaskExecuting = true;
List<HistoryItem> results = new GoogleSuggestionsModel(application).getResults(query); List<HistoryItem> results = new GoogleSuggestionsModel(application).fetchResults(query);
subscriber.onItem(results); subscriber.onItem(results);
subscriber.onComplete(); subscriber.onComplete();
sIsTaskExecuting = false; sIsTaskExecuting = false;
@ -41,7 +44,7 @@ class SuggestionsManager {
@Override @Override
public void onSubscribe(@NonNull final SingleSubscriber<List<HistoryItem>> subscriber) { public void onSubscribe(@NonNull final SingleSubscriber<List<HistoryItem>> subscriber) {
sIsTaskExecuting = true; sIsTaskExecuting = true;
List<HistoryItem> results = new BaiduSuggestionsModel(application).getResults(query); List<HistoryItem> results = new BaiduSuggestionsModel(application).fetchResults(query);
subscriber.onItem(results); subscriber.onItem(results);
subscriber.onComplete(); subscriber.onComplete();
sIsTaskExecuting = false; sIsTaskExecuting = false;
@ -56,7 +59,7 @@ class SuggestionsManager {
@Override @Override
public void onSubscribe(@NonNull final SingleSubscriber<List<HistoryItem>> subscriber) { public void onSubscribe(@NonNull final SingleSubscriber<List<HistoryItem>> subscriber) {
sIsTaskExecuting = true; sIsTaskExecuting = true;
List<HistoryItem> results = new DuckSuggestionsModel(application).getResults(query); List<HistoryItem> results = new DuckSuggestionsModel(application).fetchResults(query);
subscriber.onItem(results); subscriber.onItem(results);
subscriber.onComplete(); subscriber.onComplete();
sIsTaskExecuting = false; sIsTaskExecuting = false;

View File

@ -1,11 +1,9 @@
package acr.browser.lightning.search; package acr.browser.lightning.search.suggestions;
import android.app.Application; import android.app.Application;
import android.support.annotation.NonNull; import android.support.annotation.NonNull;
import android.support.annotation.Nullable;
import org.json.JSONArray; import org.json.JSONArray;
import org.xmlpull.v1.XmlPullParser;
import java.io.InputStream; import java.io.InputStream;
import java.util.List; import java.util.List;
@ -18,13 +16,12 @@ import acr.browser.lightning.utils.FileUtils;
// http://suggestion.baidu.com/s?wd=encodeURIComponent(U)&action=opensearch // http://suggestion.baidu.com/s?wd=encodeURIComponent(U)&action=opensearch
class BaiduSuggestionsModel extends BaseSuggestionsModel { public class BaiduSuggestionsModel extends BaseSuggestionsModel {
@NonNull private static final String ENCODING = "UTF-8"; @NonNull private static final String ENCODING = "UTF-8";
@Nullable private static XmlPullParser sXpp;
@NonNull private final String mSearchSubtitle; @NonNull private final String mSearchSubtitle;
BaiduSuggestionsModel(@NonNull Application application) { public BaiduSuggestionsModel(@NonNull Application application) {
super(application, ENCODING); super(application, ENCODING);
mSearchSubtitle = application.getString(R.string.suggestion); mSearchSubtitle = application.getString(R.string.suggestion);
} }
@ -39,12 +36,14 @@ class BaiduSuggestionsModel extends BaseSuggestionsModel {
String content = FileUtils.readStringFromStream(inputStream, "GBK"); String content = FileUtils.readStringFromStream(inputStream, "GBK");
JSONArray respArray = new JSONArray(content); JSONArray respArray = new JSONArray(content);
JSONArray jsonArray = respArray.getJSONArray(1); JSONArray jsonArray = respArray.getJSONArray(1);
int counter = 0; int counter = 0;
for (int n = 0, size = jsonArray.length(); n < size; n++) { for (int n = 0, size = jsonArray.length(); n < size; n++) {
String suggestion = jsonArray.getString(n); String suggestion = jsonArray.getString(n);
results.add(new HistoryItem(mSearchSubtitle + " \"" + suggestion + '"', results.add(new HistoryItem(mSearchSubtitle + " \"" + suggestion + '"',
suggestion, R.drawable.ic_search)); suggestion, R.drawable.ic_search));
counter++; counter++;
if (counter >= MAX_RESULTS) { if (counter >= MAX_RESULTS) {
break; break;
} }

View File

@ -1,4 +1,4 @@
package acr.browser.lightning.search; package acr.browser.lightning.search.suggestions;
import android.app.Application; import android.app.Application;
import android.support.annotation.NonNull; import android.support.annotation.NonNull;
@ -28,7 +28,7 @@ import okhttp3.Request;
import okhttp3.Response; import okhttp3.Response;
import okhttp3.ResponseBody; import okhttp3.ResponseBody;
abstract class BaseSuggestionsModel { public abstract class BaseSuggestionsModel {
private static final String TAG = "BaseSuggestionsModel"; private static final String TAG = "BaseSuggestionsModel";
@ -57,23 +57,25 @@ abstract class BaseSuggestionsModel {
mCacheControl = new CacheControl.Builder().maxStale(1, TimeUnit.DAYS).build(); mCacheControl = new CacheControl.Builder().maxStale(1, TimeUnit.DAYS).build();
} }
/**
* Retrieves the results for a query.
*
* @param rawQuery the raw query to retrieve the results for.
* @return a list of history items for the query.
*/
@NonNull @NonNull
private static String getLanguage() { public final List<HistoryItem> fetchResults(@NonNull final String rawQuery) {
String language = Locale.getDefault().getLanguage();
if (TextUtils.isEmpty(language)) {
language = DEFAULT_LANGUAGE;
}
return language;
}
@NonNull
List<HistoryItem> getResults(@NonNull String query) {
List<HistoryItem> filter = new ArrayList<>(5); List<HistoryItem> filter = new ArrayList<>(5);
String query;
try { try {
query = URLEncoder.encode(query, mEncoding); query = URLEncoder.encode(rawQuery, mEncoding);
} catch (UnsupportedEncodingException e) { } catch (UnsupportedEncodingException e) {
Log.e(TAG, "Unable to encode the URL", e); Log.e(TAG, "Unable to encode the URL", e);
return filter;
} }
InputStream inputStream = downloadSuggestionsForQuery(query, mLanguage); InputStream inputStream = downloadSuggestionsForQuery(query, mLanguage);
if (inputStream == null) { if (inputStream == null) {
// There are no suggestions for this query, return an empty list. // There are no suggestions for this query, return an empty list.
@ -83,7 +85,6 @@ abstract class BaseSuggestionsModel {
parseResults(inputStream, filter); parseResults(inputStream, filter);
} catch (Exception e) { } catch (Exception e) {
Log.e(TAG, "Unable to parse results", e); Log.e(TAG, "Unable to parse results", e);
return filter;
} finally { } finally {
Utils.close(inputStream); Utils.close(inputStream);
} }
@ -93,7 +94,7 @@ abstract class BaseSuggestionsModel {
/** /**
* This method downloads the search suggestions for the specific query. * This method downloads the search suggestions for the specific query.
* NOTE: This is a blocking operation, do not getResults on the UI thread. * NOTE: This is a blocking operation, do not fetchResults on the UI thread.
* *
* @param query the query to get suggestions for * @param query the query to get suggestions for
* @return the cache file containing the suggestions * @return the cache file containing the suggestions
@ -122,6 +123,15 @@ abstract class BaseSuggestionsModel {
return null; return null;
} }
@NonNull
private static String getLanguage() {
String language = Locale.getDefault().getLanguage();
if (TextUtils.isEmpty(language)) {
language = DEFAULT_LANGUAGE;
}
return language;
}
private static final Interceptor REWRITE_CACHE_CONTROL_INTERCEPTOR = new Interceptor() { private static final Interceptor REWRITE_CACHE_CONTROL_INTERCEPTOR = new Interceptor() {
@Override @Override
public Response intercept(@NonNull Chain chain) throws IOException { public Response intercept(@NonNull Chain chain) throws IOException {

View File

@ -1,4 +1,4 @@
package acr.browser.lightning.search; package acr.browser.lightning.search.suggestions;
import android.app.Application; import android.app.Application;
import android.support.annotation.NonNull; import android.support.annotation.NonNull;
@ -13,12 +13,12 @@ import acr.browser.lightning.R;
import acr.browser.lightning.database.HistoryItem; import acr.browser.lightning.database.HistoryItem;
import acr.browser.lightning.utils.FileUtils; import acr.browser.lightning.utils.FileUtils;
final class DuckSuggestionsModel extends BaseSuggestionsModel { public final class DuckSuggestionsModel extends BaseSuggestionsModel {
@NonNull private static final String ENCODING = "UTF-8"; @NonNull private static final String ENCODING = "UTF-8";
@NonNull private final String mSearchSubtitle; @NonNull private final String mSearchSubtitle;
DuckSuggestionsModel(@NonNull Application application) { public DuckSuggestionsModel(@NonNull Application application) {
super(application, ENCODING); super(application, ENCODING);
mSearchSubtitle = application.getString(R.string.suggestion); mSearchSubtitle = application.getString(R.string.suggestion);
} }

View File

@ -1,4 +1,4 @@
package acr.browser.lightning.search; package acr.browser.lightning.search.suggestions;
import android.app.Application; import android.app.Application;
import android.support.annotation.NonNull; import android.support.annotation.NonNull;
@ -15,13 +15,13 @@ import java.util.List;
import acr.browser.lightning.R; import acr.browser.lightning.R;
import acr.browser.lightning.database.HistoryItem; import acr.browser.lightning.database.HistoryItem;
class GoogleSuggestionsModel extends BaseSuggestionsModel { public class GoogleSuggestionsModel extends BaseSuggestionsModel {
@NonNull private static final String ENCODING = "ISO-8859-1"; @NonNull private static final String ENCODING = "ISO-8859-1";
@Nullable private static XmlPullParser sXpp; @Nullable private static XmlPullParser sXpp;
@NonNull private final String mSearchSubtitle; @NonNull private final String mSearchSubtitle;
GoogleSuggestionsModel(@NonNull Application application) { public GoogleSuggestionsModel(@NonNull Application application) {
super(application, ENCODING); super(application, ENCODING);
mSearchSubtitle = application.getString(R.string.suggestion); mSearchSubtitle = application.getString(R.string.suggestion);
} }