|
|
878a2b |
#!/bin/bash
|
|
|
878a2b |
#
|
|
|
878a2b |
# render_doBaseActions.sh -- This function performs base-rendition
|
|
|
878a2b |
# action for all files.
|
|
|
878a2b |
#
|
|
|
03486a |
# Copyright (C) 2009, 2010, 2011, 2012 The CentOS Project
|
|
|
878a2b |
#
|
|
|
878a2b |
# This program is free software; you can redistribute it and/or modify
|
|
|
878a2b |
# it under the terms of the GNU General Public License as published by
|
|
|
878a2b |
# the Free Software Foundation; either version 2 of the License, or (at
|
|
|
878a2b |
# your option) any later version.
|
|
|
878a2b |
#
|
|
|
878a2b |
# This program is distributed in the hope that it will be useful, but
|
|
|
878a2b |
# WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
878a2b |
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
878a2b |
# General Public License for more details.
|
|
|
878a2b |
#
|
|
|
878a2b |
# You should have received a copy of the GNU General Public License
|
|
|
878a2b |
# along with this program; if not, write to the Free Software
|
|
|
878a2b |
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
878a2b |
#
|
|
|
878a2b |
# ----------------------------------------------------------------------
|
|
|
878a2b |
# $Id$
|
|
|
878a2b |
# ----------------------------------------------------------------------
|
|
|
878a2b |
|
|
|
878a2b |
function render_doBaseActions {
|
|
|
878a2b |
|
|
|
878a2b |
local -a FILES
|
|
|
878a2b |
local FILE=''
|
|
|
878a2b |
local OUTPUT=''
|
|
|
878a2b |
local TEMPLATE=''
|
|
|
b4a50f |
local TEMPLATES=''
|
|
|
878a2b |
local PARENTDIR=''
|
|
|
878a2b |
local TRANSLATION=''
|
|
|
878a2b |
local EXTERNALFILE=''
|
|
|
878a2b |
local EXTERNALFILES=''
|
|
|
878a2b |
local THIS_FILE_DIR=''
|
|
|
878a2b |
local NEXT_FILE_DIR=''
|
|
|
878a2b |
local RENDER_EXTENSION=''
|
|
|
878a2b |
local COUNT=0
|
|
|
878a2b |
|
|
|
878a2b |
# Verify default directory where design models are stored in.
|
|
|
878a2b |
cli_checkFiles "$(cli_getRepoTLDir)/Identity/Models/Themes/${FLAG_THEME_MODEL}" --directory
|
|
|
878a2b |
|
|
|
878a2b |
# Redefine parent directory for current workplace.
|
|
|
878a2b |
PARENTDIR=$(basename "${ACTIONVAL}")
|
|
|
878a2b |
|
|
|
878a2b |
# Define base location of template files.
|
|
|
878a2b |
render_getDirTemplate
|
|
|
878a2b |
|
|
|
878a2b |
# Loop through list of supported file extensions.
|
|
|
878a2b |
for RENDER_EXTENSION in ${RENDER_EXTENSIONS};do
|
|
|
878a2b |
|
|
|
24ece8 |
# Redefine name of rendition format based on supported file
|
|
|
878a2b |
# extension.
|
|
|
56cf52 |
if [[ $RENDER_EXTENSION =~ '^(svg|svgz)$' ]];then
|
|
|
56cf52 |
RENDER_FORMAT='svg'
|
|
|
56cf52 |
elif [[ $RENDER_EXTENSION =~ '^(docbook)$' ]];then
|
|
|
56cf52 |
RENDER_FORMAT='docbook'
|
|
|
878a2b |
else
|
|
|
878a2b |
cli_printMessage "`eval_gettext "The \\\"\\\$RENDER_EXTENSION\\\" file extension is not supported yet."`" --as-error-line
|
|
|
878a2b |
fi
|
|
|
878a2b |
|
|
|
878a2b |
# Define the list of files to process. Use an array variable
|
|
|
b4a50f |
# to store the list of files to process. This make possible to
|
|
|
878a2b |
# realize verifications like: is the current base directory
|
|
|
878a2b |
# equal to the next one in the list of files to process?
|
|
|
b4a50f |
# Questions like this let us to know when centos-art.sh is
|
|
|
878a2b |
# leaving a directory structure and entering another. This
|
|
|
878a2b |
# information is required in order for centos-art.sh to know
|
|
|
878a2b |
# when to apply last-rendition actions.
|
|
|
878a2b |
#
|
|
|
878a2b |
# Another issue is that some directories might be named as if
|
|
|
878a2b |
# they were files (e.g., using a renderable extension like
|
|
|
878a2b |
# .docbook). In these situations we need to avoid such
|
|
|
b4a50f |
# directories from being interpreted as a render able file.
|
|
|
b4a50f |
# For this, pass the `--type="f"' option when building the
|
|
|
b4a50f |
# list of files to process in order to retrieve regular files
|
|
|
b4a50f |
# only.
|
|
|
878a2b |
#
|
|
|
878a2b |
# Another issue to consider here, is that in some cases both
|
|
|
878a2b |
# templates and outputs might be in the same location. In
|
|
|
878a2b |
# these cases localized content are stored in the same
|
|
|
b4a50f |
# location where template files are retrieved from and we need
|
|
|
878a2b |
# to avoid using localized content from being interpreted as
|
|
|
b4a50f |
# design models. In that sake, build the list of files to
|
|
|
b4a50f |
# process using the files directely stored in the directory
|
|
|
b4a50f |
# passed as argument to centos-art.sh command-line. Don't go
|
|
|
b4a50f |
# recursive here.
|
|
|
878a2b |
#
|
|
|
878a2b |
# Another issue to consider here, is the way of filtering. We
|
|
|
878a2b |
# cannot expand the pattern specified by FLAG_FILTER with a
|
|
|
878a2b |
# `.*' here (e.g., "${FLAG_FILTER}.*\.${RENDER_EXTENSION}")
|
|
|
878a2b |
# because that would suppress any possibility from the user to
|
|
|
b4a50f |
# specify just one file name in locations where more than one
|
|
|
878a2b |
# file with the same name as prefix exists (e.g.,
|
|
|
878a2b |
# `repository.docbook', `repository-preamble.docbook' and
|
|
|
878a2b |
# `repository-parts.docbook'). Instead, pass filtering
|
|
|
878a2b |
# control to the user whom can use regular expression markup
|
|
|
878a2b |
# in the `--filter' option to decide whether to match
|
|
|
878a2b |
# `repository.docbook' only (e.g., through
|
|
|
878a2b |
# `--filter="repository"') or `repository-preamble.docbook'
|
|
|
878a2b |
# and `repository-parts.docbook' but not `repository.docbook'
|
|
|
878a2b |
# (e.g., through `--filter="repository-.*"').
|
|
|
b4a50f |
if [[ ${TEMPLATE} =~ "${TCAR_WORKDIR}/trunk/Documentation/(Models|Manuals)/Docbook/.+$" ]];then
|
|
|
b4a50f |
TEMPLATES=$(cli_getFilesList ${TEMPLATE} \
|
|
|
b4a50f |
--maxdepth="1" --mindepth="1" \
|
|
|
bc8245 |
--pattern="$(cli_getRepoName ${TEMPLATE} -f)\.${RENDER_EXTENSION}" \
|
|
|
b4a50f |
--type="f")
|
|
|
b4a50f |
else
|
|
|
b4a50f |
TEMPLATES=$(cli_getFilesList ${TEMPLATE} \
|
|
|
b4a50f |
--maxdepth="1" --mindepth="1" \
|
|
|
bc8245 |
--pattern="${FLAG_FILTER}\.${RENDER_EXTENSION}" \
|
|
|
b4a50f |
--type="f")
|
|
|
b4a50f |
fi
|
|
|
b4a50f |
for FILE in $TEMPLATES;do
|
|
|
878a2b |
FILES[((++${#FILES[*]}))]=$FILE
|
|
|
878a2b |
done
|
|
|
878a2b |
|
|
|
878a2b |
# Verify list of files to process. Assuming no file is found,
|
|
|
878a2b |
# evaluate the next supported file extension.
|
|
|
878a2b |
if [[ ${#FILES[*]} -eq 0 ]];then
|
|
|
878a2b |
continue
|
|
|
878a2b |
fi
|
|
|
878a2b |
|
|
|
24ece8 |
# Initialize format-specific functionalities.
|
|
|
0a16be |
cli_exportFunctions "${CLI_FUNCDIRNAM}/$(cli_getRepoName ${RENDER_FORMAT} -d)/$(cli_getRepoName ${RENDER_FORMAT} -f)"
|
|
|
878a2b |
|
|
|
878a2b |
# Start processing the base rendition list of FILES. Fun part
|
|
|
b4a50f |
# approaching :-).
|
|
|
878a2b |
while [[ $COUNT -lt ${#FILES[*]} ]];do
|
|
|
878a2b |
|
|
|
878a2b |
# Define base file.
|
|
|
878a2b |
FILE=${FILES[$COUNT]}
|
|
|
878a2b |
|
|
|
878a2b |
# Define the base directory path for the current file being
|
|
|
878a2b |
# process.
|
|
|
878a2b |
THIS_FILE_DIR=$(dirname ${FILES[$COUNT]})
|
|
|
878a2b |
|
|
|
878a2b |
# Define the base directory path for the next file that will
|
|
|
878a2b |
# be process.
|
|
|
878a2b |
if [[ $(($COUNT + 1)) -lt ${#FILES[*]} ]];then
|
|
|
878a2b |
NEXT_FILE_DIR=$(dirname ${FILES[$(($COUNT + 1))]})
|
|
|
878a2b |
else
|
|
|
878a2b |
NEXT_FILE_DIR=''
|
|
|
878a2b |
fi
|
|
|
878a2b |
|
|
|
878a2b |
# Print separator line.
|
|
|
878a2b |
cli_printMessage '-' --as-separator-line
|
|
|
878a2b |
|
|
|
878a2b |
# Define final location of translation file.
|
|
|
878a2b |
TRANSLATION=$(dirname $FILE \
|
|
|
65dc63 |
| sed -r 's!trunk/(Documentation|Identity)!trunk/Locales/\1!')/$(${CLI_NAME} locale --get-current-locale)/messages.po
|
|
|
878a2b |
|
|
|
878a2b |
# Define final location of template file.
|
|
|
878a2b |
TEMPLATE=${FILE}
|
|
|
878a2b |
|
|
|
878a2b |
# Verify design models file existence. We cannot continue
|
|
|
878a2b |
# with out it.
|
|
|
878a2b |
if [[ ! -f $TEMPLATE ]];then
|
|
|
878a2b |
cli_printMessage "`gettext "The template file doesn't exist."`" --as-error-line
|
|
|
878a2b |
fi
|
|
|
878a2b |
|
|
|
b4a50f |
# Print action message.
|
|
|
b4a50f |
cli_printMessage "$TEMPLATE" --as-template-line
|
|
|
878a2b |
|
|
|
878a2b |
# Define final location of output directory.
|
|
|
878a2b |
render_getDirOutput
|
|
|
878a2b |
|
|
|
878a2b |
# Get relative path to file. The path string (stored in
|
|
|
878a2b |
# FILE) has two parts: 1. the variable path and 2. the
|
|
|
878a2b |
# common path. The variable path is before the common
|
|
|
878a2b |
# point in the path string. The common path is after the
|
|
|
878a2b |
# common point in the path string. The common point is the
|
|
|
878a2b |
# name of the parent directory (stored in PARENTDIR).
|
|
|
878a2b |
#
|
|
|
878a2b |
# Identity/Models/Themes/.../Firstboot/3/splash-small.svg
|
|
|
878a2b |
# -------------------------^| the |^------------^
|
|
|
878a2b |
# variable path | common | common path
|
|
|
878a2b |
# -------------------------v| point | v------------v
|
|
|
878a2b |
# Identity/Images/Themes/.../Firstboot/Img/3/splash-small.png
|
|
|
878a2b |
#
|
|
|
878a2b |
# What we do here is remove the varibale path, the common
|
|
|
878a2b |
# point, and the file extension parts in the string
|
|
|
878a2b |
# holding the path retrived from design models directory
|
|
|
878a2b |
# structure. Then we use the common path as relative path
|
|
|
878a2b |
# to store the the final image file.
|
|
|
878a2b |
#
|
|
|
878a2b |
# The file extension is removed from the common path
|
|
|
878a2b |
# because it is set when we create the final image file.
|
|
|
878a2b |
# This configuration let us use different extensions for
|
|
|
878a2b |
# the same file name.
|
|
|
878a2b |
#
|
|
|
878a2b |
# When we render using base-rendition action, the
|
|
|
878a2b |
# structure of files under the output directory will be
|
|
|
878a2b |
# the same used after the common point in the related
|
|
|
878a2b |
# design model directory structure.
|
|
|
878a2b |
FILE=$(echo ${FILE} \
|
|
|
878a2b |
| sed -r "s!.*${PARENTDIR}/!!" \
|
|
|
878a2b |
| sed -r "s/\.${RENDER_EXTENSION}$//")
|
|
|
878a2b |
|
|
|
878a2b |
# Define absolute path to final file (without extension).
|
|
|
878a2b |
FILE=${OUTPUT}/$(basename "${FILE}")
|
|
|
878a2b |
|
|
|
878a2b |
# Define instance name from design model.
|
|
|
878a2b |
INSTANCE=$(cli_getTemporalFile ${TEMPLATE})
|
|
|
878a2b |
|
|
|
878a2b |
# Apply translation file to design model to produce the design
|
|
|
878a2b |
# model translated instance.
|
|
|
878a2b |
render_doTranslation
|
|
|
878a2b |
|
|
|
878a2b |
# Expand translation markers inside design model instance.
|
|
|
878a2b |
cli_expandTMarkers ${INSTANCE}
|
|
|
878a2b |
|
|
|
24ece8 |
# Perform format base-rendition.
|
|
|
24ece8 |
${RENDER_FORMAT}
|
|
|
878a2b |
|
|
|
878a2b |
# Remove template instance.
|
|
|
878a2b |
if [[ -f $INSTANCE ]];then
|
|
|
878a2b |
rm $INSTANCE
|
|
|
878a2b |
fi
|
|
|
878a2b |
|
|
|
878a2b |
# Increment file counter.
|
|
|
878a2b |
COUNT=$(($COUNT + 1))
|
|
|
878a2b |
|
|
|
878a2b |
done
|
|
|
878a2b |
|
|
|
24ece8 |
# Unset format-specific functionalities.
|
|
|
24ece8 |
cli_unsetFunctions "${RENDER_FORMAT_DIR}/$(cli_getRepoName \
|
|
|
24ece8 |
${RENDER_FORMAT} -d)" "${RENDER_FORMAT}"
|
|
|
878a2b |
|
|
|
878a2b |
done
|
|
|
878a2b |
}
|