Working facsimiles of ls and half of cp for Repo.

git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@4510 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
Britt Park
2006-12-04 19:17:34 +00:00
parent 66c95d5dce
commit a95b3bbed0
7 changed files with 210 additions and 52 deletions

View File

@@ -0,0 +1,158 @@
/**
*
*/
package org.alfresco.repo.clt;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.List;
import java.util.Map;
import org.alfresco.service.cmr.avm.AVMNodeDescriptor;
import org.alfresco.service.cmr.repository.NodeRef;
import org.alfresco.util.Pair;
/**
* Simplified cp from a local filesystem to the repo.
* @author britt
*/
public class RepoCopyIn extends CltBase
{
private static Object [] flagDefs = { "-r", 0, "-v", 0 };
private static String USAGE = "usage: RepoCopyIn fspath repopath";
private boolean fVerbose;
/* (non-Javadoc)
* @see org.alfresco.repo.clt.CltBase#run(java.util.Map, java.util.List)
*/
@Override
protected void run(Map<String, List<String>> flags, List<String> args)
{
if (flags.containsKey("-v"))
{
fVerbose = true;
}
else
{
fVerbose = false;
}
NodeRef root = fRepoRemote.getRoot();
String path = args.get(1);
while (path.startsWith("/"))
{
path = path.substring(1);
}
Pair<NodeRef, Boolean> dst = fRepoRemote.lookup(root, path);
if (flags.containsKey("-r"))
{
if (dst == null)
{
System.err.println(args.get(1) + " does not exist.");
fContext.close();
System.exit(1);
}
recursiveCopy(args.get(0), dst.getFirst());
return;
}
File file = new File(args.get(0));
if (!file.isFile())
{
System.err.println(args.get(0) + " not found, or not a file.");
fContext.close();
System.exit(1);
}
if (dst == null)
{
try
{
if (fVerbose)
{
System.out.println(file.getName() + " -> " + args.get(1));
}
InputStream in =
new FileInputStream(file);
OutputStream out = fRepoRemote.createFile(root, path);
copyStream(in, out);
}
catch (IOException e)
{
e.printStackTrace();
fContext.close();
System.exit(1);
}
}
else
{
if (!dst.getSecond())
{
System.err.println("Target must be a directory.");
fContext.close();
System.exit(1);
}
try
{
if (fVerbose)
{
System.out.println(file.getName() + " -> " + args.get(1));
}
InputStream in =
new FileInputStream(file);
OutputStream out =
fAVMRemote.createFile(args.get(1), file.getName());
copyStream(in, out);
}
catch (IOException e)
{
e.printStackTrace();
fContext.close();
System.exit(1);
}
}
}
private void recursiveCopy(String sourcePath, NodeRef dest)
{
File file = new File(sourcePath);
if (fVerbose)
{
System.out.println(sourcePath + " -> " + dest);
}
if (file.isDirectory())
{
NodeRef dir = fRepoRemote.createDirectory(dest, file.getName());
String [] names = file.list();
for (String name : names)
{
recursiveCopy(sourcePath + File.separatorChar + name,
dir);
}
}
else
{
try
{
InputStream in =
new FileInputStream(file);
OutputStream out = fRepoRemote.createFile(dest, file.getName());
copyStream(in, out);
}
catch (IOException e)
{
e.printStackTrace();
fContext.close();
System.exit(1);
}
}
}
public static void main(String[] args)
{
RepoCopyIn me = new RepoCopyIn();
me.exec(args, flagDefs, 2, USAGE);
}
}

View File

@@ -7,7 +7,6 @@ import java.util.List;
import java.util.Map;
import org.alfresco.service.cmr.repository.NodeRef;
import org.alfresco.service.namespace.QName;
import org.alfresco.util.Pair;
/**
@@ -39,21 +38,44 @@ public class RepoLs extends CltBase
{
path = path.substring(1);
}
dir = fRepoRemote.lookup(root, path);
if (dir == null)
Pair<NodeRef, Boolean> info = fRepoRemote.lookup(root, path);
if (info == null)
{
System.err.println(path + " does not exist");
fContext.close();
System.exit(1);
}
dir = info.getFirst();
}
Map<String, Pair<NodeRef, QName>> listing = fRepoRemote.getListing(dir);
if (flags.containsKey("-R"))
{
recursiveList(dir, 0);
return;
}
Map<String, Pair<NodeRef, Boolean>> listing = fRepoRemote.getListing(dir);
for (String name : listing.keySet())
{
System.out.println(name + "\t" + listing.get(name));
}
}
private void recursiveList(NodeRef dir, int indent)
{
Map<String, Pair<NodeRef, Boolean>> listing = fRepoRemote.getListing(dir);
for (Map.Entry<String, Pair<NodeRef, Boolean>> entry : listing.entrySet())
{
for (int i = 0; i < indent; i++)
{
System.out.print(' ');
}
System.out.println(entry.getKey() + '\t' + entry.getValue());
if (entry.getValue().getSecond())
{
recursiveList(entry.getValue().getFirst(), indent + 2);
}
}
}
public static void main(String[] args)
{
RepoLs me = new RepoLs();