/******************************************************************************* * 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()]); } }