mirror of
https://github.com/rn10950/RetroZilla.git
synced 2024-11-16 12:30:13 +01:00
251 lines
7.0 KiB
Perl
251 lines
7.0 KiB
Perl
|
#!c:\perl\bin\perl
|
||
|
#
|
||
|
# ***** 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 Communicator client code, released
|
||
|
# March 31, 1998.
|
||
|
#
|
||
|
# The Initial Developer of the Original Code is
|
||
|
# Netscape Communications Corporation.
|
||
|
# Portions created by the Initial Developer are Copyright (C) 1999
|
||
|
# the Initial Developer. All Rights Reserved.
|
||
|
#
|
||
|
# Contributor(s):
|
||
|
# Sean Su <ssu@netscape.com>
|
||
|
#
|
||
|
# Alternatively, the contents of this file may be used under the terms of
|
||
|
# either of 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 *****
|
||
|
|
||
|
#
|
||
|
# Purpose:
|
||
|
# To build the mozilla self-extracting installer and its corresponding .xpi files
|
||
|
# given a mozilla build on a local system.
|
||
|
#
|
||
|
# Requirements:
|
||
|
# 1. perl needs to be installed correctly on the build system because cwd.pm is used.
|
||
|
# 2. mozilla\xpinstall\wizard\os2 needs to be built.
|
||
|
#
|
||
|
|
||
|
if($ENV{MOZ_SRC} eq "")
|
||
|
{
|
||
|
print "Error: MOZ_SRC not set!";
|
||
|
exit(1);
|
||
|
}
|
||
|
|
||
|
if($ENV{MOZ_OBJDIR} eq "")
|
||
|
{
|
||
|
print "Error: MOZ_OBJDIR not set!";
|
||
|
exit(1);
|
||
|
}
|
||
|
|
||
|
$inXpiURL = "";
|
||
|
$inRedirIniURL = "";
|
||
|
|
||
|
ParseArgv(@ARGV);
|
||
|
if($inXpiURL eq "")
|
||
|
{
|
||
|
# archive url not supplied, set it to default values
|
||
|
$inXpiURL = "ftp://not.supplied.invalid";
|
||
|
}
|
||
|
if($inRedirIniURL eq "")
|
||
|
{
|
||
|
# redirect url not supplied, set it to default value.
|
||
|
$inRedirIniURL = $inXpiURL;
|
||
|
}
|
||
|
|
||
|
$DEPTH = "$ENV{MOZ_SRC}/mozilla";
|
||
|
$cwdBuilder = "$DEPTH/xpinstall/wizard/os2/builder";
|
||
|
$cwdDist = GetCwd("dist", $DEPTH, $ENV{MOZ_OBJDIR}, $cwdBuilder);
|
||
|
$cwdInstall = GetCwd("install", $DEPTH, $ENV{MOZ_OBJDIR}, $cwdBuilder);
|
||
|
$cwdPackager = GetCwd("packager", $DEPTH, $ENV{MOZ_OBJDIR}, $cwdBuilder);
|
||
|
$cwdConfig = GetCwd("config", $DEPTH, $ENV{MOZ_OBJDIR}, $cwdBuilder);
|
||
|
#need a better way to get version from build
|
||
|
$verPartial = "1.2b.0.";
|
||
|
#get date from build_number file
|
||
|
open(FILENEW, "<$cwdConfig/build_number");
|
||
|
my $dateversion = <FILENEW>;
|
||
|
close(FILENEW);
|
||
|
$ver = $verPartial . $dateversion;
|
||
|
|
||
|
# Check for existence of mozilla.exe
|
||
|
$fileMozilla = "$DEPTH/$ENV{MOZ_OBJDIR}/dist/bin/mozilla.exe";
|
||
|
if(!(-e "$fileMozilla"))
|
||
|
{
|
||
|
print "file not found: $fileMozilla\n";
|
||
|
exit(1);
|
||
|
}
|
||
|
|
||
|
if(-d "$DEPTH/stage")
|
||
|
{
|
||
|
system("perl $cwdPackager/os2/rdir.pl $DEPTH/stage");
|
||
|
}
|
||
|
|
||
|
# The destination cannot be a sub directory of the source.
|
||
|
# pkgcp.pl will get very unhappy.
|
||
|
|
||
|
mkdir("$DEPTH/stage", 0775);
|
||
|
system("perl $cwdPackager/pkgcp.pl -s $cwdDist -d $DEPTH/stage -f $cwdPackager/packages-os2 -o unix -v");
|
||
|
system("perl $cwdPackager/xptlink.pl -s $cwdDist -d $DEPTH/stage -v");
|
||
|
|
||
|
chdir("$cwdPackager/os2");
|
||
|
if(system("perl makeall.pl $ver $DEPTH/stage $cwdDist/install -aurl $inXpiURL -rurl $inRedirIniURL"))
|
||
|
{
|
||
|
print "\n Error: perl makeall.pl $ver $DEPTH/stage $cwdDist/install $inXpiURL $inRedirIniURL\n";
|
||
|
exit(1);
|
||
|
}
|
||
|
|
||
|
chdir($cwdBuilder);
|
||
|
|
||
|
# Copy the .xpi files to the same directory as setup.exe.
|
||
|
# This is so that setup.exe can find the .xpi files
|
||
|
# in the same directory and use them.
|
||
|
#
|
||
|
# Mozilla-os2-installer.exe (a self extracting file) will use the .xpi
|
||
|
# files from its current directory as well, but it is not a requirement
|
||
|
# that they exist because it already contains the .xpi files within itself.
|
||
|
if(system("cp $cwdDist/install/xpi/*.* $cwdDist/install"))
|
||
|
{
|
||
|
print "Error: cp $cwdDist/install/xpi/*.* $cwdDist/install\n";
|
||
|
exit(1);
|
||
|
}
|
||
|
|
||
|
print "\n";
|
||
|
print "**\n";
|
||
|
print "*\n";
|
||
|
print "* A self-extracting installer has been built and delivered:\n";
|
||
|
print "*\n";
|
||
|
print "* $cwdDist/install/mozilla-os2-installer.exe\n";
|
||
|
print "*\n";
|
||
|
print "**\n";
|
||
|
print "\n";
|
||
|
|
||
|
exit(0);
|
||
|
|
||
|
sub PrintUsage
|
||
|
{
|
||
|
die "usage: $0 [options]
|
||
|
|
||
|
options available are:
|
||
|
|
||
|
-h - this usage.
|
||
|
|
||
|
-aurl - ftp or http url for where the archives (.xpi, exe, .zip, etx...) are.
|
||
|
ie: ftp://my.ftp.com/mysoftware/version1.0/xpi
|
||
|
|
||
|
-rurl - ftp or http url for where the redirect.ini file is located at.
|
||
|
ie: ftp://my.ftp.com/mysoftware/version1.0
|
||
|
|
||
|
This url can be the same as the archive url.
|
||
|
If -rurl is not supplied, it will be assumed that the redirect.ini
|
||
|
file is at -arul.
|
||
|
\n";
|
||
|
}
|
||
|
|
||
|
sub ParseArgv
|
||
|
{
|
||
|
my(@myArgv) = @_;
|
||
|
my($counter);
|
||
|
|
||
|
for($counter = 0; $counter <= $#myArgv; $counter++)
|
||
|
{
|
||
|
if($myArgv[$counter] =~ /^[-,\/]h$/i)
|
||
|
{
|
||
|
PrintUsage();
|
||
|
}
|
||
|
elsif($myArgv[$counter] =~ /^[-,\/]aurl$/i)
|
||
|
{
|
||
|
if($#myArgv >= ($counter + 1))
|
||
|
{
|
||
|
++$counter;
|
||
|
$inXpiURL = $myArgv[$counter];
|
||
|
$inRedirIniURL = $inXpiURL;
|
||
|
}
|
||
|
}
|
||
|
elsif($myArgv[$counter] =~ /^[-,\/]rurl$/i)
|
||
|
{
|
||
|
if($#myArgv >= ($counter + 1))
|
||
|
{
|
||
|
++$counter;
|
||
|
$inRedirIniURL = $myArgv[$counter];
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
sub GetCwd
|
||
|
{
|
||
|
my($whichPath, $depthPath, $objdirName, $returnCwd) = @_;
|
||
|
my($distCwd);
|
||
|
my($distPath);
|
||
|
|
||
|
if($whichPath eq "dist")
|
||
|
{
|
||
|
# verify the existance of path
|
||
|
if(!(-e "$depthPath/$objdirName/dist"))
|
||
|
{
|
||
|
print "path not found: $depthPath/$objDirName/dist\n";
|
||
|
exit(1);
|
||
|
}
|
||
|
|
||
|
$distPath = "$depthPath/$objdirName/dist";
|
||
|
}
|
||
|
elsif($whichPath eq "install")
|
||
|
{
|
||
|
# verify the existance of path
|
||
|
if(!(-e "$depthPath/$objdirName/dist/install"))
|
||
|
{
|
||
|
print "path not found: $depthPath/$objdirName/dist/install\n";
|
||
|
exit(1);
|
||
|
}
|
||
|
|
||
|
$distPath = "$depthPath/$objdirname/install";
|
||
|
}
|
||
|
elsif($whichPath eq "packager")
|
||
|
{
|
||
|
# verify the existance of path
|
||
|
if(!(-e "$depthPath/xpinstall/packager"))
|
||
|
{
|
||
|
print "path not found: $depthPath/xpinstall/packager\n";
|
||
|
exit(1);
|
||
|
}
|
||
|
|
||
|
$distPath = "$depthPath/xpinstall/packager";
|
||
|
}
|
||
|
elsif($whichPath eq "config")
|
||
|
{
|
||
|
# verify the existance of path
|
||
|
if(!(-e "$depthPath/$objdirName/config"))
|
||
|
{
|
||
|
print "path not found: $depthPath/$objdirName/config\n";
|
||
|
exit(1);
|
||
|
}
|
||
|
|
||
|
$distPath = "$depthPath/$objdirName/config";
|
||
|
}
|
||
|
|
||
|
return($distPath);
|
||
|
}
|
||
|
|