summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--tools/lpgen/lpgen.js72
1 files changed, 63 insertions, 9 deletions
diff --git a/tools/lpgen/lpgen.js b/tools/lpgen/lpgen.js
index e7d587d50d..ce08be4067 100644
--- a/tools/lpgen/lpgen.js
+++ b/tools/lpgen/lpgen.js
@@ -102,7 +102,7 @@ project_files.push(trunk+"\\plugins\\ImportTXT\\importtxt.dpr");
project_files.push(trunk+"\\plugins\\QuickSearch\\quicksearch.dpr");
project_files.push(trunk+"\\plugins\\ShlExt\\shlext.dpr");
project_files.push(trunk+"\\plugins\\Watrack\\watrack.dpr");
-project_files.push(trunk+"\\protocols\\mRadio\\mradio.dpr");
+project_files.push(trunk+"\\plugins\\mRadio\\mradio.dpr");
//create Enumerator with project files from sln and dpr file find results, sorted alphabetically
files=new Enumerator(project_files.sort());
@@ -155,6 +155,9 @@ function GeneratePluginTranslate (pluginpath,langpackfilepath,vcxprojfile) {
//init arrays with files to parse
resourcefiles=new Array();
sourcefiles=new Array();
+ versionfile=new Array();
+ //init array with muuid+"head"
+ head=new Array();
//init array with strings from parsed files
foundstrings=new Array();
//find a name of our plugin
@@ -173,9 +176,16 @@ function GeneratePluginTranslate (pluginpath,langpackfilepath,vcxprojfile) {
//define langpack filename. File will be overwritten!
langpack=langpackfilepath+"\\"+plugin+".txt";
//get MUUID of plugin and put into array as a first string.
- GetMUUID(pluginpath,foundstrings);
+ GetMUUID(pluginpath,head);
+
//put a name of plugin into array as second string
- foundstrings.push(";langpack template for "+plugin);
+ //foundstrings.push(";langpack template for "+plugin);
+
+ //Get info from version.h
+ //First, locate a version.h file
+ FindFiles(pluginpath,"^version.h$",versionfile);
+ //Parse version.h file
+ ParseVersion_h(versionfile,head);
//find all *.rc files and list files in array
FindFiles(pluginpath,"\\.rc$",resourcefiles);
//find all source files and list files in array
@@ -184,17 +194,19 @@ function GeneratePluginTranslate (pluginpath,langpackfilepath,vcxprojfile) {
ParseFiles(resourcefiles,foundstrings,ParseRCFile);
//Parse files "sourcefiles", put result into "foundstrings" using "ParseSourceFile" function
ParseFiles(sourcefiles,foundstrings,ParseSourceFile);
- //Parsing all sources done. If we still have only two strings in array [0] is muuid, [1] - plugin name, so we didn't find any string and generating file is useless, return from function and out log
- if (!foundstrings[2]) {
+ //Now we have all strings in "foundstrings", next we remove duplicate strings from array and put results into "nodupes"
+ nodupes=eliminateDuplicates(foundstrings);
+ //combine head and translated strings.
+ plugintemplate=head.concat(nodupes);
+ //Parsing all sources done and plugintepmlate are ready. If we still have head with 8 strings, so we didn't find any string and generating file is useless, return from function and out log
+ if (!plugintemplate[7]) {
if (log=="yes") WScript.Echo("Nothing to translate in "+plugin);
return;
}
- //Now we have all strings in "foundstrings", next we remove duplicate strings from array and put results into "nodupes"
- nodupes=eliminateDuplicates(foundstrings);
//logging results
- if (log=="yes") WScript.Echo("Writing "+nodupes.length+" strings for "+plugin);
+ if (log=="yes") WScript.Echo("Writing "+plugintemplate.length+" strings for "+plugin);
//finally, write "nodupes" array to file
- WriteToFile(nodupes,langpack);
+ WriteToFile(plugintemplate,langpack);
};
//Recourse find all files in "path" with file RegExp mask "name" and return file list into filelistarray
@@ -366,6 +378,7 @@ function ParseRCFile(RC_File,array) {
// check for some garbage like "List1","Tab1" etc. in *.rc files, we do not need this.
switch (regexpstring[1]) {
case "List1": {break};
+ case "List2": {break};
case "Tab1": {break};
case "Tree1": {break};
case "Tree2": {break};
@@ -417,6 +430,47 @@ function ParseSourceFile (SourceFile,array) {
sourcefile_stream.Close();
};
+//Parse Version.h file to get one translated stirng from "Description" and make a pluging template header.
+function ParseVersion_h (VersionFile,array) {
+//If file zero size, return;
+if (!FSO.GetFileName(VersionFile)) return;
+//open file
+versionfile_stream=FSO.GetFile(VersionFile).OpenAsTextStream(ForReading, TristateUseDefault);
+//read file fully into var
+allstrings=versionfile_stream.ReadAll();
+//define RegExp for var defines.
+var filename=/(?:#define\s+__FILENAME\s+")(.+)(?=")/m;
+var pluginname=/(?:#define\s+__PLUGIN_NAME\s+")(.+)(?=")/i;
+var author=/(?:#define\s+__AUTHOR\s+")(.+)(?=")/i;
+var MAJOR_VERSION=/(?:#define\s+__MAJOR_VERSION\s+)(\d+)/i;
+var MINOR_VERSION=/(?:#define\s+__MINOR_VERSION\s+)(\d+)/i;
+var RELEASE_NUM=/(?:#define\s+__RELEASE_NUM\s+)(\d+)/i;
+var BUILD_NUM=/(?:#define\s+__BUILD_NUM\s+)(\d+)/i;
+var description=/(?:#define\s+__DESCRIPTION\s+")(.+)(?=")/i;
+//exec RegExps
+filename=filename.exec(allstrings);
+pluginname=pluginname.exec(allstrings);
+MAJOR_VERSION=MAJOR_VERSION.exec(allstrings);
+MINOR_VERSION=MINOR_VERSION.exec(allstrings);
+RELEASE_NUM=RELEASE_NUM.exec(allstrings);
+BUILD_NUM=BUILD_NUM.exec(allstrings);
+author=author.exec(allstrings);
+description=description.exec(allstrings);
+
+//add a header start mark
+array.push(";============================================================");
+//push results of regexp vars into array
+if (filename) array.push("; File: "+filename[1]); else array.push("; File: "+plugin+".dll");
+if (pluginname) array.push("; Plugin: "+pluginname[1]); else array.push("; Plugin: "+plugin);
+if (MAJOR_VERSION) array.push("; Version: "+MAJOR_VERSION[1]+"."+MINOR_VERSION[1]+"."+RELEASE_NUM[1]+"."+BUILD_NUM[1]); else array.push("; Version: x.x.x.x");
+if (author) array.push("; Authors: "+author[1]); else array.push("; Authors: ");
+//add a header end mark
+array.push(";============================================================");
+if (description) array.push("["+description[1]+"]");
+//close file
+versionfile_stream.Close();
+}
+
//Removes duplicates, not mine, found at http://dreaminginjavascript.wordpress.com/2008/08/22/eliminating-duplicates/
function eliminateDuplicates(arr) {
var i,