X-Git-Url: http://gitweb.fperrin.net/?a=blobdiff_plain;f=src%2Fcom%2Fhughes%2Fandroid%2Fdictionary%2Fengine%2FCheckDictionariesMain.java;h=e43f1d098ff7c99903abfd3fecf2638b31e1bd53;hb=2fc669d88306d563fc9c899d8d91b25d591692ea;hp=84efd7c503e90e30f8332c386b3ed008964cba35;hpb=4b7bd1a73f94d1dc94ae3ef0a316f91fce21550d;p=DictionaryPC.git diff --git a/src/com/hughes/android/dictionary/engine/CheckDictionariesMain.java b/src/com/hughes/android/dictionary/engine/CheckDictionariesMain.java index 84efd7c..e43f1d0 100644 --- a/src/com/hughes/android/dictionary/engine/CheckDictionariesMain.java +++ b/src/com/hughes/android/dictionary/engine/CheckDictionariesMain.java @@ -1,9 +1,5 @@ package com.hughes.android.dictionary.engine; -import com.hughes.android.dictionary.DictionaryInfo; -import com.hughes.android.dictionary.DictionaryInfo.IndexInfo; -import com.hughes.util.CollectionUtil; - import java.io.File; import java.io.IOException; import java.io.PrintWriter; @@ -13,40 +9,50 @@ import java.util.Arrays; import java.util.Collections; import java.util.List; +import com.hughes.android.dictionary.DictionaryInfo; +import com.hughes.android.dictionary.DictionaryInfo.IndexInfo; +import com.hughes.util.CollectionUtil; + public class CheckDictionariesMain { - - static final String BASE_URL = "http://quickdic-dictionary.googlecode.com/files/"; - static final String VERSION_CODE = "v006"; - - public static void main(String[] args) throws IOException { - final File dictDir = new File(DictionaryBuilderMain.OUTPUTS); - - final PrintWriter dictionaryInfoOut = new PrintWriter(new File("../Dictionary/res/raw/dictionary_info.txt")); + + static final String BASE_URL = "https://github.com/rdoeffinger/Dictionary/releases/download/v0.3-dictionaries/"; + static final String VERSION_CODE_OLD = "v006"; + static final String VERSION_CODE = "v007"; + + public static void main(String[] args) throws IOException { + final File dictDir = new File(DictionaryBuilderMain.OUTPUTS); + + final PrintWriter dictionaryInfoOut = new PrintWriter(new File("../Dictionary/res/raw/dictionary_info.txt")); // dictionaryInfoOut.println("# LANG_1\t%LANG_2\tFILENAME\tVERSION_CODE\tFILESIZE\tNUM_MAIN_WORDS_1\tNUM_MAIN_WORDS_2\tNUM_ALL_WORDS_1\tNUM_ALL_WORDS_2"); - final File[] files = dictDir.listFiles(); - final List dictNames = new ArrayList(); - Arrays.sort(files); - for (final File dictFile : files) { - if (!dictFile.getName().endsWith("quickdic")) { - continue; - } - System.out.println(dictFile.getPath()); - - - final RandomAccessFile raf = new RandomAccessFile(dictFile, "r"); - final Dictionary dict = new Dictionary(raf); - - final DictionaryInfo dictionaryInfo = dict.getDictionaryInfo(); - - dictionaryInfo.uncompressedFilename = dictFile.getName(); - dictionaryInfo.downloadUrl = BASE_URL + dictFile.getName() + "." + VERSION_CODE + ".zip"; - // TODO: zip it right here.... - dictionaryInfo.uncompressedBytes = dictFile.length(); - final File zipFile = new File(dictFile.getPath() + "." + VERSION_CODE + ".zip"); - dictionaryInfo.zipBytes = zipFile.canRead() ? zipFile.length() : -1; - - // Print it. + final File[] files = dictDir.listFiles(); + final List dictNames = new ArrayList<>(); + Arrays.sort(files); + for (final File dictFile : files) { + if (!dictFile.getName().endsWith("quickdic")) { + continue; + } + System.out.println(dictFile.getPath()); + + + final RandomAccessFile raf = new RandomAccessFile(dictFile, "r"); + final Dictionary dict = new Dictionary(raf.getChannel()); + + final DictionaryInfo dictionaryInfo = dict.getDictionaryInfo(); + + String version_code = VERSION_CODE; + File zipFile = new File(dictFile.getPath() + "." + version_code + ".zip"); + if (!zipFile.canRead()) { + version_code = VERSION_CODE_OLD; + zipFile = new File(dictFile.getPath() + "." + version_code + ".zip"); + } + dictionaryInfo.uncompressedFilename = dictFile.getName(); + dictionaryInfo.downloadUrl = BASE_URL + dictFile.getName() + "." + version_code + ".zip"; + // TODO: zip it right here.... + dictionaryInfo.uncompressedBytes = dictFile.length(); + dictionaryInfo.zipBytes = zipFile.canRead() ? zipFile.length() : -1; + + // Print it. // final PrintWriter textOut = new PrintWriter(new BufferedWriter(new FileWriter(dictFile + ".text"))); // final List sorted = new ArrayList(dict.pairEntries); // Collections.sort(sorted); @@ -54,31 +60,31 @@ public class CheckDictionariesMain { // textOut.println(pairEntry.getRawText(false)); // } // textOut.close(); - - // Find the stats. - System.out.println("Stats..."); - final List indexNames = new ArrayList(); - for (final IndexInfo indexInfo : dictionaryInfo.indexInfos) { - indexNames.add(indexInfo.shortName); - } - dictNames.add(CollectionUtil.join(indexNames, "-") + "\n"); - final String row = dictionaryInfo.append(new StringBuilder()).toString(); - if (!zipFile.canRead()) { - System.err.println("Couldn't read zipfile: " + zipFile); - } - System.out.println(row + "\n"); - - - dictionaryInfoOut.println(row); - dictionaryInfoOut.flush(); - - raf.close(); + + // Find the stats. + System.out.println("Stats..."); + final List indexNames = new ArrayList<>(); + for (final IndexInfo indexInfo : dictionaryInfo.indexInfos) { + indexNames.add(indexInfo.shortName); + } + dictNames.add(CollectionUtil.join(indexNames, "-") + "\n"); + final String row = dictionaryInfo.append(new StringBuilder()).toString(); + if (!zipFile.canRead()) { + System.err.println("Couldn't read zipfile: " + zipFile); + } + System.out.println(row + "\n"); + + + dictionaryInfoOut.println(row); + dictionaryInfoOut.flush(); + + raf.close(); + } + + Collections.sort(dictNames); + System.out.println(dictNames.toString().replace(",", " *")); + + dictionaryInfoOut.close(); } - - Collections.sort(dictNames); - System.out.println(dictNames.toString().replaceAll(",", " *")); - - dictionaryInfoOut.close(); - } }