:
eval 'exec perl -wS $0 ${1+"$@"}'
if 0;
#
# This file is part of the LibreOffice project.
#
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
#
# This file incorporates work covered by the following license notice:
#
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed
# with this work for additional information regarding copyright
# ownership. The ASF licenses this file to you under the Apache
# License, Version 2.0 (the "License"); you may not use this file
# except in compliance with the License. You may obtain a copy of
# the License at http://www.apache.org/licenses/LICENSE-2.0 .
#
use IO::File;
use Cwd;
use File::Spec;
use File::Spec::Functions;
use File::Temp;
use File::Path;
$TempDir = "";
my $FirstTransitionIndex = 0;
my $LastTransitionIndex = -1;
# all the XML package generation is a blatant rip from AF's
# write-calc-doc.pl
###############################################################################
# Open a file with the given name.
# First it is checked if the temporary directory, in which all files for
# the document are gathered, is already present and create it if it is not.
# Then create the path to the file inside the temporary directory.
# Finally open the file and return a file handle to it.
#
sub open_file
{
my $filename = pop @_;
# Create base directory of temporary directory tree if not already
# present.
if ($TempDir eq "")
{
$TempDir = File::Temp::tempdir (CLEANUP => 1);
}
# Create the path to the file.
my $fullname = File::Spec->catfile ($TempDir, $filename);
my ($volume,$directories,$file) = File::Spec->splitpath ($fullname);
mkpath (File::Spec->catpath ($volume,$directories,""));
# Open the file and return a file handle to it.
return new IO::File ($fullname, "w");
}
###############################################################################
# Zip the files in the directory tree into the given file.
#
sub zip_dirtree
{
my $filename = pop @_;
my $cwd = getcwd;
my $zip_name = $filename;
# We are about to change the directory.
# Therefore create an absolute pathname for the zip archive.
# First transfer the drive from $cwd to $zip_name. This is a
# workaround for a bug in file_name_is_absolute which thinks
# the path \bla is an absolute path under DOS.
my ($volume,$directories,$file) = File::Spec->splitpath ($zip_name);
my ($volume_cwd,$directories_cwd,$file_cwd) = File::Spec->splitpath ($cwd);
$volume = $volume_cwd if ($volume eq "");
$zip_name = File::Spec->catpath ($volume,$directories,$file);
# Add the current working directory to a relative path.
if ( ! file_name_is_absolute ($zip_name))
{
$zip_name = File::Spec->catfile ($cwd, $zip_name);
# Try everything to clean up the name.
$zip_name = File::Spec->rel2abs ($filename);
$zip_name = File::Spec->canonpath ($zip_name);
# Remove .. directories from the middle of the path.
while ($zip_name =~ /\/[^\/][^\.\/][^\/]*\/\.\.\//)
{
$zip_name = $` . "/" . $'; # $'
}
}
# Just in case the zip program gets confused by an existing file with the
# same name as the one to be written that file is removed first.
if ( -e $filename)
{
if (unlink ($filename) == 0)
{
print "Existing file $filename could not be deleted.\n";
print "Please close the application that uses it, then try again.\n";
return;
}
}
# Finally create the zip file. First change into the temporary directory
# so that the resulting zip file contains only paths relative to it.
print "zipping [$ZipCmd $ZipFlags $zip_name *]\n";
chdir ($TempDir);
system ("$ZipCmd $ZipFlags $zip_name *");
chdir ($cwd);
}
sub writeHeader
{
print $OUT qq~
~;
}
sub writeSlideStyles
{
my $mode = pop @_;
my $direction = pop @_;
my $transitionSubType = pop @_;
my $transitionType = pop @_;
my $slideNum = pop @_;
return if $slideNum<$FirstTransitionIndex || ($LastTransitionIndex>=0 && $slideNum>$LastTransitionIndex);
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
}
sub writeIntermediate
{
print $OUT qq~
~;
}
sub writeSlide
{
my $mode = pop @_;
my $direction = pop @_;
my $transitionSubtype = pop @_;
my $transitionType = pop @_;
my $slideNum = pop @_;
return if $slideNum<$FirstTransitionIndex || ($LastTransitionIndex>=0 && $slideNum>$LastTransitionIndex);
print $OUT " ";
print $OUT " \n";
print $OUT " \n";
print $OUT " Transition “",$slideNum-1,"”\n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " Transition: ",$transitionType,"\n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " Subtype: ",$transitionSubtype,"\n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " Direction: ",$direction == 0 ? "forward" : "reverse","\n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " Mode: ",$mode == 0 ? "in" : "out","\n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
print $OUT " \n";
}
sub writeFooter
{
print $OUT qq~
~;
}
sub writeManifest
{
my $outFile = open_file("META-INF/manifest.xml");
print $outFile qq~
~;
$outFile->close;
}
$transitionsRef = [
["barWipe",
["leftToRight",
"topToBottom"]],
["blindsWipe",
["vertical",
"horizontal"]],
["boxWipe",
["topLeft",
"topRight",
"bottomRight",
"bottomLeft",
"topCenter",
"rightCenter",
"bottomCenter",
"leftCenter"]],
["fourBoxWipe",
["cornersIn",
"cornersOut"]],
["barnDoorWipe",
["vertical",
"horizontal",
"diagonalBottomLeft",
"diagonalTopLeft"]],
["bowTieWipe",
["vertical",
"horizontal"]],
["miscDiagonalWipe",
["doubleBarnDoor",
"doubleDiamond"]],
["veeWipe",
["down",
"left",
"up",
"right"]],
["barnVeeWipe",
["top",
"left",
"up",
"right"]],
["zigZagWipe",
["leftToRight",
"topToBottom"]],
["barnZigZagWipe",
["vertical",
"horizontal"]],
["irisWipe",
["rectangle",
"diamond"]],
["triangleWipe",
["up",
"right",
"down",
"left"]],
["arrowHeadWipe",
["up",
"right",
"down",
"left"]],
["pentagonWipe",
["up",
"down"]],
["hexagonWipe",
["horizontal",
"vertical"]],
["ellipseWipe",
["circle",
"horizontal",
"vertical"]],
["eyeWipe",
["vertical",
"horizontal"]],
["roundRectWipe",
["horizontal",
"vertical"]],
["starWipe",
["fourPoint",
"fivePoint",
"sixPoint"]],
["miscShapeWipe",
["heart",
"keyhole"]],
["clockWipe",
["clockwiseTwelve",
"clockwiseThree",
"clockwiseSix",
"clockwiseNine"]],
["pinWheelWipe",
["oneBlade",
"twoBladeVertical",
"twoBladeHorizontal",
"threeBlade",
"fourBlade",
"eightBlade"]],
["singleSweepWipe",
["clockwiseTop",
"clockwiseRight",
"clockwiseBottom",
"clockwiseLeft",
"clockwiseTopLeft",
"counterClockwiseBottomLeft",
"clockwiseBottomRight",
"counterClockwiseTopRight"]],
["fanWipe",
["centerTop",
"centerRight",
"top",
"right",
"bottom",
"left"]],
["doubleFanWipe",
["fanOutVertical",
"fanOutHorizontal",
"fanInVertical",
"fanInHorizontal"]],
["doubleSweepWipe",
["parallelVertical",
"parallelDiagonal",
"oppositeVertical",
"oppositeHorizontal",
"parallelDiagonalTopLeft",
"parallelDiagonalBottomLeft"]],
["saloonDoorWipe",
["top",
"left",
"bottom",
"right"]],
["windshieldWipe",
["right",
"up",
"vertical",
"horizontal"]],
["snakeWipe",
["topLeftHorizontal",
"topLeftVertical",
"topLeftDiagonal",
"topRightDiagonal",
"bottomRightDiagonal",
"bottomLeftDiagonal"]],
["spiralWipe",
["topLeftClockwise",
"topRightClockwise",
"bottomRightClockwise",
"bottomLeftClockwise",
"topLeftCounterClockwise",
"topRightCounterClockwise",
"bottomRightCounterClockwise",
"bottomLeftCounterClockwise"]],
["parallelSnakesWipe",
["verticalTopSame",
"verticalBottomSame",
"verticalTopLeftOpposite",
"verticalBottomLeftOpposite",
"horizontalLeftSame",
"horizontalRightSame",
"horizontalTopLeftOpposite",
"horizontalTopRightOpposite",
"diagonalBottomLeftOpposite",
"diagonalTopLeftOpposite"]],
["boxSnakesWipe",
["twoBoxTop",
"twoBoxLeft",
"twoBoxRight",
"fourBoxVertical",
"fourBoxHorizontal"]],
["waterfallWipe",
["verticalLeft",
"verticalRight",
"horizontalLeft",
"horizontalRight"]],
["pushWipe",
["fromLeft",
"fromTop",
"fromRight",
"fromBottom",
"fromBottomRight",
"fromBottomLeft",
"fromTopRight",
"fromTopLeft",
"combHorizontal",
"combVertical"]],
["slideWipe",
["fromLeft",
"fromTop",
"fromRight",
"fromBottom",
"fromBottomRight",
"fromBottomLeft",
"fromTopRight",
"fromTopLeft"]],
["fade",
["crossfade",
"fadeToColor",
"fadeFromColor",
"fadeOverColor"]],
["randomBarWipe",
["vertical",
"horizontal"]],
["checkerBoardWipe",
["down",
"across"]],
["dissolve",
["default"]]
];
###############################################################################
# Print usage information.
#
sub usage ()
{
print <* []
output-file-name defaults to alltransitions.odp.
options: -a Generate _all_ combinations of type, subtype,
direction, and mode
-h Print this usage information.
-f First transition to include, defaults to 0
-l Last transition to include
END_OF_USAGE
}
###############################################################################
# Process the command line.
#
sub process_command_line
{
foreach (@ARGV)
{
if (/^-h/)
{
usage;
exit 0;
}
}
$global_gen_all=0;
$global_output_name = "alltransitions.odp";
my $j = 0;
for (my $i=0; $i<=$#ARGV; $i++)
{
if ($ARGV[$i] eq "-a")
{
$global_gen_all=1;
}
elsif ($ARGV[$i] eq "-f")
{
$FirstTransitionIndex = $ARGV[++$i];
}
elsif ($ARGV[$i] eq "-l")
{
$LastTransitionIndex = $ARGV[++$i];
}
elsif ($ARGV[$i] =~ /^-/)
{
print "Unknown option $ARGV[$i]\n";
usage;
exit 1;
}
elsif ($#ARGV == $i )
{
$global_output_name = $ARGV[$i];
}
}
print "output to $global_output_name\n";
}
###############################################################################
# Main
###############################################################################
$ZipCmd = $ENV{LOG_FILE_ZIP_CMD};
$ZipFlags = $ENV{LOG_FILE_ZIP_FLAGS};
# Provide default values for the zip command and it's flags.
if ( ! defined $ZipCmd)
{
$ZipCmd = "zip" unless defined $ZipCmd;
$ZipFlags = "-r -q" unless defined $ZipFlags;
}
process_command_line();
writeManifest();
$OUT = open_file( "content.xml" );
writeHeader();
$slideNum=1;
foreach $transitionRef (@$transitionsRef)
{
$transitionType = @$transitionRef[0];
foreach $subtype (@{$transitionRef->[1]})
{
if( $global_gen_all != 0 )
{
writeSlideStyles($slideNum++,
$transitionType,
$subtype,
0, 0);
writeSlideStyles($slideNum++,
$transitionType,
$subtype,
1, 0);
writeSlideStyles($slideNum++,
$transitionType,
$subtype,
0, 1);
writeSlideStyles($slideNum++,
$transitionType,
$subtype,
1, 1);
}
else
{
writeSlideStyles($slideNum++,
$transitionType,
$subtype,
0, 0);
}
}
}
writeIntermediate();
$slideNum=1;
foreach $transitionRef (@$transitionsRef)
{
$transitionType = @$transitionRef[0];
foreach $subtype (@{$transitionRef->[1]})
{
if( $global_gen_all != 0 )
{
writeSlide($slideNum++,
$transitionType,
$subtype,
0, 0);
writeSlide($slideNum++,
$transitionType,
$subtype,
1, 0);
writeSlide($slideNum++,
$transitionType,
$subtype,
0, 1);
writeSlide($slideNum++,
$transitionType,
$subtype,
1, 1);
}
else
{
writeSlide($slideNum++,
$transitionType,
$subtype,
0, 0);
}
}
}
writeFooter();
$OUT->close;
zip_dirtree ($global_output_name);