/*
* (c) Copyright 2010-2011 AgileBirds
*
* This file is part of OpenFlexo.
*
* OpenFlexo 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 3 of the License, or
* (at your option) any later version.
*
* OpenFlexo 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 OpenFlexo. If not, see <http://www.gnu.org/licenses/>.
*
*/
package org.netbeans.lib.cvsclient.response;
import java.io.File;
import java.io.IOException;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Locale;
import org.netbeans.lib.cvsclient.admin.Entry;
import org.netbeans.lib.cvsclient.util.LoggedDataInputStream;
/**
* Indicates that a file has been successfully operated on, e.g. checked in, added etc.
*
* @author Robert Greig
*/
class CheckedInResponse implements Response {
/**
* The date Formatter used to parse and format dates. Format is: "EEE MMM dd HH:mm:ss yyyy"
*/
private DateFormat dateFormatter;
/**
* Process the data for the response.
*
* @param dis
* the data inputstream allowing the client to read the server's response. Note that the actual response name has already
* been read and the input stream is positioned just before the first argument, if any.
*/
@Override
public void process(LoggedDataInputStream dis, ResponseServices services) throws ResponseException {
try {
String localPath = dis.readLine();
// System.err.println("Pathname is: " + localPath);
String repositoryPath = dis.readLine();
// System.err.println("Repository path is: " + repositoryPath);
String entriesLine = dis.readLine();
// System.err.println("New entries line is: " + entriesLine);
// we set the date the file was last modified in the Entry line
// so that we can easily determine whether the file has been
// untouched
final File theFile = new File(services.convertPathname(localPath, repositoryPath));
final Date date = new Date(theFile.lastModified());
final Entry entry = new Entry(entriesLine);
entry.setConflict(getDateFormatter().format(date));
// for added and removed entries set the conflict to Dummy timestamp.
if (entry.isNewUserFile() || entry.isUserFileToBeRemoved()) {
entry.setConflict(Entry.DUMMY_TIMESTAMP);
}
services.setEntry(theFile, entry);
} catch (IOException e) {
throw new ResponseException((Exception) e.fillInStackTrace(), e.getLocalizedMessage());
}
}
/**
* Is this a terminal response, i.e. should reading of responses stop after this response. This is true for responses such as OK or an
* error response
*/
@Override
public boolean isTerminalResponse() {
return false;
}
/**
* Returns the DateFormatter instance that parses and formats date Strings. The exact format matches the one in
* Entry.getLastModifiedDateFormatter() method.
*
*/
protected DateFormat getDateFormatter() {
if (dateFormatter == null) {
dateFormatter = new SimpleDateFormat(Entry.getLastModifiedDateFormatter().toPattern(), Locale.US);
dateFormatter.setTimeZone(Entry.getTimeZone());
}
return dateFormatter;
}
}