Project import generated by Copybara.
GitOrigin-RevId: b578e69f18a543889ded9c57a8f0dffacdb103d8
This commit is contained in:
parent
e3f1e843de
commit
65671b0004
4 changed files with 40 additions and 17 deletions
|
@ -162,7 +162,7 @@ public class HgDestination implements Destination<HgRevision> {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean supportsHistory() {
|
public boolean supportsHistory() {
|
||||||
throw new UnsupportedOperationException("Not implemented yet");
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
private HgRepository getRepository() throws RepoException {
|
private HgRepository getRepository() throws RepoException {
|
||||||
|
@ -216,7 +216,7 @@ public class HgDestination implements Destination<HgRevision> {
|
||||||
Path workDir, HgRepository localRepo)
|
Path workDir, HgRepository localRepo)
|
||||||
throws RepoException, IOException {
|
throws RepoException, IOException {
|
||||||
// Create a temp archive of the remote repository to compute diff with
|
// Create a temp archive of the remote repository to compute diff with
|
||||||
Path tempArchivePath = generalOptions.getDirFactory().newTempDir("tempArchive");
|
Path tempArchivePath = Files.createTempDirectory(workDir.getParent(), "tempArchive");
|
||||||
localRepo.archive(tempArchivePath.toString());
|
localRepo.archive(tempArchivePath.toString());
|
||||||
|
|
||||||
// Find excluded files in the archive
|
// Find excluded files in the archive
|
||||||
|
@ -238,24 +238,20 @@ public class HgDestination implements Destination<HgRevision> {
|
||||||
Operation diffOp = diff.getOperation();
|
Operation diffOp = diff.getOperation();
|
||||||
|
|
||||||
if (diffOp.equals(Operation.ADD)) {
|
if (diffOp.equals(Operation.ADD)) {
|
||||||
|
Path targetPath = localRepo.getHgDir().getParent().resolve(diff.getName());
|
||||||
|
Files.createDirectories(targetPath.getParent());
|
||||||
Files.copy(workDir.resolve(diff.getName()),
|
Files.copy(workDir.resolve(diff.getName()),
|
||||||
localRepo.getHgDir().resolve(diff.getName()), StandardCopyOption.COPY_ATTRIBUTES);
|
targetPath, StandardCopyOption.COPY_ATTRIBUTES, StandardCopyOption.REPLACE_EXISTING);
|
||||||
localRepo.hg(localRepo.getHgDir(), "add", diff.getName());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (diffOp.equals(Operation.MODIFIED)) {
|
if (diffOp.equals(Operation.MODIFIED)) {
|
||||||
Files.copy(workDir.resolve(diff.getName()),
|
Files.copy(workDir.resolve(diff.getName()),
|
||||||
localRepo.getHgDir().resolve(diff.getName()), StandardCopyOption.REPLACE_EXISTING);
|
localRepo.getHgDir().getParent().resolve(diff.getName()), StandardCopyOption.REPLACE_EXISTING);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (diffOp.equals(Operation.DELETE)) {
|
if (diffOp.equals(Operation.DELETE)) {
|
||||||
try {
|
if (!diff.getName().equals(".hg_archival.txt")) {
|
||||||
localRepo.hg(localRepo.getHgDir(), "remove", diff.getName());
|
Files.delete(localRepo.getHgDir().getParent().resolve(diff.getName()));
|
||||||
} catch (RepoException e) {
|
|
||||||
// Ignore a .hg_archival file that is not in the workdir nor in the local repo.
|
|
||||||
if (!e.getMessage().contains(".hg_archival.txt: No such file or directory")) {
|
|
||||||
throw e;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -264,6 +260,8 @@ public class HgDestination implements Destination<HgRevision> {
|
||||||
} finally {
|
} finally {
|
||||||
FileUtil.deleteRecursively(tempArchivePath);
|
FileUtil.deleteRecursively(tempArchivePath);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
localRepo.hg(localRepo.getHgDir().getParent(), "addremove");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -282,7 +280,7 @@ public class HgDestination implements Destination<HgRevision> {
|
||||||
localRepo.cleanUpdate(remoteFetch);
|
localRepo.cleanUpdate(remoteFetch);
|
||||||
|
|
||||||
// Set the default path of the local repo to be the remote repo, so we can push to it
|
// Set the default path of the local repo to be the remote repo, so we can push to it
|
||||||
Files.write(localRepo.getHgDir().resolve(".hg/hgrc"),
|
Files.write(localRepo.getHgDir().getParent().resolve(".hg/hgrc"),
|
||||||
String.format("[paths]\ndefault = %s\n", repoUrl).getBytes(StandardCharsets.UTF_8));
|
String.format("[paths]\ndefault = %s\n", repoUrl).getBytes(StandardCharsets.UTF_8));
|
||||||
|
|
||||||
console.progress("Hg Destination: Computing diff");
|
console.progress("Hg Destination: Computing diff");
|
||||||
|
@ -293,12 +291,12 @@ public class HgDestination implements Destination<HgRevision> {
|
||||||
ChangeMessage msg = getChangeMessage(transformResult, ORIGIN_LABEL_SEPARATOR);
|
ChangeMessage msg = getChangeMessage(transformResult, ORIGIN_LABEL_SEPARATOR);
|
||||||
String date = transformResult.getTimestamp().format(DateTimeFormatter.RFC_1123_DATE_TIME);
|
String date = transformResult.getTimestamp().format(DateTimeFormatter.RFC_1123_DATE_TIME);
|
||||||
|
|
||||||
localRepo.hg(localRepo.getHgDir(), "commit", "--user",
|
localRepo.hg(localRepo.getHgDir().getParent(), "commit", "--user",
|
||||||
transformResult.getAuthor().toString(), "--date", date,
|
transformResult.getAuthor().toString(), "--date", date,
|
||||||
"-m", msg.toString());
|
"-m", msg.toString());
|
||||||
|
|
||||||
console.progress(String.format("Hg Destination: Pushing to %s %s", repoUrl, remotePush));
|
console.progress(String.format("Hg Destination: Pushing to %s %s", repoUrl, remotePush));
|
||||||
localRepo.hg(localRepo.getHgDir(), "push", "--rev", remotePush, repoUrl);
|
localRepo.hg(localRepo.getHgDir().getParent(), "push", "--rev", remotePush, repoUrl);
|
||||||
|
|
||||||
String tip = localRepo.identify("tip").getGlobalId();
|
String tip = localRepo.identify("tip").getGlobalId();
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,7 @@ package com.google.copybara.hg;
|
||||||
import static com.google.copybara.config.SkylarkUtil.checkNotEmpty;
|
import static com.google.copybara.config.SkylarkUtil.checkNotEmpty;
|
||||||
|
|
||||||
import com.google.common.base.Preconditions;
|
import com.google.common.base.Preconditions;
|
||||||
|
import com.google.copybara.GeneralOptions;
|
||||||
import com.google.copybara.Options;
|
import com.google.copybara.Options;
|
||||||
import com.google.copybara.config.LabelsAwareModule;
|
import com.google.copybara.config.LabelsAwareModule;
|
||||||
import com.google.copybara.doc.annotations.UsesFlags;
|
import com.google.copybara.doc.annotations.UsesFlags;
|
||||||
|
@ -73,4 +74,28 @@ public class HgModule implements LabelsAwareModule, StarlarkValue {
|
||||||
public HgOrigin origin(String url, String ref) throws EvalException {
|
public HgOrigin origin(String url, String ref) throws EvalException {
|
||||||
return HgOrigin.newHgOrigin(options, checkNotEmpty(url, "url"), ref);
|
return HgOrigin.newHgOrigin(options, checkNotEmpty(url, "url"), ref);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@StarlarkMethod(
|
||||||
|
name = "destination",
|
||||||
|
doc = "<b>EXPERIMENTAL:</b> Defines a standard Mercurial (Hg) destination.",
|
||||||
|
parameters = {
|
||||||
|
@Param(
|
||||||
|
name = "url",
|
||||||
|
type = String.class,
|
||||||
|
named = true,
|
||||||
|
doc = "Indicates the URL of the Hg repository"),
|
||||||
|
@Param(
|
||||||
|
name = "fetch",
|
||||||
|
type = String.class,
|
||||||
|
named = true,
|
||||||
|
doc = "XXX: ref to fetch?"),
|
||||||
|
@Param(
|
||||||
|
name = "push",
|
||||||
|
type = String.class,
|
||||||
|
named = true,
|
||||||
|
doc = "XXX: ref to push?")
|
||||||
|
})
|
||||||
|
public HgDestination destination(String url, String fetch, String push) throws EvalException {
|
||||||
|
return HgDestination.newHgDestination(url, fetch, push, options.get(GeneralOptions.class), options.get(HgOptions.class));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -141,7 +141,7 @@ public class HgRepository {
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
hg(hgDir, builder.build(), fetchTimeout);
|
hg(hgDir.getParent(), builder.build(), fetchTimeout);
|
||||||
} catch (RepoException e) {
|
} catch (RepoException e) {
|
||||||
if (INVALID_HG_REPOSITORY.matcher(e.getMessage()).find()){
|
if (INVALID_HG_REPOSITORY.matcher(e.getMessage()).find()){
|
||||||
throw new ValidationException("Repository not found: " + e.getMessage());
|
throw new ValidationException("Repository not found: " + e.getMessage());
|
||||||
|
|
|
@ -185,7 +185,7 @@ public final class CommandRunner {
|
||||||
String startMsg = ShellUtils.prettyPrintArgv(Arrays.asList(cmd.getCommandLineElements()));
|
String startMsg = ShellUtils.prettyPrintArgv(Arrays.asList(cmd.getCommandLineElements()));
|
||||||
startMsg = startMsg.length() > MAX_COMMAND_LENGTH
|
startMsg = startMsg.length() > MAX_COMMAND_LENGTH
|
||||||
? startMsg.substring(0, MAX_COMMAND_LENGTH) + "..." : startMsg;
|
? startMsg.substring(0, MAX_COMMAND_LENGTH) + "..." : startMsg;
|
||||||
String validStartMsg = "Executing [" + startMsg + "]";
|
String validStartMsg = "Executing [" + startMsg + "] in workdir [" + cmd.getWorkingDirectory() + "]";
|
||||||
logger.atInfo().log(validStartMsg);
|
logger.atInfo().log(validStartMsg);
|
||||||
if (verbose) {
|
if (verbose) {
|
||||||
System.err.println(validStartMsg);
|
System.err.println(validStartMsg);
|
||||||
|
|
Loading…
Reference in a new issue