|
|
74c0c0 |
The CentOS Artwork Repository is supported by Subversion
|
|
|
74c0c0 |
(@url{http://subversion.tigris.org/}), a version control system which
|
|
|
74c0c0 |
allows you to keep old versions of files and directories (usually
|
|
|
74c0c0 |
source code), keep a log of who, when, and why changes occurred, etc.,
|
|
|
513258 |
like CVS, RCS or SCCS.
|
|
|
513258 |
|
|
|
513258 |
When using Subversion there is one @emph{source repository} and many
|
|
|
513258 |
@emph{working copies} of that source repository. The working copies
|
|
|
513258 |
are independent one another, can be distributed all around the world
|
|
|
513258 |
and provide a local place for designers, documentors, translators and
|
|
|
513258 |
programmers to perform their works in a descentralized way. The
|
|
|
513258 |
source repository, on the other hand, provides a central place for all
|
|
|
513258 |
independent working copies to interchange data and provides the
|
|
|
74c0c0 |
information required to permit extracting previous versions of files
|
|
|
74c0c0 |
at any time.
|
|
|
74c0c0 |
|
|
|
74c0c0 |
@subsection Repository policy
|
|
|
74c0c0 |
|
|
|
32f4f2 |
The CentOS Artwork Repository is a collaborative tool that anyone can
|
|
|
32f4f2 |
have access to. However, changing that tool in any form is something
|
|
|
32f4f2 |
that should be requested in @email{centos-devel@@centos.org} mailing
|
|
|
32f4f2 |
list. Generally, people download working copies from CentOS Artwork
|
|
|
32f4f2 |
Repository, study the repository organization, make some changes in
|
|
|
513258 |
their working copies, make some tests to verify such changes do work
|
|
|
513258 |
the way expected and finally request access to commit them up to the
|
|
|
513258 |
CentOS Artwork Repository (i.e., the source repository) for others to
|
|
|
513258 |
benefit from them.
|
|
|
74c0c0 |
|
|
|
74c0c0 |
Once you've received access to commit your changes, there is no need
|
|
|
74c0c0 |
for you to request permission again to commit other changes from your
|
|
|
74c0c0 |
working copy to CentOS Artwork Repository as long as you behave as a
|
|
|
74c0c0 |
@emph{good community citizen}.
|
|
|
74c0c0 |
|
|
|
513258 |
As a good community citizen one understand of a person who respects
|
|
|
74c0c0 |
the work already done for others and share ideas with authors before
|
|
|
74c0c0 |
changing relevant parts of their work, specially in situations when
|
|
|
513258 |
the access required to realize the changes has been granted already.
|
|
|
74c0c0 |
Of course, there is a time when conversation has taken place, the
|
|
|
74c0c0 |
paths has been traced and changing the work is so obvious that there
|
|
|
513258 |
is no need for you to talk about it; that's because you already did,
|
|
|
513258 |
you already built the trust to keep going. Anyway, the mailing list
|
|
|
74c0c0 |
mentioned above is available for sharing ideas in a way that good
|
|
|
74c0c0 |
relationship between community citizens could be constantly balanced.
|
|
|
74c0c0 |
|
|
|
74c0c0 |
The relationship between community citizens is monitored by repository
|
|
|
74c0c0 |
administrators. Repository administrators are responsible of granting
|
|
|
74c0c0 |
everything goes the way it needs to go in order for the CentOS Artwork
|
|
|
74c0c0 |
Repository to comply its mission which is: to provide a colaborative
|
|
|
74c0c0 |
tool for The CentOS Community where The CentOS Project Corporate
|
|
|
74c0c0 |
Identity is built and maintained from The CentOS Community itself.
|
|
|
74c0c0 |
|
|
|
74c0c0 |
It is also important to remember that all source files inside CentOS
|
|
|
74c0c0 |
Artwork Repository should comply the terms of GNU General Public
|
|
|
74c0c0 |
License in order for them to remain inside the repository. See file
|
|
|
74c0c0 |
@url{file:///home/centos/artwork/trunk/Scripts/COPYING,trunk/Scripts/COPYING},
|
|
|
74c0c0 |
for a complete license description.
|
|
|
74c0c0 |
|
|
|
74c0c0 |
@subsection Repository organization
|
|
|
74c0c0 |
|
|
|
74c0c0 |
The CentOS Artwork Repository uses a @file{trunk}, @file{branches},
|
|
|
74c0c0 |
and @file{tags} organization.
|
|
|
74c0c0 |
|
|
|
74c0c0 |
@table @file
|
|
|
74c0c0 |
@item trunk
|
|
|
74c0c0 |
|
|
|
74c0c0 |
The @file{trunk} directory organizes the main development line of
|
|
|
74c0c0 |
CentOS Artwork Repository. @xref{Directories trunk}, for more
|
|
|
74c0c0 |
information.
|
|
|
74c0c0 |
|
|
|
74c0c0 |
@item branches
|
|
|
74c0c0 |
|
|
|
513258 |
The @file{branches} directory oranizes intermediate development lines
|
|
|
74c0c0 |
taken from the main development line. @xref{Directories branches},
|
|
|
74c0c0 |
for more information.
|
|
|
74c0c0 |
|
|
|
74c0c0 |
@item tags
|
|
|
74c0c0 |
|
|
|
74c0c0 |
The @file{tags} directory organizes frozen development lines taken
|
|
|
513258 |
either from the main or the intermediate lines of development.
|
|
|
74c0c0 |
@xref{Directories tags}, for more information.
|
|
|
74c0c0 |
@end table
|
|
|
87b0e4 |
|
|
|
87b0e4 |
@subsection Repository file names
|
|
|
87b0e4 |
|
|
|
513258 |
Inside the CentOS Artwork Repository, file names are all written in
|
|
|
513258 |
lowercase (e.g., @samp{01-welcome.png}, @samp{splash.png},
|
|
|
87b0e4 |
@samp{anaconda_header.png}, etc.) and directory names are all written
|
|
|
87b0e4 |
capitalized (e.g., @samp{Identity}, @samp{Themes}, @samp{Motifs},
|
|
|
87b0e4 |
@samp{TreeFlower}, etc.).
|
|
|
87b0e4 |
|
|
|
74c0c0 |
@subsection Repository work lines
|
|
|
c2929c |
|
|
|
513258 |
Inside CentOS Artwork Repository there are four major work lines of
|
|
|
513258 |
production which are: @emph{graphic design}, @emph{documentation},
|
|
|
32f4f2 |
@emph{localization} and @emph{automation}. These work lines describe
|
|
|
32f4f2 |
different areas of content production. Content production inside these
|
|
|
32f4f2 |
specific areas may vary as much as persons be working on them.
|
|
|
32f4f2 |
Producing content in too many different ways may result innapropriate
|
|
|
32f4f2 |
in a collaborative environment like CentOS Artwork Repository where
|
|
|
32f4f2 |
content produced in one area depends somehow from content produced in
|
|
|
513258 |
another different area. So, a @emph{content production standard} is
|
|
|
f67de1 |
required for each available work line.
|
|
|
87b0e4 |
|
|
|
2b93ca |
@subsubsection Graphic design
|
|
|
798844 |
|
|
|
74c0c0 |
The graphic design work line exists to cover brand design, typography
|
|
|
513258 |
design and themes design mainly. Additionally, some auxiliar areas
|
|
|
f67de1 |
like icon design, illustration design, brushes design, patterns
|
|
|
f67de1 |
designs and palettes of colors are also included here for
|
|
|
f67de1 |
completeness.
|
|
|
74c0c0 |
|
|
|
74c0c0 |
Inside CentOS Artwork Repository graphic design is performed through
|
|
|
74c0c0 |
Inkscape (@url{http://www.inkscape.org/}) and GIMP
|
|
|
513258 |
(@url{http://www.gimp.org/}). The Inkscape tool is used to create and
|
|
|
74c0c0 |
manipulate scalable vector graphics and export them to PNG format; it
|
|
|
74c0c0 |
also provides a command-line interface that we use to perform massive
|
|
|
513258 |
exportation from SVG files to PNG files in automation scripts. On the
|
|
|
513258 |
other hand, GIMP is used to create and manipulate rastered images,
|
|
|
513258 |
create brushes, patterns and palettes of colors.
|
|
|
74c0c0 |
|
|
|
74c0c0 |
@quotation
|
|
|
513258 |
@strong{Tip} Combine both Inkscape and GIMP specific functionalities
|
|
|
513258 |
and possibilities to produce very beautiful images.
|
|
|
74c0c0 |
@end quotation
|
|
|
74c0c0 |
|
|
|
513258 |
The CentOS Project Corporate Visual Identity is made of different
|
|
|
513258 |
visual manifestations (e.g., Distributions, Web sites, Stationery,
|
|
|
513258 |
etc.). Visual manifestations implement the corporate identity
|
|
|
513258 |
concepts by mean of images. To produce these images, we decompose
|
|
|
513258 |
image production in @emph{design models} and @emph{artistic motifs}.
|
|
|
74c0c0 |
|
|
|
74c0c0 |
Design models provide the structural information of images (i.e.,
|
|
|
513258 |
dimension, position of common elements in the visible area,
|
|
|
513258 |
translation markers, etc.) and they are generally produced as scalable
|
|
|
513258 |
vector graphics to take advantage of SVG standard, an XML-based
|
|
|
f67de1 |
standard.
|
|
|
513258 |
|
|
|
513258 |
Artistic motifs provide the visual style (i.e., the background
|
|
|
513258 |
information, the look and feel) some design models need to complete
|
|
|
513258 |
the final image produced by automation scripts. Artistic motifs are
|
|
|
513258 |
generally produced as rastered images.
|
|
|
513258 |
|
|
|
513258 |
The result produced from combining one design model with one artistic
|
|
|
c2929c |
motif is what we know as a @emph{theme}. Inside themes directory
|
|
|
c2929c |
structure (@pxref{Directories trunk Identity Themes}), you can find
|
|
|
513258 |
several design models and several artistic motifs independently one
|
|
|
513258 |
another that can be albitrarily combined through @emph{theme
|
|
|
c2929c |
rendition}, a flexible way to produce images for different visual
|
|
|
513258 |
manifestations in very specific visual styles. Inside themes directory
|
|
|
513258 |
structure, theme rendition is performed in
|
|
|
513258 |
@file{trunk/Identity/Themes/Motifs} directory structure, the required
|
|
|
74c0c0 |
design models are taken from @file{trunk/Identity/Themes/Models}
|
|
|
513258 |
directory structure and the action itself is controlled by the
|
|
|
513258 |
@code{render} functionality of @command{centos-art.sh} script.
|
|
|
74c0c0 |
|
|
|
74c0c0 |
In addition to theme rendition you can find @emph{direct rendition},
|
|
|
513258 |
too. Direct rendition is another way of image production where there
|
|
|
513258 |
is no artistic motif at all but design models only. Direct rendition
|
|
|
f67de1 |
is very useful to produce simple content that doesn't need specific
|
|
|
f67de1 |
background information. Some of these contents are brands, icons and
|
|
|
f67de1 |
illustrations. Direct rendition is performed in
|
|
|
513258 |
@file{trunk/Identity/Images}, the required design models are taken
|
|
|
513258 |
from @file{trunk/Identity/Models} directory structure and the action
|
|
|
513258 |
itself is controlled by the @code{render} functionality of
|
|
|
513258 |
@command{centos-art.sh} script.
|
|
|
513258 |
|
|
|
513258 |
@xref{Directories trunk Identity}, for more information about The
|
|
|
513258 |
CentOS Corporate Identity and how graphic design fits on it.
|
|
|
798844 |
|
|
|
2b93ca |
@subsubsection Documentation
|
|
|
2b93ca |
|
|
|
74c0c0 |
The documentation work line exists to describe what each directory
|
|
|
513258 |
inside the CentOS Artwork Repository is for, the conceptual ideas
|
|
|
513258 |
behind them and, if possible, how automation scripts make use of them.
|
|
|
74c0c0 |
|
|
|
74c0c0 |
The CentOS Artwork Repository documentation is supported by Texinfo, a
|
|
|
74c0c0 |
documentation system that uses a single source file to produce both
|
|
|
513258 |
online information and printed output.
|
|
|
513258 |
|
|
|
513258 |
The repository documentation is organized under @file{trunk/Manual}
|
|
|
513258 |
directory structure and uses the repository directories as reference.
|
|
|
513258 |
Each directory structure in the repository has a documentation entry
|
|
|
f67de1 |
associated in the documentation manual. Documentation entries are
|
|
|
f67de1 |
stored under @file{trunk/Manual/Directories} directory structure and
|
|
|
f67de1 |
the action itself is controlled by the @code{help} functionality of
|
|
|
f67de1 |
@command{centos-art.sh} script.
|
|
|
513258 |
|
|
|
513258 |
The @code{help} functionality let you create, edit and delete
|
|
|
513258 |
documentation entries in a way that you don't need to take care of
|
|
|
74c0c0 |
updating menus, nodes and cross reference information inside the
|
|
|
74c0c0 |
manual structure; the functionality takes care of it for you.
|
|
|
74c0c0 |
However, if you need to write repository documentation that have
|
|
|
74c0c0 |
nothing to do with repository directories (e.g., Preface, Introduction
|
|
|
74c0c0 |
and similar) you need to do it manually, there is no functionality to
|
|
|
74c0c0 |
automate such process yet.
|
|
|
87b230 |
|
|
|
87b230 |
@xref{Directories trunk Manual}, for more information on
|
|
|
87b230 |
documentation.
|
|
|
2b93ca |
|
|
|
8e4e50 |
@subsubsection Localization
|
|
|
87b0e4 |
|
|
|
74c0c0 |
The localization work line exists to provide the translation messages
|
|
|
513258 |
required to produce content in different languages. Translation
|
|
|
513258 |
messages inside the repository are stored as portable objects (e.g.,
|
|
|
513258 |
.po, .pot) and machine objects (.mo) under @file{trunk/Locales}
|
|
|
513258 |
directory structure.
|
|
|
87b0e4 |
|
|
|
74c0c0 |
The procedure used to localize content is taken from @command{gettext}
|
|
|
513258 |
standard specification. Basically, translatable strings are retrived
|
|
|
f67de1 |
from source files in order to create portable objects and machine
|
|
|
f67de1 |
objects for them. These portable objects are editable files that
|
|
|
f67de1 |
contain the information used by translators to localize the
|
|
|
f67de1 |
translatable strings retrived from source files. On the other hand,
|
|
|
f67de1 |
machine objects are produced to be machine-redable only, as its name
|
|
|
f67de1 |
implies, and are produced from portable objects.
|
|
|
87b0e4 |
|
|
|
87b0e4 |
Since @command{gettext} needs to extract translatable strings form
|
|
|
513258 |
source files in order to let translators to localize them, we are
|
|
|
513258 |
limitted to use source files supported by @command{gettext} program.
|
|
|
513258 |
This is not a limitation at all since @command{gettext} supports most
|
|
|
513258 |
popular programming laguages (e.g., C, C++, Java, Bash, Python, Perl,
|
|
|
f67de1 |
PHP and GNU Awk just to mention a few ones). Nevertheless, formats
|
|
|
f67de1 |
like SVG, XHTML and Docbook don't figure as supported formats in the
|
|
|
f67de1 |
list of @command{gettext} supported source files.
|
|
|
87b230 |
|
|
|
87b230 |
To translate XML based source files like SVG, XHTML and Docbook we use
|
|
|
513258 |
the @command{xml2po} program instead. The @command{xml2po} comes with
|
|
|
513258 |
the @file{gnome-doc-utils} package and retrives translatable strings
|
|
|
f67de1 |
from one XML file to produce portable objects for them.
|
|
|
f67de1 |
|
|
|
f67de1 |
@quotation
|
|
|
f67de1 |
@strong{Note}
|
|
|
f67de1 |
Portable objects produced by @command{xml2po} have the same format
|
|
|
f67de1 |
that portable objects produced by @command{gettext}. This make the
|
|
|
f67de1 |
localization process quite consistent from translators' point of view.
|
|
|
f67de1 |
No matter what the source file be, the translator will always face the
|
|
|
f67de1 |
same translation file format (i.e., the portable object format).
|
|
|
f67de1 |
@end quotation
|
|
|
f67de1 |
|
|
|
f67de1 |
With the portable object in place, the @command{xml2po} program is
|
|
|
f67de1 |
used again to create the final translated XML, just with the same
|
|
|
f67de1 |
definition of the source file where translatable strings were taken
|
|
|
f67de1 |
from (e.g., if we extract translatable strings from a SVG file, as
|
|
|
f67de1 |
result we get the same SVG file but with translatable strings already
|
|
|
f67de1 |
localized ---obviously, for this to happen translators need to
|
|
|
f67de1 |
localize translatable strings inside the portable object first,
|
|
|
f67de1 |
localization won't appear as art of magic---). When using
|
|
|
f67de1 |
@command{xml2po}, the machine object is used as temporal file to
|
|
|
f67de1 |
produce the final translated XML file.
|
|
|
87b0e4 |
|
|
|
87b0e4 |
@quotation
|
|
|
87b0e4 |
@strong{Tip} If you want to have your content localized inside CentOS
|
|
|
74c0c0 |
Artwork Repository be sure to use source files supported either by
|
|
|
74c0c0 |
@command{gettext} or @command{xml2po} programs.
|
|
|
87b0e4 |
@end quotation
|
|
|
87b0e4 |
|
|
|
8e4e50 |
@xref{Directories trunk Locales}, for more information.
|
|
|
87b0e4 |
|
|
|
2b93ca |
@subsubsection Automation
|
|
|
2b93ca |
|
|
|
513258 |
The automation work line exists to standardize content production in
|
|
|
513258 |
CentOS Artwork Repository. There is no need to type several tasks,
|
|
|
f67de1 |
time after time, if they can be programmed into just one executable
|
|
|
f67de1 |
script.
|
|
|
87b0e4 |
|
|
|
32f4f2 |
The automation work line takes place under @file{trunk/Scripts}
|
|
|
74c0c0 |
directory structure. Here is developed the @command{centos-art.sh}
|
|
|
87b0e4 |
script, a bash script specially designed to automate most frequent
|
|
|
513258 |
tasks (e.g., rendition, documentation and localization) inside the
|
|
|
513258 |
repository. Basically, the @command{centos-art.sh} script is divided
|
|
|
513258 |
in several functionalities independent one another that perform
|
|
|
f67de1 |
specific tasks and relay on repository organization to work as
|
|
|
513258 |
expected.
|
|
|
74c0c0 |
|
|
|
74c0c0 |
@quotation
|
|
|
74c0c0 |
@strong{Tip} If you need to improve the way content is produced, look
|
|
|
32f4f2 |
inside automation scripts and make your improvement there for everyone
|
|
|
32f4f2 |
to benefit.
|
|
|
87b0e4 |
@end quotation
|
|
|
87b0e4 |
|
|
|
c2929c |
@xref{Directories trunk Scripts}, for more information on automation.
|
|
|
8e4e50 |
|
|
|
87b230 |
@subsection Connection between directories
|
|
|
87b230 |
|
|
|
513258 |
In order to produce content in CentOS Artwork Repository, it is
|
|
|
513258 |
required that all work lines be connected somehow. This is the way
|
|
|
513258 |
automation scripts can know where to retrive the information they need
|
|
|
513258 |
to work with (e.g., design model, translation messages, output
|
|
|
513258 |
location, etc.). We build this kind of connection using two path
|
|
|
513258 |
constructions named @emph{master paths} and @emph{auxiliar paths}.
|
|
|
32f4f2 |
|
|
|
513258 |
The master path points only to directories that contain the source
|
|
|
513258 |
files (e.g., SVG files) required to produce base content (e.g., PNG
|
|
|
513258 |
files) through automation scripts. Each master path inside the
|
|
|
513258 |
repository may have several auxiliar paths associated, but auxiliar
|
|
|
513258 |
paths can only have one master path associated.
|
|
|
32f4f2 |
|
|
|
32f4f2 |
The auxiliar paths can point either to directories or files. When an
|
|
|
32f4f2 |
auxiliar path points to a directory, that directory contains
|
|
|
513258 |
information that modifies somehow the content produced from master
|
|
|
f67de1 |
paths (e.g., translation messages) or provides the output information
|
|
|
f67de1 |
required to know where to store the content produced from master path.
|
|
|
f67de1 |
When an auxiliar path points to a file, that file has no other purpose
|
|
|
f67de1 |
but to document the master path it refers to.
|
|
|
f67de1 |
|
|
|
f67de1 |
The relation between auxiliar paths and master paths is realized
|
|
|
f67de1 |
combining two path informations which are: the master path itself and
|
|
|
f67de1 |
one second level directory structure from the repository. Generally,
|
|
|
f67de1 |
the master path is considered the path identifier and the second level
|
|
|
f67de1 |
directory structure taken from the repository is considered the common
|
|
|
f67de1 |
part of the path where the identifier is appended.
|
|
|
f67de1 |
|
|
|
f67de1 |
@float Figure, Path construction
|
|
|
32f4f2 |
@verbatim
|
|
|
513258 |
-----+---------------+----------------------------+------+-----------
|
|
|
513258 |
Path | Suffix | Identifier |Prefix| Type
|
|
|
513258 |
-----+---------------+----------------------------+------+-----------
|
|
|
513258 |
A | |trunk/Identity/Models/Brands| | Directory
|
|
|
513258 |
-----+---------------+----------------------------+------+-----------
|
|
|
513258 |
B | trunk/Manual/|trunk/Identity/Models/Brands|.texi | File
|
|
|
513258 |
-----+---------------+----------------------------+------+-----------
|
|
|
513258 |
C | trunk/Locales/|trunk/Identity/Models/Brands| | Directory
|
|
|
513258 |
-----+---------------+----------------------------+------+-----------
|
|
|
513258 |
D | |trunk/Identity/Images/Brands| | Directory
|
|
|
513258 |
-----+---------------+----------------------------+------+-----------
|
|
|
513258 |
E | trunk/Locales/|trunk/Identity/Images/Brands|.texi | File
|
|
|
513258 |
-----+---------------+----------------------------+------+-----------
|
|
|
513258 |
|
|
|
f67de1 |
A = Master path.
|
|
|
f67de1 |
B = Auxiliar path to documentation entry.
|
|
|
f67de1 |
C = Auxiliar path to translation messages.
|
|
|
f67de1 |
D = Auxiliar path to final content output.
|
|
|
f67de1 |
E = Auxiliar path to documentation entry.
|
|
|
32f4f2 |
@end verbatim
|
|
|
f67de1 |
@caption{Path construction.}
|
|
|
513258 |
@end float
|
|
|
513258 |
|
|
|
f67de1 |
The path information described above (@pxref{Path construction}) is
|
|
|
f67de1 |
used by direct rendition and can be taken as reference to add other
|
|
|
f67de1 |
components that are equally produced in the repository. To add new
|
|
|
513258 |
components that make use of direct rendition inside the repository,
|
|
|
513258 |
change just the component name used above (e.g., @file{Brands}) to
|
|
|
f67de1 |
that one you want to add, without changing the path structure around
|
|
|
f67de1 |
it.
|
|
|
f67de1 |
|
|
|
f67de1 |
The file organization used by theme rendition extends direct rendition
|
|
|
f67de1 |
by separating design models information from backgrounds information.
|
|
|
f67de1 |
To better understand this configuration, you can consider it as two
|
|
|
f67de1 |
independent lists, one of design models and one of artistic motifs,
|
|
|
f67de1 |
which are arbitrary combined between themselves in order to render
|
|
|
f67de1 |
images in specific ways. The possibilities of this configuration are
|
|
|
f67de1 |
endless and let us describe visual manifestations very well. For
|
|
|
f67de1 |
example, consider the organization used to produce @file{Anaconda}
|
|
|
f67de1 |
images; for CentOS distribution major release 5; using @file{Default}
|
|
|
f67de1 |
design models and version @file{3} of @file{Flame} artistic motif:
|
|
|
f67de1 |
|
|
|
f67de1 |
@float Figure, Path construction extended
|
|
|
32f4f2 |
@verbatim
|
|
|
513258 |
-----+---------------+------------------------------------------------------+------+-----------
|
|
|
513258 |
Path | Suffix | Identifier |Prefix| Type
|
|
|
513258 |
-----+---------------+------------------------------------------------------+------+-----------
|
|
|
513258 |
A | |trunk/Identity/Themes/Models/Default/Distro/5/Anaconda| | Directory
|
|
|
513258 |
-----+---------------+------------------------------------------------------+------+-----------
|
|
|
513258 |
B | trunk/Manual/|trunk/Identity/Themes/Models/Default/Distro/5/Anaconda|.texi | File
|
|
|
513258 |
-----+---------------+------------------------------------------------------+------+-----------
|
|
|
513258 |
C | trunk/Locales/|trunk/Identity/Themes/Models/Default/Distro/5/Anaconda| | Directory
|
|
|
513258 |
-----+---------------+------------------------------------------------------+------+-----------
|
|
|
513258 |
D | |trunk/Identity/Themes/Motifs/Flame/3/Distro/5/Anaconda| | Directory
|
|
|
513258 |
-----+---------------+------------------------------------------------------+------+-----------
|
|
|
513258 |
E | trunk/Locales/|trunk/Identity/Themes/Motifs/Flame/3/Distro/5/Anaconda|.texi | File
|
|
|
513258 |
-----+---------------+------------------------------------------------------+------+-----------
|
|
|
513258 |
|
|
|
f67de1 |
A = Master path.
|
|
|
f67de1 |
B = Auxiliar path to documentation entry.
|
|
|
f67de1 |
C = Auxiliar path to translation messages.
|
|
|
f67de1 |
D = Auxiliar path to final content output.
|
|
|
f67de1 |
E = Auxiliar path to documentation entry.
|
|
|
32f4f2 |
@end verbatim
|
|
|
f67de1 |
@caption{Path construction extended.}
|
|
|
513258 |
@end float
|
|
|
87b230 |
|
|
|
f67de1 |
The path information described above (@pxref{Path construction
|
|
|
f67de1 |
extended}) is used by theme rendition and can be taken as reference to
|
|
|
f67de1 |
add other components that are equally produced in the repository.
|
|
|
87b230 |
|
|
|
f67de1 |
In this configuration we can change both design model name (e.g.,
|
|
|
f67de1 |
@file{Default}) and artistic motif name (e.g., @file{Flame/3}) to
|
|
|
f67de1 |
something else in order to achieve a different result. The only
|
|
|
f67de1 |
limitations impossed are the storage space provided in the server
|
|
|
f67de1 |
machine and your own creativeness as graphic designer.
|
|
|
f67de1 |
|
|
|
f67de1 |
@quotation
|
|
|
f67de1 |
@strong{Note}
|
|
|
f67de1 |
A theme ready for implementation may consume from 100 MB to 400 MB of
|
|
|
f67de1 |
storage space. The exact space consumed by a theme depends on the
|
|
|
f67de1 |
amount of screen resolutions the theme supports. The more screen
|
|
|
f67de1 |
resolutions the theme supports, the more storage space demanded for
|
|
|
f67de1 |
it.
|
|
|
f67de1 |
@end quotation
|
|
|
f67de1 |
|
|
|
f67de1 |
In this configuration we saw how to build the path information for
|
|
|
f67de1 |
@file{Anaconda} component as part of CentOS Distribution visual
|
|
|
f67de1 |
manifestation, but that is not the only component we have inside
|
|
|
f67de1 |
CentOS Distribution visual manifestation. There are other components
|
|
|
f67de1 |
like Syslinux, Grub, Rhgb, Gdm, Kdm, Gsplash and Ksplash that share a
|
|
|
f67de1 |
similar file organization to that described above for @file{Anaconda}
|
|
|
f67de1 |
component.
|
|
|
87b0e4 |
|
|
|
87b0e4 |
@subsection Syncronizing path information
|
|
|
87b0e4 |
|
|
|
f67de1 |
Syncronizing path information is the action that keeps all path
|
|
|
513258 |
information up to date in the repository. This action implies both
|
|
|
513258 |
@emph{file movement} and @emph{file content replacement} in this very
|
|
|
f67de1 |
specific order. File movement is related to duplicate, delete and
|
|
|
f67de1 |
rename files and directories in the repository. File content
|
|
|
f67de1 |
replacement is related to replace information, path information in
|
|
|
f67de1 |
this case, inside files in the repository.
|
|
|
513258 |
|
|
|
513258 |
The order followed to syncronize path information is relevant because
|
|
|
f67de1 |
the versioned nature of the files we are working with. We don't
|
|
|
f67de1 |
perform file content replacement first because that would imply a
|
|
|
f67de1 |
repository change which will immediatly demmand a commit in order for
|
|
|
f67de1 |
actions like duplicate, delete or rename to take place. However, if we
|
|
|
f67de1 |
perform file movement first, it is possible to commit both file moved
|
|
|
f67de1 |
and file content replacements as if they were just one change. In this
|
|
|
513258 |
case the file content replacement takes palce in the target location
|
|
|
f67de1 |
that have been duplicated or renamed, not the one use as source
|
|
|
f67de1 |
location. This configuration is specially useful when files are
|
|
|
f67de1 |
renamed (i.e., one file is copied from a source location to a target
|
|
|
f67de1 |
location and then the source location of it is removed from
|
|
|
f67de1 |
repository).
|
|
|
87b0e4 |
|
|
|
87b0e4 |
@quotation
|
|
|
513258 |
@strong{Warning} There is no support for URLs actions inside
|
|
|
513258 |
@command{centos-art.sh} script. The @command{centos-art.sh} script is
|
|
|
513258 |
designed to work with local files inside the working copy only. If you
|
|
|
513258 |
need to perform URL actions directly, use Subversion commands instead.
|
|
|
87b0e4 |
@end quotation
|
|
|
87b0e4 |
|
|
|
f67de1 |
When one master path is changed it is required that all related
|
|
|
f67de1 |
auxiliar paths be changed, too. This is required in order for master
|
|
|
f67de1 |
paths to retain their relation with auxiliar paths. This way,
|
|
|
f67de1 |
automation scripts are able to know where to retrive translation
|
|
|
f67de1 |
messages from, where to store final output images to and where to look
|
|
|
f67de1 |
for documentation. If relation between master paths and auxiliar paths
|
|
|
f67de1 |
is lost, there is no way for automation scripts to know where to
|
|
|
f67de1 |
retrive the information they need.
|
|
|
f67de1 |
|
|
|
f67de1 |
The auxiliar paths should never be modified under any reason but to
|
|
|
f67de1 |
satisfy the relationship with the master path. Liberal change of
|
|
|
f67de1 |
auxiliar paths may suppress the conceptual idea they were initially
|
|
|
f67de1 |
created for; and certainly, automation scripts may stop working as
|
|
|
f67de1 |
expected. The update direction to rename path information must be from
|
|
|
f67de1 |
master path to auxiliar path and never the opposite.
|
|
|
f67de1 |
|
|
|
f67de1 |
The relation between master and auxiliar paths is useful to keep
|
|
|
f67de1 |
repository organized but introduce some complications when we work
|
|
|
f67de1 |
with files that use master path information as reference to build
|
|
|
f67de1 |
structural information. This is the case of repository documentation
|
|
|
f67de1 |
manual source files where inclusions, menus, nodes and cross
|
|
|
f67de1 |
references are built using master path information as reference. Now,
|
|
|
f67de1 |
to see what kind of complication we are talking about, consider what
|
|
|
f67de1 |
would happen to a structural definitions (i.e., inlusions, menus,
|
|
|
f67de1 |
nodes and cross refereces) already set in the manual from one master
|
|
|
f67de1 |
path that is suddenly renamed to something different. If the path
|
|
|
f67de1 |
information is not syncronized, at this point, we lose connection
|
|
|
f67de1 |
between the master path and the auxiliar path created to store the
|
|
|
f67de1 |
related documentation entry, as well as the related structural
|
|
|
f67de1 |
definitions that end up pointing to a master path that no longer
|
|
|
f67de1 |
exist.
|
|
|
f67de1 |
|
|
|
f67de1 |
The syncronization of path information is aimed to solve these kind of
|
|
|
f67de1 |
issues.
|
|
|
f67de1 |
|
|
|
74c0c0 |
@subsection Extending repository organization
|
|
|
87b0e4 |
|
|
|
513258 |
Occasionly, you may find that new components of The CentOS Project
|
|
|
513258 |
Corporate Identity need to be added to the repository in order to work
|
|
|
513258 |
them out. If that is the case, the first question we need to ask
|
|
|
513258 |
ourselves, before start to create directories blindly all over, is:
|
|
|
513258 |
@emph{What is the right place to store it?}
|
|
|
87b0e4 |
|
|
|
87b230 |
The best place to find answers is in The CentOS Community (see page
|
|
|
87b230 |
@url{http://wiki.centos.org/GettingHelp}), but going there with hands
|
|
|
87b230 |
empty is not good idea. It may give the impression you don't really
|
|
|
87b230 |
care about. Instead, consider the following suggestions to find your
|
|
|
87b230 |
own comprehension in order to make your own propositions based on it.
|
|
|
87b230 |
|
|
|
513258 |
When extending respository structure it is very useful to bear in mind
|
|
|
513258 |
The CentOS Project Corporate Identity Structure (@pxref{Directories
|
|
|
513258 |
trunk Identity}) The CentOS Mission and The CentOS Release Schema. The
|
|
|
513258 |
rest is just matter of choosing appropriate names. It is also worth to
|
|
|
513258 |
know that each directory in the repository responds to a conceptual
|
|
|
513258 |
idea that justifies its existence.
|
|
|
513258 |
|
|
|
513258 |
To build a directory structure, you need to define the conceptual idea
|
|
|
513258 |
first and later create the directory. There are some locations inside
|
|
|
513258 |
the repository that already define some concepts you probably want to
|
|
|
513258 |
reuse. For example, @file{trunk/Identity/Themes/Motifs} to store theme
|
|
|
513258 |
artistic motifs, @file{trunk/Identity/Themes/Models} to store theme
|
|
|
513258 |
design models, @file{trunk/Manual} to store documentation files,
|
|
|
513258 |
@file{trunk/Locales} to store translation messages,
|
|
|
513258 |
@file{trunk/Scripts} to store automation scripts and so on.
|
|
|
87b230 |
|
|
|
87b230 |
To illustrate this desition process let's consider the
|
|
|
513258 |
@file{trunk/Identity/Themes/Motifs/TreeFlower/3} directory structure
|
|
|
513258 |
as example. This directory can be read as: the theme development line
|
|
|
513258 |
of version @file{3} of @file{TreeFlower} artistic motif. Additional,
|
|
|
513258 |
we can identify that artistic motifs are part of themes as well as
|
|
|
513258 |
themes are part of The CentOS Project Corporate Identity. These
|
|
|
513258 |
concepts are better described independently in each documentation
|
|
|
513258 |
entry related to the directory structure as it is respectively shown
|
|
|
513258 |
in the list of commands bellow.
|
|
|
87b0e4 |
|
|
|
87b0e4 |
@verbatim
|
|
|
74c0c0 |
centos-art help --read turnk
|
|
|
74c0c0 |
centos-art help --read turnk/Identity
|
|
|
74c0c0 |
centos-art help --read turnk/Identity/Themes
|
|
|
74c0c0 |
centos-art help --read turnk/Identity/Themes/Motifs
|
|
|
74c0c0 |
centos-art help --read turnk/Identity/Themes/Motifs/TreeFlower
|
|
|
513258 |
centos-art help --read turnk/Identity/Themes/Motifs/TreeFlower/3
|
|
|
87b0e4 |
@end verbatim
|
|
|
87b0e4 |
|
|
|
513258 |
The concepts behind other location can be found in the same way
|
|
|
513258 |
described above, just change the path information used above to the
|
|
|
87b230 |
one you are trying to know concepts for.
|