Blame Manual/repository-html/repository_59.html

ee1f37
ee1f37
<html>
ee1f37
ee1f37
ee1f37
Permission is granted to copy, distribute and/or modify this document
ee1f37
under the terms of the GNU Free Documentation License, Version 1.2 or
ee1f37
any later version published by the Free Software Foundation; with no
ee1f37
Invariant Sections, no Front-Cover Texts, and no Back-Cover Texts. A
ee1f37
copy of the license is included in the section entitled GNU Free
ee1f37
Documentation License.  
ee1f37
-->
406f69
ee1f37
ee1f37
Written by: Lionel Cons <Lionel.Cons@cern.ch> (original author)
ee1f37
            Karl Berry  <karl@freefriends.org>
ee1f37
            Olaf Bachmann <obachman@mathematik.uni-kl.de>
ee1f37
            and many others.
ee1f37
Maintained by: Many creative people <dev@texi2html.cvshome.org>
ee1f37
Send bugs and suggestions to <users@texi2html.cvshome.org>
ee1f37
ee1f37
-->
ee1f37
<head>
982d5c
<title>CentOS Artwork Repository: 2.57 The trunk/Scripts/Bash/Cli/Functions/Render Directory</title>
ee1f37
982d5c
<meta name="description" content="CentOS Artwork Repository: 2.57 The trunk/Scripts/Bash/Cli/Functions/Render Directory">
982d5c
<meta name="keywords" content="CentOS Artwork Repository: 2.57 The trunk/Scripts/Bash/Cli/Functions/Render Directory">
ee1f37
<meta name="resource-type" content="document">
ee1f37
<meta name="distribution" content="global">
ee1f37
<meta name="Generator" content="texi2html 1.76">
ee1f37
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
ee1f37
<style type="text/css">
ee1f37
ee1f37
@import "/home/centos/artwork/trunk/Identity/Models/Css/Texi2html/common.css";
ee1f37
ee1f37
a.summary-letter {text-decoration: none}
ee1f37
pre.display {font-family: serif}
ee1f37
pre.format {font-family: serif}
ee1f37
pre.menu-comment {font-family: serif}
ee1f37
pre.menu-preformatted {font-family: serif}
ee1f37
pre.smalldisplay {font-family: serif; font-size: smaller}
ee1f37
pre.smallexample {font-size: smaller}
ee1f37
pre.smallformat {font-family: serif; font-size: smaller}
ee1f37
pre.smalllisp {font-size: smaller}
ee1f37
span.sansserif {font-family:sans-serif; font-weight:normal;}
ee1f37
ul.toc {list-style: none}
ee1f37
-->
ee1f37
</style>
ee1f37
ee1f37
ee1f37
</head>
ee1f37
ee1f37
<body lang="en" bgcolor="#FFFFFF" text="#000000" link="#0000FF" vlink="#800080" alink="#FF0000">
ee1f37
ee1f37
982d5c
[ < ]
982d5c
[ > ]
ee1f37
   
982d5c
[ << ]
982d5c
[ Up ]
982d5c
[ >> ]
ee1f37
   
ee1f37
   
ee1f37
   
ee1f37
   
56a476
[Top]
56a476
[Contents]
982d5c
[Index]
56a476
[ ? ]
ee1f37
982d5c
982d5c
982d5c

2.57 The <tt>`trunk/Scripts/Bash/Cli/Functions/Render'</tt> Directory

ee1f37
982d5c

The render functionality exists to produce both identity and

982d5c
translation files on different levels of information (i.e., different
982d5c
languages, release numbers, architectures, etc.).
982d5c

982d5c

The render functionality relies on "renderable directory

982d5c
structures" to produce files. Renderable directory structures can be
982d5c
either "identity directory structures" or "translation directory
982d5c
structures" with special directories inside.
ee1f37

ee1f37
982d5c
982d5c

2.57.1 Renderable identity directory structures

ee1f37
982d5c

Renderable identity directory structures are the starting point of

982d5c
identity rendition. Whenever we want to render a component of CentOS
982d5c
corporate visual identity, we need to point <tt>`centos-art.sh'</tt> to a
982d5c
renderable identity directory structure. If such renderable identity
982d5c
directory structure doesn't exist, then it is good time to create it. 
982d5c

982d5c

Inside the working copy, one renderable identity directory structures

982d5c
represents one visual manifestation of CentOS corporate visual
982d5c
identity, or said differently, each visual manifestation of CentOS
982d5c
corporate visual identity should have one renderable identity
982d5c
directory structure.
982d5c

982d5c

