Skip to content
This repository has been archived by the owner on Jul 26, 2022. It is now read-only.

Commit

Permalink
Remove indirection via Client (Command->Client->Operation) when calli…
Browse files Browse the repository at this point in the history
…ng Operations; reduced to Command->Operation
  • Loading branch information
binwiederhier committed Mar 23, 2015
1 parent 3c5e4d3 commit f81ab9a
Show file tree
Hide file tree
Showing 19 changed files with 159 additions and 146 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@

import org.syncany.cli.util.CommandLineUtil;
import org.syncany.operations.OperationResult;
import org.syncany.operations.cleanup.CleanupOperation;
import org.syncany.operations.cleanup.CleanupOperationOptions;
import org.syncany.operations.cleanup.CleanupOperationResult;
import org.syncany.operations.daemon.messages.CleanupStartCleaningSyncExternalEvent;
Expand All @@ -46,7 +47,7 @@ public boolean canExecuteInDaemonScope() {
@Override
public int execute(String[] operationArgs) throws Exception {
CleanupOperationOptions operationOptions = parseOptions(operationArgs);
CleanupOperationResult operationResult = client.cleanup(operationOptions);
CleanupOperationResult operationResult = new CleanupOperation(config, operationOptions).execute();

printResults(operationResult);

Expand Down
12 changes: 8 additions & 4 deletions syncany-cli/src/main/java/org/syncany/cli/Command.java
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,8 @@
import java.io.File;
import java.io.PrintStream;

import org.syncany.Client;
import org.syncany.cli.util.CarriageReturnPrinter;
import org.syncany.config.Config;
import org.syncany.config.LocalEventBus;
import org.syncany.operations.OperationOptions;
import org.syncany.operations.OperationResult;
Expand All @@ -47,7 +47,7 @@
* @author Philipp C. Heckel <philipp.heckel@gmail.com>
*/
public abstract class Command {
protected Client client;
protected Config config;
protected File localDir;
protected CarriageReturnPrinter out;

Expand Down Expand Up @@ -112,8 +112,12 @@ public void setLocalDir(File localDir) {
this.localDir = localDir;
}

public void setClient(Client client) {
this.client = client;
public Config getConfig() {
return config;
}

public void setConfig(Config config) {
this.config = config;
}

public void setOut(PrintStream out) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -381,7 +381,7 @@ private int runCommand(Command command, String commandName, String[] commandArgs
}

private int runLocally(Command command, String[] commandArgs) {
command.setClient(this);
command.setConfig(config);
command.setLocalDir(localDir);

// Run!
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@

import org.syncany.config.to.ConfigTO;
import org.syncany.operations.OperationResult;
import org.syncany.operations.init.ConnectOperation;
import org.syncany.operations.init.ConnectOperationOptions;
import org.syncany.operations.init.ConnectOperationOptions.ConnectOptionsStrategy;
import org.syncany.operations.init.ConnectOperationResult;
Expand Down Expand Up @@ -57,7 +58,7 @@ public int execute(String[] operationArgs) throws Exception {
ConnectOperationOptions operationOptions = parseOptions(operationArgs);

while (retryNeeded && performOperation) {
ConnectOperationResult operationResult = client.connect(operationOptions, this);
ConnectOperationResult operationResult = new ConnectOperation(operationOptions, this).execute();
printResults(operationResult);

retryNeeded = operationResult.getResultCode() != ConnectResultCode.OK
Expand Down
4 changes: 1 addition & 3 deletions syncany-cli/src/main/java/org/syncany/cli/DebugCommand.java
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,6 @@
import joptsimple.OptionSet;

import org.apache.commons.io.IOUtils;
import org.syncany.config.Config;
import org.syncany.operations.OperationOptions;
import org.syncany.operations.OperationResult;

Expand Down Expand Up @@ -88,15 +87,14 @@ private void runDebugCommand(List<?> nonOptionArgs) throws Exception {
throw new Exception("Given file does not exist: "+decryptFile);
}

Config config = client.getConfig();
InputStream fileInputStream = config.getTransformer().createInputStream(new FileInputStream(decryptFile));

IOUtils.copy(fileInputStream, System.out);
System.exit(0);
}

private boolean isInitializedScope() {
return client != null && client.getConfig() != null;
return config != null;
}

@Override
Expand Down
3 changes: 2 additions & 1 deletion syncany-cli/src/main/java/org/syncany/cli/DownCommand.java
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@
import org.syncany.operations.OperationResult;
import org.syncany.operations.daemon.messages.DownDownloadFileSyncExternalEvent;
import org.syncany.operations.daemon.messages.LsRemoteStartSyncExternalEvent;
import org.syncany.operations.down.DownOperation;
import org.syncany.operations.down.DownOperationOptions;
import org.syncany.operations.down.DownOperationOptions.DownConflictStrategy;
import org.syncany.operations.down.DownOperationResult;
Expand All @@ -52,7 +53,7 @@ public boolean canExecuteInDaemonScope() {
@Override
public int execute(String[] operationArgs) throws Exception {
DownOperationOptions operationOptions = parseOptions(operationArgs);
DownOperationResult operationResult = client.down(operationOptions);
DownOperationResult operationResult = new DownOperation(config, operationOptions).execute();

printResults(operationResult);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
import joptsimple.OptionSpec;

import org.syncany.operations.OperationResult;
import org.syncany.operations.init.GenlinkOperation;
import org.syncany.operations.init.GenlinkOperationOptions;
import org.syncany.operations.init.GenlinkOperationResult;

Expand All @@ -42,7 +43,7 @@ public boolean canExecuteInDaemonScope() {
@Override
public int execute(String[] operationArgs) throws Exception {
GenlinkOperationOptions operationOptions = parseOptions(operationArgs);
GenlinkOperationResult operationResult = client.genlink(operationOptions);
GenlinkOperationResult operationResult = new GenlinkOperation(config, operationOptions).execute();

printResults(operationResult);

Expand Down
3 changes: 2 additions & 1 deletion syncany-cli/src/main/java/org/syncany/cli/InitCommand.java
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@
import org.syncany.crypto.CipherUtil;
import org.syncany.operations.OperationResult;
import org.syncany.operations.init.GenlinkOperationOptions;
import org.syncany.operations.init.InitOperation;
import org.syncany.operations.init.InitOperationOptions;
import org.syncany.operations.init.InitOperationResult;
import org.syncany.operations.init.InitOperationResult.InitResultCode;
Expand Down Expand Up @@ -65,7 +66,7 @@ public int execute(String[] operationArgs) throws Exception {
operationOptions = parseOptions(operationArgs);

while (retryNeeded && performOperation) {
InitOperationResult operationResult = client.init(operationOptions, this);
InitOperationResult operationResult = new InitOperation(operationOptions, this).execute();
printResults(operationResult);

retryNeeded = operationResult.getResultCode() != InitResultCode.OK;
Expand Down
3 changes: 2 additions & 1 deletion syncany-cli/src/main/java/org/syncany/cli/LogCommand.java
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@

import org.syncany.operations.OperationResult;
import org.syncany.operations.log.LightweightDatabaseVersion;
import org.syncany.operations.log.LogOperation;
import org.syncany.operations.log.LogOperationOptions;
import org.syncany.operations.log.LogOperationResult;

Expand All @@ -55,7 +56,7 @@ public boolean canExecuteInDaemonScope() {
@Override
public int execute(String[] operationArgs) throws Exception {
LogOperationOptions operationOptions = parseOptions(operationArgs);
LogOperationResult operationResult = client.log(operationOptions);
LogOperationResult operationResult = new LogOperation(config, operationOptions).execute();

printResults(operationResult);

Expand Down
3 changes: 2 additions & 1 deletion syncany-cli/src/main/java/org/syncany/cli/LsCommand.java
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@
import org.syncany.database.ObjectId;
import org.syncany.database.PartialFileHistory;
import org.syncany.operations.OperationResult;
import org.syncany.operations.ls.LsOperation;
import org.syncany.operations.ls.LsOperationOptions;
import org.syncany.operations.ls.LsOperationResult;

Expand Down Expand Up @@ -71,7 +72,7 @@ public boolean canExecuteInDaemonScope() {
@Override
public int execute(String[] operationArgs) throws Exception {
LsOperationOptions operationOptions = parseOptions(operationArgs);
LsOperationResult operationResult = client.ls(operationOptions);
LsOperationResult operationResult = new LsOperation(config, operationOptions).execute();

printResults(operationResult);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@
import org.syncany.operations.OperationOptions;
import org.syncany.operations.OperationResult;
import org.syncany.operations.daemon.messages.LsRemoteStartSyncExternalEvent;
import org.syncany.operations.ls_remote.LsRemoteOperation;
import org.syncany.operations.ls_remote.LsRemoteOperationResult;
import org.syncany.plugins.transfer.files.DatabaseRemoteFile;
import org.syncany.plugins.transfer.files.RemoteFile;
Expand All @@ -41,7 +42,7 @@ public boolean canExecuteInDaemonScope() {

@Override
public int execute(String[] operationArgs) throws Exception {
LsRemoteOperationResult operationResult = client.lsRemote();
LsRemoteOperationResult operationResult = new LsRemoteOperation(config).execute();
printResults(operationResult);

return 0;
Expand Down
5 changes: 4 additions & 1 deletion syncany-cli/src/main/java/org/syncany/cli/PluginCommand.java
Original file line number Diff line number Diff line change
Expand Up @@ -28,14 +28,17 @@
import org.syncany.operations.daemon.messages.PluginInstallExternalEvent;
import org.syncany.operations.plugin.ExtendedPluginInfo;
import org.syncany.operations.plugin.PluginInfo;
import org.syncany.operations.plugin.PluginOperation;
import org.syncany.operations.plugin.PluginOperationAction;
import org.syncany.operations.plugin.PluginOperationOptions;
import org.syncany.operations.plugin.PluginOperationOptions.PluginListMode;
import org.syncany.operations.plugin.PluginOperationResult;
import org.syncany.operations.plugin.PluginOperationResult.PluginResultCode;
import org.syncany.util.StringUtil;

import com.google.common.collect.Iterables;
import com.google.common.eventbus.Subscribe;

import joptsimple.OptionParser;
import joptsimple.OptionSet;
import joptsimple.OptionSpec;
Expand All @@ -56,7 +59,7 @@ public boolean canExecuteInDaemonScope() {
@Override
public int execute(String[] operationArgs) throws Exception {
PluginOperationOptions operationOptions = parseOptions(operationArgs);
PluginOperationResult operationResult = client.plugin(operationOptions);
PluginOperationResult operationResult = new PluginOperation(config, operationOptions).execute();

printResults(operationResult);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@

import org.syncany.database.PartialFileHistory.FileHistoryId;
import org.syncany.operations.OperationResult;
import org.syncany.operations.restore.RestoreOperation;
import org.syncany.operations.restore.RestoreOperationOptions;
import org.syncany.operations.restore.RestoreOperationResult;

Expand All @@ -47,7 +48,7 @@ public boolean canExecuteInDaemonScope() {
@Override
public int execute(String[] operationArgs) throws Exception {
RestoreOperationOptions operationOptions = parseOptions(operationArgs);
RestoreOperationResult operationResult = client.restore(operationOptions);
RestoreOperationResult operationResult = new RestoreOperation(config, operationOptions).execute();

printResults(operationResult);

Expand Down
3 changes: 2 additions & 1 deletion syncany-cli/src/main/java/org/syncany/cli/StatusCommand.java
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@

import org.syncany.operations.OperationResult;
import org.syncany.operations.daemon.messages.StatusStartSyncExternalEvent;
import org.syncany.operations.status.StatusOperation;
import org.syncany.operations.status.StatusOperationOptions;
import org.syncany.operations.status.StatusOperationResult;

Expand All @@ -43,7 +44,7 @@ public boolean canExecuteInDaemonScope() {
@Override
public int execute(String[] operationArgs) throws Exception {
StatusOperationOptions operationOptions = parseOptions(operationArgs);
StatusOperationResult operationResult = client.status(operationOptions);
StatusOperationResult operationResult = new StatusOperation(config, operationOptions).execute();

printResults(operationResult);

Expand Down
3 changes: 2 additions & 1 deletion syncany-cli/src/main/java/org/syncany/cli/UpCommand.java
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@
import org.syncany.operations.daemon.messages.UpUploadFileInTransactionSyncExternalEvent;
import org.syncany.operations.daemon.messages.UpUploadFileSyncExternalEvent;
import org.syncany.operations.status.StatusOperationOptions;
import org.syncany.operations.up.UpOperation;
import org.syncany.operations.up.UpOperationOptions;
import org.syncany.operations.up.UpOperationResult;
import org.syncany.operations.up.UpOperationResult.UpResultCode;
Expand All @@ -54,7 +55,7 @@ public boolean canExecuteInDaemonScope() {
@Override
public int execute(String[] operationArgs) throws Exception {
UpOperationOptions operationOptions = parseOptions(operationArgs);
UpOperationResult operationResult = client.up(operationOptions);
UpOperationResult operationResult = new UpOperation(config, operationOptions).execute();

printResults(operationResult);

Expand Down
3 changes: 2 additions & 1 deletion syncany-cli/src/main/java/org/syncany/cli/UpdateCommand.java
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@
import org.syncany.operations.OperationResult;
import org.syncany.operations.daemon.messages.ConnectToHostExternalEvent;
import org.syncany.operations.update.AppInfo;
import org.syncany.operations.update.UpdateOperation;
import org.syncany.operations.update.UpdateOperationAction;
import org.syncany.operations.update.UpdateOperationOptions;
import org.syncany.operations.update.UpdateOperationResult;
Expand All @@ -50,7 +51,7 @@ public boolean canExecuteInDaemonScope() {
@Override
public int execute(String[] operationArgs) throws Exception {
UpdateOperationOptions operationOptions = parseOptions(operationArgs);
UpdateOperationResult operationResult = client.update(operationOptions);
UpdateOperationResult operationResult = new UpdateOperation(config, operationOptions).execute();

printResults(operationResult);

Expand Down
3 changes: 2 additions & 1 deletion syncany-cli/src/main/java/org/syncany/cli/WatchCommand.java
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@
import joptsimple.OptionSpec;

import org.syncany.operations.OperationResult;
import org.syncany.operations.watch.WatchOperation;
import org.syncany.operations.watch.WatchOperationOptions;

public class WatchCommand extends Command {
Expand All @@ -47,7 +48,7 @@ public boolean canExecuteInDaemonScope() {
@Override
public int execute(String[] operationArgs) throws Exception {
WatchOperationOptions operationOptions = parseOptions(operationArgs);
client.watch(operationOptions);
new WatchOperation(config, operationOptions).execute();

return 0;
}
Expand Down

0 comments on commit f81ab9a

Please sign in to comment.