diff options
author | Dan Armak <danarmak@gentoo.org> | 2001-09-30 21:43:05 +0000 |
---|---|---|
committer | Dan Armak <danarmak@gentoo.org> | 2001-09-30 21:43:05 +0000 |
commit | 967dd7f601db7e3c6ce170510a1fe718312cc268 (patch) | |
tree | df40138b810d55b70fca0ad40f325c0c716fc69b /eclass | |
parent | added modutils-2.4.9 to try and fix a problem for gugi (diff) | |
download | gentoo-2-967dd7f601db7e3c6ce170510a1fe718312cc268.tar.gz gentoo-2-967dd7f601db7e3c6ce170510a1fe718312cc268.tar.bz2 gentoo-2-967dd7f601db7e3c6ce170510a1fe718312cc268.zip |
welcome the new eclass-howto!
multiple formats for now. someone PLEASE make the sgml wok with the
linux docs.
Diffstat (limited to 'eclass')
-rw-r--r-- | eclass/eclass-howto.lyx | 635 | ||||
-rw-r--r-- | eclass/eclass-howto.sgml | 317 | ||||
-rw-r--r-- | eclass/eclass-howto.txt | 323 | ||||
-rw-r--r-- | eclass/kde-i18n.eclass | 4 | ||||
-rw-r--r-- | eclass/notes.txt | 1 |
5 files changed, 1278 insertions, 2 deletions
diff --git a/eclass/eclass-howto.lyx b/eclass/eclass-howto.lyx new file mode 100644 index 000000000000..5d17d6f35729 --- /dev/null +++ b/eclass/eclass-howto.lyx @@ -0,0 +1,635 @@ +#LyX 1.1 created this file. For more info see http://www.lyx.org/ +\lyxformat 218 +\textclass docbook-chapter +\language english +\inputencoding auto +\fontscheme default +\graphics default +\paperfontsize default +\spacing single +\papersize Default +\paperpackage a4 +\use_geometry 0 +\use_amsmath 0 +\paperorientation portrait +\secnumdepth 3 +\tocdepth 3 +\paragraph_separation indent +\defskip medskip +\quotes_language english +\quotes_times 2 +\papercolumns 1 +\papersides 1 +\paperpagestyle default + +\layout Title + +eclass howto +\layout Author + +Dan Armak +\layout Date + +30/9/01 +\layout Section + +Introduction +\layout Standard + +eclasses are parts of ebuilds; that is, they have the same syntax ebuilds + do, but do not define all the required variables and functions. + ebuilds can inherit from eclasses, and eclasses can inherit from other + eclasses. + As in OOP, this is used to ensure maximum code reuse among similar ebuilds. +\layout Standard + +The most similar group of ebuilds is the kde apps. + These have been selected to be the test case for this first incarnation + of eclasses. + Currently test ebuilds are available for all of kde-2.2.1 (as kde*-2.2.1-r1), + kdevelop-2.0.1 and koffice-1.1. + Many others will follow. +\layout Standard + +Section two explains how eclasses work.Section three shows a sample inheriting + ebuild. +\layout Subsection + +Notes on this document +\layout Itemize + + +\emph on +ebuild variables/functions +\emph default + refers to those used in std. + ebuilds e.g. + $S, $P, src_unpack()... +\layout Section + +The eclasses +\layout Standard + +The best way of becoming familiar with the current eclass structure is an + explanation of what each eclass does. +\layout Subsection + +inherit.eclass +\layout Standard + +Defines inherit() function which handles sourcing of eclasses. +\layout Standard + +Syntax of inheriting: we define a simple function inherit(): +\layout Code + +ECLASSDIR=/usr/portage/eclass +\layout Code + +inherit() { +\layout Code + + while [ "$1" ]; do +\layout Code + + source ${ECLASSDIR}/${1}.eclass +\layout Code + + shift +\layout Code + + done +\layout Code + +} +\layout Standard + +This function simply sources files from a hard-coded location. + If, in the future, we will decide to move eclasses to a different location + or to introduce more +\begin_inset Quotes eld +\end_inset + +formats +\begin_inset Quotes erd +\end_inset + + (like drobbins' projected +\emph on +xbuilds +\emph default +), any name-to-file resolution code will go in here. +\layout Standard + +This function is the entire contents of inherit.eclass. + In the future, once eclasses are considered to be stable, this function + will live in ebuild.sh, and every ebuild will be able to use it. + For now, we don't want to make a new version of portage just for this, + so we put this function in a separate eclass. + Every inheriting ebuild begins with these two lines: +\layout Standard + +. + /usr/portage/eclass/inherit.eclass || die +\layout Standard + +inherit kde-base || die +\layout Standard + +Once the inherit() function goes into ebuild.sh, we can drop the first line; + there will be no further change necessary. +\layout Standard + +Eclasses do not need this first line, since they are always sourced from + an ebuild which has it. +\layout Subsection + +virtual.eclass +\layout Standard + +Defines empty variables and functions; defines EXPORT_FUNCTIONS(). +\layout Standard + +This eclass is inherited by most other eclasses e.g. + base, kde*. + As a rule, any eclass that defines some of the base functions needs it. + Therefore the only ebuilds which don't get it are the ones that only inherit + one of the smaller eclasses e.g. + c, autoconf. +\layout Standard + +It defines all ebuild vars and funcs to be empty. +\layout Standard + +It also defines the EXPORT_FUNCTIONS() function which looks like this: +\layout Code + +EXPORT_FUNCTIONS() { +\layout Code + + while [ "$1" ]; do +\layout Code + + eval "$1() { ${ECLASS}_$1 ; }" > /dev/null +\layout Code + + shift +\layout Code + + done +\layout Code + +} +\layout Standard + +This means that after foo.eclass has defined e.g. + src_unpack() and src_install(), it says: +\layout Standard + +ECLASS=foo +\layout Standard + +EXPORT_FUNCTIONS src_unpack src_install +\layout Standard + +Actually, the ECLASS setting is put at the beginning of the eclass, directly + after the inherit statements. + It will in the future be used by other functions as well. + Someday we will (I hope) adapt the portage ebuild filename->name algorithm + and get the ECLASS setting the same way we do $P and $PN. +\layout Standard + +EXPORT_FUNCTIONS() creates stub functions called ${ECLASS}_blah for every + parameter blah passed to it. + The stub function does nothing but call blah. +\layout Standard + +When you inherit more than one eclass (almost always), your ebuild functions + are those defined by the 1st eclass inherited. + Since eclasses usually inherit other eclasses, you do not want to keep + track of that. + Instead, you prefix all your functions from foo.eclass with foo_, or ${ECLASS}_. + This way, people can call a specific function from a specific eclass and + know what they are going to get. +\layout Standard + +Because you still want default functions to be defined with the original + ebuild names, you call EXPORT_FUNCTIONS() at the end of every eclass. + This makes sure that the default functions you passed as parameters are + stubs calling the ones you just defined. +\layout Standard + +I looked at adding ${EBUILD}_ instead of literal strings to the actual function + definitions, but the bash syntax for that is too ugly. +\layout Subsubsection + +ebuild function sections +\layout Standard + +Although this is not an integral part of eclasses, this is a good place + to introduce function sections. + +\layout Standard + +One rarely uses predefined functions as-is; you usually want to extend them. + Once they have unique names (foo_src_unpack) it's easy to add code that + executes before or after them. + Function sections break them down and allow code to execute between any + two sections. +\layout Standard + +The implementation is simple. + Let's take as an example the src_compile() function from base.eclass. + It looks like this: +\layout Code + +base_src_compile() { +\layout Code + +./configure || die +\layout Code + +make || die +\layout Code + +} +\layout Standard + +Here is the same function, divided into sections: +\layout Code + +base_src_compile() { +\layout Code + +\SpecialChar ~ + +\layout Code + +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ + [ -z "$1" ] && base_src_compile all +\layout Code + +\SpecialChar ~ + +\layout Code + +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ + while [ "$1" ]; do +\layout Code + +\layout Code + +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +case $1 in +\layout Code + +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ + configure) +\layout Code + +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +./configure || die;; +\layout Code + +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ + make) +\layout Code + +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +make || die;; +\layout Code + +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ + all) +\layout Code + +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +base_src_compile configure make;; +\layout Code + +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ +esac +\layout Code + +\layout Code + +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ + shift +\layout Code + +\SpecialChar ~ +\SpecialChar ~ +\SpecialChar ~ + done +\layout Code + +\SpecialChar ~ + +\layout Code + +} +\layout Standard + +The code has been divided into two +\begin_inset Quotes eld +\end_inset + +sections +\begin_inset Quotes erd +\end_inset + +: +\emph on +configure +\emph default + and +\emph on +make +\emph default +. + In our simple example, they correspond to the two commands in the original + function. +\layout Standard + +In the center of the new function is a while;case...esac;shift;done block. + This block matches the parameters to the functions with the defined section + names and executes the corresponding lines of code. +\layout Standard + +The special case +\emph on +all +\emph default + calls the same function recursively with a list of sections in order. + It's up to the eclass's author to maintain this list, which is very important. +\layout Standard + +The line before the block says that a call without parameters should be + treated the same as a call with the single parameter +\emph on +all. + +\emph default +As you see, this function recurses a lot. + Note, however, that the call +\emph on +base_src_compile configure all make +\emph default +is also legal; it will execute +\emph on +base_src_compile configure configure make make +\emph default +. +\layout Standard + +Now, in your ebuild (or eclass) that inherits from base.eclass, you get the + stub function src_compile which calls base_src_compile without parameters. + This makes base_src_compile execute +\emph on +all +\emph default +, that is, all its sections. + You can leave it as-is. + If you wish to extend it, you define a new src_compile and call base_src_compil +e a section at a time: +\layout Code + +src_compile() { +\layout Code + + myfunc1 +\layout Code + + base_src_compile configure +\layout Code + + myfunc2 +\layout Code + + base_src_compile make +\layout Code + +} +\layout Standard + +The only way to know what functions contain what sections is to read the + eclasses. +\layout Subsection + +base.eclass +\layout Standard + +This eclass defines some default variables and functions, similar to those + you'd get by default in a non-inheriting ebuild. + For example, it defines: +\layout Code + +base_src_unpack() { unpack ${A}; } +\layout Standard + +Only with sections, of course. +\layout Standard + +It is inherited by higher-level eclasses like the kde ones. +\layout Subsection + +kde.eclass +\layout Standard + +Used by all kde apps, whether directly or indirectly. + This is a higher-level eclass, which is intended to provide not only sensible + defaults but functions which can be used as-is more often then not. + +\layout Standard + +It inherits c, autoconf and base. +\layout Standard + +Read it to find out what it defines. + It is quite self-explanatory. +\layout Standard + +Briefly, it handles all standard kde-2.1* and 2.2* apps that need configure/make/m +ake install cycles. + It handles all the std. + configure options e.g. + objprelink. + It also adds kdelibs and qt to DEPEND. +\layout Subsection + +kde-base.eclass +\layout Standard + +Meant for kde apps part of the core kde distribution. +\layout Standard + +Differences from kde.eclass: +\layout Itemize + +Sets appropriate DESCRIPTION and HOMEPAGE=www.kde.org. +\layout Itemize + +Sets default download path to the correct location on ftp.kde.org and several + of its mirrors. +\layout Subsection + +kde-i18n.eclass +\layout Standard + +Meant for the kde-i18n-* packages. + Niche use. +\layout Standard + +In fact, all kde-i18n ebuilds are completely identical and so all they have + to do is inherit from this eclass. +\layout Standard + +Differences from kde.eclass: +\layout Standard + +Many. + Doesn't inherit c. + Doesn't depend on qt. + Provides virtual/kde-i18n-${PV}. + Doesn't have +\emph on +myconf +\emph default +section in src_compile(). + Doesn't have any sections in src_install(). + Probably something else I forgot as well. +\layout Subsection + +c.eclass +\layout Standard + +Adds gcc and glibc to DEPEND and RDEPEND. + Not meant to be used alone, inherited by kde*. +\layout Subsection + +autoconf.eclass +\layout Standard + +Adds make/automake/autoconf to DEPEND. + Not meant to be used alone, inherited by kde*. +\layout Subsection + +debug.eclass +\layout Standard + +Will be written soon. + Will provide verbose debug output functions to centralise the numerous + +\emph on +echo +\emph default +s I have scattered around the eclasses. +\layout Section + +The inheriting ebuilds +\layout Standard + +Not much here as yet. + Look at the kde*-2.2.1-r1 ebuilds for examples. + As a rule, read the eclass you are inheriting from and put any necessary + changes in your ebuild. +\layout Standard + +Remember: always extend variables and fnctions. + You should almost never need to replace them. +\the_end diff --git a/eclass/eclass-howto.sgml b/eclass/eclass-howto.sgml new file mode 100644 index 000000000000..2c7670e10108 --- /dev/null +++ b/eclass/eclass-howto.sgml @@ -0,0 +1,317 @@ +<!doctype chapter public "-//OASIS//DTD DocBook V3.1//EN"> + +<chapter lang="en"> +<!-- DocBook file was created by LyX 1.1 + See http://www.lyx.org/ for more information --> + <title> + eclass howto + </title> + <author> + Dan Armak + </author> + <date> + 30/9/01 + </date> + <sect1> + <title> + Introduction + </title> + <para> + eclasses are parts of ebuilds; that is, they have the same syntax ebuilds do, but do not define all the required variables and functions. ebuilds can inherit from eclasses, and eclasses can inherit from other eclasses. As in OOP, this is used to ensure maximum code reuse among similar ebuilds. + </para> + <para> + The most similar group of ebuilds is the kde apps. These have been selected to be the test case for this first incarnation of eclasses. Currently test ebuilds are available for all of kde-2.2.1 (as kde*-2.2.1-r1), kdevelop-2.0.1 and koffice-1.1. Many others will follow. + </para> + <para> + Section two explains how eclasses work.Section three shows a sample inheriting ebuild. + </para> + <sect2> + <title> + Notes on this document + </title> + <itemizedlist> + <listitem> + <para> + ebuild variables/functions</emphasis> refers to those used in std. ebuilds e.g. $S, $P, src_unpack()... + </para> + </listitem> + </itemizedlist> + </sect2> + </sect1> + <sect1> + <title> + The eclasses + </title> + <para> + The best way of becoming familiar with the current eclass structure is an explanation of what each eclass does. + </para> + <sect2> + <title> + inherit.eclass + </title> + <para> + Defines inherit() function which handles sourcing of eclasses. + </para> + <para> + Syntax of inheriting: we define a simple function inherit(): + </para> + <programlisting> +<![ CDATA [ECLASSDIR=/usr/portage/eclass +]]><![ CDATA [inherit() { +]]><![ CDATA [ while [ "$1" ]; do +]]><![ CDATA [ source ${ECLASSDIR}/${1}.eclass +]]><![ CDATA [ shift +]]><![ CDATA [ done +]]><![ CDATA [} +]]> </programlisting> + <para> + This function simply sources files from a hard-coded location. If, in the future, we will decide to move eclasses to a different location or to introduce more “formats” (like drobbins' projected <emphasis>xbuilds</emphasis>), any name-to-file resolution code will go in here. + </para> + <para> + This function is the entire contents of inherit.eclass. In the future, once eclasses are considered to be stable, this function will live in ebuild.sh, and every ebuild will be able to use it. For now, we don't want to make a new version of portage just for this, so we put this function in a separate eclass. Every inheriting ebuild begins with these two lines: + </para> + <para> + . /usr/portage/eclass/inherit.eclass || die + </para> + <para> + inherit kde-base || die + </para> + <para> + Once the inherit() function goes into ebuild.sh, we can drop the first line; there will be no further change necessary. + </para> + <para> + Eclasses do not need this first line, since they are always sourced from an ebuild which has it. + </para> + </sect2> + <sect2> + <title> + virtual.eclass + </title> + <para> + Defines empty variables and functions; defines EXPORT_FUNCTIONS(). + </para> + <para> + This eclass is inherited by most other eclasses e.g. base, kde*. As a rule, any eclass that defines some of the base functions needs it. Therefore the only ebuilds which don't get it are the ones that only inherit one of the smaller eclasses e.g. c, autoconf. + </para> + <para> + It defines all ebuild vars and funcs to be empty. + </para> + <para> + It also defines the EXPORT_FUNCTIONS() function which looks like this: + </para> + <programlisting> +<![ CDATA [EXPORT_FUNCTIONS() { +]]><![ CDATA [ while [ "$1" ]; do +]]><![ CDATA [ eval "$1() { ${ECLASS}_$1 ; }" > /dev/null +]]><![ CDATA [ shift +]]><![ CDATA [ done +]]><![ CDATA [} +]]> </programlisting> + <para> + This means that after foo.eclass has defined e.g. src_unpack() and src_install(), it says: + </para> + <para> + ECLASS=foo + </para> + <para> + EXPORT_FUNCTIONS src_unpack src_install + </para> + <para> + Actually, the ECLASS setting is put at the beginning of the eclass, directly after the inherit statements. It will in the future be used by other functions as well. Someday we will (I hope) adapt the portage ebuild filename->name algorithm and get the ECLASS setting the same way we do $P and $PN. + </para> + <para> + EXPORT_FUNCTIONS() creates stub functions called ${ECLASS}_blah for every parameter blah passed to it. The stub function does nothing but call blah. + </para> + <para> + When you inherit more than one eclass (almost always), your ebuild functions are those defined by the 1st eclass inherited. Since eclasses usually inherit other eclasses, you do not want to keep track of that. Instead, you prefix all your functions from foo.eclass with foo_, or ${ECLASS}_. This way, people can call a specific function from a specific eclass and know what they are going to get. + </para> + <para> + Because you still want default functions to be defined with the original ebuild names, you call EXPORT_FUNCTIONS() at the end of every eclass. This makes sure that the default functions you passed as parameters are stubs calling the ones you just defined. + </para> + <para> + I looked at adding ${EBUILD}_ instead of literal strings to the actual function definitions, but the bash syntax for that is too ugly. + </para> + <sect3> + <title> + ebuild function sections + </title> + <para> + Although this is not an integral part of eclasses, this is a good place to introduce function sections. + </para> + <para> + One rarely uses predefined functions as-is; you usually want to extend them. Once they have unique names (foo_src_unpack) it's easy to add code that executes before or after them. Function sections break them down and allow code to execute between any two sections. + </para> + <para> + The implementation is simple. Let's take as an example the src_compile() function from base.eclass. It looks like this: + </para> + <programlisting> +<![ CDATA [base_src_compile() { +]]><![ CDATA [./configure || die +]]><![ CDATA [make || die +]]><![ CDATA [} +]]> </programlisting> + <para> + Here is the same function, divided into sections: + </para> + <programlisting> +<![ CDATA [base_src_compile() { +]]><![ CDATA [ +]]><![ CDATA [ [ -z "$1" ] && base_src_compile all +]]><![ CDATA [ +]]><![ CDATA [ while [ "$1" ]; do +]]><![ CDATA [ +]]><![ CDATA [ case $1 in +]]><![ CDATA [ configure) +]]><![ CDATA [ ./configure || die;; +]]><![ CDATA [ make) +]]><![ CDATA [ make || die;; +]]><![ CDATA [ all) +]]><![ CDATA [ base_src_compile configure make;; +]]><![ CDATA [ esac +]]><![ CDATA [ +]]><![ CDATA [ shift +]]><![ CDATA [ done +]]><![ CDATA [ +]]><![ CDATA [} +]]> </programlisting> + <para> + The code has been divided into two “sections”: <emphasis>configure</emphasis> and <emphasis>make</emphasis>. In our simple example, they correspond to the two commands in the original function. + </para> + <para> + In the center of the new function is a while;case...esac;shift;done block. This block matches the parameters to the functions with the defined section names and executes the corresponding lines of code. + </para> + <para> + The special case <emphasis>all</emphasis> calls the same function recursively with a list of sections in order. It's up to the eclass's author to maintain this list, which is very important. + </para> + <para> + The line before the block says that a call without parameters should be treated the same as a call with the single parameter <emphasis>all. </emphasis>As you see, this function recurses a lot. Note, however, that the call <emphasis>base_src_compile configure all make </emphasis>is also legal; it will execute <emphasis>base_src_compile configure configure make make</emphasis>. + </para> + <para> + Now, in your ebuild (or eclass) that inherits from base.eclass, you get the stub function src_compile which calls base_src_compile without parameters. This makes base_src_compile execute <emphasis>all</emphasis>, that is, all its sections. You can leave it as-is. If you wish to extend it, you define a new src_compile and call base_src_compile a section at a time: + </para> + <programlisting> +<![ CDATA [src_compile() { +]]><![ CDATA [ myfunc1 +]]><![ CDATA [ base_src_compile configure +]]><![ CDATA [ myfunc2 +]]><![ CDATA [ base_src_compile make +]]><![ CDATA [} +]]> </programlisting> + <para> + The only way to know what functions contain what sections is to read the eclasses. + </para> + </sect3> + </sect2> + <sect2> + <title> + base.eclass + </title> + <para> + This eclass defines some default variables and functions, similar to those you'd get by default in a non-inheriting ebuild. For example, it defines: + </para> + <programlisting> +<![ CDATA [base_src_unpack() { unpack ${A}; } +]]> </programlisting> + <para> + Only with sections, of course. + </para> + <para> + It is inherited by higher-level eclasses like the kde ones. + </para> + </sect2> + <sect2> + <title> + kde.eclass + </title> + <para> + Used by all kde apps, whether directly or indirectly. This is a higher-level eclass, which is intended to provide not only sensible defaults but functions which can be used as-is more often then not. + </para> + <para> + It inherits c, autoconf and base. + </para> + <para> + Read it to find out what it defines. It is quite self-explanatory. + </para> + <para> + Briefly, it handles all standard kde-2.1* and 2.2* apps that need configure/make/make install cycles. It handles all the std. configure options e.g. objprelink. It also adds kdelibs and qt to DEPEND. + </para> + </sect2> + <sect2> + <title> + kde-base.eclass + </title> + <para> + Meant for kde apps part of the core kde distribution. + </para> + <para> + Differences from kde.eclass: + </para> + <itemizedlist> + <listitem> + <para> + Sets appropriate DESCRIPTION and HOMEPAGE=www.kde.org. + </para> + </listitem> + <listitem> + <para> + Sets default download path to the correct location on ftp.kde.org and several of its mirrors. + </para> + </listitem> + </itemizedlist> + </sect2> + <sect2> + <title> + kde-i18n.eclass + </title> + <para> + Meant for the kde-i18n-* packages. Niche use. + </para> + <para> + In fact, all kde-i18n ebuilds are completely identical and so all they have to do is inherit from this eclass. + </para> + <para> + Differences from kde.eclass: + </para> + <para> + Many. Doesn't inherit c. Doesn't depend on qt. Provides virtual/kde-i18n-${PV}. Doesn't have <emphasis>myconf </emphasis>section in src_compile(). Doesn't have any sections in src_install(). Probably something else I forgot as well. + </para> + </sect2> + <sect2> + <title> + c.eclass + </title> + <para> + Adds gcc and glibc to DEPEND and RDEPEND. Not meant to be used alone, inherited by kde*. + </para> + </sect2> + <sect2> + <title> + autoconf.eclass + </title> + <para> + Adds make/automake/autoconf to DEPEND. Not meant to be used alone, inherited by kde*. + </para> + </sect2> + <sect2> + <title> + debug.eclass + </title> + <para> + Will be written soon. Will provide verbose debug output functions to centralise the numerous <emphasis>echo</emphasis>s I have scattered around the eclasses. + </para> + </sect2> + </sect1> + <sect1> + <title> + The inheriting ebuilds + </title> + <para> + Not much here as yet. Look at the kde*-2.2.1-r1 ebuilds for examples. As a rule, read the eclass you are inheriting from and put any necessary changes in your ebuild. + </para> + <para> + Remember: always extend variables and fnctions. You should almost never need to replace them. + </para> + </sect1> + + +</chapter> diff --git a/eclass/eclass-howto.txt b/eclass/eclass-howto.txt new file mode 100644 index 000000000000..d9ee3c9b5a20 --- /dev/null +++ b/eclass/eclass-howto.txt @@ -0,0 +1,323 @@ + + +eclass howto + +Dan Armak + +30/9/01 + +1 Introduction + +eclasses are parts of ebuilds; that is, they have the same +syntax ebuilds do, but do not define all the required variables +and functions. ebuilds can inherit from eclasses, and eclasses +can inherit from other eclasses. As in OOP, this is used +to ensure maximum code reuse among similar ebuilds. + +The most similar group of ebuilds is the kde apps. These +have been selected to be the test case for this first incarnation +of eclasses. Currently test ebuilds are available for all +of kde-2.2.1 (as kde*-2.2.1-r1), kdevelop-2.0.1 and koffice-1.1. +Many others will follow. + +Section two explains how eclasses work.Section three shows +a sample inheriting ebuild. + +1.1 Notes on this document + +* ebuild variables/functions refers to those used in std. + ebuilds e.g. $S, $P, src_unpack()... + +2 The eclasses + +The best way of becoming familiar with the current eclass +structure is an explanation of what each eclass does. + +2.1 inherit.eclass + +Defines inherit() function which handles sourcing of eclasses. + +Syntax of inheriting: we define a simple function inherit(): + +ECLASSDIR=/usr/portage/eclass + +inherit() { + + while [ "$1" ]; do + + source ${ECLASSDIR}/${1}.eclass + + shift + + done + +} + +This function simply sources files from a hard-coded location. +If, in the future, we will decide to move eclasses to a +different location or to introduce more "formats" +(like drobbins' projected xbuilds), any name-to-file resolution +code will go in here. + +This function is the entire contents of inherit.eclass. In +the future, once eclasses are considered to be stable, this +function will live in ebuild.sh, and every ebuild will be +able to use it. For now, we don't want to make a new version +of portage just for this, so we put this function in a separate +eclass. Every inheriting ebuild begins with these two lines: + +. /usr/portage/eclass/inherit.eclass || die + +inherit kde-base || die + +Once the inherit() function goes into ebuild.sh, we can drop +the first line; there will be no further change necessary. + +Eclasses do not need this first line, since they are always +sourced from an ebuild which has it. + +2.2 virtual.eclass + +Defines empty variables and functions; defines EXPORT_FUNCTIONS(). + +This eclass is inherited by most other eclasses e.g. base, +kde*. As a rule, any eclass that defines some of the base +functions needs it. Therefore the only ebuilds which don't +get it are the ones that only inherit one of the smaller +eclasses e.g. c, autoconf. + +It defines all ebuild vars and funcs to be empty. + +It also defines the EXPORT_FUNCTIONS() function which looks +like this: + +EXPORT_FUNCTIONS() { + + while [ "$1" ]; do + + eval "$1() { ${ECLASS}_$1 ; }" > /dev/null + + shift + + done + +} + +This means that after foo.eclass has defined e.g. src_unpack() +and src_install(), it says: + +ECLASS=foo + +EXPORT_FUNCTIONS src_unpack src_install + +Actually, the ECLASS setting is put at the beginning of the +eclass, directly after the inherit statements. It will in +the future be used by other functions as well. Someday we +will (I hope) adapt the portage ebuild filename->name algorithm +and get the ECLASS setting the same way we do $P and $PN. + +EXPORT_FUNCTIONS() creates stub functions called ${ECLASS}_blah +for every parameter blah passed to it. The stub function +does nothing but call blah. + +When you inherit more than one eclass (almost always), your +ebuild functions are those defined by the 1st eclass inherited. +Since eclasses usually inherit other eclasses, you do not +want to keep track of that. Instead, you prefix all your +functions from foo.eclass with foo_, or ${ECLASS}_. This +way, people can call a specific function from a specific +eclass and know what they are going to get. + +Because you still want default functions to be defined with +the original ebuild names, you call EXPORT_FUNCTIONS() at +the end of every eclass. This makes sure that the default +functions you passed as parameters are stubs calling the +ones you just defined. + +I looked at adding ${EBUILD}_ instead of literal strings +to the actual function definitions, but the bash syntax +for that is too ugly. + +2.2.1 ebuild function sections + +Although this is not an integral part of eclasses, this is +a good place to introduce function sections. + +One rarely uses predefined functions as-is; you usually want +to extend them. Once they have unique names (foo_src_unpack) +it's easy to add code that executes before or after them. +Function sections break them down and allow code to execute +between any two sections. + +The implementation is simple. Let's take as an example the +src_compile() function from base.eclass. It looks like this: + +base_src_compile() { + +./configure || die + +make || die + +} + +Here is the same function, divided into sections: + +base_src_compile() { + + + + [ -z "$1" ] && base_src_compile all + + + + while [ "$1" ]; do + + case $1 in + + +configure) + + ./configure +|| die;; + + +make) + + make +|| die;; + + +all) + + base_src_compile +configure make;; + + esac + + shift + + done + + + +} + +The code has been divided into two "sections": +configure and make. In our simple example, they correspond +to the two commands in the original function. + +In the center of the new function is a while;case...esac;shift;done +block. This block matches the parameters to the functions +with the defined section names and executes the corresponding +lines of code. + +The special case all calls the same function recursively +with a list of sections in order. It's up to the eclass's +author to maintain this list, which is very important. + +The line before the block says that a call without parameters +should be treated the same as a call with the single parameter +all. As you see, this function recurses a lot. Note, however, +that the call base_src_compile configure all make is also +legal; it will execute base_src_compile configure configure +make make. + +Now, in your ebuild (or eclass) that inherits from base.eclass, +you get the stub function src_compile which calls base_src_compile +without parameters. This makes base_src_compile execute +all, that is, all its sections. You can leave it as-is. +If you wish to extend it, you define a new src_compile and +call base_src_compile a section at a time: + +src_compile() { + + myfunc1 + + base_src_compile configure + + myfunc2 + + base_src_compile make + +} + +The only way to know what functions contain what sections +is to read the eclasses. + +2.3 base.eclass + +This eclass defines some default variables and functions, +similar to those you'd get by default in a non-inheriting +ebuild. For example, it defines: + +base_src_unpack() { unpack ${A}; } + +Only with sections, of course. + +It is inherited by higher-level eclasses like the kde ones. + +2.4 kde.eclass + +Used by all kde apps, whether directly or indirectly. This +is a higher-level eclass, which is intended to provide not +only sensible defaults but functions which can be used as-is +more often then not. + +It inherits c, autoconf and base. + +Read it to find out what it defines. It is quite self-explanatory. + +Briefly, it handles all standard kde-2.1* and 2.2* apps that +need configure/make/make install cycles. It handles all +the std. configure options e.g. objprelink. It also adds +kdelibs and qt to DEPEND. + +2.5 kde-base.eclass + +Meant for kde apps part of the core kde distribution. + +Differences from kde.eclass: + +* Sets appropriate DESCRIPTION and HOMEPAGE=www.kde.org. + +* Sets default download path to the correct location on ftp.kde.org + and several of its mirrors. + +2.6 kde-i18n.eclass + +Meant for the kde-i18n-* packages. Niche use. + +In fact, all kde-i18n ebuilds are completely identical and +so all they have to do is inherit from this eclass. + +Differences from kde.eclass: + +Many. Doesn't inherit c. Doesn't depend on qt. Provides virtual/kde-i18n-${PV}. +Doesn't have myconf section in src_compile(). Doesn't have +any sections in src_install(). Probably something else I +forgot as well. + +2.7 c.eclass + +Adds gcc and glibc to DEPEND and RDEPEND. Not meant to be +used alone, inherited by kde*. + +2.8 autoconf.eclass + +Adds make/automake/autoconf to DEPEND. Not meant to be used +alone, inherited by kde*. + +2.9 debug.eclass + +Will be written soon. Will provide verbose debug output functions +to centralise the numerous echos I have scattered around +the eclasses. + +3 The inheriting ebuilds + +Not much here as yet. Look at the kde*-2.2.1-r1 ebuilds for +examples. As a rule, read the eclass you are inheriting +from and put any necessary changes in your ebuild. + +Remember: always extend variables and fnctions. You should +almost never need to replace them. diff --git a/eclass/kde-i18n.eclass b/eclass/kde-i18n.eclass index 5923d9263519..43877c3ad2df 100644 --- a/eclass/kde-i18n.eclass +++ b/eclass/kde-i18n.eclass @@ -1,7 +1,7 @@ # Copyright 1999-2000 Gentoo Technologies, Inc. # Distributed under the terms of the GNU General Public License, v2 or later -# Author Dan Armak <danarmak@gentoo.ogr> -# $Header: /var/cvsroot/gentoo-x86/eclass/kde-i18n.eclass,v 1.1 2001/09/29 12:35:38 danarmak Exp $ +# Author Dan Armak <danarmak@gentoo.org> +# $Header: /var/cvsroot/gentoo-x86/eclass/kde-i18n.eclass,v 1.2 2001/09/30 21:43:05 danarmak Exp $ . /usr/portage/eclass/inherit.eclass || die inherit autoconf base || die ECLASS=kde-i18n diff --git a/eclass/notes.txt b/eclass/notes.txt index a6cc208d688c..64f165c6b3db 100644 --- a/eclass/notes.txt +++ b/eclass/notes.txt @@ -1,4 +1,5 @@ Note: this is outdated. Do not rely on it! +Second note: even more outdated now! Notes about moving deps from ebuilds into eclasses -------------------------------------------------- |