Ver código fonte

Merge "archive: Add --format option that switches between formats"

tags/v2.2.0.201212191850-r
Shawn Pearce 11 anos atrás
pai
commit
c9a8844586

+ 2
- 1
org.eclipse.jgit.pgm/META-INF/MANIFEST.MF Ver arquivo

Bundle-Vendor: %provider_name Bundle-Vendor: %provider_name
Bundle-Localization: plugin Bundle-Localization: plugin
Bundle-RequiredExecutionEnvironment: J2SE-1.5 Bundle-RequiredExecutionEnvironment: J2SE-1.5
Import-Package: org.apache.commons.compress.archivers.zip;version="[1.3,2.0)",
Import-Package: org.apache.commons.compress.archivers;version="[1.3,2.0)",
org.apache.commons.compress.archivers.zip;version="[1.3,2.0)",
org.eclipse.jgit.api;version="[2.2.0,2.3.0)", org.eclipse.jgit.api;version="[2.2.0,2.3.0)",
org.eclipse.jgit.api.errors;version="[2.2.0,2.3.0)", org.eclipse.jgit.api.errors;version="[2.2.0,2.3.0)",
org.eclipse.jgit.awtui;version="[2.2.0,2.3.0)", org.eclipse.jgit.awtui;version="[2.2.0,2.3.0)",

+ 2
- 0
org.eclipse.jgit.pgm/resources/org/eclipse/jgit/pgm/CLIText.properties Ver arquivo

mergedSquashed=Squash commit -- not updating HEAD\nAutomatic merge went well; stopped before committing as requested mergedSquashed=Squash commit -- not updating HEAD\nAutomatic merge went well; stopped before committing as requested
metaVar_DAG=DAG metaVar_DAG=DAG
metaVar_KEY=KEY metaVar_KEY=KEY
metaVar_archiveFormat=format
metaVar_arg=ARG metaVar_arg=ARG
metaVar_author=AUTHOR metaVar_author=AUTHOR
metaVar_base=base metaVar_base=base
usage_alterTheDetailShown=alter the detail shown usage_alterTheDetailShown=alter the detail shown
usage_approveDestructionOfRepository=approve destruction of repository usage_approveDestructionOfRepository=approve destruction of repository
usage_archive=zip up files from the named tree usage_archive=zip up files from the named tree
usage_archiveFormat=archive format. Currently supported formats: 'zip'
usage_blameLongRevision=show long revision usage_blameLongRevision=show long revision
usage_blameRange=annotate only the given range usage_blameRange=annotate only the given range
usage_blameRawTimestamp=show raw timestamp usage_blameRawTimestamp=show raw timestamp

+ 61
- 18
org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Archive.java Ver arquivo



import java.lang.String; import java.lang.String;
import java.lang.System; import java.lang.System;
import java.io.IOException;
import java.io.OutputStream;
import java.util.EnumMap;
import java.util.Map;
import java.text.MessageFormat; import java.text.MessageFormat;


import org.apache.commons.compress.archivers.ArchiveEntry;
import org.apache.commons.compress.archivers.ArchiveOutputStream;
import org.apache.commons.compress.archivers.zip.ZipArchiveEntry; import org.apache.commons.compress.archivers.zip.ZipArchiveEntry;
import org.apache.commons.compress.archivers.zip.ZipArchiveOutputStream; import org.apache.commons.compress.archivers.zip.ZipArchiveOutputStream;
import org.eclipse.jgit.lib.FileMode; import org.eclipse.jgit.lib.FileMode;
import org.eclipse.jgit.treewalk.AbstractTreeIterator; import org.eclipse.jgit.treewalk.AbstractTreeIterator;
import org.eclipse.jgit.treewalk.TreeWalk; import org.eclipse.jgit.treewalk.TreeWalk;
import org.kohsuke.args4j.Argument; import org.kohsuke.args4j.Argument;
import org.kohsuke.args4j.Option;


