/* * Copyright (C) 2010-2013 Geometer Plus * * 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 2 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, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA * 02110-1301, USA. */ package org.geometerplus.android.fbreader.libraryService; import android.app.Service; import android.content.Intent; import android.os.IBinder; import org.geometerplus.fbreader.library.*; import org.geometerplus.android.fbreader.library.SQLiteBooksDatabase; public class LibraryService extends Service { public final class LibraryImplementation extends LibraryInterface.Stub { LibraryImplementation() { BooksDatabase database = SQLiteBooksDatabase.Instance(); if (database == null) { database = new SQLiteBooksDatabase(LibraryService.this, "LIBRARY SERVICE"); } final BookCollection collection = new BookCollection(database); final long start = System.currentTimeMillis(); collection.addChangeListener(new BookCollection.ChangeListener() { public void onCollectionChanged(Code code, Book book) { switch (code) { case BookAdded: System.err.println("Added " + book.getTitle()); break; case BuildStarted: System.err.println("Build started"); break; case BuildSucceeded: System.err.println("Build succeeded"); break; case BuildCompleted: System.err.println("Build completed with " + collection.size() + " books in " + (System.currentTimeMillis() - start) + " milliseconds"); break; } } }); collection.startBuild(); } public boolean isUpToDate() { return true; } } private LibraryImplementation myLibrary; @Override public void onStart(Intent intent, int startId) { onStartCommand(intent, 0, startId); } @Override public int onStartCommand(Intent intent, int flags, int startId) { System.err.println("LibraryService started for intent " + intent); return START_STICKY; } @Override public IBinder onBind(Intent intent) { System.err.println("LibraryService binded for intent " + intent); return myLibrary; } @Override public void onCreate() { System.err.println("LibraryService.onCreate()"); super.onCreate(); myLibrary = new LibraryImplementation(); } @Override public void onDestroy() { System.err.println("LibraryService.onDestroy()"); myLibrary = null; super.onDestroy(); } }