2004-09-09 05:26:39 +04:00
|
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
|
|
|
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
|
|
*
|
|
|
|
* The contents of this file are subject to the Mozilla Public License Version
|
|
|
|
* 1.1 (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.mozilla.org/MPL/
|
|
|
|
*
|
|
|
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
|
|
* for the specific language governing rights and limitations under the
|
|
|
|
* License.
|
|
|
|
*
|
|
|
|
* The Original Code is Mozilla.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is IBM Corporation.
|
|
|
|
* Portions created by IBM Corporation are Copyright (C) 2003
|
|
|
|
* IBM Corporation. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
|
|
|
* Darin Fisher <darin@meer.net>
|
2005-05-12 17:23:30 +04:00
|
|
|
* Benjamin Smedberg <benjamin@smedbergs.us>
|
2004-09-09 05:26:39 +04:00
|
|
|
*
|
|
|
|
* Alternatively, the contents of this file may be used under the terms of
|
|
|
|
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
|
|
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
|
|
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
|
|
* of those above. If you wish to allow use of your version of this file only
|
|
|
|
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
|
|
* use your version of this file under the terms of the MPL, indicate your
|
|
|
|
* decision by deleting the provisions above and replace them with the notice
|
|
|
|
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
|
|
* the provisions above, a recipient may use your version of this file under
|
|
|
|
* the terms of any one of the MPL, the GPL or the LGPL.
|
|
|
|
*
|
|
|
|
* ***** END LICENSE BLOCK ***** */
|
|
|
|
|
2004-09-09 11:03:04 +04:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
2004-09-09 05:26:39 +04:00
|
|
|
#ifdef XP_WIN
|
|
|
|
#include <windows.h>
|
|
|
|
#endif
|
|
|
|
|
2004-12-20 08:54:06 +03:00
|
|
|
#include "nsXULAppAPI.h"
|
2005-06-13 20:45:22 +04:00
|
|
|
#include "nsXPCOMGlue.h"
|
|
|
|
#include "nsRegisterGRE.h"
|
2004-12-20 08:54:06 +03:00
|
|
|
#include "nsAppRunner.h"
|
|
|
|
#include "nsINIParser.h"
|
|
|
|
#include "nsILocalFile.h"
|
|
|
|
#include "nsCOMPtr.h"
|
|
|
|
#include "nsMemory.h"
|
|
|
|
#include "nsBuildID.h"
|
|
|
|
#include "plstr.h"
|
|
|
|
#include "prprf.h"
|
2005-05-26 23:51:19 +04:00
|
|
|
#include "prenv.h"
|
2004-12-20 08:54:06 +03:00
|
|
|
|
2005-05-03 02:35:55 +04:00
|
|
|
/**
|
|
|
|
* Output a string to the user. This method is really only meant to be used to
|
|
|
|
* output last-ditch error messages designed for developers NOT END USERS.
|
|
|
|
*
|
|
|
|
* @param isError
|
|
|
|
* Pass true to indicate severe errors.
|
|
|
|
* @param fmt
|
|
|
|
* printf-style format string followed by arguments.
|
|
|
|
*/
|
|
|
|
static void Output(PRBool isError, const char *fmt, ... )
|
|
|
|
{
|
|
|
|
va_list ap;
|
|
|
|
va_start(ap, fmt);
|
|
|
|
|
|
|
|
#if defined(XP_WIN) && !MOZ_WINCONSOLE
|
|
|
|
char *msg = PR_vsmprintf(fmt, ap);
|
|
|
|
if (msg)
|
|
|
|
{
|
|
|
|
UINT flags = MB_OK;
|
|
|
|
if (isError)
|
|
|
|
flags |= MB_ICONERROR;
|
|
|
|
else
|
|
|
|
flags |= MB_ICONINFORMATION;
|
|
|
|
MessageBox(NULL, msg, "XULRunner", flags);
|
|
|
|
PR_smprintf_free(msg);
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
vfprintf(stderr, fmt, ap);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
va_end(ap);
|
|
|
|
}
|
|
|
|
|
2004-12-20 08:54:06 +03:00
|
|
|
/**
|
|
|
|
* Return true if |arg| matches the given argument name.
|
|
|
|
*/
|
2004-09-09 11:03:04 +04:00
|
|
|
static PRBool IsArg(const char* arg, const char* s)
|
|
|
|
{
|
|
|
|
if (*arg == '-')
|
|
|
|
{
|
|
|
|
if (*++arg == '-')
|
|
|
|
++arg;
|
|
|
|
return !PL_strcasecmp(arg, s);
|
|
|
|
}
|
|
|
|
|
|
|
|
#if defined(XP_WIN) || defined(XP_OS2)
|
|
|
|
if (*arg == '/')
|
|
|
|
return !PL_strcasecmp(++arg, s);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
return PR_FALSE;
|
|
|
|
}
|
2004-09-09 05:26:39 +04:00
|
|
|
|
2004-12-20 08:54:06 +03:00
|
|
|
/**
|
|
|
|
* Version checking.
|
|
|
|
*/
|
|
|
|
|
|
|
|
static PRUint32 geckoVersion = 0;
|
|
|
|
|
|
|
|
static PRUint32 ParseVersion(const char *versionStr)
|
|
|
|
{
|
|
|
|
PRUint16 major, minor;
|
|
|
|
if (PR_sscanf(versionStr, "%hu.%hu", &major, &minor) != 2) {
|
|
|
|
NS_WARNING("invalid version string");
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
return PRUint32(major) << 16 | PRUint32(minor);
|
|
|
|
}
|
|
|
|
|
|
|
|
static PRBool CheckMinVersion(const char *versionStr)
|
|
|
|
{
|
|
|
|
PRUint32 v = ParseVersion(versionStr);
|
|
|
|
return geckoVersion >= v;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PRBool CheckMaxVersion(const char *versionStr)
|
|
|
|
{
|
|
|
|
PRUint32 v = ParseVersion(versionStr);
|
|
|
|
return geckoVersion <= v;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Parse application data.
|
|
|
|
*/
|
2005-08-12 02:07:08 +04:00
|
|
|
static int LoadAppData(const char* appDataFile, nsXREAppData* aResult)
|
2004-12-20 08:54:06 +03:00
|
|
|
{
|
2005-08-12 02:07:08 +04:00
|
|
|
static char vendor[256], name[256], version[32], buildID[32], appID[256], copyright[512];
|
|
|
|
|
2005-05-12 17:23:30 +04:00
|
|
|
nsresult rv;
|
|
|
|
|
2004-12-20 08:54:06 +03:00
|
|
|
nsCOMPtr<nsILocalFile> lf;
|
2005-03-19 00:24:05 +03:00
|
|
|
XRE_GetFileFromPath(appDataFile, getter_AddRefs(lf));
|
2004-12-20 08:54:06 +03:00
|
|
|
if (!lf)
|
2005-05-12 17:23:30 +04:00
|
|
|
return 2;
|
2004-12-20 08:54:06 +03:00
|
|
|
|
2005-05-12 21:40:03 +04:00
|
|
|
nsCOMPtr<nsIFile> appDir;
|
|
|
|
rv = lf->GetParent(getter_AddRefs(appDir));
|
2005-05-12 17:23:30 +04:00
|
|
|
if (NS_FAILED(rv))
|
|
|
|
return 2;
|
2005-05-12 21:40:03 +04:00
|
|
|
|
|
|
|
rv = CallQueryInterface(appDir, &aResult->directory);
|
|
|
|
if (NS_FAILED(rv))
|
|
|
|
return 2;
|
|
|
|
|
2005-05-12 17:23:30 +04:00
|
|
|
nsINIParser parser;
|
2005-05-12 21:40:03 +04:00
|
|
|
rv = parser.Init(lf);
|
2005-05-12 17:23:30 +04:00
|
|
|
if (NS_FAILED(rv))
|
|
|
|
return 2;
|
2004-12-20 08:54:06 +03:00
|
|
|
|
|
|
|
// Gecko version checking
|
|
|
|
//
|
|
|
|
// TODO: If these version checks fail, then look for a compatible XULRunner
|
|
|
|
// version on the system, and launch it instead.
|
|
|
|
|
2005-08-12 02:07:08 +04:00
|
|
|
char gkVersion[32];
|
|
|
|
rv = parser.GetString("Gecko", "MinVersion", gkVersion, sizeof(gkVersion));
|
|
|
|
if (NS_FAILED(rv) || !CheckMinVersion(gkVersion)) {
|
2005-05-03 02:35:55 +04:00
|
|
|
Output(PR_TRUE, "Error: Gecko MinVersion requirement not met.\n");
|
2005-05-12 17:23:30 +04:00
|
|
|
return 1;
|
2004-12-20 08:54:06 +03:00
|
|
|
}
|
|
|
|
|
2005-08-12 02:07:08 +04:00
|
|
|
rv = parser.GetString("Gecko", "MaxVersion", gkVersion, sizeof(gkVersion));
|
|
|
|
if (NS_SUCCEEDED(rv) && !CheckMaxVersion(gkVersion)) {
|
2005-05-03 02:35:55 +04:00
|
|
|
Output(PR_TRUE, "Error: Gecko MaxVersion requirement not met.\n");
|
2005-05-12 17:23:30 +04:00
|
|
|
return 1;
|
2004-12-20 08:54:06 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
PRUint32 i;
|
|
|
|
|
|
|
|
// Read string-valued fields
|
|
|
|
const struct {
|
2005-05-12 17:23:30 +04:00
|
|
|
const char *key;
|
2005-05-12 21:40:03 +04:00
|
|
|
const char **fill;
|
2005-08-12 02:07:08 +04:00
|
|
|
char *buf;
|
|
|
|
size_t bufLen;
|
2005-05-12 17:23:30 +04:00
|
|
|
PRBool required;
|
2004-12-20 08:54:06 +03:00
|
|
|
} string_fields[] = {
|
2005-08-12 02:07:08 +04:00
|
|
|
{ "Vendor", &aResult->vendor, vendor, sizeof(vendor), PR_FALSE },
|
|
|
|
{ "Name", &aResult->name, name, sizeof(name), PR_TRUE },
|
|
|
|
{ "Version", &aResult->version, version, sizeof(version), PR_FALSE },
|
|
|
|
{ "BuildID", &aResult->buildID, buildID, sizeof(buildID), PR_TRUE },
|
|
|
|
{ "ID", &aResult->ID, appID, sizeof(appID), PR_FALSE },
|
|
|
|
{ "Copyright", &aResult->copyright, copyright, sizeof(copyright), PR_FALSE }
|
2004-12-20 08:54:06 +03:00
|
|
|
};
|
|
|
|
for (i = 0; i < NS_ARRAY_LENGTH(string_fields); ++i) {
|
2005-08-12 02:07:08 +04:00
|
|
|
rv = parser.GetString("App", string_fields[i].key, string_fields[i].buf,
|
|
|
|
string_fields[i].bufLen);
|
2005-05-12 17:23:30 +04:00
|
|
|
if (NS_SUCCEEDED(rv)) {
|
2005-08-12 02:07:08 +04:00
|
|
|
*string_fields[i].fill = string_fields[i].buf;
|
2005-05-12 17:23:30 +04:00
|
|
|
}
|
|
|
|
else if (string_fields[i].required) {
|
|
|
|
Output(PR_TRUE, "Error: %x: No \"%s\" field.\n",
|
2005-06-13 20:45:22 +04:00
|
|
|
rv, string_fields[i].key);
|
2005-05-12 17:23:30 +04:00
|
|
|
return 1;
|
2004-12-20 08:54:06 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Read boolean-valued fields
|
|
|
|
const struct {
|
|
|
|
const char* key;
|
|
|
|
PRUint32 flag;
|
|
|
|
} boolean_fields[] = {
|
|
|
|
{ "EnableProfileMigrator", NS_XRE_ENABLE_PROFILE_MIGRATOR },
|
|
|
|
{ "EnableExtensionManager", NS_XRE_ENABLE_EXTENSION_MANAGER }
|
|
|
|
};
|
|
|
|
char buf[6]; // large enough to hold "false"
|
2005-05-12 17:23:30 +04:00
|
|
|
aResult->flags = 0;
|
2004-12-20 08:54:06 +03:00
|
|
|
for (i = 0; i < NS_ARRAY_LENGTH(boolean_fields); ++i) {
|
|
|
|
rv = parser.GetString("XRE", boolean_fields[i].key, buf, sizeof(buf));
|
|
|
|
// accept a truncated result since we are only interested in the
|
|
|
|
// first character. this is designed to allow the possibility of
|
|
|
|
// expanding these boolean attributes to express additional options.
|
|
|
|
if ((NS_SUCCEEDED(rv) || rv == NS_ERROR_LOSS_OF_SIGNIFICANT_DATA) &&
|
|
|
|
(buf[0] == '1' || buf[0] == 't' || buf[0] == 'T')) {
|
2005-05-12 17:23:30 +04:00
|
|
|
aResult->flags |= boolean_fields[i].flag;
|
2004-12-20 08:54:06 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef DEBUG
|
|
|
|
printf("---------------------------------------------------------\n");
|
2005-05-17 04:58:08 +04:00
|
|
|
printf(" Vendor %s\n", aResult->vendor);
|
|
|
|
printf(" Name %s\n", aResult->name);
|
|
|
|
printf(" Version %s\n", aResult->version);
|
|
|
|
printf(" BuildID %s\n", aResult->buildID);
|
2005-05-12 17:23:30 +04:00
|
|
|
printf(" Copyright %s\n", aResult->copyright);
|
|
|
|
printf(" Flags %08x\n", aResult->flags);
|
2004-12-20 08:54:06 +03:00
|
|
|
printf("---------------------------------------------------------\n");
|
|
|
|
#endif
|
|
|
|
|
2005-05-12 17:23:30 +04:00
|
|
|
return 0;
|
2004-12-20 08:54:06 +03:00
|
|
|
}
|
|
|
|
|
2005-05-26 23:51:19 +04:00
|
|
|
static void Usage()
|
2004-09-09 05:26:39 +04:00
|
|
|
{
|
2005-05-03 02:35:55 +04:00
|
|
|
// display additional information (XXX make localizable?)
|
|
|
|
Output(PR_FALSE,
|
2005-06-13 20:45:22 +04:00
|
|
|
"Mozilla XULRunner %s\n\n"
|
2005-06-28 02:35:55 +04:00
|
|
|
"Usage: " XULRUNNER_PROGNAME " [OPTIONS]\n"
|
|
|
|
" " XULRUNNER_PROGNAME " APP-FILE [APP-OPTIONS...]\n"
|
2005-05-03 02:35:55 +04:00
|
|
|
"\n"
|
|
|
|
"OPTIONS\n"
|
2005-06-13 20:45:22 +04:00
|
|
|
" --app specify APP-FILE (optional)\n"
|
|
|
|
" -h, --help show this message\n"
|
|
|
|
" -v, --version show version\n"
|
2005-06-28 02:35:55 +04:00
|
|
|
" --gre-version print the GRE version string on stdout\n"
|
|
|
|
" --register-global register this GRE in the machine registry\n"
|
2005-06-13 20:45:22 +04:00
|
|
|
" --register-user register this GRE in the user registry\n"
|
|
|
|
" --unregister-global unregister this GRE formerly registered with\n"
|
|
|
|
" --register-global\n"
|
|
|
|
" --unregister-user unregister this GRE formely registered with\n"
|
|
|
|
" --register-user\n"
|
|
|
|
" --find-gre <version> Find a GRE with version <version> and print\n"
|
|
|
|
" the path on stdout\n"
|
2005-05-03 02:35:55 +04:00
|
|
|
"\n"
|
|
|
|
"APP-FILE\n"
|
|
|
|
" Application initialization file.\n"
|
|
|
|
"\n"
|
|
|
|
"APP-OPTIONS\n"
|
|
|
|
" Application specific options.\n",
|
2005-06-13 20:45:22 +04:00
|
|
|
GRE_BUILD_ID);
|
|
|
|
}
|
|
|
|
|
|
|
|
static nsresult
|
|
|
|
GetXULRunnerDir(const char *argv0, nsIFile* *aResult)
|
|
|
|
{
|
|
|
|
nsresult rv;
|
|
|
|
|
|
|
|
nsCOMPtr<nsILocalFile> appFile;
|
|
|
|
rv = XRE_GetBinaryPath(argv0, getter_AddRefs(appFile));
|
|
|
|
if (NS_FAILED(rv)) {
|
|
|
|
Output(PR_TRUE, "Could not find XULRunner application path.\n");
|
|
|
|
return rv;
|
|
|
|
}
|
|
|
|
|
|
|
|
rv = appFile->GetParent(aResult);
|
|
|
|
if (NS_FAILED(rv)) {
|
|
|
|
Output(PR_TRUE, "Could not find XULRunner installation dir.\n");
|
|
|
|
}
|
|
|
|
return rv;
|
2005-05-26 23:51:19 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
int main(int argc, char* argv[])
|
|
|
|
{
|
|
|
|
if (argc > 1 && (IsArg(argv[1], "h") ||
|
|
|
|
IsArg(argv[1], "help") ||
|
|
|
|
IsArg(argv[1], "?")))
|
|
|
|
{
|
|
|
|
Usage();
|
2004-09-09 11:03:04 +04:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2004-12-20 08:54:06 +03:00
|
|
|
if (argc == 2 && (IsArg(argv[1], "v") || IsArg(argv[1], "version")))
|
|
|
|
{
|
2005-06-13 20:45:22 +04:00
|
|
|
Output(PR_FALSE, "Mozilla XULRunner %s\n", GRE_BUILD_ID);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2005-06-14 18:56:16 +04:00
|
|
|
if (argc > 1) {
|
|
|
|
PRBool registerGlobal = IsArg(argv[1], "register-global");
|
|
|
|
PRBool registerUser = IsArg(argv[1], "register-user");
|
|
|
|
if (registerGlobal || registerUser) {
|
|
|
|
if (argc != 2) {
|
2005-06-16 17:29:45 +04:00
|
|
|
Usage();
|
|
|
|
return 1;
|
2005-06-14 18:56:16 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
nsCOMPtr<nsIFile> regDir;
|
|
|
|
nsresult rv = GetXULRunnerDir(argv[0], getter_AddRefs(regDir));
|
|
|
|
if (NS_FAILED(rv))
|
2005-06-13 20:45:22 +04:00
|
|
|
return 2;
|
|
|
|
|
2005-06-14 18:56:16 +04:00
|
|
|
return RegisterXULRunner(registerGlobal, regDir) ? 0 : 2;
|
2005-06-13 20:45:22 +04:00
|
|
|
}
|
|
|
|
|
2005-06-14 18:56:16 +04:00
|
|
|
registerGlobal = IsArg(argv[1], "unregister-global");
|
|
|
|
registerUser = IsArg(argv[1], "unregister-user");
|
2005-06-16 17:29:45 +04:00
|
|
|
if (registerGlobal || registerUser) {
|
2005-06-14 18:56:16 +04:00
|
|
|
if (argc != 2) {
|
2005-06-16 17:29:45 +04:00
|
|
|
Usage();
|
|
|
|
return 1;
|
2005-06-14 18:56:16 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
nsCOMPtr<nsIFile> regDir;
|
|
|
|
nsresult rv = GetXULRunnerDir(argv[0], getter_AddRefs(regDir));
|
|
|
|
if (NS_FAILED(rv))
|
2005-06-13 20:45:22 +04:00
|
|
|
return 2;
|
2005-06-14 18:56:16 +04:00
|
|
|
UnregisterXULRunner(registerGlobal, regDir);
|
|
|
|
return 0;
|
2005-06-13 20:45:22 +04:00
|
|
|
}
|
|
|
|
|
2005-06-14 18:56:16 +04:00
|
|
|
if (IsArg(argv[1], "find-gre")) {
|
|
|
|
if (argc != 3) {
|
2005-06-16 17:29:45 +04:00
|
|
|
Usage();
|
|
|
|
return 1;
|
2005-06-14 18:56:16 +04:00
|
|
|
}
|
2005-06-13 20:45:22 +04:00
|
|
|
|
2005-06-14 18:56:16 +04:00
|
|
|
char version[MAXPATHLEN];
|
|
|
|
nsresult rv = GRE_GetGREPathForVersion(argv[2], version, MAXPATHLEN);
|
|
|
|
if (NS_FAILED(rv))
|
2005-06-16 17:29:45 +04:00
|
|
|
return 1;
|
2005-06-13 20:45:22 +04:00
|
|
|
|
2005-06-14 18:56:16 +04:00
|
|
|
printf("%s\n", version);
|
|
|
|
return 0;
|
2005-06-13 20:45:22 +04:00
|
|
|
}
|
|
|
|
|
2005-06-14 18:56:16 +04:00
|
|
|
if (IsArg(argv[1], "gre-version")) {
|
|
|
|
if (argc != 2) {
|
2005-06-16 17:29:45 +04:00
|
|
|
Usage();
|
|
|
|
return 1;
|
2005-06-14 18:56:16 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
printf("%s\n", GRE_BUILD_ID);
|
|
|
|
return 0;
|
|
|
|
}
|
2004-09-09 11:03:04 +04:00
|
|
|
}
|
|
|
|
|
2004-12-20 08:54:06 +03:00
|
|
|
geckoVersion = ParseVersion(GRE_BUILD_ID);
|
|
|
|
|
2005-05-26 23:51:19 +04:00
|
|
|
const char *appDataFile = PR_GetEnv("XUL_APP_FILE");
|
2005-05-18 21:53:53 +04:00
|
|
|
|
2005-05-26 23:51:19 +04:00
|
|
|
if (!(appDataFile && *appDataFile)) {
|
|
|
|
if (argc < 2) {
|
|
|
|
Usage();
|
2004-12-20 08:54:06 +03:00
|
|
|
return 1;
|
|
|
|
}
|
2005-05-26 23:51:19 +04:00
|
|
|
|
|
|
|
if (IsArg(argv[1], "app")) {
|
|
|
|
if (argc == 2) {
|
|
|
|
Usage();
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
argv[1] = argv[0];
|
|
|
|
++argv;
|
|
|
|
--argc;
|
|
|
|
}
|
|
|
|
|
2004-12-20 08:54:06 +03:00
|
|
|
appDataFile = argv[1];
|
2005-05-26 23:51:19 +04:00
|
|
|
argv[1] = argv[0];
|
|
|
|
++argv;
|
|
|
|
--argc;
|
|
|
|
|
|
|
|
static char kAppEnv[MAXPATHLEN];
|
|
|
|
PR_snprintf(kAppEnv, MAXPATHLEN, "XUL_APP_FILE=%s", appDataFile);
|
|
|
|
PR_SetEnv(kAppEnv);
|
2004-12-20 08:54:06 +03:00
|
|
|
}
|
|
|
|
|
2005-05-12 17:23:30 +04:00
|
|
|
nsXREAppData appData = { sizeof(nsXREAppData), 0 };
|
2004-09-09 11:03:04 +04:00
|
|
|
|
2005-08-12 02:07:08 +04:00
|
|
|
int rv = LoadAppData(appDataFile, &appData);
|
2005-05-12 17:23:30 +04:00
|
|
|
if (!rv)
|
2005-05-12 21:40:03 +04:00
|
|
|
rv = XRE_main(argc, argv, &appData);
|
2004-09-09 11:03:04 +04:00
|
|
|
|
2005-05-12 21:40:03 +04:00
|
|
|
NS_IF_RELEASE(appData.directory);
|
2004-09-09 11:03:04 +04:00
|
|
|
|
|
|
|
return rv;
|
2004-09-09 05:26:39 +04:00
|
|
|
}
|
2005-03-19 00:24:05 +03:00
|
|
|
|
2004-09-09 05:26:39 +04:00
|
|
|
#if defined( XP_WIN ) && defined( WIN32 ) && !defined(__GNUC__)
|
|
|
|
// We need WinMain in order to not be a console app. This function is
|
|
|
|
// unused if we are a console application.
|
|
|
|
int WINAPI WinMain( HINSTANCE, HINSTANCE, LPSTR args, int )
|
|
|
|
{
|
2004-09-09 11:03:04 +04:00
|
|
|
// Do the real work.
|
|
|
|
return main( __argc, __argv );
|
2004-09-09 05:26:39 +04:00
|
|
|
}
|
|
|
|
#endif
|