/* * Copyright (C) 2009 eXo Platform SAS. * * This is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation; either version 2.1 of * the License, or (at your option) any later version. * * This software 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this software; if not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA, or see the FSF site: http://www.fsf.org. */ package org.xcmis.search.lucene.index; import java.io.File; import java.util.ArrayList; import java.util.List; /** * Created by The eXo Platform SAS. <br/> * Date: * * @author <a href="karpenko.sergiy@gmail.com">Karpenko Sergiy</a> * @version $Id: FSIndexTransactionService.java 2 2010-02-04 17:21:49Z andrew00x $ */ public class FSIndexTransactionService implements IndexTransactionService { private final ConcurrentDirectoryFactory lockFactory; private final File storageDir; public FSIndexTransactionService(final File storageDir, final ConcurrentDirectoryFactory lockFactory) { this.storageDir = storageDir; this.lockFactory = lockFactory; } public final ConcurrentDirectoryFactory getLockFactory() { return lockFactory; } public final File getStorageDir() { return storageDir; } public List<TransactionLog> getTransactionLogs() throws TransactionLogException { final List<File> logFileList = this.getFileList(storageDir); final List<TransactionLog> logs = new ArrayList<TransactionLog>(); for (final File file : logFileList) { final TransactionLog log = new FileSystemTransactionLog(file, this); logs.add(log); } return logs; } /** * {@inheritDoc} */ public boolean hasUncommitedTransactions() { return this.hasFiles(storageDir); } /** * Return file list from storage. * * @param dir - storage of files * @return Complete list of storage files.Or empty list if there is no files. */ protected List<File> getFileList(final File dir) { final List<File> resList = new ArrayList<File>(); final File[] list = dir.listFiles(); for (final File file : list) { if (file.isFile()) { resList.add(file); } else { resList.addAll(this.getFileList(file)); } } return resList; } /** * Check directory for internal files. * * @param dir - directory to check * @return <code>true</code> if directory has files, <code>false</code> in * other case */ private boolean hasFiles(final File dir) { if (dir.exists()) { final File[] list = dir.listFiles(); for (final File file : list) { if (file.isFile()) { return true; } else { if (this.hasFiles(file)) { return true; } } } } return false; } }