Inside renderable identity directory structures, <tt>`centos-art.sh'</tt>

982d5c
can render both image-based and text-based files. Specification of
982d5c
whether a renderable identity directory structure produces image-based
982d5c
or text-based content is a configuration action that takes place in
982d5c
the pre-rendition configuration script of that renderable identity
982d5c
directory structure.
010b2d

982d5c

Inside renderable identity directory structures, content production is

982d5c
organized in different configurations. A content production
982d5c
configuration is a unique combination of the components that make an
982d5c
identity directory structure renderable. One content production
982d5c
configuration does one thing only (e.g., to produce untranslated
982d5c
images), but it can be extended (e.g., adding translation files) to
982d5c
achieve different needs (e.g., to produce translated images).
ee1f37

ee1f37
982d5c
982d5c

2.57.1.1 Design template without translation

ee1f37
982d5c

The design template without translation configuration is based on a

982d5c
renderable identity directory structure with an empty translation
982d5c
directory structure. In this configuration, one design template
982d5c
produces one untranslated file. Both design templates and final
982d5c
untranslated files share the same file name, but they differ one
982d5c
another in file-type and file-extension.
982d5c

982d5c

For example, to produce images without translations (there is no much

982d5c
use in producing text-based files without translations), consider the
982d5c
following configuration:
982d5c

982d5c
982d5c
One renderable identity directory structure:
982d5c
982d5c

In this example we used <tt>`Identity/Path/To/Dir'</tt> as the identity

982d5c
component we want to produce untranslated images for.  Identity
982d5c
components can be either under <tt>`trunk/'</tt> or <tt>`branches/'</tt>
982d5c
directory structure.
982d5c

982d5c

