/*******************************************************************************
* Copyright (c) 2012, 2014 Pivotal Software, Inc.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of 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.
*
* Contributors:
* Pivotal Software, Inc. - initial API and implementation
********************************************************************************/
package org.cloudfoundry.ide.eclipse.server.rse.internal;
import java.util.ArrayList;
import java.util.List;
import org.eclipse.rse.services.files.IHostFile;
import org.eclipse.rse.subsystems.files.core.servicesubsystem.AbstractRemoteFile;
import org.eclipse.rse.subsystems.files.core.servicesubsystem.FileServiceSubSystem;
import org.eclipse.rse.subsystems.files.core.subsystems.IHostFileToRemoteFileAdapter;
import org.eclipse.rse.subsystems.files.core.subsystems.IRemoteFile;
import org.eclipse.rse.subsystems.files.core.subsystems.IRemoteFileContext;
/**
* @author Leo Dos Santos
*/
public class CloudFoundryFileAdapter implements IHostFileToRemoteFileAdapter {
public AbstractRemoteFile convertToRemoteFile(FileServiceSubSystem ss, IRemoteFileContext context,
IRemoteFile parent, IHostFile node) {
CloudFoundryRemoteFile file = new CloudFoundryRemoteFile(ss, context, parent, (CloudFoundryHostFile) node);
ss.cacheRemoteFile(file);
return file;
}
public AbstractRemoteFile[] convertToRemoteFiles(FileServiceSubSystem ss, IRemoteFileContext context,
IRemoteFile parent, IHostFile[] nodes) {
List<CloudFoundryRemoteFile> results = new ArrayList<CloudFoundryRemoteFile>();
if (nodes != null) {
for (int i = 0; i < nodes.length; i++) {
CloudFoundryHostFile node = (CloudFoundryHostFile) nodes[i];
CloudFoundryRemoteFile remote = new CloudFoundryRemoteFile(ss, context, parent, node);
results.add(remote);
ss.cacheRemoteFile(remote);
}
}
return results.toArray(new CloudFoundryRemoteFile[results.size()]);
}
}