Add a plumbing option to dicttool info.

Also align the `porcelain' option to the diff command
that was used mistakenly.

Bug: 7388665
Change-Id: Ic0e1b98c62ce37b2e909384a0370af4458563703
This commit is contained in:
Jean Chalard 2012-10-31 15:35:20 +09:00
parent a8058d169d
commit 51a0ef8c59
3 changed files with 31 additions and 15 deletions

View file

@ -290,19 +290,23 @@ public final class FusionDictionary implements Iterable<Word> {
} }
@Override @Override
public String toString() { // Convenience method public String toString() { // Convenience method
return toString(0); return toString(0, false);
} }
public String toString(final int indentCount) { public String toString(final int indentCount, final boolean plumbing) {
final StringBuilder indent = new StringBuilder(); final StringBuilder indent = new StringBuilder();
for (int i = 0; i < indentCount; ++i) { if (plumbing) {
indent.append(" "); indent.append("H:");
} else {
for (int i = 0; i < indentCount; ++i) {
indent.append(" ");
}
} }
final StringBuilder s = new StringBuilder(); final StringBuilder s = new StringBuilder();
for (final String optionKey : mAttributes.keySet()) { for (final String optionKey : mAttributes.keySet()) {
s.append(indent); s.append(indent);
s.append(optionKey); s.append(optionKey);
s.append(" = "); s.append(" = ");
if ("date".equals(optionKey)) { if ("date".equals(optionKey) && !plumbing) {
// Date needs a number of milliseconds, but the dictionary contains seconds // Date needs a number of milliseconds, but the dictionary contains seconds
s.append(new Date( s.append(new Date(
1000 * Long.parseLong(mAttributes.get(optionKey))).toString()); 1000 * Long.parseLong(mAttributes.get(optionKey))).toString());

View file

@ -34,7 +34,7 @@ public class Diff extends Dicttool.Command {
@Override @Override
public String getHelp() { public String getHelp() {
return COMMAND + " [-p] <dict> <dict> : shows differences between two dictionaries.\n" return COMMAND + " [-p] <dict> <dict> : shows differences between two dictionaries.\n"
+ " If -p (porcelain) option is given, produce output suitable for a script"; + " If -p (plumbing) option is given, produce output suitable for a script";
} }
@Override @Override
@ -42,15 +42,15 @@ public class Diff extends Dicttool.Command {
if (mArgs.length < 2) { if (mArgs.length < 2) {
throw new RuntimeException("Not enough arguments for command " + COMMAND); throw new RuntimeException("Not enough arguments for command " + COMMAND);
} }
final boolean porcelain; final boolean plumbing;
if ("-p".equals(mArgs[0])) { if ("-p".equals(mArgs[0])) {
porcelain = true; plumbing = true;
mArgs = Arrays.copyOfRange(mArgs, 1, mArgs.length); mArgs = Arrays.copyOfRange(mArgs, 1, mArgs.length);
if (mArgs.length != 2) { // There should be only 2 arguments left if (mArgs.length != 2) { // There should be only 2 arguments left
throw new RuntimeException("Wrong number of arguments for command " + COMMAND); throw new RuntimeException("Wrong number of arguments for command " + COMMAND);
} }
} else { } else {
porcelain = false; plumbing = false;
} }
final FusionDictionary dict0 = final FusionDictionary dict0 =
BinaryDictOffdeviceUtils.getDictionary(mArgs[0], false /* report */); BinaryDictOffdeviceUtils.getDictionary(mArgs[0], false /* report */);
@ -58,7 +58,7 @@ public class Diff extends Dicttool.Command {
final FusionDictionary dict1 = final FusionDictionary dict1 =
BinaryDictOffdeviceUtils.getDictionary(mArgs[1], false /* report */); BinaryDictOffdeviceUtils.getDictionary(mArgs[1], false /* report */);
if (null == dict1) throw new RuntimeException("Can't read dictionary " + mArgs[1]); if (null == dict1) throw new RuntimeException("Can't read dictionary " + mArgs[1]);
if (!porcelain) { if (!plumbing) {
System.out.println("Header :"); System.out.println("Header :");
diffHeaders(dict0, dict1); diffHeaders(dict0, dict1);
if (languageDiffers(dict0, dict1)) { if (languageDiffers(dict0, dict1)) {

View file

@ -22,6 +22,7 @@ import com.android.inputmethod.latin.makedict.FusionDictionary.CharGroup;
import com.android.inputmethod.latin.makedict.FusionDictionary.WeightedString; import com.android.inputmethod.latin.makedict.FusionDictionary.WeightedString;
import com.android.inputmethod.latin.makedict.Word; import com.android.inputmethod.latin.makedict.Word;
import java.util.Arrays;
import java.util.ArrayList; import java.util.ArrayList;
public class Info extends Dicttool.Command { public class Info extends Dicttool.Command {
@ -35,9 +36,9 @@ public class Info extends Dicttool.Command {
return COMMAND + " <filename>: prints various information about a dictionary file"; return COMMAND + " <filename>: prints various information about a dictionary file";
} }
private static void showInfo(final FusionDictionary dict) { private static void showInfo(final FusionDictionary dict, final boolean plumbing) {
System.out.println("Header attributes :"); System.out.println("Header attributes :");
System.out.print(dict.mOptions.toString(2)); System.out.print(dict.mOptions.toString(2, plumbing));
int wordCount = 0; int wordCount = 0;
int bigramCount = 0; int bigramCount = 0;
int shortcutCount = 0; int shortcutCount = 0;
@ -62,7 +63,8 @@ public class Info extends Dicttool.Command {
+ " whitelist entries)"); + " whitelist entries)");
} }
private static void showWordInfo(final FusionDictionary dict, final String word) { private static void showWordInfo(final FusionDictionary dict, final String word,
final boolean plumbing) {
final CharGroup group = FusionDictionary.findWordInTree(dict.mRoot, word); final CharGroup group = FusionDictionary.findWordInTree(dict.mRoot, word);
if (null == group) { if (null == group) {
System.out.println(word + " is not in the dictionary"); System.out.println(word + " is not in the dictionary");
@ -101,15 +103,25 @@ public class Info extends Dicttool.Command {
if (mArgs.length < 1) { if (mArgs.length < 1) {
throw new RuntimeException("Not enough arguments for command " + COMMAND); throw new RuntimeException("Not enough arguments for command " + COMMAND);
} }
final boolean plumbing;
if ("-p".equals(mArgs[0])) {
plumbing = true;
mArgs = Arrays.copyOfRange(mArgs, 1, mArgs.length);
if (mArgs.length != 1) { // There should be only 1 argument left
throw new RuntimeException("Wrong number of arguments for command " + COMMAND);
}
} else {
plumbing = false;
}
final String filename = mArgs[0]; final String filename = mArgs[0];
final boolean hasWordArguments = (1 == mArgs.length); final boolean hasWordArguments = (1 == mArgs.length);
final FusionDictionary dict = BinaryDictOffdeviceUtils.getDictionary(filename, final FusionDictionary dict = BinaryDictOffdeviceUtils.getDictionary(filename,
hasWordArguments /* report */); hasWordArguments /* report */);
if (hasWordArguments) { if (hasWordArguments) {
showInfo(dict); showInfo(dict, plumbing);
} else { } else {
for (int i = 1; i < mArgs.length; ++i) { for (int i = 1; i < mArgs.length; ++i) {
showWordInfo(dict, mArgs[i]); showWordInfo(dict, mArgs[i], plumbing);
} }
} }
} }