/**
* Copyright 2007-2008 Konrad-Zuse-Zentrum für Informationstechnik Berlin
*
* Licensed under 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.
*/
package de.zib.chordsharp.examples;
import java.util.Vector;
import com.ericsson.otp.erlang.OtpErlangList;
import com.ericsson.otp.erlang.OtpErlangString;
import de.zib.chordsharp.ConnectionException;
import de.zib.chordsharp.Transaction;
import de.zib.chordsharp.TransactionNotFinishedException;
import de.zib.chordsharp.UnknownException;
/**
* Provides an example for using the {@code parallelReads} method of the
* {@link Transaction} class.
*
* @author Nico Kruber, kruber@zib.de
* @version 1.0
*/
@Deprecated
public class TransactionParallelReadsExample {
/**
* Reads all keys given on the command line (given as "key1 key2 ...") with
* the {@link Transaction#parallelReads(String[])} and
* {@link Transaction#parallelReads(OtpErlangList)} methods in a single
* transaction.<br />
* If no keys are given, the default keys {@code "key1"}, {@code "key2"},
* {@code "key3"} are used.
*
* @param args
* command line arguments (optional keys to look up)
*/
public static void main(String[] args) {
String[] keys;
Vector<String> values;
if (args.length == 0) {
keys = new String[] { "key1", "key2", "key3" };
} else {
keys = args;
}
OtpErlangString[] otpKeys_temp = new OtpErlangString[keys.length];
for (int i = 0; i < keys.length; ++i) {
otpKeys_temp[i] = new OtpErlangString(keys[i]);
}
OtpErlangList otpKeys = (new OtpErlangList(otpKeys_temp));
OtpErlangList otpValues;
System.out
.println("Reading values with the class `Transaction`:");
System.out.print(" Initialising Transaction object... ");
try {
Transaction transaction = new Transaction();
System.out.println("done");
System.out.print(" Starting transaction... ");
transaction.start();
System.out.println("done");
System.out.println(" `OtpErlangList parallelReads(OtpErlangList)`...");
try {
otpValues = transaction.parallelReads(otpKeys);
System.out.println(" parallelReads(" + otpKeys.toString()
+ ") == " + otpValues.toString());
} catch (ConnectionException e) {
System.out.println(" parallelReads(" + otpKeys.toString()
+ ") failed: " + e.getMessage());
} catch (UnknownException e) {
System.out.println(" parallelReads(" + otpKeys.toString()
+ ") failed with unknown: " + e.getMessage());
}
System.out.println(" `Vector<String> parallelReads(String[])`...");
try {
values = transaction.parallelReads(keys);
System.out.println(" parallelReads(" + keys + ") == " + values);
} catch (ConnectionException e) {
System.out.println(" parallelReads(" + keys + ") failed: "
+ e.getMessage());
} catch (UnknownException e) {
System.out.println(" parallelReads(" + keys
+ ") failed with unknown: " + e.getMessage());
}
System.out.print(" Committing transaction... ");
transaction.commit();
System.out.println("done");
} catch (ConnectionException e) {
System.out.println("failed: " + e.getMessage());
return;
} catch (TransactionNotFinishedException e) {
System.out.println("failed: " + e.getMessage());
return;
} catch (UnknownException e) {
System.out.println("failed: " + e.getMessage());
return;
}
}
}