1#************************************************************** 2# 3# Licensed to the Apache Software Foundation (ASF) under one 4# or more contributor license agreements. See the NOTICE file 5# distributed with this work for additional information 6# regarding copyright ownership. The ASF licenses this file 7# to you under the Apache License, Version 2.0 (the 8# "License"); you may not use this file except in compliance 9# with the License. You may obtain a copy of the License at 10# 11# http://www.apache.org/licenses/LICENSE-2.0 12# 13# Unless required by applicable law or agreed to in writing, 14# software distributed under the License is distributed on an 15# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16# KIND, either express or implied. See the License for the 17# specific language governing permissions and limitations 18# under the License. 19# 20#************************************************************** 21 22 23 24################# 25# use 26################# 27 28use lib ("$ENV{SOLARENV}/bin/modules"); 29 30use Cwd; 31use File::Copy; 32use installer::archivefiles; 33use installer::control; 34use installer::converter; 35use installer::copyproject; 36use installer::download; 37use installer::environment; 38use installer::epmfile; 39use installer::exiter; 40use installer::files; 41use installer::followme; 42use installer::globals; 43use installer::javainstaller; 44use installer::languagepack; 45use installer::languages; 46use installer::logger; 47use installer::mail; 48use installer::packagelist; 49use installer::packagepool; 50use installer::parameter; 51use installer::pathanalyzer; 52use installer::profiles; 53use installer::scppatchsoname; 54use installer::scpzipfiles; 55use installer::scriptitems; 56use installer::setupscript; 57use installer::simplepackage; 58use installer::sorter; 59use installer::strip; 60use installer::substfilenamefiles; 61use installer::upx; 62use installer::systemactions; 63use installer::windows::assembly; 64use installer::windows::binary; 65use installer::windows::component; 66use installer::windows::createfolder; 67use installer::windows::directory; 68use installer::windows::feature; 69use installer::windows::featurecomponent; 70use installer::windows::file; 71use installer::windows::font; 72use installer::windows::icon; 73use installer::windows::idtglobal; 74use installer::windows::inifile; 75use installer::windows::java; 76use installer::windows::media; 77use installer::windows::mergemodule; 78use installer::windows::msiglobal; 79use installer::windows::msp; 80use installer::windows::patch; 81use installer::windows::property; 82use installer::windows::removefile; 83use installer::windows::registry; 84use installer::windows::selfreg; 85use installer::windows::shortcut; 86use installer::windows::strip; 87use installer::windows::update; 88use installer::windows::upgrade; 89use installer::worker; 90use installer::xpdinstaller; 91use installer::ziplist; 92 93################################################# 94# Main program 95################################################# 96 97################################################# 98# Part 1: The platform independent part 99################################################# 100 101################################################# 102# Part 1a: The language independent part 103################################################# 104 105installer::logger::starttime(); 106 107######################################### 108# Checking the environment and setting 109# most important variables 110######################################### 111 112installer::logger::print_message( "... checking environment variables ...\n" ); 113my $environmentvariableshashref = installer::control::check_system_environment(); 114 115installer::environment::set_global_environment_variables($environmentvariableshashref); 116 117################################# 118# Check and output of parameter 119################################# 120 121installer::parameter::saveparameter(); 122installer::parameter::getparameter(); 123 124# debugging can start after function "getparameter" 125if ( $installer::globals::debug ) { installer::logger::debuginfo("\nPart 1: The platform independent part\n"); } 126if ( $installer::globals::debug ) { installer::logger::debuginfo("\nPart 1a: The language independent part\n"); } 127 128installer::parameter::control_fundamental_parameter(); 129installer::parameter::setglobalvariables(); 130installer::parameter::control_required_parameter(); 131 132if (!($installer::globals::languages_defined_in_productlist)) { installer::languages::analyze_languagelist(); } 133installer::parameter::outputparameter(); 134 135installer::control::check_updatepack(); 136 137$installer::globals::build = uc($installer::globals::build); # using "SRC680" instead of "src680" 138 139###################################### 140# Creating the log directory 141###################################### 142 143my $loggingdir = installer::systemactions::create_directories("logging", ""); 144$loggingdir = $loggingdir . $installer::globals::separator; 145$installer::globals::exitlog = $loggingdir; 146 147my $installdir = ""; 148my $currentdir = cwd(); 149my $shipinstalldir = ""; 150my $current_install_number = ""; 151 152###################################### 153# Checking the system requirements 154###################################### 155 156installer::logger::print_message( "... checking required files ...\n" ); 157installer::control::check_system_path(); 158 159my $pathvariableshashref = installer::environment::create_pathvariables($environmentvariableshashref); 160 161############################################### 162# Checking saved setting for Windows patches 163############################################### 164 165if (( $installer::globals::iswindowsbuild ) && ( $installer::globals::prepare_winpatch )) { installer::windows::msiglobal::read_saved_mappings(); } 166 167################################################### 168# Analyzing the settings and variables in zip.lst 169################################################### 170 171installer::logger::globallog("zip list file: $installer::globals::ziplistname"); 172 173my $ziplistref = installer::files::read_file($installer::globals::ziplistname); 174 175installer::logger::print_message( "... analyzing $installer::globals::ziplistname ... \n" ); 176 177my ($productblockref, $parent) = installer::ziplist::getproductblock($ziplistref, $installer::globals::product, 1); # product block from zip.lst 178if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "productblock.log" ,$productblockref); } 179 180my ($settingsblockref, undef) = installer::ziplist::getproductblock($productblockref, "Settings", 0); # settings block from zip.lst 181if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "settingsblock1.log" ,$settingsblockref); } 182 183$settingsblockref = installer::ziplist::analyze_settings_block($settingsblockref); # select data from settings block in zip.lst 184if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "settingsblock2.log" ,$settingsblockref); } 185 186my $allsettingsarrayref = installer::ziplist::get_settings_from_ziplist($settingsblockref); 187if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "allsettings1.log" ,$allsettingsarrayref); } 188 189my $allvariablesarrayref = installer::ziplist::get_variables_from_ziplist($settingsblockref); 190if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "allvariables1.log" ,$allvariablesarrayref); } 191 192my ($globalproductblockref, undef) = installer::ziplist::getproductblock($ziplistref, $installer::globals::globalblock, 0); # global product block from zip.lst 193if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "globalproductblock.log" ,$globalproductblockref); } 194 195while (defined $parent) 196{ 197 my $parentproductblockref; 198 ($parentproductblockref, $parent) = installer::ziplist::getproductblock( 199 $ziplistref, $parent, 1); 200 my ($parentsettingsblockref, undef) = installer::ziplist::getproductblock( 201 $parentproductblockref, "Settings", 0); 202 $parentsettingsblockref = installer::ziplist::analyze_settings_block( 203 $parentsettingsblockref); 204 my $allparentsettingsarrayref = 205 installer::ziplist::get_settings_from_ziplist($parentsettingsblockref); 206 my $allparentvariablesarrayref = 207 installer::ziplist::get_variables_from_ziplist($parentsettingsblockref); 208 $allsettingsarrayref = 209 installer::converter::combine_arrays_from_references_first_win( 210 $allsettingsarrayref, $allparentsettingsarrayref) 211 if $#{$allparentsettingsarrayref} > -1; 212 $allvariablesarrayref = 213 installer::converter::combine_arrays_from_references_first_win( 214 $allvariablesarrayref, $allparentvariablesarrayref) 215 if $#{$allparentvariablesarrayref} > -1; 216} 217 218if ( $#{$globalproductblockref} > -1 ) 219{ 220 my ($globalsettingsblockref, undef) = installer::ziplist::getproductblock($globalproductblockref, "Settings", 0); # settings block from zip.lst 221 if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "globalsettingsblock1.log" ,$globalsettingsblockref); } 222 223 $globalsettingsblockref = installer::ziplist::analyze_settings_block($globalsettingsblockref); # select data from settings block in zip.lst 224 if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "globalsettingsblock2.log" ,$globalsettingsblockref); } 225 226 my $allglobalsettingsarrayref = installer::ziplist::get_settings_from_ziplist($globalsettingsblockref); 227 if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "allglobalsettings1.log" ,$allglobalsettingsarrayref); } 228 229 my $allglobalvariablesarrayref = installer::ziplist::get_variables_from_ziplist($globalsettingsblockref); 230 if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "allglobalvariables1.log" ,$allglobalvariablesarrayref); } 231 232 if ( $#{$allglobalsettingsarrayref} > -1 ) { $allsettingsarrayref = installer::converter::combine_arrays_from_references_first_win($allsettingsarrayref, $allglobalsettingsarrayref); } 233 if ( $#{$allglobalvariablesarrayref} > -1 ) { $allvariablesarrayref = installer::converter::combine_arrays_from_references_first_win($allvariablesarrayref, $allglobalvariablesarrayref); } 234} 235 236$allsettingsarrayref = installer::ziplist::remove_multiples_from_ziplist($allsettingsarrayref); # the settings from the zip.lst 237if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "allsettings2.log" ,$allsettingsarrayref); } 238 239$allvariablesarrayref = installer::ziplist::remove_multiples_from_ziplist($allvariablesarrayref); 240if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "allvariables2.log" ,$allvariablesarrayref); } 241 242installer::ziplist::replace_variables_in_ziplist_variables($allvariablesarrayref); 243if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "allvariables2a.log" ,$allvariablesarrayref); } 244 245my $allvariableshashref = installer::converter::convert_array_to_hash($allvariablesarrayref); # the variables from the zip.lst 246if ( $installer::globals::globallogging ) { installer::files::save_hash($loggingdir . "allvariables3.log", $allvariableshashref); } 247 248installer::ziplist::set_default_productversion_if_required($allvariableshashref); 249if ( $installer::globals::globallogging ) { installer::files::save_hash($loggingdir . "allvariables3a.log", $allvariableshashref); } 250 251installer::ziplist::add_variables_to_allvariableshashref($allvariableshashref); 252if ( $installer::globals::globallogging ) { installer::files::save_hash($loggingdir . "allvariables3b.log", $allvariableshashref); } 253 254installer::ziplist::overwrite_ooovendor( $allvariableshashref ); 255if ( $installer::globals::globallogging ) { installer::files::save_hash($loggingdir . "allvariables3c.log", $allvariableshashref); } 256 257######################################################## 258# Check if this is simple packaging mechanism 259######################################################## 260 261installer::simplepackage::check_simple_packager_project($allvariableshashref); 262 263#################################################################### 264# setting global variables 265#################################################################### 266 267installer::control::set_addchildprojects($allvariableshashref); 268installer::control::set_addjavainstaller($allvariableshashref); 269installer::control::set_addsystemintegration($allvariableshashref); 270 271######################################################## 272# Re-define logging dir, after all variables are set 273######################################################## 274 275my $oldloggingdir = $loggingdir; 276installer::systemactions::remove_empty_directory($oldloggingdir); 277$loggingdir = installer::systemactions::create_directories("logging", ""); 278$loggingdir = $loggingdir . $installer::globals::separator; 279$installer::globals::exitlog = $loggingdir; 280 281# checking, whether this is an opensource product 282 283if (!($installer::globals::is_copy_only_project)) { installer::ziplist::set_manufacturer($allvariableshashref); } 284 285############################################## 286# Checking version of makecab.exe 287############################################## 288 289if ( $installer::globals::iswindowsbuild ) { installer::control::check_makecab_version(); } 290 291########################################################## 292# Getting the include path from the settings in zip list 293########################################################## 294 295my $includepathref = installer::ziplist::getinfofromziplist($allsettingsarrayref, "include"); 296if ( $$includepathref eq "" ) 297{ 298 installer::exiter::exit_program("ERROR: Definition for \"include\" not found in $installer::globals::ziplistname", "Main"); 299} 300 301my $includepatharrayref = installer::converter::convert_stringlist_into_array($includepathref, ","); 302if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "allpatharray1.log" ,$includepatharrayref); } 303 304installer::ziplist::replace_all_variables_in_pathes($includepatharrayref, $pathvariableshashref); 305if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "allpatharray2.log" ,$includepatharrayref); } 306 307installer::ziplist::replace_minor_in_pathes($includepatharrayref); 308if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "allpatharray3.log" ,$includepatharrayref); } 309 310installer::ziplist::replace_packagetype_in_pathes($includepatharrayref); 311if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "allpatharray3a.log" ,$includepatharrayref); } 312 313installer::ziplist::resolve_relative_pathes($includepatharrayref); 314if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "allpatharray3b.log" ,$includepatharrayref); } 315 316installer::ziplist::remove_ending_separator($includepatharrayref); 317if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "allpatharray3c.log" ,$includepatharrayref); } 318 319############################################## 320# Collecting all files from all include 321# pathes in global hashes. 322############################################## 323 324installer::worker::collect_all_files_from_includepathes($includepatharrayref); 325 326############################################## 327# Analyzing languages in zip.lst if required 328# Probably no longer used. 329############################################## 330 331if ($installer::globals::languages_defined_in_productlist) { installer::languages::get_info_about_languages($allsettingsarrayref); } 332 333##################################### 334# Windows requires the encoding list 335##################################### 336 337if ( $installer::globals::iswindowsbuild ) { installer::control::read_encodinglist($includepatharrayref); } 338 339#################################################################### 340# MacOS dmg build requires special DS_Store file to arrange icons 341#################################################################### 342if (($installer::globals::ismacdmgbuild) && ($installer::globals::product eq "OpenOffice_Dev")) { $installer::globals::devsnapshotbuild = 1; } 343 344##################################################################### 345# Including additional inc files for variable settings, if defined 346##################################################################### 347 348if ( $allvariableshashref->{'ADD_INCLUDE_FILES'} ) { installer::worker::add_variables_from_inc_to_hashref($allvariableshashref, $includepatharrayref); } 349 350################################################ 351# Disable xpd installer, if SOLAR_JAVA not set 352################################################ 353 354installer::control::check_java_for_xpd($allvariableshashref); 355 356##################################### 357# Analyzing the setup script 358##################################### 359 360if ($installer::globals::setupscript_defined_in_productlist) { installer::setupscript::set_setupscript_name($allsettingsarrayref, $includepatharrayref); } 361 362installer::logger::globallog("setup script file: $installer::globals::setupscriptname"); 363 364installer::logger::print_message( "... analyzing script: $installer::globals::setupscriptname ... \n" ); 365 366my $setupscriptref = installer::files::read_file($installer::globals::setupscriptname); # Reading the setup script file 367 368# Resolving variables defined in the zip list file into setup script 369# All the variables are defined in $allvariablesarrayref 370 371installer::scpzipfiles::replace_all_ziplistvariables_in_file($setupscriptref, $allvariableshashref); 372if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "setupscript1.log" ,$setupscriptref); } 373 374# Resolving %variables defined in the installation object 375 376my $allscriptvariablesref = installer::setupscript::get_all_scriptvariables_from_installation_object($setupscriptref); 377if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "setupscriptvariables1.log" ,$allscriptvariablesref); } 378 379installer::setupscript::add_lowercase_productname_setupscriptvariable($allscriptvariablesref); 380if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "setupscriptvariables2.log" ,$allscriptvariablesref); } 381 382installer::setupscript::resolve_lowercase_productname_setupscriptvariable($allscriptvariablesref); 383if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "setupscriptvariables3.log" ,$allscriptvariablesref); } 384 385$setupscriptref = installer::setupscript::replace_all_setupscriptvariables_in_script($setupscriptref, $allscriptvariablesref); 386if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "setupscript2.log" ,$setupscriptref); } 387 388# Adding all variables defined in the installation object into the hash of all variables. 389# This is needed if variables are defined in the installation object, but not in the zip list file. 390# If there is a definition in the zip list file and in the installation object, the installation object is more important 391 392installer::setupscript::add_installationobject_to_variables($allvariableshashref, $allscriptvariablesref); 393if ( $installer::globals::globallogging ) { installer::files::save_hash($loggingdir . "allvariables4.log", $allvariableshashref); } 394 395# Adding also all variables, that must be included into the $allvariableshashref. 396installer::setupscript::add_forced_properties($allvariableshashref); 397if ( $installer::globals::globallogging ) { installer::files::save_hash($loggingdir . "allvariables5.log", $allvariableshashref); } 398 399# Replacing preset properties, not using the default mechanisms (for example for UNIXPRODUCTNAME) 400installer::setupscript::replace_preset_properties($allvariableshashref); 401if ( $installer::globals::globallogging ) { installer::files::save_hash($loggingdir . "allvariables6.log", $allvariableshashref); } 402 403installer::scpzipfiles::replace_all_ziplistvariables_in_file($setupscriptref, $allvariableshashref); 404if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "setupscript3.log" ,$setupscriptref); } 405 406 407installer::logger::log_hashref($allvariableshashref); 408 409installer::logger::print_message( "... analyzing directories ... \n" ); 410 411# Collect all directories in the script to get the destination dirs 412 413my $dirsinproductarrayref = installer::setupscript::get_all_items_from_script($setupscriptref, "Directory"); 414if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productdirectories1.log", $dirsinproductarrayref); } 415 416if ( $installer::globals::languagepack ) { installer::scriptitems::use_langpack_hostname($dirsinproductarrayref); } 417if ( $installer::globals::patch ) { installer::scriptitems::use_patch_hostname($dirsinproductarrayref); } 418if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productdirectories1a.log", $dirsinproductarrayref); } 419 420if ( $allvariableshashref->{'SHIFT_BASIS_INTO_BRAND_LAYER'} ) { $dirsinproductarrayref = installer::scriptitems::shift_basis_directory_parents($dirsinproductarrayref); } 421if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productdirectories1b.log", $dirsinproductarrayref); } 422if ( $allvariableshashref->{'OFFICEDIRECTORYNAME'} ) { installer::scriptitems::set_officedirectory_name($dirsinproductarrayref, $allvariableshashref->{'OFFICEDIRECTORYNAME'}); } 423if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productdirectories1b.log", $dirsinproductarrayref); } 424 425 426installer::scriptitems::resolve_all_directory_names($dirsinproductarrayref); 427if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productdirectories2.log", $dirsinproductarrayref); } 428 429installer::logger::print_message( "... analyzing files ... \n" ); 430 431my $filesinproductarrayref = installer::setupscript::get_all_items_from_script($setupscriptref, "File"); 432if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles1.log", $filesinproductarrayref); } 433 434$filesinproductarrayref = installer::scriptitems::remove_delete_only_files_from_productlists($filesinproductarrayref); 435if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles2.log", $filesinproductarrayref); } 436 437if (( ! $installer::globals::iswindowsbuild ) && 438 ( ! $installer::globals::islinuxrpmbuild ) && 439 ( ! $installer::globals::islinuxdebbuild ) && 440 ( ! $installer::globals::issolarispkgbuild ) && 441 ( $installer::globals::packageformat ne "installed" ) && 442 ( $installer::globals::packageformat ne "dmg" ) && 443 ( $installer::globals::packageformat ne "archive" )) 444 { installer::control::check_oxtfiles($filesinproductarrayref); } 445 446if ($installer::globals::product =~ /suite/i ) { $filesinproductarrayref = installer::scriptitems::remove_notinsuite_files_from_productlists($filesinproductarrayref); } 447if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles2aa.log", $filesinproductarrayref); } 448 449if (! $installer::globals::languagepack) 450{ 451 $filesinproductarrayref = installer::scriptitems::remove_Languagepacklibraries_from_Installset($filesinproductarrayref); 452 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles2b.log", $filesinproductarrayref); } 453} 454 455if (! $installer::globals::patch) 456{ 457 $filesinproductarrayref = installer::scriptitems::remove_patchonlyfiles_from_Installset($filesinproductarrayref); 458 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles2c.log", $filesinproductarrayref); } 459} 460 461if (! $installer::globals::tab) 462{ 463 $filesinproductarrayref = installer::scriptitems::remove_tabonlyfiles_from_Installset($filesinproductarrayref); 464 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles2c.log", $filesinproductarrayref); } 465} 466 467if (( $installer::globals::packageformat ne "installed" ) && ( $installer::globals::packageformat ne "archive" )) 468{ 469 $filesinproductarrayref = installer::scriptitems::remove_installedproductonlyfiles_from_Installset($filesinproductarrayref); 470 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles2cc.log", $filesinproductarrayref); } 471} 472 473installer::logger::print_message( "... analyzing scpactions ... \n" ); 474 475my $scpactionsinproductarrayref = installer::setupscript::get_all_items_from_script($setupscriptref, "ScpAction"); 476if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productscpactions1.log", $scpactionsinproductarrayref); } 477 478if (( ! $allvariableshashref->{'XPDINSTALLER'} ) || ( ! $installer::globals::isxpdplatform )) 479{ 480 $scpactionsinproductarrayref = installer::scriptitems::remove_Xpdonly_Items($scpactionsinproductarrayref); 481 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productscpactions1a.log", $scpactionsinproductarrayref); } 482} 483 484if ( $installer::globals::languagepack ) { installer::scriptitems::use_langpack_copy_scpaction($scpactionsinproductarrayref); } 485if ( $installer::globals::patch ) { installer::scriptitems::use_patch_copy_scpaction($scpactionsinproductarrayref); } 486if (($installer::globals::devsnapshotbuild)) { installer::scriptitems::use_dev_copy_scpaction($scpactionsinproductarrayref); } 487if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productscpactions1b.log", $scpactionsinproductarrayref); } 488 489# $scpactionsinproductarrayref = installer::scriptitems::remove_scpactions_without_name($scpactionsinproductarrayref); 490# if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productscpactions2.log", $scpactionsinproductarrayref); } 491 492installer::scriptitems::change_keys_of_scpactions($scpactionsinproductarrayref); 493if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productscpactions2.log", $scpactionsinproductarrayref); } 494 495installer::logger::print_message( "... analyzing shortcuts ... \n" ); 496 497my $linksinproductarrayref = installer::setupscript::get_all_items_from_script($setupscriptref, "Shortcut"); 498if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productlinks1.log", $linksinproductarrayref); } 499 500installer::logger::print_message( "... analyzing unix links ... \n" ); 501 502my $unixlinksinproductarrayref = installer::setupscript::get_all_items_from_script($setupscriptref, "Unixlink"); 503if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "unixlinks1.log", $unixlinksinproductarrayref); } 504 505# $unixlinksinproductarrayref = installer::scriptitems::filter_layerlinks_from_unixlinks($unixlinksinproductarrayref); 506# if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "unixlinks1b.log", $unixlinksinproductarrayref); } 507 508installer::logger::print_message( "... analyzing profile ... \n" ); 509 510my $profilesinproductarrayref = installer::setupscript::get_all_items_from_script($setupscriptref, "Profile"); 511if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "profiles1.log", $profilesinproductarrayref); } 512 513installer::logger::print_message( "... analyzing profileitems ... \n" ); 514 515my $profileitemsinproductarrayref = installer::setupscript::get_all_items_from_script($setupscriptref, "ProfileItem"); 516if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "profileitems1.log", $profileitemsinproductarrayref); } 517 518my $folderinproductarrayref; 519my $folderitemsinproductarrayref; 520my $registryitemsinproductarrayref; 521my $windowscustomactionsarrayref; 522my $mergemodulesarrayref; 523 524if ( $installer::globals::iswindowsbuild ) # Windows specific items: Folder, FolderItem, RegistryItem, WindowsCustomAction 525{ 526 installer::logger::print_message( "... analyzing folders ... \n" ); 527 528 $folderinproductarrayref = installer::setupscript::get_all_items_from_script($setupscriptref, "Folder"); 529 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "folder1.log", $folderinproductarrayref); } 530 531 installer::logger::print_message( "... analyzing folderitems ... \n" ); 532 533 $folderitemsinproductarrayref = installer::setupscript::get_all_items_from_script($setupscriptref, "FolderItem"); 534 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "folderitems1.log", $folderitemsinproductarrayref); } 535 536 installer::setupscript::add_predefined_folder($folderitemsinproductarrayref, $folderinproductarrayref); 537 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "folder1b.log", $folderinproductarrayref); } 538 539 installer::setupscript::prepare_non_advertised_files($folderitemsinproductarrayref, $filesinproductarrayref); 540 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles2d.log", $filesinproductarrayref); } 541 542 installer::logger::print_message( "... analyzing registryitems ... \n" ); 543 544 $registryitemsinproductarrayref = installer::setupscript::get_all_items_from_script($setupscriptref, "RegistryItem"); 545 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "registryitems1.log", $registryitemsinproductarrayref); } 546 547 $registryitemsinproductarrayref = installer::scriptitems::remove_uninstall_regitems_from_script($registryitemsinproductarrayref); 548 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "registryitems1b.log", $registryitemsinproductarrayref); } 549 550 installer::logger::print_message( "... analyzing Windows custom actions ... \n" ); 551 552 $windowscustomactionsarrayref = installer::setupscript::get_all_items_from_script($setupscriptref, "WindowsCustomAction"); 553 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "windowscustomactions1.log", $windowscustomactionsarrayref); } 554 555 installer::logger::print_message( "... analyzing Windows merge modules ... \n" ); 556 557 $mergemodulesarrayref = installer::setupscript::get_all_items_from_script($setupscriptref, "MergeModule"); 558 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "mergemodules1.log", $mergemodulesarrayref); } 559} 560 561my $modulesinproductarrayref; 562 563if (!($installer::globals::is_copy_only_project)) 564{ 565 installer::logger::print_message( "... analyzing modules ... \n" ); 566 567 $modulesinproductarrayref = installer::setupscript::get_all_items_from_script($setupscriptref, "Module"); 568 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "modules1.log", $modulesinproductarrayref); } 569 570 if (( ! $allvariableshashref->{'XPDINSTALLER'} ) || ( ! $installer::globals::isxpdplatform )) 571 { 572 $modulesinproductarrayref = installer::scriptitems::remove_Xpdonly_Items($modulesinproductarrayref); 573 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "modules1a.log", $modulesinproductarrayref); } 574 } 575 576 installer::scriptitems::resolve_assigned_modules($modulesinproductarrayref); 577 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "modules1b.log", $modulesinproductarrayref); } 578 579 $modulesinproductarrayref = installer::scriptitems::remove_template_modules($modulesinproductarrayref); 580 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "modules1c.log", $modulesinproductarrayref); } 581 582 installer::scriptitems::set_children_flag($modulesinproductarrayref); 583 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "modules1d.log", $modulesinproductarrayref); } 584 585 installer::scriptitems::collect_all_languagemodules($modulesinproductarrayref); 586 587 # Assigning the modules to the items 588 589 installer::scriptitems::assigning_modules_to_items($modulesinproductarrayref, $filesinproductarrayref, "Files"); 590 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles3.log", $filesinproductarrayref); } 591 592 installer::scriptitems::assigning_modules_to_items($modulesinproductarrayref, $unixlinksinproductarrayref, "Unixlinks"); 593 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "unixlinks2.log", $unixlinksinproductarrayref); } 594 595 installer::scriptitems::assigning_modules_to_items($modulesinproductarrayref, $dirsinproductarrayref, "Dirs"); 596 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productdirectories2aa.log", $dirsinproductarrayref); } 597} 598 599if ( $installer::globals::debug ) { installer::logger::debuginfo("\nEnd of part 1a: The language independent part\n"); } 600 601# saving debug info, before staring part 1b 602if ( $installer::globals::debug ) { installer::logger::savedebug($installer::globals::exitlog); } 603 604################################################# 605# Part 1b: The language dependent part 606# (still platform independent) 607################################################# 608 609# Now starts the language dependent part, if more than one product is defined on the command line 610# Example -l en-US,de#es,fr,it defines two multilingual products 611 612############################################################################### 613# Beginning of language dependent part 614# The for iterates over all products, separated by an # in the language list 615############################################################################### 616 617if ( $installer::globals::debug ) { installer::logger::debuginfo("\nPart 1b: The language dependent part\n"); } 618 619for ( my $n = 0; $n <= $#installer::globals::languageproducts; $n++ ) 620{ 621 my $languagesarrayref = installer::languages::get_all_languages_for_one_product($installer::globals::languageproducts[$n], $allvariableshashref); 622 if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "languages.log" ,$languagesarrayref); } 623 624 $installer::globals::alllanguagesinproductarrayref = $languagesarrayref; 625 my $languagestringref = installer::languages::get_language_string($languagesarrayref); 626 installer::logger::print_message( "------------------------------------\n" ); 627 installer::logger::print_message( "... languages $$languagestringref ... \n" ); 628 629 if ( $installer::globals::patch ) 630 { 631 $installer::globals::addlicensefile = 0; # no license files for patches 632 $installer::globals::makedownload = 0; 633 $installer::globals::makejds = 0; 634 } 635 636 if ( $installer::globals::languagepack ) 637 { 638 $installer::globals::addchildprojects = 0; 639 $installer::globals::addsystemintegration = 0; 640 $installer::globals::makejds = 0; 641 $installer::globals::addlicensefile = 0; 642 643 if ( $allvariableshashref->{'OPENSOURCE'} ) { $installer::globals::makedownload = 1; } 644 else { $installer::globals::makedownload = 0; } 645 } 646 647 ############################################################ 648 # Beginning of language specific logging mechanism 649 # Until now only global logging into default: logfile.txt 650 ############################################################ 651 652 @installer::globals::logfileinfo = (); # new logfile array and new logfile name 653 installer::logger::copy_globalinfo_into_logfile(); 654 $installer::globals::globalinfo_copied = 1; 655 656 my $logminor = ""; 657 if ( $installer::globals::updatepack ) { $logminor = $installer::globals::lastminor; } 658 else { $logminor = $installer::globals::minor; } 659 660 my $loglanguagestring = $$languagestringref; 661 my $loglanguagestring_orig = $loglanguagestring; 662 if (length($loglanguagestring) > $installer::globals::max_lang_length) 663 { 664 my $number_of_languages = installer::systemactions::get_number_of_langs($loglanguagestring); 665 chomp(my $shorter = `echo $loglanguagestring | md5sum | sed -e "s/ .*//g"`); 666 my $id = substr($shorter, 0, 8); # taking only the first 8 digits 667 $loglanguagestring = "lang_" . $number_of_languages . "_id_" . $id; 668 } 669 670 $installer::globals::logfilename = "log_" . $installer::globals::build; 671 if ( $logminor ne "" ) { $installer::globals::logfilename .= "_" . $logminor; } 672 $installer::globals::logfilename .= "_" . $loglanguagestring; 673 $installer::globals::logfilename .= ".log"; 674 $loggingdir = $loggingdir . $loglanguagestring . $installer::globals::separator; 675 installer::systemactions::create_directory($loggingdir); 676 677 if ($loglanguagestring ne $loglanguagestring_orig) { 678 (my $dir = $loggingdir) =~ s!/$!!; 679 open(my $F1, "> $dir.dir"); 680 open(my $F2, "> " . $loggingdir . $installer::globals::logfilename . '.file'); 681 my @s = map { "$_\n" } split('_', $loglanguagestring_orig); 682 print $F1 @s; 683 print $F2 @s; 684 } 685 686 $installer::globals::exitlog = $loggingdir; 687 688 ############################################################## 689 # Determining the ship location, if this is an update pack 690 ############################################################## 691 692 if ( $installer::globals::updatepack ) { $shipinstalldir = installer::control::determine_ship_directory($languagestringref); } 693 694 ################################################################### 695 # Reading an existing msi database, to prepare update and patch 696 ################################################################### 697 698 my $refdatabase = ""; 699 my $uniquefilename = ""; 700 my $revuniquefilename = ""; 701 my $revshortfilename = ""; 702 my $allupdatesequences = ""; 703 my $allupdatecomponents = ""; 704 my $allupdatefileorder = ""; 705 my $allupdatecomponentorder = ""; 706 my $shortdirname = ""; 707 my $componentid = ""; 708 my $componentidkeypath = ""; 709 my $alloldproperties = ""; 710 my $allupdatelastsequences = ""; 711 my $allupdatediskids = ""; 712 713 if ( $installer::globals::iswindowsbuild ) 714 { 715 if ( $allvariableshashref->{'UPDATE_DATABASE'} ) 716 { 717 installer::logger::print_message( "... analyzing update database ...\n" ); 718 $refdatabase = installer::windows::update::readdatabase($allvariableshashref, $languagestringref, $includepatharrayref); 719 720 if ( $installer::globals::updatedatabase ) 721 { 722 ($uniquefilename, $revuniquefilename, $revshortfilename, $allupdatesequences, $allupdatecomponents, $allupdatefileorder, $allupdatecomponentorder, $shortdirname, $componentid, $componentidkeypath, $alloldproperties, $allupdatelastsequences, $allupdatediskids) = installer::windows::update::create_database_hashes($refdatabase); 723 if ( $mergemodulesarrayref > -1 ) { installer::windows::update::readmergedatabase($mergemodulesarrayref, $languagestringref, $includepatharrayref); } 724 } 725 } 726 } 727 728 ############################################## 729 # Setting global code variables for Windows 730 ############################################## 731 732 if (!($installer::globals::is_copy_only_project)) 733 { 734 if (( $installer::globals::iswindowsbuild ) && ( $installer::globals::packageformat ne "archive" ) && ( $installer::globals::packageformat ne "installed" )) 735 { 736 installer::windows::msiglobal::set_global_code_variables($languagesarrayref, $languagestringref, $allvariableshashref, $alloldproperties); 737 } 738 } 739 740 ################################################ 741 # Resolving include paths (language dependent) 742 ################################################ 743 744 $includepatharrayref_lang = installer::ziplist::replace_languages_in_pathes($includepatharrayref, $languagesarrayref); 745 if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "allpatharray4.log" ,$includepatharrayref_lang); } 746 747 if ( $installer::globals::refresh_includepathes ) { installer::worker::collect_all_files_from_includepathes($includepatharrayref_lang); } 748 749 installer::ziplist::list_all_files_from_include_path($includepatharrayref_lang); 750 751 ############################################## 752 # Analyzing spellchecker languages 753 ############################################## 754 755 if ( $allvariableshashref->{'SPELLCHECKERFILE'} ) { installer::worker::set_spellcheckerlanguages($languagesarrayref, $allvariableshashref); } 756 757 ##################################### 758 # Language dependent directory part 759 ##################################### 760 761 my $dirsinproductlanguageresolvedarrayref = installer::scriptitems::resolving_all_languages_in_productlists($dirsinproductarrayref, $languagesarrayref); 762 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productdirectories3.log", $dirsinproductlanguageresolvedarrayref); } 763 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productdirectories2a.log", $dirsinproductarrayref); } 764 765 # A new directory array is needed ($dirsinproductlanguageresolvedarrayref instead of $dirsinproductarrayref) 766 # because $dirsinproductarrayref is needed in get_Destination_Directory_For_Item_From_Directorylist 767 768 installer::scriptitems::changing_name_of_language_dependent_keys($dirsinproductlanguageresolvedarrayref); 769 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productdirectories4.log", $dirsinproductlanguageresolvedarrayref); } 770 771 installer::scriptitems::checking_directories_with_corrupt_hostname($dirsinproductlanguageresolvedarrayref, $languagesarrayref); 772 773 installer::scriptitems::set_global_directory_hostnames($dirsinproductlanguageresolvedarrayref, $allvariableshashref); 774 775 ##################################### 776 # files part, language dependent 777 ##################################### 778 779 installer::logger::print_message( "... analyzing files ...\n" ); 780 781 my $filesinproductlanguageresolvedarrayref = installer::scriptitems::resolving_all_languages_in_productlists($filesinproductarrayref, $languagesarrayref); 782 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles4.log", $filesinproductlanguageresolvedarrayref); } 783 784 if ( ! $installer::globals::set_office_start_language ) 785 { 786 $filesinproductlanguageresolvedarrayref = installer::scriptitems::remove_office_start_language_files($filesinproductlanguageresolvedarrayref); 787 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles4b.log", $filesinproductlanguageresolvedarrayref); } 788 } 789 790 installer::scriptitems::changing_name_of_language_dependent_keys($filesinproductlanguageresolvedarrayref); 791 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles5.log", $filesinproductlanguageresolvedarrayref); } 792 793 if ( $installer::globals::iswin and $^O =~ /MSWin/i ) { installer::converter::convert_slash_to_backslash($filesinproductlanguageresolvedarrayref); } 794 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles6.log", $filesinproductlanguageresolvedarrayref); } 795 796 $filesinproductlanguageresolvedarrayref = installer::scriptitems::remove_non_existent_languages_in_productlists($filesinproductlanguageresolvedarrayref, $languagestringref, "Name", "file"); 797 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles7.log", $filesinproductlanguageresolvedarrayref); } 798 799 installer::scriptitems::get_Destination_Directory_For_Item_From_Directorylist($filesinproductlanguageresolvedarrayref, $dirsinproductarrayref); 800 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles8.log", $filesinproductlanguageresolvedarrayref); } 801 802 installer::scriptitems::get_Source_Directory_For_Files_From_Includepathlist($filesinproductlanguageresolvedarrayref, $includepatharrayref_lang, $dirsinproductlanguageresolvedarrayref, "Files"); 803 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles9.log", $filesinproductlanguageresolvedarrayref); } 804 805 $filesinproductlanguageresolvedarrayref = installer::scriptitems::remove_Files_Without_Sourcedirectory($filesinproductlanguageresolvedarrayref); 806 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles10.log", $filesinproductlanguageresolvedarrayref); } 807 808 if ($installer::globals::languagepack) 809 { 810 $filesinproductlanguageresolvedarrayref = installer::scriptitems::remove_Files_For_Languagepacks($filesinproductlanguageresolvedarrayref); 811 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles10c.log", $filesinproductlanguageresolvedarrayref); } 812 } 813 814 815 if ( ! $allvariableshashref->{'NO_README_IN_ROOTDIR'} ) 816 { 817 $filesinproductlanguageresolvedarrayref = installer::scriptitems::add_License_Files_into_Installdir($filesinproductlanguageresolvedarrayref, $dirsinproductlanguageresolvedarrayref, $languagesarrayref); 818 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles10b.log", $filesinproductlanguageresolvedarrayref); } 819 } 820 821 $filesinproductlanguageresolvedarrayref = installer::scriptitems::remove_onlyasialanguage_files_from_productlists($filesinproductlanguageresolvedarrayref); 822 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles10d.log", $filesinproductlanguageresolvedarrayref); } 823 824 $filesinproductlanguageresolvedarrayref = installer::scriptitems::remove_onlywesternlanguage_files_from_productlists($filesinproductlanguageresolvedarrayref); 825 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles10e.log", $filesinproductlanguageresolvedarrayref); } 826 827 installer::scriptitems::make_filename_language_specific($filesinproductlanguageresolvedarrayref); 828 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles10f.log", $filesinproductlanguageresolvedarrayref); } 829 830 # print "... calculating checksums ...\n"; 831 # my $checksumfile = installer::worker::make_checksum_file($filesinproductlanguageresolvedarrayref, $includepatharrayref); 832 # if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . $installer::globals::checksumfilename, $checksumfile); } 833 834 ###################################################################################### 835 # Unzipping files with flag ARCHIVE and putting all included files into the file list 836 ###################################################################################### 837 838 installer::logger::print_message( "... analyzing files with flag ARCHIVE ...\n" ); 839 840 my @additional_paths_from_zipfiles = (); 841 842 $filesinproductlanguageresolvedarrayref = installer::archivefiles::resolving_archive_flag($filesinproductlanguageresolvedarrayref, \@additional_paths_from_zipfiles, $languagestringref, $loggingdir); 843 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles11.log", $filesinproductlanguageresolvedarrayref); } 844 if ( $installer::globals::globallogging ) { installer::files::save_file($loggingdir . "additional_paths.log" ,\@additional_paths_from_zipfiles); } 845 846 # packed files sometimes contain a "$" in their name: HighlightText$1.class. For epm the "$" has to be quoted by "$$" 847 848 if (!( $installer::globals::iswindowsbuild || $installer::globals::simple ) ) 849 { 850 installer::scriptitems::quoting_illegal_filenames($filesinproductlanguageresolvedarrayref); 851 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles12.log", $filesinproductlanguageresolvedarrayref); } 852 } 853 854 ##################################### 855 # Files with flag SUBST_FILENAME 856 ##################################### 857 858 installer::logger::print_message( "... analyzing files with flag SUBST_FILENAME ...\n" ); 859 860 installer::substfilenamefiles::resolving_subst_filename_flag($filesinproductlanguageresolvedarrayref, $allvariableshashref, $languagestringref); 861 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles12d.log", $filesinproductlanguageresolvedarrayref); } 862 863 ##################################### 864 # Files with flag SCPZIP_REPLACE 865 ##################################### 866 867 installer::logger::print_message( "... analyzing files with flag SCPZIP_REPLACE ...\n" ); 868 869 # Editing files with flag SCPZIP_REPLACE. 870 871 installer::scpzipfiles::resolving_scpzip_replace_flag($filesinproductlanguageresolvedarrayref, $allvariableshashref, "File", $languagestringref); 872 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles13.log", $filesinproductlanguageresolvedarrayref); } 873 874 ##################################### 875 # Files with flag PATCH_SO_NAME 876 ##################################### 877 878 installer::logger::print_message( "... analyzing files with flag PATCH_SO_NAME ...\n" ); 879 880 # Editing files with flag PATCH_SO_NAME. 881 882 installer::scppatchsoname::resolving_patchsoname_flag($filesinproductlanguageresolvedarrayref, $allvariableshashref, "File", $languagestringref); 883 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles13b.log", $filesinproductlanguageresolvedarrayref); } 884 885 ##################################### 886 # Files with flag HIDDEN 887 ##################################### 888 889 installer::logger::print_message( "... analyzing files with flag HIDDEN ...\n" ); 890 891 installer::worker::resolving_hidden_flag($filesinproductlanguageresolvedarrayref, $allvariableshashref, "File", $languagestringref); 892 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles13c.log", $filesinproductlanguageresolvedarrayref); } 893 894 ############################################ 895 # Collecting directories for epm list file 896 ############################################ 897 898 installer::logger::print_message( "... analyzing all directories for this product ...\n" ); 899 900 # There are two ways for a directory to be included into the epm directory list: 901 # 1. Looking for all destination paths in the files array 902 # 2. Looking for directories with CREATE flag in the directory array 903 # Advantage: Many pathes are hidden in zip files, they are not defined in the setup script. 904 # It will be possible, that in the setup script only those directoies have to be defined, 905 # that have a CREATE flag. All other directories are created, if they contain at least one file. 906 907 my ($directoriesforepmarrayref, $alldirectoryhash) = installer::scriptitems::collect_directories_from_filesarray($filesinproductlanguageresolvedarrayref); 908 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "directoriesforepmlist1.log", $directoriesforepmarrayref); } 909 910 ($directoriesforepmarrayref, $alldirectoryhash) = installer::scriptitems::collect_directories_with_create_flag_from_directoryarray($dirsinproductlanguageresolvedarrayref, $alldirectoryhash); 911 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "directoriesforepmlist2.log", $directoriesforepmarrayref); } 912 913 # installer::sorter::sorting_array_of_hashes($directoriesforepmarrayref, "HostName"); 914 # if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "directoriesforepmlist3.log", $directoriesforepmarrayref); } 915 916 ######################################################### 917 # language dependent scpactions part 918 ######################################################### 919 920 my $scpactionsinproductlanguageresolvedarrayref = installer::scriptitems::resolving_all_languages_in_productlists($scpactionsinproductarrayref, $languagesarrayref); 921 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productscpactions3.log", $scpactionsinproductlanguageresolvedarrayref); } 922 923 installer::scriptitems::changing_name_of_language_dependent_keys($scpactionsinproductlanguageresolvedarrayref); 924 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productscpactions4.log", $scpactionsinproductlanguageresolvedarrayref); } 925 926 installer::scriptitems::get_Source_Directory_For_Files_From_Includepathlist($scpactionsinproductlanguageresolvedarrayref, $includepatharrayref_lang, $dirsinproductlanguageresolvedarrayref, "ScpActions"); 927 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productscpactions5.log", $scpactionsinproductlanguageresolvedarrayref); } 928 929 # Editing scpactions with flag SCPZIP_REPLACE and PATCH_SO_NAME. 930 931 installer::scpzipfiles::resolving_scpzip_replace_flag($scpactionsinproductlanguageresolvedarrayref, $allvariableshashref, "ScpAction", $languagestringref); 932 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productscpactions6.log", $scpactionsinproductlanguageresolvedarrayref); } 933 934 installer::scppatchsoname::resolving_patchsoname_flag($scpactionsinproductlanguageresolvedarrayref, $allvariableshashref, "ScpAction", $languagestringref); 935 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productscpactions6a.log", $scpactionsinproductlanguageresolvedarrayref); } 936 937 ######################################################### 938 # language dependent links part 939 ######################################################### 940 941 installer::logger::print_message( "... analyzing links ...\n" ); 942 943 my $linksinproductlanguageresolvedarrayref = installer::scriptitems::resolving_all_languages_in_productlists($linksinproductarrayref, $languagesarrayref); 944 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productlinks2.log", $linksinproductlanguageresolvedarrayref); } 945 946 installer::scriptitems::changing_name_of_language_dependent_keys($linksinproductlanguageresolvedarrayref); 947 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productlinks3.log", $linksinproductlanguageresolvedarrayref); } 948 949 installer::scriptitems::get_destination_file_path_for_links($linksinproductlanguageresolvedarrayref, $filesinproductlanguageresolvedarrayref); 950 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productlinks4.log", $linksinproductlanguageresolvedarrayref); } 951 952 installer::scriptitems::get_Destination_Directory_For_Item_From_Directorylist($linksinproductlanguageresolvedarrayref, $dirsinproductarrayref); 953 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productlinks5.log", $linksinproductlanguageresolvedarrayref); } 954 955 # Now taking all links that have no FileID but a ShortcutID, linking to another link 956 957 installer::scriptitems::get_destination_link_path_for_links($linksinproductlanguageresolvedarrayref); 958 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productlinks6.log", $linksinproductlanguageresolvedarrayref); } 959 960 $linksinproductlanguageresolvedarrayref = installer::scriptitems::remove_workstation_only_items($linksinproductlanguageresolvedarrayref); 961 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productlinks7.log", $linksinproductlanguageresolvedarrayref); } 962 963 installer::scriptitems::resolve_links_with_flag_relative($linksinproductlanguageresolvedarrayref); 964 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productlinks8.log", $linksinproductlanguageresolvedarrayref); } 965 966 ######################################################### 967 # language dependent unix links part 968 ######################################################### 969 970 installer::logger::print_message( "... analyzing unix links ...\n" ); 971 972 my $unixlinksinproductlanguageresolvedarrayref = installer::scriptitems::resolving_all_languages_in_productlists($unixlinksinproductarrayref, $languagesarrayref); 973 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "unixlinks3.log", $unixlinksinproductlanguageresolvedarrayref); } 974 975 installer::scriptitems::changing_name_of_language_dependent_keys($unixlinksinproductlanguageresolvedarrayref); 976 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "unixlinks4.log", $unixlinksinproductlanguageresolvedarrayref); } 977 978 installer::scriptitems::get_Destination_Directory_For_Item_From_Directorylist($unixlinksinproductlanguageresolvedarrayref, $dirsinproductarrayref); 979 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "unixlinks5.log", $unixlinksinproductlanguageresolvedarrayref); } 980 981 ######################################################### 982 # language dependent part for profiles and profileitems 983 ######################################################### 984 985 my $profilesinproductlanguageresolvedarrayref; 986 my $profileitemsinproductlanguageresolvedarrayref; 987 988 if ((!($installer::globals::is_copy_only_project)) && (!($installer::globals::product =~ /ada/i )) && (!($installer::globals::languagepack))) 989 { 990 installer::logger::print_message( "... creating profiles ...\n" ); 991 992 $profilesinproductlanguageresolvedarrayref = installer::scriptitems::resolving_all_languages_in_productlists($profilesinproductarrayref, $languagesarrayref); 993 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "profiles2.log", $profilesinproductlanguageresolvedarrayref); } 994 995 $profileitemsinproductlanguageresolvedarrayref = installer::scriptitems::resolving_all_languages_in_productlists($profileitemsinproductarrayref, $languagesarrayref); 996 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "profileitems2.log", $profilesinproductlanguageresolvedarrayref); } 997 998 installer::scriptitems::changing_name_of_language_dependent_keys($profilesinproductlanguageresolvedarrayref); 999 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "profiles3.log", $profilesinproductlanguageresolvedarrayref); } 1000 1001 installer::scriptitems::changing_name_of_language_dependent_keys($profileitemsinproductlanguageresolvedarrayref); 1002 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "profileitems3.log", $profileitemsinproductlanguageresolvedarrayref); } 1003 1004 installer::scriptitems::replace_setup_variables($profileitemsinproductlanguageresolvedarrayref, $languagestringref, $allvariableshashref); 1005 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "profileitems4.log", $profileitemsinproductlanguageresolvedarrayref); } 1006 1007 if ( $installer::globals::patch_user_dir ) 1008 { 1009 installer::scriptitems::replace_userdir_variable($profileitemsinproductlanguageresolvedarrayref); 1010 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "profileitems4a.log", $profileitemsinproductlanguageresolvedarrayref); } 1011 } 1012 1013 installer::scriptitems::get_Destination_Directory_For_Item_From_Directorylist($profilesinproductlanguageresolvedarrayref, $dirsinproductarrayref); 1014 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "profiles4.log", $profilesinproductlanguageresolvedarrayref); } 1015 1016 # Now the Profiles can be created 1017 1018 installer::profiles::create_profiles($profilesinproductlanguageresolvedarrayref, $profileitemsinproductlanguageresolvedarrayref, $filesinproductlanguageresolvedarrayref, $languagestringref, $allvariableshashref); 1019 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles15.log", $filesinproductlanguageresolvedarrayref); } 1020 } 1021 1022 my $registryitemsinproductlanguageresolvedarrayref; # cannot be defined in the following "if ( $installer::globals::iswindowsbuild )" 1023 my $folderinproductlanguageresolvedarrayref; # cannot be defined in the following "if ( $installer::globals::iswindowsbuild )" 1024 my $folderitemsinproductlanguageresolvedarrayref; # cannot be defined in the following "if ( $installer::globals::iswindowsbuild )" 1025 1026 if ( $installer::globals::iswindowsbuild ) # Windows specific items: Folder, FolderItem, RegistryItem 1027 { 1028 ######################################################### 1029 # language dependent part for folder 1030 ######################################################### 1031 1032 installer::logger::print_message( "... analyzing folder ...\n" ); 1033 1034 $folderinproductlanguageresolvedarrayref = installer::scriptitems::resolving_all_languages_in_productlists($folderinproductarrayref, $languagesarrayref); 1035 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "folder2.log", $folderinproductlanguageresolvedarrayref); } 1036 1037 installer::scriptitems::changing_name_of_language_dependent_keys($folderinproductlanguageresolvedarrayref); 1038 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "folder3.log", $folderinproductlanguageresolvedarrayref); } 1039 1040 ######################################################### 1041 # language dependent part for folderitems 1042 ######################################################### 1043 1044 installer::logger::print_message( "... analyzing folderitems ...\n" ); 1045 1046 $folderitemsinproductlanguageresolvedarrayref = installer::scriptitems::resolving_all_languages_in_productlists($folderitemsinproductarrayref, $languagesarrayref); 1047 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "folderitems2.log", $folderitemsinproductlanguageresolvedarrayref); } 1048 1049 installer::scriptitems::changing_name_of_language_dependent_keys($folderitemsinproductlanguageresolvedarrayref); 1050 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "folderitems3.log", $folderitemsinproductlanguageresolvedarrayref); } 1051 1052 ######################################################### 1053 # language dependent part for registryitems 1054 ######################################################### 1055 1056 installer::logger::print_message( "... analyzing registryitems ...\n" ); 1057 1058 $registryitemsinproductlanguageresolvedarrayref = installer::scriptitems::resolving_all_languages_in_productlists($registryitemsinproductarrayref, $languagesarrayref); 1059 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "registryitems2.log", $registryitemsinproductlanguageresolvedarrayref); } 1060 1061 installer::scriptitems::changing_name_of_language_dependent_keys($registryitemsinproductlanguageresolvedarrayref); 1062 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "registryitems3.log", $registryitemsinproductlanguageresolvedarrayref); } 1063 } 1064 1065 ######################################################### 1066 # language dependent part for modules 1067 ######################################################### 1068 1069 my $modulesinproductlanguageresolvedarrayref; 1070 1071 if (!($installer::globals::is_copy_only_project)) 1072 { 1073 installer::logger::print_message( "... analyzing modules ...\n" ); 1074 1075 $modulesinproductlanguageresolvedarrayref = installer::scriptitems::resolving_all_languages_in_productlists($modulesinproductarrayref, $languagesarrayref); 1076 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes_modules($loggingdir . "modules2.log", $modulesinproductlanguageresolvedarrayref); } 1077 1078 $modulesinproductlanguageresolvedarrayref = installer::scriptitems::remove_not_required_language_modules($modulesinproductlanguageresolvedarrayref, $languagesarrayref); 1079 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes_modules($loggingdir . "modules2a.log", $modulesinproductlanguageresolvedarrayref); } 1080 1081 if ( $installer::globals::analyze_spellcheckerlanguage ) 1082 { 1083 $modulesinproductlanguageresolvedarrayref = installer::scriptitems::remove_not_required_spellcheckerlanguage_modules($modulesinproductlanguageresolvedarrayref); 1084 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes_modules($loggingdir . "modules3.log", $modulesinproductlanguageresolvedarrayref); } 1085 1086 $filesinproductlanguageresolvedarrayref = installer::scriptitems::remove_not_required_spellcheckerlanguage_files($filesinproductlanguageresolvedarrayref); 1087 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles15b.log", $filesinproductlanguageresolvedarrayref); } 1088 } 1089 1090 installer::scriptitems::changing_name_of_language_dependent_keys($modulesinproductlanguageresolvedarrayref); 1091 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes_modules($loggingdir . "modules3a.log", $modulesinproductlanguageresolvedarrayref); } 1092 1093 # installer::scriptitems::collect_language_specific_names($modulesinproductlanguageresolvedarrayref); 1094 installer::scriptitems::select_required_language_strings($modulesinproductlanguageresolvedarrayref); # using english strings 1095 1096 } 1097 1098 # Copy-only projects can now start to copy all items File and ScpAction 1099 if ( $installer::globals::is_copy_only_project ) { installer::copyproject::copy_project($filesinproductlanguageresolvedarrayref, $scpactionsinproductlanguageresolvedarrayref, $loggingdir, $languagestringref, $shipinstalldir, $allsettingsarrayref); } 1100 1101 # Language pack projects can now start to select the required information 1102 if ( $installer::globals::languagepack ) 1103 { 1104 $filesinproductlanguageresolvedarrayref = installer::languagepack::select_language_items($filesinproductlanguageresolvedarrayref, $languagesarrayref, "File"); 1105 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles16b.log", $filesinproductlanguageresolvedarrayref); } 1106 $scpactionsinproductlanguageresolvedarrayref = installer::languagepack::select_language_items($scpactionsinproductlanguageresolvedarrayref, $languagesarrayref, "ScpAction"); 1107 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productscpactions6b.log", $scpactionsinproductlanguageresolvedarrayref); } 1108 $linksinproductlanguageresolvedarrayref = installer::languagepack::select_language_items($linksinproductlanguageresolvedarrayref, $languagesarrayref, "Shortcut"); 1109 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productlinks8b.log", $linksinproductlanguageresolvedarrayref); } 1110 $unixlinksinproductlanguageresolvedarrayref = installer::languagepack::select_language_items($unixlinksinproductlanguageresolvedarrayref, $languagesarrayref, "Unixlink"); 1111 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "unixlinks5.log", $unixlinksinproductlanguageresolvedarrayref); } 1112 @{$folderitemsinproductlanguageresolvedarrayref} = (); # no folderitems in languagepacks 1113 1114 # Collecting the directories again, to include only the language specific directories 1115 ($directoriesforepmarrayref, $alldirectoryhash) = installer::scriptitems::collect_directories_from_filesarray($filesinproductlanguageresolvedarrayref); 1116 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "directoriesforepmlist3alangpack.log", $directoriesforepmarrayref); } 1117 ($directoriesforepmarrayref, $alldirectoryhash) = installer::scriptitems::collect_directories_with_create_flag_from_directoryarray($dirsinproductlanguageresolvedarrayref, $alldirectoryhash); 1118 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "directoriesforepmlist3blangpack.log", $directoriesforepmarrayref); } 1119 installer::sorter::sorting_array_of_hashes($directoriesforepmarrayref, "HostName"); 1120 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "directoriesforepmlist3clangpack.log", $directoriesforepmarrayref); } 1121 1122 if ( $installer::globals::iswindowsbuild ) 1123 { 1124 $registryitemsinproductlanguageresolvedarrayref = installer::worker::select_langpack_items($registryitemsinproductlanguageresolvedarrayref, "RegistryItem"); 1125 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "registryitems3aa.log", $registryitemsinproductlanguageresolvedarrayref); } 1126 } 1127 1128 } 1129 1130 # Collecting all files without flag PATCH (for maintenance reasons) 1131 if ( $installer::globals::patch ) { installer::worker::collect_all_files_without_patch_flag($filesinproductlanguageresolvedarrayref); } 1132 1133 # Patch projects can now start to select the required information 1134 if (( $installer::globals::patch ) && (( $installer::globals::issolarispkgbuild ) || ( $installer::globals::iswindowsbuild ))) 1135 { 1136 $filesinproductlanguageresolvedarrayref = installer::worker::select_patch_items($filesinproductlanguageresolvedarrayref, "File"); 1137 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles16patch.log", $filesinproductlanguageresolvedarrayref); } 1138 $scpactionsinproductlanguageresolvedarrayref = installer::worker::select_patch_items($scpactionsinproductlanguageresolvedarrayref, "ScpAction"); 1139 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productscpactions6patch.log", $scpactionsinproductlanguageresolvedarrayref); } 1140 $linksinproductlanguageresolvedarrayref = installer::worker::select_patch_items($linksinproductlanguageresolvedarrayref, "Shortcut"); 1141 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productlinks8patch.log", $linksinproductlanguageresolvedarrayref); } 1142 $unixlinksinproductlanguageresolvedarrayref = installer::worker::select_patch_items($unixlinksinproductlanguageresolvedarrayref, "Unixlink"); 1143 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "unixlinks6patch.log", $unixlinksinproductlanguageresolvedarrayref); } 1144 $folderitemsinproductlanguageresolvedarrayref = installer::worker::select_patch_items($folderitemsinproductlanguageresolvedarrayref, "FolderItem"); 1145 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfolderitems1patch.log", $folderitemsinproductlanguageresolvedarrayref); } 1146 # @{$folderitemsinproductlanguageresolvedarrayref} = (); # no folderitems in languagepacks 1147 1148 if ( $installer::globals::iswindowsbuild ) 1149 { 1150 $registryitemsinproductlanguageresolvedarrayref = installer::worker::select_patch_items_without_name($registryitemsinproductlanguageresolvedarrayref, "RegistryItem"); 1151 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "registryitems3a.log", $registryitemsinproductlanguageresolvedarrayref); } 1152 1153 installer::worker::prepare_windows_patchfiles($filesinproductlanguageresolvedarrayref, $languagestringref, $allvariableshashref); 1154 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles16bpatch.log", $filesinproductlanguageresolvedarrayref); } 1155 1156 # For Windows patches, the directories can now be collected again 1157 ($directoriesforepmarrayref, $alldirectoryhash) = installer::scriptitems::collect_directories_from_filesarray($filesinproductlanguageresolvedarrayref); 1158 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "directoriesforepmlist4_patch.log", $directoriesforepmarrayref); } 1159 1160 installer::sorter::sorting_array_of_hashes($directoriesforepmarrayref, "HostName"); 1161 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "directoriesforepmlist5_patch.log", $directoriesforepmarrayref); } 1162 } 1163 } 1164 1165 ######################################################### 1166 # Collecting all scp actions 1167 ######################################################### 1168 1169 installer::worker::collect_scpactions($scpactionsinproductlanguageresolvedarrayref); 1170 1171 ######################################################### 1172 # creating inf files for user system integration 1173 ######################################################### 1174 1175 if (( $installer::globals::iswindowsbuild ) && ( ! $installer::globals::patch )) # Windows specific items: Folder, FolderItem, RegistryItem 1176 { 1177 installer::logger::print_message( "... creating inf files ...\n" ); 1178 installer::worker::create_inf_file($filesinproductlanguageresolvedarrayref, $registryitemsinproductlanguageresolvedarrayref, $folderinproductlanguageresolvedarrayref, $folderitemsinproductlanguageresolvedarrayref, $modulesinproductlanguageresolvedarrayref, $languagesarrayref, $languagestringref, $allvariableshashref); 1179 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles16c.log", $filesinproductlanguageresolvedarrayref); } 1180 } 1181 1182 ########################################### 1183 # Using upx, to decrease file size 1184 # Currently only for Windows. 1185 ########################################### 1186 1187 if ( $allvariableshashref->{'UPXPRODUCT'} ) 1188 { 1189 installer::upx::upx_on_libraries($filesinproductlanguageresolvedarrayref, $languagestringref); 1190 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles16d.log", $filesinproductlanguageresolvedarrayref); } 1191 } 1192 1193 ########################################################### 1194 # Simple package projects can now start to create the 1195 # installation structure by creating Directories, Files 1196 # Links and ScpActions. This is the last platform 1197 # independent part. 1198 ########################################################### 1199 1200 if ( $installer::globals::is_simple_packager_project ) 1201 { 1202 installer::simplepackage::create_simple_package($filesinproductlanguageresolvedarrayref, $directoriesforepmarrayref, $scpactionsinproductlanguageresolvedarrayref, $linksinproductlanguageresolvedarrayref, $unixlinksinproductlanguageresolvedarrayref, $loggingdir, $languagestringref, $shipinstalldir, $allsettingsarrayref, $allvariableshashref, $includepatharrayref); 1203 next; # ! leaving the current loop, because no further packaging required. 1204 } 1205 1206 ########################################################### 1207 # Analyzing the package structure 1208 ########################################################### 1209 1210 installer::logger::print_message( "... analyzing package list ...\n" ); 1211 1212 my $packages = installer::packagelist::collectpackages($modulesinproductlanguageresolvedarrayref, $languagesarrayref); 1213 installer::packagelist::check_packagelist($packages); 1214 1215 $packages = installer::packagelist::analyze_list($packages, $modulesinproductlanguageresolvedarrayref); 1216 installer::packagelist::remove_multiple_modules_packages($packages); 1217 1218 # printing packages content: 1219 installer::packagelist::log_packages_content($packages); 1220 installer::packagelist::create_module_destination_hash($packages, $allvariableshashref); 1221 1222 if ( $installer::globals::debug ) { installer::logger::debuginfo("\nEnd of part 1b: The language dependent part\n"); } 1223 1224 # saving debug info, before starting part 2 1225 if ( $installer::globals::debug ) { installer::logger::savedebug($installer::globals::exitlog); } 1226 1227 ################################################# 1228 # Part 2: The platform dependent part 1229 ################################################# 1230 1231 if ( $installer::globals::debug ) { installer::logger::debuginfo("\nPart 2: The platform dependent part\n"); } 1232 1233 ################################################# 1234 # Part 2a: All non-Windows platforms 1235 ################################################# 1236 1237 if ( $installer::globals::debug ) { installer::logger::debuginfo("\nPart 2a: All non-Windows platforms\n"); } 1238 1239 ######################################################### 1240 # ... creating epm list file ... 1241 # Only for non-Windows platforms 1242 ######################################################### 1243 1244 if (!( $installer::globals::iswindowsbuild )) 1245 { 1246 #################################################### 1247 # Writing log file before packages are packed 1248 #################################################### 1249 1250 installer::logger::print_message( "... creating log file " . $loggingdir . $installer::globals::logfilename . "\n" ); 1251 installer::files::save_file($loggingdir . $installer::globals::logfilename, \@installer::globals::logfileinfo); 1252 1253 #################################################### 1254 # Creating directories 1255 #################################################### 1256 1257 $installdir = installer::worker::create_installation_directory($shipinstalldir, $languagestringref, \$current_install_number); 1258 1259 my $listfiledir = installer::systemactions::create_directories("listfile", $languagestringref); 1260 my $installlogdir = installer::systemactions::create_directory_next_to_directory($installdir, "log"); 1261 # installer::packagelist::add_defaultpathes_into_filescollector($filesinproductlanguageresolvedarrayref); 1262 # my $installchecksumdir = installer::systemactions::create_directory_next_to_directory($installdir, "checksum"); 1263 1264 #################################################### 1265 # Reading for Solaris all package descriptions 1266 # from file defined in property PACKAGEMAP 1267 #################################################### 1268 1269 if ( $installer::globals::issolarisbuild ) { installer::epmfile::read_packagemap($allvariableshashref, $includepatharrayref, $languagesarrayref); } 1270 1271 my $epmexecutable = ""; 1272 my $found_epm = 0; 1273 1274 # shuffle array to reduce parallel packaging process in pool 1275 installer::worker::shuffle_array($packages); 1276 1277 # iterating over all packages 1278 for ( my $k = 0; $k <= $#{$packages}; $k++ ) 1279 { 1280 my $onepackage = ${$packages}[$k]; 1281 1282 # checking, if this is a language pack or a project pack. 1283 # Creating language packs only, if $installer::globals::languagepack is set. Parameter: -languagepack 1284 1285 if ( $installer::globals::languagepack ) { installer::languagepack::replace_languagestring_variable($onepackage, $languagestringref); } 1286 1287 my $onepackagename = $onepackage->{'module'}; # name of the top module (required) 1288 1289 my $shellscriptsfilename = ""; 1290 if ( $onepackage->{'script'} ) { $shellscriptsfilename = $onepackage->{'script'}; } 1291 # no scripts for Solaris patches! 1292 if (( $installer::globals::patch ) && ( $installer::globals::issolarispkgbuild )) { $shellscriptsfilename = ""; } 1293 1294 ########################### 1295 # package name 1296 ########################### 1297 1298 my $packagename = ""; 1299 1300 if ( $installer::globals::issolarisbuild ) # only for Solaris 1301 { 1302 if ( $onepackage->{'solarispackagename'} ) { $packagename = $onepackage->{'solarispackagename'}; } 1303 } 1304 else # not Solaris 1305 { 1306 if ( $onepackage->{'packagename'} ) { $packagename = $onepackage->{'packagename'}; } 1307 } 1308 1309 if (!($packagename eq "")) 1310 { 1311 installer::packagelist::resolve_packagevariables(\$packagename, $allvariableshashref, 0); 1312 } 1313 1314 # Debian allows no underline in package name 1315 if ( $installer::globals::debian ) { $packagename =~ s/_/-/g; } 1316 1317 # Debian allows no underline in package name 1318 if ( $installer::globals::debian ) { $packagename =~ s/_/-/g; } 1319 1320 my $linkaddon = ""; 1321 my $linkpackage = 0; 1322 $installer::globals::add_required_package = ""; 1323 $installer::globals::linuxlinkrpmprocess = 0; 1324 1325 if ( $installer::globals::makelinuxlinkrpm ) 1326 { 1327 my $oldpackagename = $packagename; 1328 $installer::globals::add_required_package = $oldpackagename; # the link rpm requires the non-linked version 1329 if ( $installer::globals::languagepack ) { $packagename = $packagename . "_u"; } 1330 else { $packagename = $packagename . "u"; } 1331 my $savestring = $oldpackagename . "\t" . $packagename; 1332 push(@installer::globals::linkrpms, $savestring); 1333 $linkaddon = "_links"; 1334 $installer::globals::linuxlinkrpmprocess = 1; 1335 $linkpackage = 1; 1336 } 1337 1338 #################################################### 1339 # Header for this package into log file 1340 #################################################### 1341 1342 installer::logger::include_header_into_logfile("Creating package: $packagename ($k)"); 1343 1344 #################################################### 1345 # Pool check: If package is created at the moment 1346 # try it again later. 1347 #################################################### 1348 1349 if (( $installer::globals::patch ) || 1350 ( $installer::globals::languagepack ) || 1351 ( $installer::globals::packageformat eq "native" ) || 1352 ( $installer::globals::packageformat eq "portable" ) || 1353 ( $installer::globals::packageformat eq "osx" )) { $allvariableshashref->{'POOLPRODUCT'} = 0; } 1354 1355 if ( $allvariableshashref->{'POOLPRODUCT'} ) 1356 { 1357 if ( ! $installer::globals::sessionidset ) { installer::packagepool::set_sessionid(); } 1358 if ( ! $installer::globals::poolpathset ) { installer::packagepool::set_pool_path(); } 1359 if (( ! $installer::globals::getuidpathset ) && ( $installer::globals::issolarisbuild )) { installer::worker::set_getuid_path($includepatharrayref); } 1360 1361 my $package_is_creatable = installer::packagepool::check_package_availability($packagename); 1362 1363 if (( ! $package_is_creatable ) && ( ! exists($installer::globals::poolshiftedpackages{$packagename}) )) 1364 { 1365 splice(@{$packages}, $k, 1); # removing package ... 1366 push(@{$packages}, $onepackage); # ... and adding it to the end 1367 $installer::globals::poolshiftedpackages{$packagename} = 1; # only shifting each package once 1368 $k--; # decreasing the counter 1369 my $localinfoline = "Pool: Package \"$packagename\" cannot be created at the moment. Trying again later (1).\n"; 1370 installer::logger::print_message($localinfoline); 1371 push( @installer::globals::logfileinfo, $localinfoline); 1372 next; # repeating this iteration with new package 1373 } 1374 } 1375 1376 ########################################### 1377 # Root path, can be defined as parameter 1378 ########################################### 1379 1380 my $packagerootpath = ""; 1381 1382 if ($installer::globals::rootpath eq "") 1383 { 1384 $packagerootpath = $onepackage->{'destpath'}; 1385 installer::packagelist::resolve_packagevariables(\$packagerootpath, $allvariableshashref, 1); 1386 if ( $^O =~ /darwin/i ) { $packagerootpath =~ s/\/opt\//\/Applications\//; } 1387 } 1388 else 1389 { 1390 $packagerootpath = $installer::globals::rootpath; 1391 } 1392 1393 ############################################# 1394 # copying the collectors for each package 1395 ############################################# 1396 1397 my $filesinpackage = installer::converter::copy_collector($filesinproductlanguageresolvedarrayref); 1398 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "files1_" . $packagename . ".log", $filesinpackage); } 1399 my $linksinpackage = installer::converter::copy_collector($linksinproductlanguageresolvedarrayref); 1400 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "links1_" . $packagename . ".log", $linksinpackage); } 1401 my $unixlinksinpackage = installer::converter::copy_collector($unixlinksinproductlanguageresolvedarrayref); 1402 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "unixlinks1_" . $packagename . ".log", $unixlinksinpackage); } 1403 my $dirsinpackage = installer::converter::copy_collector($directoriesforepmarrayref); 1404 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "dirs1_" . $packagename . ".log", $dirsinpackage); } 1405 1406 ########################################### 1407 # setting the root path for the packages 1408 ########################################### 1409 1410 installer::scriptitems::add_rootpath_to_directories($dirsinpackage, $packagerootpath); 1411 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "dirs2_" . $packagename . ".log", $dirsinpackage); } 1412 installer::scriptitems::add_rootpath_to_files($filesinpackage, $packagerootpath); 1413 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "files2_" . $packagename . ".log", $filesinpackage); } 1414 installer::scriptitems::add_rootpath_to_links($linksinpackage, $packagerootpath); 1415 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "links2_" . $packagename . ".log", $linksinpackage); } 1416 installer::scriptitems::add_rootpath_to_files($unixlinksinpackage, $packagerootpath); 1417 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "unixlinks2_" . $packagename . ".log", $unixlinksinpackage); } 1418 1419 ################################# 1420 # collecting items for package 1421 ################################# 1422 1423 $filesinpackage = installer::packagelist::find_files_for_package($filesinpackage, $onepackage); 1424 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "files3_" . $packagename . ".log", $filesinpackage); } 1425 $unixlinksinpackage = installer::packagelist::find_files_for_package($unixlinksinpackage, $onepackage); 1426 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "unixlinks3_" . $packagename . ".log", $unixlinksinpackage); } 1427 $linksinpackage = installer::packagelist::find_links_for_package($linksinpackage, $filesinpackage); 1428 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "links3_" . $packagename . ".log", $linksinpackage); } 1429 $dirsinpackage = installer::packagelist::find_dirs_for_package($dirsinpackage, $onepackage); 1430 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "dirs3_" . $packagename . ".log", $dirsinpackage); } 1431 1432 ############################################### 1433 # nothing to do, if $filesinpackage is empty 1434 ############################################### 1435 1436 if ( ! ( $#{$filesinpackage} > -1 )) 1437 { 1438 push(@installer::globals::emptypackages, $packagename); 1439 $infoline = "\n\nNo file in package: $packagename \-\> Skipping\n\n"; 1440 push(@installer::globals::logfileinfo, $infoline); 1441 next; # next package, end of loop ! 1442 } 1443 1444 ################################################################# 1445 # nothing to do for Linux patches, if no file has flag PATCH 1446 ################################################################# 1447 1448 # Linux Patch: The complete RPM has to be built, if one file in the RPM has the flag PATCH (also for DEBs) 1449 if (( $installer::globals::patch ) && (( $installer::globals::islinuxrpmbuild ) || ( $installer::globals::islinuxdebbuild ))) 1450 { 1451 my $patchfiles = installer::worker::collect_all_items_with_special_flag($filesinpackage ,"PATCH"); 1452 if ( ! ( $#{$patchfiles} > -1 )) 1453 { 1454 $infoline = "\n\nLinux Patch: No patch file in package: $packagename \-\> Skipping\n\n"; 1455 push(@installer::globals::logfileinfo, $infoline); 1456 next; 1457 } 1458 } 1459 1460 ########################################### 1461 # Stripping libraries 1462 ########################################### 1463 1464 # Building for non Windows platforms in cws requires, that all files are stripped before packaging: 1465 # 1. copy all files that need to be stripped locally 1466 # 2. strip all these files 1467 1468 if ( $installer::globals::strip ) 1469 { 1470 installer::strip::strip_libraries($filesinpackage, $languagestringref); 1471 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . $packagename ."_files.log", $filesinpackage); } 1472 } 1473 1474 ############################################################### 1475 # Searching for files in $filesinpackage with flag LINUXLINK 1476 ############################################################### 1477 1478 if (( $installer::globals::islinuxbuild ) && ( ! $installer::globals::simple )) # for rpms and debian packages 1479 { 1480 # special handling for all RPMs in $installer::globals::linuxlinkrpms 1481 1482 # if (( $installer::globals::linuxlinkrpms =~ /\b$onepackagename\b/ ) || ( $installer::globals::languagepack )) 1483 if ( $installer::globals::linuxlinkrpms =~ /\b$onepackagename\b/ ) 1484 { 1485 my $run = 0; 1486 1487 if (( $installer::globals::makelinuxlinkrpm ) && ( ! $run )) 1488 { 1489 $filesinpackage = \@installer::globals::linuxpatchfiles; 1490 $linksinpackage = \@installer::globals::linuxlinks; 1491 $installer::globals::makelinuxlinkrpm = 0; 1492 if ( $installer::globals::patch ) { $installer::globals::call_epm = 1; } # enabling packing again 1493 $run = 1; 1494 1495 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "files3b_" . $packagename . ".log", $filesinpackage); } 1496 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "links3b_" . $packagename . ".log", $linksinpackage); } 1497 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "dirs3b_" . $packagename . ".log", $dirsinpackage); } 1498 } 1499 1500 if (( ! $installer::globals::makelinuxlinkrpm ) && ( ! $run )) 1501 { 1502 $filesinpackage = installer::worker::prepare_linuxlinkfiles($filesinpackage); 1503 $linksinpackage = installer::worker::prepare_forced_linuxlinkfiles($linksinpackage); 1504 $installer::globals::makelinuxlinkrpm = 1; 1505 if ( $allvariableshashref->{'OPENSOURCE'} ) { $installer::globals::add_required_package = $packagename . "u"; } 1506 if ( $installer::globals::patch ) { $installer::globals::call_epm = 0; } # no packing of core module in patch 1507 $shellscriptsfilename = ""; # shell scripts only need to be included into the link rpm 1508 $run = 1; 1509 1510 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "files3a_" . $packagename . ".log", $filesinpackage); } 1511 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "links3a_" . $packagename . ".log", $linksinpackage); } 1512 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "dirs3a_" . $packagename . ".log", $dirsinpackage); } 1513 } 1514 } 1515 } 1516 1517 ########################################### 1518 # Simple installation mechanism 1519 ########################################### 1520 1521 if ( $installer::globals::simple ) { installer::worker::install_simple($onepackagename, $$languagestringref, $dirsinpackage, $filesinpackage, $linksinpackage, $unixlinksinpackage); } 1522 1523 ########################################### 1524 # Checking epm state 1525 ########################################### 1526 1527 if (( $installer::globals::call_epm ) && ( ! $found_epm )) 1528 { 1529 $epmexecutable = installer::epmfile::find_epm_on_system($includepatharrayref); 1530 installer::epmfile::set_patch_state($epmexecutable); # setting $installer::globals::is_special_epm 1531 $found_epm = 1; # searching only once 1532 } 1533 1534 ########################################### 1535 # Creating epm list file 1536 ########################################### 1537 1538 if ( ! $installer::globals::simple ) 1539 { 1540 # epm list file format: 1541 # type mode owner group destination source options 1542 # Example for a file: f 755 root sys /usr/bin/foo foo 1543 # Example for a directory: d 755 root sys /var/spool/foo - 1544 # Example for a link: l 000 root sys /usr/bin/linkname filename 1545 # The source field specifies the file to link to 1546 1547 my $epmfilename = "epm_" . $onepackagename . $linkaddon . ".lst"; 1548 1549 installer::logger::print_message( "... creating epm list file $epmfilename ... \n" ); 1550 1551 my $completeepmfilename = $listfiledir . $installer::globals::separator . $epmfilename; 1552 1553 my @epmfile = (); 1554 1555 my $epmheaderref = installer::epmfile::create_epm_header($allvariableshashref, $filesinproductlanguageresolvedarrayref, $languagesarrayref, $onepackage); 1556 installer::epmfile::adding_header_to_epm_file(\@epmfile, $epmheaderref); 1557 1558 if (( $installer::globals::patch ) && ( $installer::globals::issolarispkgbuild )) 1559 { 1560 $filesinpackage = installer::worker::analyze_patch_files($filesinpackage); 1561 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "files4_" . $packagename . ".log", $filesinpackage); } 1562 1563 if ( ! ( $#{$filesinpackage} > -1 )) 1564 { 1565 push(@installer::globals::emptypackages, $packagename); 1566 $infoline = "\nNo file in package: $packagename \-\> Skipping\n"; 1567 push(@installer::globals::logfileinfo, $infoline); 1568 next; # next package, end of loop ! 1569 } 1570 } 1571 1572 # adding directories, files and links into epm file 1573 1574 installer::epmfile::put_directories_into_epmfile($dirsinpackage, \@epmfile, $allvariableshashref, $packagerootpath); 1575 installer::epmfile::put_files_into_epmfile($filesinpackage, \@epmfile ); 1576 installer::epmfile::put_links_into_epmfile($linksinpackage, \@epmfile ); 1577 installer::epmfile::put_unixlinks_into_epmfile($unixlinksinpackage, \@epmfile ); 1578 1579 if ((!( $shellscriptsfilename eq "" )) && (!($installer::globals::iswindowsbuild))) { installer::epmfile::adding_shellscripts_to_epm_file(\@epmfile, $shellscriptsfilename, $packagerootpath, $allvariableshashref, $filesinpackage); } 1580 1581 installer::files::save_file($completeepmfilename ,\@epmfile); 1582 1583 # ... splitting the rootpath into a relocatable part and a static part, if possible 1584 1585 my $staticpath = ""; 1586 my $relocatablepath = ""; 1587 # relocatable path can be defined in package list 1588 if ( $onepackage->{'relocatablepath'} ) { $relocatablepath = $onepackage->{'relocatablepath'}; } 1589 # setting fix part and variable part of destination path 1590 installer::epmfile::analyze_rootpath($packagerootpath, \$staticpath, \$relocatablepath, $allvariableshashref); 1591 1592 # ... replacing the variable PRODUCTDIRECTORYNAME in the shellscriptfile by $staticpath 1593 1594 installer::epmfile::resolve_path_in_epm_list_before_packaging(\@epmfile, $completeepmfilename, "PRODUCTDIRECTORYNAME", $staticpath); 1595 installer::epmfile::resolve_path_in_epm_list_before_packaging(\@epmfile, $completeepmfilename, "SOLSUREPACKAGEPREFIX", $allvariableshashref->{'SOLSUREPACKAGEPREFIX'}); 1596 installer::epmfile::resolve_path_in_epm_list_before_packaging(\@epmfile, $completeepmfilename, "UREPACKAGEPREFIX", $allvariableshashref->{'UREPACKAGEPREFIX'}); 1597 # installer::epmfile::resolve_path_in_epm_list_before_packaging(\@epmfile, $completeepmfilename, "BASISDIRECTORYVERSION", $allvariableshashref->{'OOOBASEVERSION'}); 1598 installer::files::save_file($completeepmfilename ,\@epmfile); 1599 1600 ####################################################### 1601 # Now the complete content of the package is known, 1602 # including variables and shell scripts. 1603 # Create the package or using the package pool? 1604 ####################################################### 1605 1606 my $use_package_from_pool = 0; 1607 if ( $allvariableshashref->{'POOLPRODUCT'} ) { $use_package_from_pool = installer::packagepool::package_is_up_to_date($allvariableshashref, $onepackage, $packagename, \@epmfile, $filesinpackage, $installdir, $installer::globals::epmoutpath, $languagestringref); } 1608 1609 if ( $use_package_from_pool == 3 ) # repeat this package later 1610 { 1611 my $package_is_creatable = installer::packagepool::check_package_availability($packagename); 1612 1613 if (( ! $package_is_creatable ) && ( ! exists($installer::globals::poolshiftedpackages{$packagename}) )) 1614 { 1615 splice(@{$packages}, $k, 1); # removing package ... 1616 push(@{$packages}, $onepackage); # ... and adding it to the end 1617 $installer::globals::poolshiftedpackages{$packagename} = 1; # only shifting each package once 1618 $k--; # decreasing the counter 1619 my $localinfoline = "\nPool: Package \"$packagename\" cannot be created at the moment. Trying again later (2).\n"; 1620 installer::logger::print_message($localinfoline); 1621 push( @installer::globals::logfileinfo, $localinfoline); 1622 next; # repeating this iteration with new package 1623 } 1624 } 1625 1626 if ( $use_package_from_pool == 4 ) # There was a problem with pooling. Repeat this package immediately. 1627 { 1628 $k--; # decreasing the counter 1629 my $localinfoline = "\nPool: Package \"$packagename\" had pooling problems. Repeating packaging immediately (3).\n"; 1630 installer::logger::print_message($localinfoline); 1631 push( @installer::globals::logfileinfo, $localinfoline); 1632 next; # repeating this iteration 1633 } 1634 1635 if ( $use_package_from_pool == 0 ) 1636 { 1637 # changing into the "install" directory to create installation sets 1638 1639 $currentdir = cwd(); # $currentdir is global in this file 1640 1641 chdir($installdir); # changing into install directory ($installdir is global in this file) 1642 1643 ########################################### 1644 # Starting epm 1645 ########################################### 1646 1647 # With a patched epm, it is now possible to set the relocatable directory, change 1648 # the directory in which the packages are created, setting "requires" and "provides" 1649 # (Linux) or creating the "depend" file (Solaris) and finally to begin 1650 # the packaging process with standard tooling and standard parameter 1651 # Linux: Adding into the spec file: Prefix: /opt 1652 # Solaris: Adding into the pkginfo file: BASEDIR=/opt 1653 # Attention: Changing of the path can influence the shell scripts 1654 1655 if (( $installer::globals::is_special_epm ) && ( ($installer::globals::islinuxrpmbuild) || ($installer::globals::issolarispkgbuild) )) # special handling only for Linux RPMs and Solaris Packages 1656 { 1657 if ( $installer::globals::call_epm ) # only do something, if epm is really executed 1658 { 1659 # ... now epm can be started, to create the installation sets 1660 1661 installer::logger::print_message( "... starting patched epm ... \n" ); 1662 1663 installer::epmfile::call_epm($epmexecutable, $completeepmfilename, $packagename, $includepatharrayref); 1664 1665 my $newepmdir = installer::epmfile::prepare_packages($loggingdir, $packagename, $staticpath, $relocatablepath, $onepackage, $allvariableshashref, $filesinpackage, $languagestringref); # adding the line for Prefix / Basedir, include rpmdir 1666 1667 installer::epmfile::create_packages_without_epm($newepmdir, $packagename, $includepatharrayref, $allvariableshashref, $languagestringref); # start to package 1668 1669 # finally removing all temporary files 1670 1671 installer::epmfile::remove_temporary_epm_files($newepmdir, $loggingdir, $packagename); 1672 1673 # Installation: 1674 # Install: pkgadd -a myAdminfile -d ./SUNWso8m34.pkg 1675 # Install: rpm -i --prefix=/opt/special --nodeps so8m35.rpm 1676 1677 installer::epmfile::create_new_directory_structure($newepmdir); 1678 $installer::globals::postprocess_specialepm = 1; 1679 1680 # solaris patch not needed anymore 1681 # if (( $installer::globals::patch ) && ( $installer::globals::issolarisx86build )) { installer::worker::fix2_solaris_x86_patch($packagename, $installer::globals::epmoutpath); } 1682 } 1683 } 1684 else # this is the standard epm (not relocatable) or ( nonlinux and nonsolaris ) 1685 { 1686 installer::epmfile::resolve_path_in_epm_list_before_packaging(\@epmfile, $completeepmfilename, "\$\$PRODUCTINSTALLLOCATION", $relocatablepath); 1687 installer::files::save_file($completeepmfilename ,\@epmfile); # Warning for pool, content of epm file is changed. 1688 1689 if ( $installer::globals::call_epm ) 1690 { 1691 # ... now epm can be started, to create the installation sets 1692 1693 installer::logger::print_message( "... starting unpatched epm ... \n" ); 1694 1695 if ( $installer::globals::call_epm ) { installer::epmfile::call_epm($epmexecutable, $completeepmfilename, $packagename, $includepatharrayref); } 1696 1697 if (($installer::globals::islinuxrpmbuild) || ($installer::globals::issolarispkgbuild) || ($installer::globals::debian)) 1698 { 1699 $installer::globals::postprocess_standardepm = 1; 1700 } 1701 } 1702 } 1703 1704 if ( $allvariableshashref->{'POOLPRODUCT'} ) { installer::packagepool::put_content_into_pool($packagename, $installdir, $installer::globals::epmoutpath, $filesinpackage, \@epmfile); } 1705 1706 chdir($currentdir); # changing back into start directory 1707 1708 } # end of "if ( ! $use_package_from_pool ) 1709 1710 } # end of "if ( ! $installer::globals::simple ) 1711 1712 ########################################### 1713 # xpd installation mechanism 1714 ########################################### 1715 1716 # Creating the xpd file for the package. This has to happen always, not determined by $use_package_from_pool 1717 1718 if ( $installer::globals::isxpdplatform ) 1719 { 1720 if (( ! $installer::globals::languagepack ) && ( ! $installer::globals::patch )) 1721 { 1722 if (( $allvariableshashref->{'XPDINSTALLER'} ) && ( $installer::globals::call_epm != 0 )) 1723 { 1724 installer::xpdinstaller::create_xpd_file($onepackage, $packages, $languagestringref, $allvariableshashref, $modulesinproductarrayref, $installdir, $installer::globals::epmoutpath, $linkpackage, \%installer::globals::xpdpackageinfo); 1725 $installer::globals::xpd_files_prepared = 1; 1726 %installer::globals::xpdpackageinfo = (); 1727 } 1728 } 1729 } 1730 1731 if ( $installer::globals::makelinuxlinkrpm ) { $k--; } # decreasing the counter to create the link rpm! 1732 1733 } # end of "for ( my $k = 0; $k <= $#{$packages}; $k++ )" 1734 1735 installer::packagepool::log_pool_statistics(); 1736 1737 ############################################################## 1738 # Post epm functionality, after the last package is packed 1739 ############################################################## 1740 1741 if ( $installer::globals::postprocess_specialepm ) 1742 { 1743 installer::logger::include_header_into_logfile("Post EPM processes (Patched EPM):"); 1744 1745 chdir($installdir); 1746 1747 # Copying the cde, kde and gnome packages into the installation set 1748 if ( $installer::globals::addsystemintegration ) { installer::epmfile::put_systemintegration_into_installset($installer::globals::epmoutpath, $includepatharrayref, $allvariableshashref, $modulesinproductarrayref); } 1749 1750 # Adding license and readme into installation set 1751 # if ($installer::globals::addlicensefile) { installer::epmfile::put_installsetfiles_into_installset($installer::globals::epmoutpath); } 1752 if ($installer::globals::addlicensefile) { installer::worker::put_scpactions_into_installset("."); } 1753 1754 # Adding child projects to installation dynamically 1755 if ($installer::globals::addchildprojects) { installer::epmfile::put_childprojects_into_installset($installer::globals::epmoutpath, $allvariableshashref, $modulesinproductarrayref, $includepatharrayref); } 1756 1757 # Adding license file into setup 1758 if ( $allvariableshashref->{'PUT_LICENSE_INTO_SETUP'} ) { installer::worker::put_license_into_setup(".", $includepatharrayref); } 1759 1760 # Creating installation set for Unix language packs, that are not part of multi lingual installation sets 1761 if ( ( $installer::globals::languagepack ) && ( ! $installer::globals::debian ) && ( ! $installer::globals::makedownload ) ) { installer::languagepack::build_installer_for_languagepack($installer::globals::epmoutpath, $allvariableshashref, $includepatharrayref, $languagesarrayref, $languagestringref); } 1762 1763 # Finalizing patch installation sets 1764 if (( $installer::globals::patch ) && ( $installer::globals::issolarispkgbuild )) { installer::epmfile::finalize_patch($installer::globals::epmoutpath, $allvariableshashref); } 1765 if (( $installer::globals::patch ) && ( $installer::globals::islinuxrpmbuild )) { installer::epmfile::finalize_linux_patch($installer::globals::epmoutpath, $allvariableshashref, $includepatharrayref); } 1766 1767 # Copying the xpd installer into the installation set 1768 if (( $allvariableshashref->{'XPDINSTALLER'} ) && ( $installer::globals::isxpdplatform ) && ( $installer::globals::xpd_files_prepared )) 1769 { 1770 installer::xpdinstaller::create_xpd_installer($installdir, $allvariableshashref, $languagestringref); 1771 $installer::globals::addjavainstaller = 0; # only one java installer possible 1772 } 1773 1774 # Copying the java installer into the installation set 1775 chdir($currentdir); # changing back into start directory 1776 if ( $installer::globals::addjavainstaller ) { installer::javainstaller::create_java_installer($installdir, $installer::globals::epmoutpath, $languagestringref, $languagesarrayref, $allvariableshashref, $includepatharrayref, $modulesinproductarrayref); } 1777 } 1778 1779 if ( $installer::globals::postprocess_standardepm ) 1780 { 1781 installer::logger::include_header_into_logfile("Post EPM processes (Standard EPM):"); 1782 1783 chdir($installdir); 1784 1785 # determine the destination directory 1786 my $newepmdir = installer::epmfile::determine_installdir_ooo(); 1787 1788 # Copying the cde, kde and gnome packages into the installation set 1789 if ( $installer::globals::addsystemintegration ) { installer::epmfile::put_systemintegration_into_installset($newepmdir, $includepatharrayref, $allvariableshashref, $modulesinproductarrayref); } 1790 1791 # Adding license and readme into installation set 1792 # if ($installer::globals::addlicensefile) { installer::epmfile::put_installsetfiles_into_installset($newepmdir); } 1793 if ($installer::globals::addlicensefile) { installer::worker::put_scpactions_into_installset("."); } 1794 1795 # Adding license file into setup 1796 if ( $allvariableshashref->{'PUT_LICENSE_INTO_SETUP'} ) { installer::worker::put_license_into_setup(".", $includepatharrayref); } 1797 1798 # Creating installation set for Unix language packs, that are not part of multi lingual installation sets 1799 if ( ( $installer::globals::languagepack ) && ( ! $installer::globals::debian ) && ( ! $installer::globals::makedownload ) ) { installer::languagepack::build_installer_for_languagepack($newepmdir, $allvariableshashref, $includepatharrayref, $languagesarrayref, $languagestringref); } 1800 1801 chdir($currentdir); # changing back into start directory 1802 } 1803 1804 if (( $installer::globals::issolarispkgbuild ) && ( $allvariableshashref->{'COLLECT_PKGMAP'} )) { installer::worker::collectpackagemaps($installdir, $languagestringref, $allvariableshashref); } 1805 1806 ####################################################### 1807 # Analyzing the log file 1808 ####################################################### 1809 1810 my $is_success = 0; 1811 my $finalinstalldir = ""; 1812 1813 installer::worker::clean_output_tree(); # removing directories created in the output tree 1814 ($is_success, $finalinstalldir) = installer::worker::analyze_and_save_logfile($loggingdir, $installdir, $installlogdir, $allsettingsarrayref, $languagestringref, $current_install_number); 1815 my $downloadname = installer::ziplist::getinfofromziplist($allsettingsarrayref, "downloadname"); 1816 if ( $is_success ) { installer::followme::save_followme_info($finalinstalldir, $includepatharrayref, $allvariableshashref, $$downloadname, $languagestringref, $languagesarrayref, $current_install_number, $loggingdir, $installlogdir); } 1817 1818 ####################################################### 1819 # Creating download installation set 1820 ####################################################### 1821 1822 if ( $installer::globals::makedownload ) 1823 { 1824 my $create_download = 0; 1825 if ( $$downloadname ne "" ) { $create_download = 1; } 1826 if (( $is_success ) && ( $create_download ) && ( $ENV{'ENABLE_DOWNLOADSETS'} )) 1827 { 1828 my $downloaddir = installer::download::create_download_sets($finalinstalldir, $includepatharrayref, $allvariableshashref, $$downloadname, $languagestringref, $languagesarrayref); 1829 installer::worker::analyze_and_save_logfile($loggingdir, $downloaddir, $installlogdir, $allsettingsarrayref, $languagestringref, $current_install_number); 1830 } 1831 } 1832 1833 ####################################################### 1834 # Creating jds installation set 1835 ####################################################### 1836 1837 if ( $installer::globals::makejds ) 1838 { 1839 my $create_jds = 0; 1840 1841 if ( $allvariableshashref->{'JDSBUILD'} ) { $create_jds = 1; } 1842 if (! $installer::globals::issolarispkgbuild ) { $create_jds = 0; } 1843 1844 if (( $is_success ) && ( $create_jds )) 1845 { 1846 if ( ! $installer::globals::jds_language_controlled ) 1847 { 1848 my $correct_language = installer::worker::check_jds_language($allvariableshashref, $languagestringref); 1849 $installer::globals::correct_jds_language = $correct_language; 1850 $installer::globals::jds_language_controlled = 1; 1851 } 1852 1853 if ( $installer::globals::correct_jds_language ) 1854 { 1855 my $jdsdir = installer::worker::create_jds_sets($finalinstalldir, $allvariableshashref, $languagestringref, $languagesarrayref, $includepatharrayref); 1856 installer::worker::clean_jds_temp_dirs(); 1857 installer::worker::analyze_and_save_logfile($loggingdir, $jdsdir, $installlogdir, $allsettingsarrayref, $languagestringref, $current_install_number); 1858 } 1859 } 1860 } 1861 1862 } # end of "if (!( $installer::globals::iswindowsbuild ))" 1863 1864 if ( $installer::globals::debug ) { installer::logger::debuginfo("\nEnd of part 2a: All non-Windows platforms\n"); } 1865 1866 ################################################# 1867 # Part 2b: The Windows platform 1868 ################################################# 1869 1870 if ( $installer::globals::debug ) { installer::logger::debuginfo("\nPart 2b: The Windows platform\n"); } 1871 1872 ##################################################################### 1873 # ... creating idt files ... 1874 # Only for Windows builds ($installer::globals::compiler is wntmsci) 1875 ##################################################################### 1876 1877 if ( $installer::globals::iswindowsbuild ) 1878 { 1879 ########################################### 1880 # Stripping libraries 1881 ########################################### 1882 1883 # Building for gcc build in cws requires, that all files are stripped before packaging: 1884 # 1. copy all files that need to be stripped locally 1885 # 2. strip all these files 1886 1887 if ( $installer::globals::compiler =~ /wntgcci/ ) 1888 { 1889 installer::windows::strip::strip_binaries($filesinproductlanguageresolvedarrayref, $languagestringref); 1890 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles16e.log", $filesinproductlanguageresolvedarrayref); } 1891 } 1892 1893 $installdir = installer::worker::create_installation_directory($shipinstalldir, $languagestringref, \$current_install_number); 1894 1895 my $idtdirbase = installer::systemactions::create_directories("idt_files", $languagestringref); 1896 $installer::globals::infodirectory = installer::systemactions::create_directories("info_files", $languagestringref); 1897 my $installlogdir = installer::systemactions::create_directory_next_to_directory($installdir, "log"); 1898 # my $installchecksumdir = installer::systemactions::create_directory_next_to_directory($installdir, "checksum"); 1899 1900 ################################################################################# 1901 # Preparing cabinet files from package definitions 1902 ################################################################################# 1903 1904 # installer::packagelist::prepare_cabinet_files($packages, $allvariableshashref, $$languagestringref); 1905 installer::packagelist::prepare_cabinet_files($packages, $allvariableshashref); 1906 # printing packages content: 1907 installer::packagelist::log_cabinet_assignments(); 1908 1909 ################################################################################# 1910 # Begin of functions that are used for the creation of idt files (Windows only) 1911 ################################################################################# 1912 1913 installer::logger::print_message( "... creating idt files ...\n" ); 1914 1915 installer::logger::include_header_into_logfile("Creating idt files:"); 1916 1917 my $newidtdir = $idtdirbase . $installer::globals::separator . "00"; # new files into language independent directory "00" 1918 installer::systemactions::create_directory($newidtdir); 1919 1920 my @allfilecomponents = (); 1921 my @allregistrycomponents = (); 1922 1923 # Collecting all files with flag "BINARYTABLE" 1924 my $binarytablefiles = installer::worker::collect_all_items_with_special_flag($filesinproductlanguageresolvedarrayref ,"BINARYTABLE"); 1925 1926 # Removing all files with flag "BINARYTABLE_ONLY" 1927 @installer::globals::binarytableonlyfiles = (); 1928 $filesinproductlanguageresolvedarrayref = installer::worker::remove_all_items_with_special_flag($filesinproductlanguageresolvedarrayref ,"BINARYTABLE_ONLY"); 1929 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles17.log", $filesinproductlanguageresolvedarrayref); } 1930 1931 # Collecting all profileitems with flag "INIFILETABLE" for table "IniFile" 1932 my $inifiletableentries = installer::worker::collect_all_items_with_special_flag($profileitemsinproductlanguageresolvedarrayref ,"INIFILETABLE"); 1933 1934 # Creating the important dynamic idt files 1935 installer::windows::msiglobal::set_msiproductversion($allvariableshashref); 1936 installer::windows::msiglobal::put_msiproductversion_into_bootstrapfile($filesinproductlanguageresolvedarrayref); 1937 1938 # Add cabinet assignments to files 1939 installer::windows::file::assign_cab_to_files($filesinproductlanguageresolvedarrayref); 1940 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles17a.log", $filesinproductlanguageresolvedarrayref); } 1941 installer::windows::file::assign_sequencenumbers_to_files($filesinproductlanguageresolvedarrayref); 1942 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles17b.log", $filesinproductlanguageresolvedarrayref); } 1943 1944 # Collection all available directory trees 1945 installer::windows::directory::collectdirectorytrees($directoriesforepmarrayref); 1946 1947 $filesinproductlanguageresolvedarrayref = installer::windows::file::create_files_table($filesinproductlanguageresolvedarrayref, \@allfilecomponents, $newidtdir, $allvariableshashref, $uniquefilename, $allupdatesequences, $allupdatecomponents, $allupdatefileorder); 1948 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles17c.log", $filesinproductlanguageresolvedarrayref); } 1949 if ( $installer::globals::updatedatabase ) { installer::windows::file::check_file_sequences($allupdatefileorder, $allupdatecomponentorder); } 1950 1951 installer::windows::directory::create_directory_table($directoriesforepmarrayref, $newidtdir, $allvariableshashref, $shortdirname, $loggingdir); 1952 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles18.log", $filesinproductlanguageresolvedarrayref); } 1953 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "directoriesforidt1.log", $directoriesforepmarrayref); } 1954 1955 # Attention: The table "Registry.idt" contains language specific strings -> parameter: $languagesarrayref ! 1956 installer::windows::registry::create_registry_table($registryitemsinproductlanguageresolvedarrayref, \@allregistrycomponents, $newidtdir, $languagesarrayref, $allvariableshashref); 1957 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "registryitems4.log", $registryitemsinproductlanguageresolvedarrayref); } 1958 1959 installer::windows::component::create_component_table($filesinproductlanguageresolvedarrayref, $registryitemsinproductlanguageresolvedarrayref, $directoriesforepmarrayref, \@allfilecomponents, \@allregistrycomponents, $newidtdir, $componentid, $componentidkeypath, $allvariableshashref); 1960 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles19.log", $filesinproductlanguageresolvedarrayref); } 1961 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "registryitems5.log", $registryitemsinproductlanguageresolvedarrayref); } 1962 1963 # Attention: The table "Feature.idt" contains language specific strings -> parameter: $languagesarrayref ! 1964 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "modules4.log", $modulesinproductlanguageresolvedarrayref); } 1965 installer::windows::feature::add_uniquekey($modulesinproductlanguageresolvedarrayref); 1966 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "modules4a.log", $modulesinproductlanguageresolvedarrayref); } 1967 $modulesinproductlanguageresolvedarrayref = installer::windows::feature::sort_feature($modulesinproductlanguageresolvedarrayref); 1968 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "modules4b.log", $modulesinproductlanguageresolvedarrayref); } 1969 installer::windows::feature::create_feature_table($modulesinproductlanguageresolvedarrayref, $newidtdir, $languagesarrayref, $allvariableshashref); 1970 1971 installer::windows::featurecomponent::create_featurecomponent_table($filesinproductlanguageresolvedarrayref, $registryitemsinproductlanguageresolvedarrayref, $newidtdir); 1972 1973 installer::windows::media::create_media_table($filesinproductlanguageresolvedarrayref, $newidtdir, $allvariableshashref, $allupdatelastsequences, $allupdatediskids); 1974 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "productfiles20.log", $filesinproductlanguageresolvedarrayref); } 1975 1976 installer::windows::font::create_font_table($filesinproductlanguageresolvedarrayref, $newidtdir); 1977 1978 # Attention: The table "Shortcut.idt" contains language specific strings -> parameter: $languagesarrayref ! 1979 # Attention: Shortcuts (Folderitems) have icon files, that have to be copied into the Icon directory (last parameter) 1980 my @iconfilecollector = (); 1981 1982 installer::windows::shortcut::create_shortcut_table($filesinproductlanguageresolvedarrayref, $linksinproductlanguageresolvedarrayref, $folderinproductlanguageresolvedarrayref, $folderitemsinproductlanguageresolvedarrayref, $directoriesforepmarrayref, $newidtdir, $languagesarrayref, $includepatharrayref, \@iconfilecollector); 1983 if ( $installer::globals::globallogging ) { installer::files::save_array_of_hashes($loggingdir . "folderitems4.log", $folderitemsinproductlanguageresolvedarrayref); } 1984 1985 installer::windows::inifile::create_inifile_table($inifiletableentries, $filesinproductlanguageresolvedarrayref, $newidtdir); 1986 1987 installer::windows::icon::create_icon_table(\@iconfilecollector, $newidtdir); # creating the icon table with all iconfiles used as shortcuts (FolderItems) 1988 1989 installer::windows::createfolder::create_createfolder_table($directoriesforepmarrayref, $filesinproductlanguageresolvedarrayref, $newidtdir, $allvariableshashref); 1990 1991 installer::windows::upgrade::create_upgrade_table($newidtdir, $allvariableshashref); 1992 1993 if ( ! $installer::globals::languagepack ) # the following tables not for language packs 1994 { 1995 installer::windows::removefile::create_removefile_table($folderitemsinproductlanguageresolvedarrayref, $newidtdir); 1996 1997 installer::windows::selfreg::create_selfreg_table($filesinproductlanguageresolvedarrayref, $newidtdir); 1998 1999 # Adding Assemblies into the tables MsiAssembly and MsiAssemblyName dynamically 2000 installer::windows::assembly::create_msiassembly_table($filesinproductlanguageresolvedarrayref, $newidtdir); 2001 installer::windows::assembly::create_msiassemblyname_table($filesinproductlanguageresolvedarrayref, $newidtdir); 2002 installer::windows::assembly::add_assembly_condition_into_component_table($filesinproductlanguageresolvedarrayref, $newidtdir); 2003 } 2004 2005 $infoline = "\n"; 2006 push(@installer::globals::logfileinfo, $infoline); 2007 2008 # Localizing the language dependent idt files 2009 # For every language there will be a localized msi database 2010 # For multilingual installation sets, the differences of this 2011 # databases have to be stored in transforms. 2012 2013 for ( my $m = 0; $m <= $#{$languagesarrayref}; $m++ ) 2014 { 2015 my $onelanguage = ${$languagesarrayref}[$m]; 2016 2017 my $is_bidi = 0; 2018 if ( installer::existence::exists_in_array($onelanguage, \@installer::globals::bidilanguages) ) { $is_bidi = 1; } 2019 2020 my $languageidtdir = $idtdirbase . $installer::globals::separator . $onelanguage; 2021 if ( -d $languageidtdir ) { installer::systemactions::remove_complete_directory($languageidtdir, 1); } 2022 installer::systemactions::create_directory($languageidtdir); 2023 2024 # Copy the template idt files and the new created idt files into this language directory 2025 2026 installer::logger::print_message( "... copying idt files ...\n" ); 2027 2028 installer::logger::include_header_into_logfile("Copying idt files to $languageidtdir:"); 2029 2030 installer::windows::idtglobal::prepare_language_idt_directory($languageidtdir, $newidtdir, $onelanguage, $filesinproductlanguageresolvedarrayref, \@iconfilecollector, $binarytablefiles, $allvariableshashref); 2031 2032 if (( ! $installer::globals::languagepack ) && ( ! $allvariableshashref->{'NOLANGUAGESELECTIONPRODUCT'} )) 2033 { 2034 # For multilingual installation sets, the dialog for the language selection can now be prepared, with 2035 # a checkbox for each available language. This has to happen before the following translation. 2036 # The new controls have to be added into the Control.idt 2037 2038 my $controlidttablename = $languageidtdir . $installer::globals::separator . "Control.idt"; 2039 my $controlidttable = installer::files::read_file($controlidttablename); 2040 installer::windows::idtglobal::add_language_checkboxes_to_database($controlidttable, $languagesarrayref); 2041 installer::files::save_file($controlidttablename, $controlidttable); 2042 $infoline = "Added checkboxes for language selection dialog into table $controlidttablename\n"; 2043 push(@installer::globals::logfileinfo, $infoline); 2044 } 2045 2046 # Now all files are copied into a language specific directory 2047 # The template idt files can be translated 2048 2049 installer::logger::print_message( "... localizing idt files (language: $onelanguage) ...\n" ); 2050 2051 installer::logger::include_header_into_logfile("Localizing idt files (Language: $onelanguage):"); 2052 2053 my @translationfiles = (); # all idt files, that need a translation 2054 push(@translationfiles, "ActionTe.idt"); 2055 push(@translationfiles, "Control.idt"); 2056 push(@translationfiles, "CustomAc.idt"); 2057 push(@translationfiles, "Error.idt"); 2058 push(@translationfiles, "LaunchCo.idt"); 2059 push(@translationfiles, "RadioBut.idt"); 2060 push(@translationfiles, "Property.idt"); 2061 push(@translationfiles, "UIText.idt"); 2062 2063 my $oneidtfilename; 2064 my $oneidtfile; 2065 2066 foreach $oneidtfilename (@translationfiles) 2067 { 2068 my $languagefilename = installer::windows::idtglobal::get_languagefilename($oneidtfilename, $installer::globals::idtlanguagepath); 2069 my $languagefile = installer::files::read_file($languagefilename); 2070 2071 $oneidtfilename = $languageidtdir . $installer::globals::separator . $oneidtfilename; 2072 $oneidtfile = installer::files::read_file($oneidtfilename); 2073 2074 # Now the substitution can start 2075 installer::windows::idtglobal::translate_idtfile($oneidtfile, $languagefile, $onelanguage); 2076 2077 installer::files::save_file($oneidtfilename, $oneidtfile); 2078 2079 $infoline = "Translated idt file: $oneidtfilename into language $onelanguage\n"; 2080 push(@installer::globals::logfileinfo, $infoline); 2081 $infoline = "Used languagefile: $languagefilename\n"; 2082 push(@installer::globals::logfileinfo, $infoline); 2083 } 2084 2085 # setting the encoding in every table (replacing WINDOWSENCODINGTEMPLATE) 2086 2087 installer::windows::idtglobal::setencoding($languageidtdir, $onelanguage); 2088 2089 # setting bidi attributes, if required 2090 2091 if ( $is_bidi ) { installer::windows::idtglobal::setbidiattributes($languageidtdir, $onelanguage); } 2092 2093 # setting the encoding in every table (replacing WINDOWSENCODINGTEMPLATE) 2094 installer::windows::idtglobal::set_multilanguageonly_condition($languageidtdir); 2095 2096 # include the license text into the table Control.idt 2097 2098 if ( ! $allvariableshashref->{'HIDELICENSEDIALOG'} ) 2099 { 2100 my $licensefilesource = installer::windows::idtglobal::get_rtflicensefilesource($onelanguage, $includepatharrayref_lang); 2101 my $licensefile = installer::files::read_file($licensefilesource); 2102 installer::scpzipfiles::replace_all_ziplistvariables_in_rtffile($licensefile, $allvariablesarrayref, $onelanguage, $loggingdir); 2103 my $controltablename = $languageidtdir . $installer::globals::separator . "Control.idt"; 2104 my $controltable = installer::files::read_file($controltablename); 2105 installer::windows::idtglobal::add_licensefile_to_database($licensefile, $controltable); 2106 installer::files::save_file($controltablename, $controltable); 2107 2108 $infoline = "Added licensefile $licensefilesource into database $controltablename\n"; 2109 push(@installer::globals::logfileinfo, $infoline); 2110 } 2111 2112 # include a component into environment table if required 2113 2114 installer::windows::component::set_component_in_environment_table($languageidtdir, $filesinproductlanguageresolvedarrayref); 2115 2116 # include the ProductCode and the UpgradeCode from codes-file into the Property.idt 2117 2118 installer::windows::property::set_codes_in_property_table($languageidtdir); 2119 2120 # the language specific properties can now be set in the Property.idt 2121 2122 installer::windows::property::update_property_table($languageidtdir, $onelanguage, $allvariableshashref, $languagestringref); 2123 2124 # replacing variables in RegLocat.idt 2125 2126 installer::windows::msiglobal::update_reglocat_table($languageidtdir, $allvariableshashref); 2127 2128 # replacing variables in RemoveRe.idt (RemoveRegistry.idt) 2129 2130 installer::windows::msiglobal::update_removere_table($languageidtdir); 2131 2132 # adding language specific properties for multilingual installation sets 2133 2134 installer::windows::property::set_languages_in_property_table($languageidtdir, $languagesarrayref); 2135 2136 # adding settings into CheckBox.idt 2137 installer::windows::property::update_checkbox_table($languageidtdir, $allvariableshashref); 2138 2139 # adding the files from the binary directory into the binary table 2140 installer::windows::binary::update_binary_table($languageidtdir, $filesinproductlanguageresolvedarrayref, $binarytablefiles); 2141 2142 # setting patch codes to detect installed products 2143 2144 if (( $installer::globals::patch ) || ( $installer::globals::languagepack ) || ( $allvariableshashref->{'PDFCONVERTER'} )) { installer::windows::patch::update_patch_tables($languageidtdir, $allvariableshashref); } 2145 2146 # Adding Windows Installer CustomActions 2147 2148 installer::windows::idtglobal::addcustomactions($languageidtdir, $windowscustomactionsarrayref, $filesinproductlanguageresolvedarrayref); 2149 2150 # Adding child projects if specified 2151 2152 if ($installer::globals::addchildprojects) 2153 { 2154 # Adding child projects to installation dynamically (also in feature table) 2155 installer::windows::idtglobal::add_childprojects($languageidtdir, $filesinproductlanguageresolvedarrayref, $allvariableshashref); 2156 # setting Java variables for Java products 2157 if ( $allvariableshashref->{'JAVAPRODUCT'} ) { installer::windows::java::update_java_tables($languageidtdir, $allvariableshashref); } 2158 } 2159 2160 # Then the language specific msi database can be created 2161 2162 if ( $installer::globals::iswin ) # only possible on a Windows platform 2163 { 2164 my $msidatabasename = installer::windows::msiglobal::get_msidatabasename($allvariableshashref, $onelanguage); 2165 my $msifilename = $languageidtdir . $installer::globals::separator . $msidatabasename; 2166 2167 installer::logger::print_message( "... creating msi database (language $onelanguage) ... \n" ); 2168 2169 installer::windows::msiglobal::set_uuid_into_component_table($languageidtdir, $allvariableshashref); # setting new GUID for the components using the tool uuidgen.exe 2170 installer::windows::msiglobal::prepare_64bit_database($languageidtdir, $allvariableshashref); # making last 64 bit changes 2171 installer::windows::msiglobal::create_msi_database($languageidtdir ,$msifilename); 2172 2173 # validating the database # ToDo 2174 2175 my $languagefile = installer::files::read_file($installer::globals::idtlanguagepath . $installer::globals::separator . "SIS.mlf"); 2176 # my $languagefile = installer::files::read_file($installer::globals::idtlanguagepath . $installer::globals::separator . "SIS.ulf"); 2177 2178 installer::windows::msiglobal::write_summary_into_msi_database($msifilename, $onelanguage, $languagefile, $allvariableshashref); 2179 2180 # if there are Merge Modules, they have to be integrated now 2181 $filesinproductlanguageresolvedarrayref = installer::windows::mergemodule::merge_mergemodules_into_msi_database($mergemodulesarrayref, $filesinproductlanguageresolvedarrayref, $msifilename, $languagestringref, $onelanguage, $languagefile, $allvariableshashref, $includepatharrayref, $allupdatesequences, $allupdatelastsequences, $allupdatediskids); 2182 if (( $installer::globals::globallogging ) && ($installer::globals::globalloggingform21)) { installer::files::save_array_of_hashes($loggingdir . "productfiles21_" . $onelanguage . ".log", $filesinproductlanguageresolvedarrayref); } 2183 $installer::globals::globalloggingform21 = 0; 2184 if ( $installer::globals::use_packages_for_cabs ) { installer::windows::media::create_media_table($filesinproductlanguageresolvedarrayref, $newidtdir, $allvariableshashref, $allupdatelastsequences, $allupdatediskids); } 2185 2186 # copy msi database into installation directory 2187 2188 my $msidestfilename = $installdir . $installer::globals::separator . $msidatabasename; 2189 installer::systemactions::copy_one_file($msifilename, $msidestfilename); 2190 } 2191 } 2192 2193 # Creating transforms, if the installation set has more than one language 2194 # renaming the msi database and generating the setup.ini file 2195 2196 my $defaultlanguage = installer::languages::get_default_language($languagesarrayref); 2197 2198 if ( $installer::globals::iswin ) # only possible on a Windows platform 2199 { 2200 if ( $#{$languagesarrayref} > 0 ) 2201 { 2202 installer::windows::msiglobal::create_transforms($languagesarrayref, $defaultlanguage, $installdir, $allvariableshashref); 2203 } 2204 2205 installer::windows::msiglobal::rename_msi_database_in_installset($defaultlanguage, $installdir, $allvariableshashref); 2206 2207 if ( $allvariableshashref->{'ADDLANGUAGEINDATABASENAME'} ) { installer::windows::msiglobal::add_language_to_msi_database($defaultlanguage, $installdir, $allvariableshashref); } 2208 2209 installer::logger::print_message( "... generating setup.ini ...\n" ); 2210 2211 if ( ! $allvariableshashref->{'NOLOADERREQUIRED'} ) { installer::windows::msiglobal::create_setup_ini($languagesarrayref, $defaultlanguage, $installdir, $allvariableshashref); } 2212 } 2213 2214 # Analyzing the ScpActions and copying the files into the installation set 2215 # At least the loader.exe 2216 2217 installer::logger::print_message( "... copying files into installation set ...\n" ); 2218 2219 # installer::windows::msiglobal::copy_scpactions_into_installset($defaultlanguage, $installdir, $scpactionsinproductlanguageresolvedarrayref); 2220 installer::worker::put_scpactions_into_installset($installdir); 2221 2222 # ... copying the setup.exe 2223 2224 installer::windows::msiglobal::copy_windows_installer_files_into_installset($installdir, $includepatharrayref, $allvariableshashref); 2225 2226 # ... copying MergeModules into installation set 2227 2228 if ( ! $installer::globals::fix_number_of_cab_files ) { installer::windows::msiglobal::copy_merge_modules_into_installset($installdir); } 2229 2230 # ... copying the child projects 2231 2232 if ($installer::globals::addchildprojects) 2233 { 2234 installer::windows::msiglobal::copy_child_projects_into_installset($installdir, $allvariableshashref); 2235 } 2236 2237 installer::logger::print_message( "... creating ddf files ...\n" ); 2238 2239 # Creating all needed ddf files and generating a list 2240 # for the package process containing all system calls 2241 2242 my $ddfdir = installer::systemactions::create_directories("ddf", $languagestringref); 2243 2244 $installer::globals::packjobref = installer::windows::msiglobal::generate_cab_file_list($filesinproductlanguageresolvedarrayref, $installdir, $ddfdir, $allvariableshashref); 2245 2246 # Update and patch reasons the pack order needs to be saved 2247 installer::windows::msiglobal::save_packorder(); 2248 2249 $infoline = "\n"; 2250 push(@installer::globals::logfileinfo, $infoline); 2251 2252 #################################### 2253 # Writing log file 2254 # before cab files are packed 2255 #################################### 2256 2257 installer::logger::print_message( "... creating log file $installer::globals::logfilename \n" ); 2258 2259 installer::files::save_file($loggingdir . $installer::globals::logfilename, \@installer::globals::logfileinfo); 2260 2261 ####################################################### 2262 # Finally really create the installation packages, 2263 # Only for Windows and only on a windows platform. 2264 ####################################################### 2265 2266 if ( $installer::globals::iswin ) # only possible on a Windows platform 2267 { 2268 installer::logger::print_message( "... packaging installation set ... \n" ); 2269 installer::windows::msiglobal::execute_packaging($installer::globals::packjobref, $loggingdir, $allvariableshashref); 2270 if ( $installer::globals::include_cab_in_msi ) { installer::windows::msiglobal::include_cabs_into_msi($installdir); } 2271 2272 #################################### 2273 # Writing log file 2274 # after cab files are packed 2275 #################################### 2276 2277 installer::logger::print_message( "\n... creating log file $installer::globals::logfilename \n" ); 2278 installer::files::save_file($loggingdir . $installer::globals::logfilename, \@installer::globals::logfileinfo); 2279 } 2280 2281 ####################################################### 2282 # Analyzing the log file 2283 ####################################################### 2284 2285 my $is_success = 0; 2286 my $finalinstalldir = ""; 2287 installer::worker::clean_output_tree(); # removing directories created in the output tree 2288 ($is_success, $finalinstalldir) = installer::worker::analyze_and_save_logfile($loggingdir, $installdir, $installlogdir, $allsettingsarrayref, $languagestringref, $current_install_number); 2289 2290 ####################################################### 2291 # Creating Windows msp patches 2292 ####################################################### 2293 2294 if (( $is_success ) && ( $installer::globals::updatedatabase ) && ( $allvariableshashref->{'CREATE_MSP_INSTALLSET'} )) 2295 { 2296 # Required: 2297 # Temp path for administrative installations: $installer::globals::temppath 2298 # Path of new installation set: $finalinstalldir 2299 # Path of old installation set: $installer::globals::updatedatabasepath 2300 my $mspdir = installer::windows::msp::create_msp_patch($finalinstalldir, $includepatharrayref, $allvariableshashref, $languagestringref, $languagesarrayref, $filesinproductlanguageresolvedarrayref); 2301 ($is_success, $finalinstalldir) = installer::worker::analyze_and_save_logfile($loggingdir, $mspdir, $installlogdir, $allsettingsarrayref, $languagestringref, $current_install_number); 2302 installer::worker::clean_output_tree(); # removing directories created in the output tree 2303 } 2304 2305 ####################################################### 2306 # Creating download installation set 2307 ####################################################### 2308 2309 my $create_download = 0; 2310 my $downloadname = installer::ziplist::getinfofromziplist($allsettingsarrayref, "downloadname"); 2311 if ( $installer::globals::languagepack ) { $downloadname = installer::ziplist::getinfofromziplist($allsettingsarrayref, "langpackdownloadname"); } 2312 if ( $installer::globals::patch ) { $downloadname = installer::ziplist::getinfofromziplist($allsettingsarrayref, "patchdownloadname"); } 2313 2314 if ( $is_success ) { installer::followme::save_followme_info($finalinstalldir, $includepatharrayref, $allvariableshashref, $$downloadname, $languagestringref, $languagesarrayref, $current_install_number, $loggingdir, $installlogdir); } 2315 2316 if ( $$downloadname ne "" ) { $create_download = 1; } 2317 if (( $is_success ) && ( $create_download ) && ( $ENV{'ENABLE_DOWNLOADSETS'} )) 2318 { 2319 my $downloaddir = installer::download::create_download_sets($finalinstalldir, $includepatharrayref, $allvariableshashref, $$downloadname, $languagestringref, $languagesarrayref); 2320 installer::worker::analyze_and_save_logfile($loggingdir, $downloaddir, $installlogdir, $allsettingsarrayref, $languagestringref, $current_install_number); 2321 } 2322 2323 } # end of "if ( $installer::globals::iswindowsbuild )" 2324 2325 if ( $installer::globals::debug ) { installer::logger::debuginfo("\nEnd of part 2b: The Windows platform\n"); } 2326 2327 # saving file_info file for later analysis 2328 my $speciallogfilename = "fileinfo_" . $installer::globals::product . "\.log"; 2329 installer::files::save_array_of_hashes($loggingdir . $speciallogfilename, $filesinproductlanguageresolvedarrayref); 2330 2331} # end of iteration for one language group 2332 2333# saving debug info at end 2334if ( $installer::globals::debug ) { installer::logger::savedebug($installer::globals::exitlog); } 2335 2336####################################################### 2337# Stopping time 2338####################################################### 2339 2340installer::logger::stoptime(); 2341 2342#################################### 2343# Main program end 2344#################################### 2345