00001 /* 00002 * ################################################################ 00003 * 00004 * ProActive: The Java(TM) library for Parallel, Distributed, 00005 * Concurrent computing with Security and Mobility 00006 * 00007 * Copyright (C) 1997-2007 INRIA/University of Nice-Sophia Antipolis 00008 * Contact: proactive@objectweb.org 00009 * 00010 * This library is free software; you can redistribute it and/or 00011 * modify it under the terms of the GNU Lesser General Public 00012 * License as published by the Free Software Foundation; either 00013 * version 2.1 of the License, or any later version. 00014 * 00015 * This library is distributed in the hope that it will be useful, 00016 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00017 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00018 * Lesser General Public License for more details. 00019 * 00020 * You should have received a copy of the GNU Lesser General Public 00021 * License along with this library; if not, write to the Free Software 00022 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 00023 * USA 00024 * 00025 * Initial developer(s): The ProActive Team 00026 * http://www.inria.fr/oasis/ProActive/contacts.html 00027 * Contributor(s): 00028 * 00029 * ################################################################ 00030 */ 00031 package org.objectweb.proactive.filetransfer; 00032 00033 import java.io.File; 00034 import java.io.Serializable; 00035 import java.util.Vector; 00036 00037 import org.apache.log4j.Logger; 00038 import org.objectweb.proactive.core.filetransfer.FileTransferRequest; 00039 import org.objectweb.proactive.core.util.log.Loggers; 00040 import org.objectweb.proactive.core.util.log.ProActiveLogger; 00041 00042 00053 public class FileVector implements Serializable { 00054 protected static Logger logger = ProActiveLogger.getLogger(Loggers.FILETRANSFER); 00055 Vector fileList; //Contains futures of FileTransferRequests 00056 00057 public FileVector() { 00058 fileList = new Vector(); 00059 } 00060 00066 public void waitForAll() { 00067 for (int i = 0; i < fileList.size(); i++) { 00068 FileTransferRequest request = ((FileTransferRequest) fileList.get(i)); 00069 request.waitForOperation(); 00070 } 00071 } 00072 00085 public File getFile(int i) throws Exception { 00086 FileTransferRequest ftr = (FileTransferRequest) fileList.get(i); 00087 ftr.waitForOperation(); 00088 if (ftr.getOperationFuture().hasException()) { 00089 throw ftr.getOperationFuture().getException(); 00090 } 00091 return ftr.getDstFile(); 00092 } 00093 00098 public int size() { 00099 return fileList.size(); 00100 } 00101 00109 protected Vector getFilesRequest() { 00110 return fileList; 00111 } 00112 00113 protected void add(FileTransferRequest ftr) { 00114 fileList.add(ftr); 00115 } 00116 00117 protected void add(Vector newFileReq) { 00118 for (int i = 0; i < newFileReq.size(); i++) { 00119 add((FileTransferRequest) newFileReq.get(i)); 00120 } 00121 } 00122 00123 public void add(FileVector fw) { 00124 add(fw.getFilesRequest()); 00125 } 00126 }