|
|
e935c3 |
|
|
|
9b9860 |
<preface>
|
|
|
9b9860 |
|
|
|
c1f6dd |
<title>History</title>
|
|
|
9b9860 |
|
|
|
09f899 |
<para>The CentOS Artwork Repository started around 2008, at
|
|
|
09f899 |
url="mailto:centos-devel@centos.org">CentOS Developers mailing
|
|
|
09f899 |
list</ulink> during a discussion about how to automate the slide
|
|
|
09f899 |
images of Anaconda. In such discussion, Ralph Angenendt rose up
|
|
|
09f899 |
his hand to ask: Do you have something to show?</para>
|
|
|
09f899 |
|
|
|
09f899 |
<para>To answer the question, Alain Reguera Delgado suggested a
|
|
|
09f899 |
bash script which combined SVG and SED files in order to produce
|
|
|
09f899 |
PNG images in different languages —together with the
|
|
|
09f899 |
proposition of creating a Subversion repository where translations
|
|
|
09f899 |
and image production could be distributed inside The CentOS
|
|
|
09f899 |
Community—.</para>
|
|
|
09f899 |
|
|
|
09f899 |
<para>Karanbirn Sighn considered the idea intresting and provided
|
|
|
09f899 |
the infrastructure necessary to support the effort. This way the
|
|
|
09f899 |
<ulink url="https://projects.centos.org/trac/artwork/">CentOS
|
|
|
09f899 |
Artwork SIG</ulink> and the
|
|
|
09f899 |
url="https://projects.centos.org/svn/artwork/">CentOS Artwork
|
|
|
09f899 |
Repository</ulink> were officially created.</para>
|
|
|
09f899 |
|
|
|
09f899 |
<para>Once the CentOS Artwork Repository was available, Alain
|
|
|
09f899 |
Reguera Delagdo uploaded the bash script for rendering Anaconda
|
|
|
09f899 |
slides; Ralph Angenendt documented it very well; and people
|
|
|
09f899 |
started to download working copies of CentOS Artwork Repository to
|
|
|
09f899 |
produce slide images in their own languages.</para>
|
|
|
9b9860 |
|
|
|
09f899 |
<para>Around 2009, The rendition script was at a very rustic state
|
|
|
09f899 |
where only slide images could be produced, so it was redesigned to
|
|
|
09f899 |
extend the image production to other areas, not just slide images.
|
|
|
09f899 |
In this configuration, one SVG file was used as input to produce a
|
|
|
09f899 |
translated instance of it which, in turn, was used to produce one
|
|
|
09f899 |
translated PNG image as output. The SVG translated instance was
|
|
|
09f899 |
created through SED replacement commands. The translated PNG image
|
|
|
09f899 |
was created from the SVG translated instance using Inkscape
|
|
|
09f899 |
command-line interface.</para>
|
|
|
09f899 |
|
|
|
09f899 |
<para>The rendition script was named
|
|
|
09f899 |
<quote>render.sh</quote>.</para>
|
|
|
09f899 |
|
|
|
09f899 |
<para>The repository directory structure was prepared to receive
|
|
|
09f899 |
the rendition script using design templates and translation files
|
|
|
09f899 |
in the same location. There was one directory structure for each
|
|
|
09f899 |
artwork that needed to be produced. In this configuration, if you
|
|
|
09f899 |
would want to produce the same artwork with a different visual
|
|
|
09f899 |
style or structure, it was needed to create a new directory
|
|
|
09f899 |
structure for it because both the image structure and the image
|
|
|
09f899 |
visual style were together in the design template.</para>
|
|
|
09f899 |
|
|
|
09f899 |
<para>The rendition script was moved to a common place and linked
|
|
|
09f899 |
from different directory structures. There was no need to have the
|
|
|
09f899 |
same code in different directory structures if it could be in just
|
|
|
09f899 |
one place and then be linked from different locations.</para>
|
|
|
09f899 |
|
|
|
09f899 |
<para>The concepts about corporate identity began to be
|
|
|
09f899 |
considered. As referece, it was used the book <quote>Corporate
|
|
|
09f899 |
Identity</quote> by Wally Olins (1989) and Wikipedia (
|
|
|
09f899 |
url="http://en.wikipedia.org/Corporate_identity" />). This way,
|
|
|
09f899 |
the rendition script main's goal becomes to: automate production
|
|
|
09f899 |
of a monolithic corporate visual identity structure, based on the
|
|
|
09f899 |
mission and the release schema of The CentOS Project.</para>
|
|
|
09f899 |
|
|
|
09f899 |
<para>The directory structures started to be documented inside the
|
|
|
09f899 |
repository using text files without markup. Later, documentation
|
|
|
09f899 |
in flat text files was moved to LaTeX format and this way
|
|
|
09f899 |
<quote>The CentOS Artwork Repository Manual</quote> started to
|
|
|
09f899 |
take form.</para>
|
|
|
9b9860 |
|
|
|
09f899 |
<para>Around 2010, the rendition script changed its name from
|
|
|
09f899 |
<command>render.sh</command> to <command>centos-art.sh</command>
|
|
|
09f899 |
and became a collection of functionalities where rendition was
|
|
|
09f899 |
just one among others (e.g., documenting and localizing).</para>
|
|
|
09f899 |
|
|
|
09f899 |
<para>The <command>centos-art.sh</command> was created to organize
|
|
|
09f899 |
automation of most frequent tasks inside the repository. There
|
|
|
09f899 |
was no need to have links all around the repository if a
|
|
|
09f899 |
command-line interface could be created (through symbolic links,
|
|
|
09f899 |
in the <filename class="directory">~/bin</filename> directory) and
|
|
|
09f899 |
be called anywhere inside the repository as it would be a regular
|
|
|
09f899 |
command.</para>
|
|
|
09f899 |
|
|
|
09f899 |
<para>Inside <command>centos-art.sh</command>, functionalities
|
|
|
09f899 |
started to get identified and separated one another. For example,
|
|
|
09f899 |
when images were rendered, there was no need to load
|
|
|
09f899 |
functionalities related to documentation manual. This layout moved
|
|
|
09f899 |
us onto common functionalities and specific functionalities inside
|
|
|
09f899 |
<command>centos-art.sh</command> script. Common functionalities
|
|
|
09f899 |
are loaded when <command>centos-art.sh</command> script is
|
|
|
09f899 |
initiated and are available to specific functionalities.</para>
|
|
|
09f899 |
|
|
|
09f899 |
<para>The <command>centos-art.sh</command> script was redesigned
|
|
|
09f899 |
to handle command-line options trough <command>getopt</command>
|
|
|
09f899 |
option parser.</para>
|
|
|
09f899 |
|
|
|
09f899 |
<para>The repository directory structure was updated to improve
|
|
|
09f899 |
the implementation of concepts related to corporate visual
|
|
|
09f899 |
identity. Specially in the area related to themes which were
|
|
|
09f899 |
divided into <emphasis>design models</emphasis> and
|
|
|
09f899 |
<emphasis>artistic motifs</emphasis> to eliminate the content
|
|
|
09f899 |
duplication produced by having both image structure and image
|
|
|
09f899 |
visual style in the same file. Now, themes are produced as result
|
|
|
09f899 |
of arbitrary combinations of both design models (structures) and
|
|
|
09f899 |
artistic motifs (visual styles).</para>
|
|
|
09f899 |
|
|
|
09f899 |
<para>In the documentation area, the documentation files in LaTeX
|
|
|
09f899 |
format were migrated to Texinfo format. In this configuration,
|
|
|
09f899 |
each directory structure in the repository has a documentation
|
|
|
09f899 |
entry associated in a Texinfo structure which can be read, edited
|
|
|
09f899 |
and administered (e.g., renamed, deleted, copied) interactively
|
|
|
09f899 |
throuch <command>centos-art.sh</command>. Additionally, the
|
|
|
09f899 |
<command>texi2html</command> program was used to produced XHTML
|
|
|
09f899 |
output customized by CSS from The CentOS Webenv.</para>
|
|
|
9b9860 |
|
|
|
09f899 |
<para>Around 2011, the <command>centos-art.sh</command> script was
|
|
|
09f899 |
redesigned to start translating SVG and other XML-based files
|
|
|
09f899 |
(e.g., XHTML and Docbook files) through the
|
|
|
09f899 |
<command>xml2po</command> program and shell scripts files (e.g.,
|
|
|
09f899 |
Bash scripts) through GNU <command>gettext</command> tools. This
|
|
|
09f899 |
configuration provided a stronger interface for graphic designers,
|
|
|
09f899 |
translators and programmers to produce localized content. The SED
|
|
|
09f899 |
files are no longer used to handle translations.</para>
|
|
|
09f899 |
|
|
|
09f899 |
<para>Improve option parsing through
|
|
|
09f899 |
<command>getopt</command>.</para>
|
|
|
9b9860 |
|
|
|
09f899 |
<para>Consolidate the render , help and
|
|
|
09f899 |
locale functionalities as the most frequent tasks
|
|
|
09f899 |
performed inside the repository. Additionally, the
|
|
|
09f899 |
prepare and tuneup functionalities are
|
|
|
09f899 |
maintained as useful tasks.</para>
|
|
|
09f899 |
|
|
|
09f899 |
<para>The <command>centos-art.sh</command> script is updated to
|
|
|
09f899 |
organize functionalities in two groups: <quote>the administrative
|
|
|
09f899 |
functionalities</quote> and <quote>the productive
|
|
|
09f899 |
functionalities</quote>. The administrative functionalities cover
|
|
|
09f899 |
actions like: copying, deleting and renaming directory structures
|
|
|
09f899 |
inside the repository. Also, preparing your workstation for using
|
|
|
09f899 |
<command>centos-art.sh</command> script, making backups of the
|
|
|
09f899 |
distribution theme currently installed, installing themes created
|
|
|
09f899 |
inside repository and restoring themes from backup. On the other
|
|
|
09f899 |
hand, the productive functionalities cover actions like: content
|
|
|
09f899 |
rendition, content localization, content documentation and content
|
|
|
09f899 |
maintainance.</para>
|
|
|
9b9860 |
|
|
|
9b9860 |
</preface>
|