@Command(common = true, usage = "usage_archive") @Command(common = true, usage = "usage_archive")
class Archive extends TextBuiltin { class Archive extends TextBuiltin {
@Argument(index = 0, metaVar = "metaVar_treeish") @Argument(index = 0, metaVar = "metaVar_treeish")
private AbstractTreeIterator tree; private AbstractTreeIterator tree;


@Option(name = "--format", metaVar = "metaVar_archiveFormat", usage = "usage_archiveFormat")
private Format format = Format.ZIP;

@Override @Override
protected void run() throws Exception { protected void run() throws Exception {
final TreeWalk walk = new TreeWalk(db); final TreeWalk walk = new TreeWalk(db);
final ObjectReader reader = walk.getObjectReader(); final ObjectReader reader = walk.getObjectReader();
final MutableObjectId idBuf = new MutableObjectId(); final MutableObjectId idBuf = new MutableObjectId();
final ZipArchiveOutputStream out = new ZipArchiveOutputStream(outs);
final Archiver fmt = formats.get(format);
final ArchiveOutputStream out = fmt.createArchiveOutputStream(outs);


if (tree == null) if (tree == null)
throw die(CLIText.get().treeIsRequired); throw die(CLIText.get().treeIsRequired);
continue; continue;


walk.getObjectId(idBuf, 0); walk.getObjectId(idBuf, 0);
final ZipArchiveEntry entry = new ZipArchiveEntry(name);
final ObjectLoader loader = reader.open(idBuf);
entry.setSize(loader.getSize());

if (mode == FileMode.REGULAR_FILE)
; // ok
else if (mode == FileMode.EXECUTABLE_FILE ||
mode == FileMode.SYMLINK)
entry.setUnixMode(mode.getBits());
else
System.err.println(MessageFormat.format( //
CLIText.get().archiveEntryModeIgnored, //
name));

out.putArchiveEntry(entry);
loader.copyTo(out);
out.closeArchiveEntry();
fmt.putEntry(name, mode, reader.open(idBuf), out);
} }


out.close(); out.close();
} }

static private void warnArchiveEntryModeIgnored(String name) {
System.err.println(MessageFormat.format( //
CLIText.get().archiveEntryModeIgnored, //
name));
}

public enum Format {
ZIP
};

private static interface Archiver {
ArchiveOutputStream createArchiveOutputStream(OutputStream s);
void putEntry(String path, FileMode mode, //
ObjectLoader loader, ArchiveOutputStream out) //
throws IOException;
}

private static final Map<Format, Archiver> formats;
static {
Map<Format, Archiver> fmts = new EnumMap<Format, Archiver>(Format.class);
fmts.put(Format.ZIP, new Archiver() {
@Override
public ArchiveOutputStream createArchiveOutputStream(OutputStream s) {
return new ZipArchiveOutputStream(s);
}

@Override
public void putEntry(String path, FileMode mode, //
ObjectLoader loader, ArchiveOutputStream out) //
throws IOException {
final ZipArchiveEntry entry = new ZipArchiveEntry(path);

if (mode == FileMode.REGULAR_FILE)
; // ok
else if (mode == FileMode.EXECUTABLE_FILE ||
mode == FileMode.SYMLINK)
entry.setUnixMode(mode.getBits());
else
warnArchiveEntryModeIgnored(path);
entry.setSize(loader.getSize());
out.putArchiveEntry(entry);
loader.copyTo(out);
out.closeArchiveEntry();
}
});
formats = fmts;
}
} }

+ 1
- 0
org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/CLIText.java Ver arquivo

/***/ public String mergeMadeBy; /***/ public String mergeMadeBy;
/***/ public String mergedSquashed; /***/ public String mergedSquashed;
/***/ public String metaVar_KEY; /***/ public String metaVar_KEY;
/***/ public String metaVar_archiveFormat;
/***/ public String metaVar_arg; /***/ public String metaVar_arg;
/***/ public String metaVar_author; /***/ public String metaVar_author;
/***/ public String metaVar_bucket; /***/ public String metaVar_bucket;

Carregando…
Cancelar
Salvar