The identity component (i.e., <tt>`Identity/Path/To/Dir'</tt>, in this

982d5c
case) is also the bond component we use to connect the identity
982d5c
directory structures with their respective auxiliar directories (i.e.,
982d5c
translation directory structres and pre-rendition configuration
982d5c
structures).  The bond component is the path convenction that
982d5c
<tt>`centos-art.sh'</tt> uses to know where to look for related
982d5c
translations, configuration scripts and whatever auxiliar thing a
982d5c
renderable directory structure may need to have.
982d5c

982d5c
      | The bond component
982d5c
      |----------------->|
982d5c
trunk/Identity/Path/To/Dir  <-- Renderable identity directory structure.
982d5c
|-- Tpl                     <-- Design template directory.
982d5c
|   `-- file.svg            <-- Design template file.
982d5c
`-- Img                     <-- Directory used to store final files.
982d5c
    `-- file.png            <-- Final image-based file produced from
982d5c
                                design template file.
982d5c
982d5c

Inside design template directory, design template files are based on

982d5c
SVG (Scalable Vector Graphics) and use the extension
982d5c
.svg.  Design template files can be organized using several
982d5c
directory levels to create a simple but extensible configuration,
982d5c
specially if translated images are not required.
ee1f37

982d5c

In order for SVG (Scalable Vector Graphics) files to be

982d5c
considered "design template" files, they should be placed under the
982d5c
design template directory and to have set a CENTOSARTWORK
982d5c
object id inside.
ee1f37

982d5c

The CENTOSARTWORK word itself is a convenction name we use to

982d5c
define which object/design area, inside a design template, the
982d5c
<tt>`centos-art.sh'</tt> script will use to export as
982d5c
PNG (Portable Network Graphic) image at rendition time.
982d5c
Whithout such object id specification, the <tt>`centos-art.sh'</tt> script
982d5c
cannot know what object/design area you (as designer) want to export
982d5c
as PNG (Portable Network Graphic) image file.
982d5c

982d5c
info

Note

At rendition time, the content of <tt>`Img/'</tt> directory

982d5c
structure is produced by <tt>`centos-art.sh'</tt> automatically.
982d5c

010b2d
982d5c

When a renderable identity directory structure is configured to

982d5c
produce image-based content, <tt>`centos-art.sh'</tt> produces
982d5c
PNG (Portable Network Graphics) files with the .png
982d5c
extension. Once the base image format has been produced, it is
982d5c
possible for <tt>`centos-art.sh'</tt> to use it in order to automatically
982d5c
create other image formats that may be needed (-- Removed(pxref:trunk Scripts
982d5c
Bash Functions Render Config) --).
982d5c

982d5c

Inside the working copy, you can find an example of "design template

982d5c
without translation" configuration at <tt>`trunk/Identity/Models/'</tt>.
982d5c

982d5c

See section The <tt>`trunk/Identity'</tt> Directory, for more information.

982d5c

982d5c
982d5c
One translation directory structure:
982d5c
982d5c

In order for an identity entry to be considered an identity renderable

982d5c
directory structure, it should have a translation entry. The content
982d5c
of the translation entry is relevant to determine how to process the
982d5c
identity renderable directory entry.
982d5c

982d5c

If the translation entry is empty (i.e., there is no file inside it),

982d5c
<tt>`centos-art.sh'</tt> interprets the identity renderable directory
982d5c
structure as a "design templates without translation" configuration.
982d5c

982d5c
                   | The bond component
982d5c
                   |----------------->|
982d5c
trunk/Translations/Identity/Path/To/Dir
982d5c
`-- (empty)
982d5c
982d5c

If the translation entry is not empty, <tt>`centos-art.sh'</tt> can

982d5c
interpret the identity renderable directory structure as one of the
982d5c
following configurations: "design template with translation
982d5c
(one-to-one)" or "design template with translation (optimized)".
982d5c
Which one of these configurations is used depends on the value
982d5c
assigned to the matching list (MATCHINGLIST) variable in the
982d5c
pre-rendition configuration script of the renderable identity
982d5c
directory structure we are producing images for.
982d5c

982d5c

If the matching list variable is empty (as it is by default), then

982d5c
"design template with translation (one-to-one)" configuration is
982d5c
used. In this configuration it is required that both design templates
982d5c
and translation files have the same file names. This way, one
982d5c
translation files is applied to one design template, to produce
982d5c
one translated image.
982d5c

982d5c

If the matching list variable is not empty (because you redefine it in

982d5c
the pre-rendition configuration script), then "design template with
982d5c
translation (optimized)" configuration is used instead. In this
982d5c
configuration, design templates and translation files don't need to
982d5c
have the same names since such name relationship between them is
982d5c
specified in the matching list properly.
982d5c

982d5c

-- Removed(xref:trunk Translations) --, for more information.

982d5c

982d5c
982d5c
One pre-rendition configuration script:
982d5c
982d5c

In order to make an identity directory structure renderable, a

982d5c
pre-rendition configuration script should exist for it.  The
982d5c
pre-rendition configuration script specifies what type of rendition
982d5c
does <tt>`centos-art.sh'</tt> will perform over the identity directory
982d5c
structure and how does it do that.
982d5c

982d5c
                                           | The bond component
982d5c
                                           |----------------->|
982d5c
trunk/Scripts/Bash/Functions/Render/Config/Identity/Path/To/Dir
982d5c
`-- render.conf.sh
982d5c
982d5c

In this configuration the pre-rendition configuration script

982d5c
(<tt>`render.conf.sh'</tt>) would look like the following:
982d5c

982d5c
function render_loadConfig {
010b2d
982d5c
    # Define rendition actions.
010b2d
    ACTIONS[0]='BASE:renderImage'
010b2d
010b2d
}
010b2d
982d5c

Since translation directory structure is empty, <tt>`centos-art.sh'</tt>

982d5c
assumes a "design template without translation" configuration to
982d5c
produce untranslated images.
ee1f37

982d5c

To produce untranslated images, <tt>`centos-art.sh'</tt> takes one design

982d5c
template and creates one temporal instance from it.  Later,
982d5c
<tt>`centos-art.sh'</tt> uses the temporal design template instance as
982d5c
source file to export the final untranslated image. The action of
982d5c
exporting images from SVG (Scalable Vector Graphics) to
982d5c
PNG (Portable Network Graphics) is possible thanks to
982d5c
Inkscape's command-line interface and the CENTOSARTWORK object
982d5c
id we previously set inside design templates.
982d5c

982d5c
centos-art.sh render --identity=trunk/Identity/Path/To/Dir
982d5c
-------------------------------------------------
982d5c
0 | Execute centos-art.sh on renderable identity directory structure.
982d5c
--v----------------------------------------------
982d5c
trunk/Identity/Path/To/Dir/Tpl/file.svg
982d5c
-------------------------------------------------
982d5c
1 | Create instance from design template.
982d5c
--v----------------------------------------------
982d5c
/tmp/centos-art.sh-a07e824a-5953-4c21-90ae-f5e8e9781f5f-file.svg
982d5c
-------------------------------------------------
982d5c
2 | Render untranslated image from design template instance.
982d5c
--v----------------------------------------------
982d5c
trunk/Identity/NewDir/Img/file.png
982d5c
-------------------------------------------------
982d5c
3 | Remove design template instance.
010b2d
982d5c

Finally, when the untranslated image has been created, the temporal

982d5c
design template instance is removed. At this point,
982d5c
<tt>`centos-art.sh'</tt> takes the next design template and repeats the
982d5c
whole production flow once again (design template by design template),
982d5c
until all design templates be processed.
ee1f37

982d5c

-- Removed(xref:trunk Scripts Bash Functions Render Config) --, for more

982d5c
information.
982d5c

982d5c
010b2d
010b2d
982d5c
982d5c

2.57.1.2 Design template with translation (one-to-one)

982d5c
982d5c

Producing untranslated images is fine in many cases, but not always.

982d5c
Sometimes it is required to produce images in different languages and
982d5c
that is something that untrasnlated image production cannot achieve.
982d5c
However, if we fill its empty translation entry with translation files
982d5c
(one for each design template) we extend the production flow from
982d5c
untranslated image production to translated image production.
982d5c

982d5c

In order for <tt>`centos-art.sh'</tt> to produce images correctly, each

982d5c
design template should have one translation file and each translation
982d5c
file should have one design template.  Otherwise, if there is a
982d5c
missing design template or a missing translation file,
982d5c
<tt>`centos-art.sh'</tt> will not produce the final image related to the
982d5c
missing component.
ee1f37

982d5c

In order for <tt>`centos-art.sh'</tt> to know which is the relation

982d5c
between translation files and design templates the translation
982d5c
directory structure is taken as reference.  For example, the
982d5c
<tt>`trunk/Translations/Identity/Path/To/Dir/file.sed'</tt> translation
982d5c
file does match <tt>`trunk/Identity/Path/To/Dir/Tpl/file.svg'</tt> design
982d5c
template, but it doesn't match
982d5c
<tt>`trunk/Identity/Path/To/Dir/File.svg'</tt> or
982d5c
<tt>`trunk/Identity/Path/To/Dir/Tpl/File.svg'</tt> or
982d5c
<tt>`trunk/Identity/Path/To/Dir/Tpl/SubDir/file.svg'</tt> design
982d5c
templates.
982d5c

982d5c

The pre-rendition configuration script used to produce untranslated

982d5c
images is the same we use to produce translated images. There is no
982d5c
need to modify it. So, as we are using the same pre-rendition
982d5c
configuration script, we can say that translated image production is
982d5c
somehow an extended/improved version of untranslated image production.
982d5c

982d5c
info

Note

If we use no translation file in the translation entry

982d5c
(i.e., an empty directory), <tt>`centos-art.sh'</tt> assumes the
982d5c
untranslated image production. If we fill the translation entry with
982d5c
translation files, <tt>`centos-art.sh'</tt> assumes the translated image
982d5c
production.  
982d5c

010b2d
982d5c

To produce final images, <tt>`centos-art.sh'</tt> applies one translation

982d5c
file to one design template and produce a translated design template
982d5c
instance. Later, <tt>`centos-art.sh'</tt> uses the translated template
982d5c
instance to produce the translated image. Finally, when the translated
982d5c
image has been produced, <tt>`centos-art.sh'</tt> removes the translated
982d5c
design template instance. This production flow is repeated for each
982d5c
translation file available in the translatio entry. 
982d5c

982d5c
centos-art.sh render --identity=trunk/Identity/Path/To/Dir
982d5c
-------------------------------------------------
982d5c
0 | Execute centos-art.sh on directory structure.
982d5c
--v----------------------------------------------
982d5c
trunk/Translations/Identity/Path/To/Dir/file.sed
982d5c
-------------------------------------------------
982d5c
1 | Apply translation to design template.
982d5c
--v----------------------------------------------
982d5c
trunk/Identity/Path/To/Dir/Tpl/file.svg
982d5c
-------------------------------------------------
982d5c
2 | Create design template instance.
982d5c
--v----------------------------------------------
982d5c
/tmp/centos-art.sh-a07e824a-5953-4c21-90ae-f5e8e9781f5f-file.svg
982d5c
-------------------------------------------------
982d5c
3 | Render PNG image from template instance.
982d5c
--v----------------------------------------------
982d5c
trunk/Identity/NewDir/Img/file.png
982d5c
-------------------------------------------------
982d5c
4 | Remove design template instance.
982d5c
010b2d
982d5c
982d5c

2.57.1.3 Design template with translation (optimized)

982d5c
982d5c

Producing translated images satisfies almost all our production images

982d5c
needs, but there is still a pitfall in them. In order to produce
982d5c
translated images as in the "one-to-one" configuration describes
982d5c
previously, it is required that one translation file has one design
982d5c
template. That's useful in many cases, but what would happen if we
982d5c
need to apply many different translation files to the same design
982d5c
template?  Should we have to duplicate the same design template file
982d5c
for each translation file, in order to satisfy the "one-to-one"
982d5c
relation? What if we need to assign translation files to design
982d5c
templates arbitrarily?
982d5c

982d5c

Certenly, that's something the "one-to-one" configuration cannot

982d5c
handle.  So, that's why we had to "optimize" it. The optimized
982d5c
configuration consists on using a matching list (MATCHINGLIST)
982d5c
variable that specifies the relationship between translation files and
982d5c
design templates in an arbitrary way. Using such matching list between
982d5c
translation files and design templates let us use as many assignment
982d5c
combinations as translation files and design templates we are working
982d5c
with.
ee1f37

982d5c

The MATCHINGLIST variable is set in the pre-rendition

982d5c
configuration script of the component we want to produce images for.
982d5c
By default, the MATCHINGLIST variable is empty which means no
982d5c
matching list is used. Otherwise, if MATCHINGLIST variable has a
982d5c
value different to empty value then, <tt>`centos-art.sh'</tt> interprets
982d5c
the matching list in order to know how translation files are applied
982d5c
to design templates.
ee1f37

982d5c

For example, consider the following configuration:

982d5c

982d5c
982d5c
One entry under <tt>`trunk/Identity/'</tt>:
982d5c
982d5c

In this configuration we want to produce three images using a

982d5c
paragraph-based style, controlled by <tt>`paragraph.svg'</tt> design
982d5c
template; and one image using a list-based style, controlled by
982d5c
<tt>`list.svg'</tt> design template.
ee1f37

982d5c
trunk/Identity/Path/To/Dir
982d5c
|-- Tpl
982d5c
|   |-- paragraph.svg
982d5c
|   `-- list.svg
982d5c
`-- Img
982d5c
    |-- 01-welcome.png
982d5c
    |-- 02-donate.png
982d5c
    |-- 03-docs.png
982d5c
    `-- 04-support.png
010b2d
982d5c
982d5c
One entry under <tt>`trunk/Translations/'</tt>:
982d5c
982d5c

In order to produce translated images we need to have one translation

982d5c
file for each translated image we want to produce. Notice how
982d5c
translation names do match final image file names, but how translation
982d5c
names do not match design template names. When we use matching list
982d5c
there is no need for translation files to match the names of design
982d5c
templates, such name relation is set inside the matching list itself.
982d5c

982d5c
trunk/Translations/Identity/Path/To/Dir
982d5c
|-- 01-welcome.sed
982d5c
|-- 02-donate.sed
982d5c
|-- 03-docs.sed
982d5c
`-- 04-support.sed
010b2d
982d5c
982d5c
One entry under <tt>`trunk/trunk/Scripts/Bash/Functions/Render/Config/'</tt>:
982d5c
982d5c

In order to produce different translated images using specific design

982d5c
templates, we need to specify the relation between translation files
982d5c
and design templates in a way that <tt>`centos-art.sh'</tt> could know
982d5c
exactly what translation file to apply to what design template. This
982d5c
relation between translation files and design templates is set using
982d5c
the matching list MATCHINGLIST variable inside the pre-rendition
982d5c
configuration script of the component we want to produce images for.  
982d5c

982d5c
trunk/Scripts/Bash/Functions/Render/Config/Identity/Path/To/Dir
982d5c
`-- render.conf.sh
010b2d
982d5c

In this configuration the pre-rendition configuration script

982d5c
(<tt>`render.conf.sh'</tt>) would look like the following:
ee1f37

982d5c
function render_loadConfig {
982d5c
982d5c
    # Define rendition actions.
982d5c
    ACTIONS[0]='BASE:renderImage'
982d5c
982d5c
    # Define matching list.
982d5c
    MATCHINGLIST="\
982d5c
    paragraph.svg:\
982d5c
        01-welcome.sed\
982d5c
        02-donate.sed\
982d5c
        04-support.sed
982d5c
    list.svg:\
982d5c
        03-docs.sed
982d5c
    "
982d5c
982d5c
}
010b2d
982d5c

As result, <tt>`centos-art.sh'</tt> will produce <tt>`01-welcome.png'</tt>,

982d5c
<tt>`02-donate.png'</tt> and <tt>`04-support.png'</tt> using the
982d5c
paragraph-based design template, but <tt>`03-docs.png'</tt> using the
982d5c
list-based design template.
982d5c

982d5c
982d5c
010b2d
982d5c
982d5c

2.57.1.4 Design template with translation (optimized+flexibility)

010b2d
982d5c

In the production models we've seen so far, there are design templates

982d5c
to produce untranslated images and translation files which combiend
982d5c
with design templates produce translated images. That may seems like
982d5c
all our needs are covered, doesn't it? Well, it almost does.
982d5c

982d5c

Generally, we use design templates to define how final images will

982d5c
look like. Generally, each renderable directory structure has one
982d5c
<tt>`Tpl/'</tt> directory where we organize design templates for that
982d5c
identity component. So, we can say that there is only one unique
982d5c
design template definition for each identity component; or what is the
982d5c
same, said differently, identity components can be produced in one way
982d5c
only, the way its own design template directory specifies.  This is
982d5c
not enough for theme production. It is a limitation, indeed.
982d5c

982d5c

Initially, to create one theme, we created one renderable directory

982d5c
structure for each theme component. When we found ourselves with many
982d5c
themes, and components inside them, it was obvious that the same
982d5c
design model was duplicated inside each theme. As design models were
982d5c
independently one another, if we changed one theme's design model,
982d5c
that change was useless to other themes. So, in order to reuse design
982d5c
model changes, we unified design models into one common directory
982d5c
structure.
982d5c

982d5c

With design models unified in a common structure, another problem rose

982d5c
up. As design models also had the visual style of theme components,
982d5c
there was no difference between themes, so there was no apparent need
982d5c
to have an independent theme directory structure for each different
982d5c
theme.  So, it was also needed to separate visual styles from design
982d5c
models.
982d5c

982d5c

At this point there are two independent worklines: one directory

982d5c
structure to store design models (the final image characteristics
982d5c
[i.e., dimensions, translation markers, etc.]) and one directory
982d5c
structure to store visual styles (the final image visual style [i.e.,
982d5c
the image look and feel]).  So, it is possible to handle both
982d5c
different design models and different visual styles independtly one
982d5c
another and later create combinations among them using
982d5c
<tt>`centos-art.sh'</tt>. 
982d5c

982d5c

For example, consider the following configuration:

ee1f37

010b2d
982d5c
One entry under <tt>`trunk/Identity/Themes/Models/'</tt>:
010b2d
982d5c

The design model entry exists to organize design model files (similar

982d5c
to design templates). Both design models and design templates are very
982d5c
similar; they both should have the CENTOSARTWORK export id
982d5c
present to identify the exportation area, translation marks, etc.
982d5c
However, design models do use dynamic backgrounds inclusion while
982d5c
design templates don't.
982d5c

982d5c
                        THEMEMODEL | | The bond component
982d5c
                             |<----| |--------------------->|
982d5c
trunk/Identity/Themes/Models/Default/Distro/Anaconda/Progress/
982d5c
|-- paragraph.svg
982d5c
`-- list.svg
982d5c
982d5c

Inisde design models, dynamic backgrounds are required in order for

982d5c
different artistic motifs to reuse common design models. Firstly, in
982d5c
order to create dynamic backgrounds inside design models, we import a
982d5c
bitmap to cover design model's background and later, update design
982d5c
model's path information to replace fixed values to dynamic values.
ee1f37

ee1f37
982d5c
One entry under <tt>`trunk/Identity/Themes/Motifs/'</tt>:
010b2d
982d5c

The artistic motif entry defines the visual style we want to produce

982d5c
images for, only. Final images (i.e., those built from combining both
982d5c
design models and artistic motif backrounds) are not stored here, but
982d5c
under branches directory structure. In the artistic motif entry, we
982d5c
only define those images that cannot be produced automatically by
982d5c
<tt>`centos-art.sh'</tt> (e.g., Backgrounds, Color information,
982d5c
Screenshots, etc.).
ee1f37

982d5c
                  Artistic motif name | | Artistic motif backgrounds
982d5c
                             |<-------| |-------->|
982d5c
trunk/Identity/Themes/Motifs/TreeFlower/Backgrounds/
982d5c
|-- Img
982d5c
|   |-- Png
982d5c
|   |   |-- 510x300.png
982d5c
|   |   `-- 510x300-final.png
982d5c
|   `-- Jpg
982d5c
|       |-- 510x300.jpg
982d5c
|       `-- 510x300-final.jpg
982d5c
|-- Tpl
982d5c
|   `-- 510x300.svg
982d5c
`-- Xcf
982d5c
    `-- 510x300.xcf
982d5c
ee1f37
982d5c
One entry under <tt>`trunk/Translations/'</tt>:
010b2d
982d5c

The translation entry specifies, by means of translation files, the

982d5c
language-specific information we want to produce image for. When we
982d5c
create the translation entry we don't use the name of neither design
982d5c
model nor artistic motif, just the design model component we want to
982d5c
produce images for.
ee1f37

982d5c
                                   | The bond component
982d5c
                                   |--------------------->|
982d5c
trunk/Translations/Identity/Themes/Distro/Anaconda/Progress/
982d5c
`-- 5
982d5c
    |-- en
982d5c
    |   |-- 01-welcome.sed
982d5c
    |   |-- 02-donate.sed
982d5c
    |   `-- 03-docs.sed
982d5c
    `-- es
982d5c
        |-- 01-welcome.sed
982d5c
        |-- 02-donate.sed
982d5c
        `-- 03-docs.sed
982d5c
010b2d
982d5c
One entry under <tt>`trunk/Scripts/Bash/Functions/Render/Config/'</tt>:
010b2d
982d5c

There is one pre-rendition configuration script for each theme

982d5c
component. So, each time a theme component is rendered, its
982d5c
pre-rendition configuration script is evaluated to teach
982d5c
<tt>`centos-art.sh'</tt> how to render the component.
ee1f37

982d5c
trunk/Scripts/Bash/Functions/Render/Config/Identity/Themes/Distro/Anaconda/Progress/
982d5c
`-- render.conf.sh
982d5c
982d5c

In this configuration the pre-rendition configuration script

982d5c
(<tt>`render.conf.sh'</tt>) would look like the following:
982d5c

982d5c
function render_loadConfig {
982d5c
982d5c
    # Define rendition actions.
982d5c
    ACTIONS[0]='BASE:renderImage'
982d5c
982d5c
    # Define matching list.
982d5c
    MATCHINGLIST="\
982d5c
    paragraph.svg:\
982d5c
        01-welcome.sed\
982d5c
        02-donate.sed
982d5c
    list.svg:\
982d5c
        03-docs.sed
982d5c
        "
982d5c
982d5c
    # Deifne theme model.
982d5c
    THEMEMODEL='Default'
982d5c
982d5c
}
982d5c
ee1f37
ee1f37
982d5c

The production flow of "optimize+flexibility" configuration…

982d5c

982d5c
982d5c

2.57.2 Renderable translation directory structures

982d5c
982d5c

Translation directory structures are auxiliar structures of renderable

982d5c
identity directory structures. There is one translation directory
982d5c
structure for each renderable identity directory structure.  Inside
982d5c
translation directory structures we organize translation files used by
982d5c
renderable identity directory structures that produce translated
982d5c
images. Renderable identity directory structures that produce
982d5c
untranslated images don't use translation files, but they do use a
982d5c
translation directory structure, an empty translation directory
982d5c
structure, to be precise.
982d5c

982d5c

In order to aliviate production of translation file, we made

982d5c
translation directory structures renderable adding a template
982d5c
(<tt>`Tpl/'</tt>) directory structure to handle common content inside
982d5c
translation files.  This way, we work on translation templates and
982d5c
later use <tt>`centos-art.sh'</tt> to produce specific translation files
982d5c
(based on translation templates) for different information (e.g.,
982d5c
languages, release numbers, architectures, etc.).  
982d5c

982d5c

If for some reason, translation files get far from translation

982d5c
templates and translation templates become incovenient to produce such
982d5c
translation files then, care should be taken to avoid replacing the
982d5c
content of translation files with the content of translation templates
982d5c
when <tt>`centos-art.sh'</tt> is executed to produce translation files
982d5c
from translation templates.
982d5c

982d5c

Inside renderable translation directory structures,

982d5c
<tt>`centos-art.sh'</tt> can produce text-based files only.
982d5c

982d5c
982d5c
982d5c

2.57.3 Copying renderable directory structures

982d5c
982d5c

A renderable layout is formed by design models, design images,

982d5c
pre-rendition configuration scripts and translations files. This way,
982d5c
when we say to duplicate rendition stuff we are saying to duplicate
982d5c
these four directory structures (i.e., design models, design images,
982d5c
pre-rendition configuration scripts, and related translations files).
982d5c

982d5c

When we duplicate directories, inside `trunk/Identity' directory

982d5c
structure, we need to be aware of renderable layout described above
982d5c
and the source location used to perform the duplication action.  The
982d5c
source location is relevant to centos-art.sh script in order to
982d5c
determine the required auxiliar information inside directory
982d5c
structures that need to be copied too (otherwise we may end up with
982d5c
orphan directory structures unable to be rendered, due the absence of
982d5c
required information).
982d5c

982d5c

In order for a renderable directory structure to be valid, the new

982d5c
directory structure copied should match the following conditions:
982d5c

982d5c
    982d5c
  1. To have a unique directory structure under
  2. 982d5c
    <tt>`trunk/Identity'</tt>, organized by any one of the above
    982d5c
    organizational designs above.
    982d5c
    982d5c
  3. To have a unique directory structure under
  4. 982d5c
    <tt>`trunk/Translations'</tt> to store translation files.
    982d5c
    982d5c
  5. To have a unique directory structure under
  6. 982d5c
    <tt>`trunk/Scripts/Bash/Functions/Render/Config'</tt> to set pre-rendition
    982d5c
    configuration script.
    982d5c
    982d5c
    982d5c

    As convenction, the render_doCopy function uses

    982d5c
    <tt>`trunk/Identity'</tt> directory structure as source location.  Once
    982d5c
    the <tt>`trunk/Identity'</tt> directory structure has been specified and
    982d5c
    verified, the related path information is built from it and copied
    982d5c
    automatically to the new location specified by FLAG_TO variable.
    982d5c

    982d5c

    Design templates + No translation:

    982d5c

    982d5c

    Command:

    982d5c
    - centos-art render -copy=trunk/Identity/Path/To/Dir -to=trunk/Identity/NewPath/To/Dir
    982d5c

    982d5c

    Sources:

    982d5c
    - trunk/Identity/Path/To/Dir
    982d5c
    - trunk/Translations/Identity/Path/To/Dir
    982d5c
    - trunk/Scripts/Bash/Functions/Render/Config/Identity/Path/To/Dir
    982d5c

    982d5c

    Targets:

    982d5c
    - trunk/Identity/NewPath/To/Dir
    982d5c
    - trunk/Translations/Identity/NewPath/To/Dir
    982d5c
    - trunk/Scripts/Bash/Functions/Render/Config/Identity/NewPath/To/Dir
    982d5c

    982d5c

    Renderable layout 2:

    982d5c

    982d5c

    Command:

    982d5c
    - centos-art render -copy=trunk/Identity/Themes/Motifs/TreeFlower \
    982d5c
                        -to=trunk/Identity/Themes/Motifs/NewPath/To/Dir
    982d5c

    982d5c

    Sources:

    982d5c
    - trunk/Identity/Themes/Motifs/TreeFlower
    982d5c
    - trunk/Translations/Identity/Themes
    982d5c
    - trunk/Translations/Identity/Themes/Motifs/TreeFlower
    982d5c
    - trunk/Scripts/Bash/Functions/Render/Config/Identity/Themes
    982d5c
    - trunk/Scripts/Bash/Functions/Render/Config/Identity/Themes/Motifs/TreeFlower
    ee1f37

    982d5c

    Targets:

    982d5c
    - trunk/Identity/Themes/Motifs/NewPath/To/Dir
    982d5c
    - trunk/Translations/Identity/Themes
    982d5c
    - trunk/Translations/Identity/Themes/Motifs/NewPath/To/Dir
    982d5c
    - trunk/Scripts/Bash/Functions/Render/Config/Identity/Themes
    982d5c
    - trunk/Scripts/Bash/Functions/Render/Config/Identity/Themes/Motifs/NewPath/To/Dir
    982d5c

    982d5c

    Notice that design models are not included in source or target

    982d5c
    locations. This is intentional. In "Renderable layout 2", design
    982d5c
    models live by their own, they just exist, they are there, available
    982d5c
    for any artistic motif to use. By default `Themes/Models/Default'
    982d5c
    design model directory structure is used, but other design models
    982d5c
    directory structures (under Themes/Models/) can be created and used
    982d5c
    changing the value of THEMEMODEL variable inside the pre-rendition
    982d5c
    configuration script of the artistic motif source location you want to
    982d5c
    produce.
    982d5c

    982d5c

    Notice how translations and pre-rendition configuration scripts may

    982d5c
    both be equal in source and target. This is because such structures
    982d5c
    are common to all artistic motifs (the default values to use when no
    982d5c
    specific values are provided).
    982d5c

    982d5c

    - The common directory structures are not copied or deleted. We cannot

    982d5c
      copy a directory structure to itself.
    982d5c

    982d5c

    - The common directory structures represent the default value to use

    982d5c
      when no specific translations and/or pre-rendition configuration
    982d5c
      script are provided inside source location.
    982d5c

    982d5c

    - The specific directory structures, if present, are both copiable and

    982d5c
      removable. This is, when you perform a copy or delete action from
    982d5c
      source, that source specific auxiliar directories are transfered in
    982d5c
      the copy action to a new location (that specified by FLAG_TO
    982d5c
      variable).
    982d5c

    982d5c

    - When translations and/or pre-rendition configuration scripts are

    982d5c
      found inside the source directory structure, the centos-art.sh
    982d5c
      script loads common auxiliar directories first and later specific
    982d5c
      auxiliar directories.  This way, identity rendition of source
    982d5c
      locations can be customized idividually over the base of common
    982d5c
      default values.
    982d5c

    982d5c

    - The specific auxiliar directories are optional.

    982d5c

    982d5c

    - The common auxiliar directories should be present always. This is,

    982d5c
      in order to provide the information required by render functionality
    982d5c
      (i.e., to make it functional in the more basic level of its
    982d5c
      existence).
    982d5c

    982d5c

    Notice how the duplication process is done from `trunk/Identity' on,

    982d5c
    not the oposite. If you try to duplicate a translation structure (or
    982d5c
    similar auxiliar directory structures like pre-rendition configuration
    982d5c
    scripts), the `trunk/Identity' for that translation is not created.
    982d5c
    This limitation is impossed by the fact that many `trunk/Identity'
    982d5c
    directory structures may reuse/share the same translation directory
    982d5c
    structure. We cannot delete one translation (or similar) directory
    982d5c
    structures while a related `trunk/Identity/' directory structure is
    982d5c
    still in need of it.
    982d5c

    982d5c

    The `render_doCopy' functionality does duplicate directory structures

    982d5c
    directly involved in rendition process only. Once such directories
    982d5c
    have been duplicated, the functionality stops thereat. 
    982d5c

    982d5c
    982d5c
    982d5c

    2.57.4 Usage

    982d5c
    982d5c
      982d5c
    • ...
    • 982d5c
      ee1f37
      ee1f37
      982d5c
      982d5c

      2.57.5 See also

      982d5c
      ee1f37
      ee1f37
      ee1f37
      982d5c
      [ < ]
      982d5c
      [ > ]
      ee1f37
         
      982d5c
      [ << ]
      982d5c
      [ Up ]
      982d5c
      [ >> ]
      ee1f37
      ee1f37

      ee1f37
       <font size="-1">
      406f69
        This document was generated on March, 1 2011 using texi2html 1.76.
      ee1f37
       </font>
      ee1f37
       
      ee1f37
      ee1f37

      ee1f37
      </body>
      ee1f37
      </html>