All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.activeandroid.sqlbrite.SqlBrite Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (C) 2015 Square, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.activeandroid.sqlbrite;

import android.content.ContentResolver;
import android.database.Cursor;
import android.database.sqlite.SQLiteOpenHelper;
import android.support.annotation.CheckResult;
import android.support.annotation.NonNull;
import android.util.Log;
import rx.Observable;
import rx.Subscriber;
import rx.functions.Func1;

/**
 * A lightweight wrapper around {@link SQLiteOpenHelper} which allows for continuously observing
 * the result of a query.
 */
public final class SqlBrite {
  @CheckResult @NonNull
  public static SqlBrite create() {
    return create(new Logger() {
      @Override public void log(String message) {
        Log.d("SqlBrite", message);
      }
    });
  }

  @CheckResult @NonNull
  public static SqlBrite create(@NonNull Logger logger) {
    return new SqlBrite(logger);
  }

  private final Logger logger;

  private SqlBrite(@NonNull Logger logger) {
    this.logger = logger;
  }

  /**
   * Wrap a {@link SQLiteOpenHelper} for observable queries.
   * 

* While not strictly required, instances of this class assume that they will be the only ones * interacting with the underlying {@link SQLiteOpenHelper} and it is required for automatic * notifications of table changes to work. See {@linkplain BriteDatabase#createQuery the * query method} for more information on that behavior. */ @CheckResult @NonNull public BriteDatabase wrapDatabaseHelper(@NonNull SQLiteOpenHelper helper) { return new BriteDatabase(helper, logger); } /** Wrap a {@link ContentResolver} for observable queries. */ @CheckResult @NonNull public BriteContentResolver wrapContentProvider(@NonNull ContentResolver contentResolver) { return new BriteContentResolver(contentResolver, logger); } /** An executable query. */ public static abstract class Query { /** Execute the query on the underlying database and return the resulting cursor. */ @CheckResult // TODO @WorkerThread // TODO Implementations might return null, which is gross. Throw? public abstract Cursor run(); /** * Execute the query on the underlying database and return an Observable of each row mapped to * {@code T} by {@code mapper}. *

* Standard usage of this operation is in {@code flatMap}: *

{@code
     * flatMap(q -> q.asRows(Item.MAPPER).toList())
     * }
* However, the above is a more-verbose but identical operation as * {@link QueryObservable#mapToList}. This {@code asRows} method should be used when you need * to limit or filter the items separate from the actual query. *
{@code
     * flatMap(q -> q.asRows(Item.MAPPER).take(5).toList())
     * // or...
     * flatMap(q -> q.asRows(Item.MAPPER).filter(i -> i.isActive).toList())
     * }
*

* Note: Limiting results or filtering will almost always be faster in the database as part of * a query and should be preferred, where possible. */ @CheckResult @NonNull public final Observable asRows(final Func1 mapper) { return Observable.create(new Observable.OnSubscribe() { @Override public void call(Subscriber subscriber) { Cursor cursor = run(); try { while (cursor.moveToNext() && !subscriber.isUnsubscribed()) { subscriber.onNext(mapper.call(cursor)); } } finally { cursor.close(); } if (!subscriber.isUnsubscribed()) { subscriber.onCompleted(); } } }); } } /** A simple indirection for logging debug messages. */ public interface Logger { void log(String message); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy