From: "André Erdmann" <dywi@mailerd.de>
To: gentoo-commits@lists.gentoo.org
Subject: [gentoo-commits] proj/R_overlay:master commit in: roverlay/
Date: Tue, 29 May 2012 17:09:32 +0000 (UTC) [thread overview]
Message-ID: <1338311023.a60a7f76d1a2dd2d5f4d1bb3d9766a2e803f2655.dywi@gentoo> (raw)
commit: a60a7f76d1a2dd2d5f4d1bb3d9766a2e803f2655
Author: Andre Erdmann <dywi <AT> mailerd <DOT> de>
AuthorDate: Tue May 29 17:03:43 2012 +0000
Commit: André Erdmann <dywi <AT> mailerd <DOT> de>
CommitDate: Tue May 29 17:03:43 2012 +0000
URL: http://git.overlays.gentoo.org/gitweb/?p=proj/R_overlay.git;a=commit;h=a60a7f76
roverlay, ebuild creation: Ebuild.py
* module that produces ebuild text lines
new file: ebuild.py
---
roverlay/ebuild.py | 335 ++++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 335 insertions(+), 0 deletions(-)
diff --git a/roverlay/ebuild.py b/roverlay/ebuild.py
new file mode 100644
index 0000000..495b189
--- /dev/null
+++ b/roverlay/ebuild.py
@@ -0,0 +1,335 @@
+# R Overlay -- ebuild creation, ebuild class
+# Copyright 2006-2012 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+class Ebuild:
+ # could move this to const
+ EBUILD_INDENT = "\t"
+
+ @classmethod
+ def __init__ ( self ):
+ """Initializes an Ebuild.
+ This is an abstraction layer between the verified + calculated data
+ and the ebuild data, which can be written into a file / stdout / stdin.
+ Most functions here assume that everything is fine when it reaches them.
+ """
+
+ # elements in ebuild_data are either a str or a list of str
+ self._data = dict ()
+ self._ebuild_lines = None
+
+ # --- end of __init__ (...) ---
+
+ @classmethod
+ def cleanup ( self ):
+ """Removes stored data if ebuild_lines have already been calculated.
+ This saves some memory but makes this Ebuild read-only.
+ """
+ if self._ebuild_lines:
+ del self._data
+ self._data = None
+
+ # --- end of cleanup (...) ---
+
+ @classmethod
+ def prepare ( self, force_update=False, cleanup_after=False ):
+ """Tells this Ebuild to create ebuild lines.
+
+ arguments:
+ * force_update -- create ebuild lines if they exist; defaults to False
+ and ignored if this Ebuild has been cleaned up
+ * cleanup_after -- run cleanup() after successful creation
+
+ Returns True if ebuild_lines have been created or if they exist and
+ an update has not been enforced. Else returns False.
+ """
+ if self._ebuild_lines and not force_update:
+ return True
+ elif self._data:
+ self._ebuild_lines = self._make_ebuild_lines()
+ if self._ebuild_lines:
+ if cleanup_after: self.cleanup()
+ return True
+ elif self._ebuild_lines:
+ # self._data is None
+ return True
+
+
+ return False
+
+ # --- end of prepare (...) ---
+
+ @classmethod
+ def add ( self, key, value, append=True ):
+ """Adds data to this Ebuild.
+
+ arguments:
+ * key -- identifier of the data (e.g. DEPEND).
+ May be remapped here (e.g. merging 'Title' and 'Description')
+ * value --
+ * append -- whether to append values or overwrite existing ones,
+ defaults to True.
+
+ raises: Exception when ebuild data are readonly
+ """
+ if self._data is None:
+ # -- todo
+ raise Exception ("Ebuild data are readonly.")
+
+ if append and key in self._data:
+ if isinstance ( self._data [key], list ):
+ self._data [key].extend ( value )
+ else:
+ self._data [key] = [ self._data [key] ].extend ( value )
+
+ else:
+ self._data [key] = value
+
+ # --- end of add (...) ---
+
+ @classmethod
+ def write ( self, file_to_write ):
+ """Writes an ebuild file.
+
+ arguments:
+ * file_to_write -- path to the file that should be written
+ """
+ # prepare ebuild lines and open file handle after that
+ if self.prepare ( False, False ):
+ try:
+ fh = open ( file_to_write, 'w' )
+ self.show ( fh )
+ fh.close()
+ del fh
+ return True
+ except IOError as err:
+ # ? todo
+ raise
+
+ else:
+ # todo log this
+ raise Exception ("cannot write ebuild")
+
+ # --- end of write (...) ---
+
+ @classmethod
+ def show ( self, file_handle ):
+ """Prints the ebuild content into a file_handle.
+
+ arguments:
+ file_handle -- object that has a writelines ( list ) method, e.g. file.
+
+ Returns True if writing was successful, else False.
+ """
+ if self.prepare ( False, False ):
+ lines = [ line + "\n" for line in self._ebuild_lines ]
+ file_handle.writelines ( lines )
+ del lines
+ return True
+ else:
+ return False
+
+ # --- end of show (...) ---
+
+ def suggest_name ( self, fallback_name=None ):
+ """Suggests a file name for the ebuild. This is calculated using
+ pkg_name/version/revision. Returns a fallback_name if this is not
+ possible.
+
+ arguments:
+ fallback_name -- name to return if no suggestion available, defaults to None
+ """
+
+ if 'pkg_name' in self._data and 'pkg_version' in self._data:
+ join = [ 'pkg_name' , 'pkg_version' ]
+ if 'pkg_revision' in self._data: join.append ('pkg_revision')
+
+ return '-' . join ( [ self._data [c] for c in join ] )
+
+ else:
+ return fallback_name
+
+ # --- end of suggest_name (...) ---
+
+ @classmethod
+ def _make_ebuild_lines ( self ):
+ """Creates text lines for this Ebuild.
+ It assumes that enough data to do this are available. Exceptions (KeyError, NameError, ...)
+ are passed if that's not the case.
+ """
+
+ def get_dep_and_use():
+ """Creates values for the DEPEND, RDEPEND, IUSE and, if possible,
+ R_SUGGESTS variables and returns them as dict { VARNAME -> VALUE }.
+ """
+
+ # have suggests if they're set and not empty
+ have_suggests = bool ( 'RSUGGESTS' in self._data and self._data ['RSUGGESTS'] )
+
+ # set defaults: inherit eclass + include depend in rdepend
+ ret = dict (
+ DEPEND = [ '${DEPEND:-}' ],
+ RDEPEND = [ '${DEPEND:-}', '${RDEPEND:-}' ],
+ IUSE = [ '${IUSE:-}' ],
+ )
+
+ if 'DEPEND' in self._data:
+ ret ['DEPEND'].extend ( self._data ['DEPEND'] )
+
+ if 'RDEPEND' in self._data:
+ ret ['RDEPEND'].extend ( self._data ['RDEPEND'] )
+
+ if have_suggests:
+ ret ['R_SUGGESTS'] = self._data ['R_SUGGESTS']
+
+ # +R_SUGGESTS, -R_SUGGESTS?
+ ret ['IUSE'].append ( 'R_suggests' )
+ # do these braces help or confuse? TODO FIXME
+ ret ['RDEPEND'].append ( '( R_suggests ? ${R_SUGGESTS} )' )
+
+ return ret
+
+ # --- end of get_dep_and_use () ---
+
+ def make_var ( varname, value=None, oneline_list=True, indent_list=True, indent_level=0 ):
+ """Creates a <name>=<value> statement for ebuilds.
+
+ arguments:
+ * varname -- name of the variable
+ * value -- value of the variable. This has to be either None (the default),
+ str, or list of str.
+ * oneline_list -- if value is a list: controls whether it's components should be
+ put into one line (True) or multiple (False). Defaults to True.
+ * indent_list -- if value is a list and not oneline_list:
+ controls whether each value line should be indentend
+ (by indent_level + 1) or not ("by 0"). Defaults to True.
+ * indent_level -- current indentation level, defaults to 0
+
+ """
+
+ # assumption: value is either None, scalar with str representation or list of str
+ var_value = None
+
+ if not value:
+ var_value = ""
+
+ elif isinstance ( value, list ):
+ if oneline_list:
+ var_value = ' '.join ( value )
+ elif indent_list:
+ var_value = ('\n' + (indent_level + 1) * EBUILD_INDENT).join ( value )
+ else:
+ '\n'.join ( value )
+
+ else:
+ var_value = str ( value )
+
+ return indent_level * EBUILD_INDENT + varname + '"' + value_str + '"'
+
+ # --- end of make_var (...) ---
+
+ def remove_newlines ( line_list ):
+ """
+ Removes leading, ending and repeated empty/whitespace lines in line_list.
+
+ arguments:
+ * line_list
+ """
+ lines = []
+ line = None
+ last_line_empty = False
+
+ for line in line_list:
+ line = line.rstrip()
+ # re.sub \n{2,} \n :: FIXME?
+
+ if line:
+ last_line_empty = False
+ elif not last_line_empty:
+ last_line_empty = True
+ else:
+ continue
+
+ lines.append ( line )
+
+ # remove last line if empty
+ ##if last_line_empty: (?)
+ if len ( lines ) and not lines [-1]:
+ del lines [-1]
+
+ return lines
+
+ # --- end of remove_newlines (...) ---
+
+ def add_easyvar ( ebuild_content, varname, value_key=None, add_newline=False):
+ """Adds a 'simple' variable to the ebuild lines. This means that it
+ can directly be taken from self._data [value_key]. This method assumes
+ that value_key exists in self._data, any exceptions (KeyError) will be passed.
+
+ arguments:
+ * ebuild_content -- list of ebuild text lines, will be modified directly,
+ so copy it before calling addvar if you need the original list.
+ * varname -- name of the variable. Nothing happens if this is None.
+ * value_key -- key of the value, defaults to varname if it is None
+ * add_newline -- adds a newline after the var statement, defaults to False
+
+ Returns given list (ebuild_content), which will then have been modified.
+ """
+
+ if not varname is None:
+ if value_key is None:
+ ebuild_content.append ( make_var ( varname, self._data [varname] ) )
+ else:
+ ebuild_content.append ( make_var ( varname, self._data [value_key] ) )
+
+ if add_newline:
+ ebuild_content.append ( "" )
+
+ return ebuild_content
+
+ # --- end of add_easyvar (...) ---
+
+ try:
+ ebuild_lines = []
+
+ if 'ebuild_header' in self._data:
+ ebuild_lines = self._data ['ebuild_header']
+ ebuild_lines.append ( "" )
+
+ add_easyvar ( ebuild_lines, "PKG_FILE" )
+ if 'PKG_ORIGIN' in self._data:
+ add_easyvar ( ebuild_lines, "PKG_ORIGIN", None, True )
+
+ add_easyvar ( ebuild_lines, "DESCRIPTION" )
+
+ if 'SRC_URI' in self._data:
+ add_easyvar ( ebuild_lines, "SRC_URI" )
+ else:
+ # > calculate SRC_URI using self._data ['origin']
+ ebuild_lines.append ( make_var ( "SRC_URI" , None ) )
+ # (temporary, todo) setting restrict to fetch
+ ebuild_lines.append ( make_var ( "RESTRICT" , "fetch" ) )
+
+ ebuild_lines.append ( "" )
+
+ # LICENSE ?
+
+ dep_and_use = get_dep_and_use ()
+
+ ebuild_lines.append ( make_var ( "IUSE", dep_and_use ['IUSE'], True ) )
+
+ if 'R_SUGGESTS' in dep_and_use:
+ ebuild_lines.append ( make_var ( "R_SUGGESTS", dep_and_use ['R_SUGGESTS'], False ) )
+
+ ebuild_lines.append ( make_var ( "DEPEND", dep_and_use ['DEPEND'], False ) )
+ ebuild_lines.append ( make_var ( "RDEPEND", dep_and_use ['RDEPEND'], False ) )
+
+ del dep_and_use
+ return remove_newlines ( ebuild_lines )
+
+ except Exception as err:
+ # log this
+ ## ..
+ raise
+
+ # --- end of make_ebuild_lines (...) ---
next reply other threads:[~2012-05-29 17:10 UTC|newest]
Thread overview: 159+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-05-29 17:09 André Erdmann [this message]
-- strict thread matches above, loose matches on Subject: below --
2015-01-26 17:41 [gentoo-commits] proj/R_overlay:master commit in: roverlay/ André Erdmann
2015-01-26 17:41 André Erdmann
2014-07-18 16:20 André Erdmann
2014-07-18 2:50 [gentoo-commits] proj/R_overlay:wip/addition_control " André Erdmann
2014-07-18 16:20 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2014-07-18 2:28 [gentoo-commits] proj/R_overlay:wip/addition_control " André Erdmann
2014-07-18 16:20 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2014-07-16 15:14 André Erdmann
2014-06-05 22:09 André Erdmann
2014-04-01 16:38 André Erdmann
2014-02-16 16:30 André Erdmann
2014-02-15 19:49 André Erdmann
2014-02-15 19:49 André Erdmann
2014-01-25 18:14 André Erdmann
2013-12-11 18:40 André Erdmann
2013-12-11 18:40 André Erdmann
2013-09-23 15:30 André Erdmann
2013-09-20 15:57 André Erdmann
2013-09-19 15:00 André Erdmann
2013-09-17 16:40 André Erdmann
2013-09-17 16:40 André Erdmann
2013-09-17 16:40 André Erdmann
2013-09-17 16:40 André Erdmann
2013-09-16 13:43 André Erdmann
2013-09-13 15:10 André Erdmann
2013-09-12 16:36 André Erdmann
2013-09-12 16:36 André Erdmann
2013-09-12 16:36 André Erdmann
2013-09-11 11:14 André Erdmann
2013-09-11 10:19 André Erdmann
2013-09-10 14:40 André Erdmann
2013-09-10 14:40 André Erdmann
2013-09-10 14:40 André Erdmann
2013-09-10 14:40 André Erdmann
2013-09-06 17:27 André Erdmann
2013-09-06 17:27 André Erdmann
2013-09-03 15:50 André Erdmann
2013-09-02 12:27 André Erdmann
2013-09-02 8:44 André Erdmann
2013-08-30 14:49 André Erdmann
2013-08-30 14:49 André Erdmann
2013-08-29 12:36 André Erdmann
2013-08-29 12:36 André Erdmann
2013-08-28 15:54 André Erdmann
2013-08-27 15:39 André Erdmann
2013-08-23 13:52 André Erdmann
2013-08-23 13:52 André Erdmann
2013-08-23 13:52 André Erdmann
2013-08-19 15:42 André Erdmann
2013-08-16 14:05 André Erdmann
2013-08-16 11:02 André Erdmann
2013-08-16 10:43 André Erdmann
2013-08-16 10:43 André Erdmann
2013-08-14 14:56 André Erdmann
2013-08-14 14:56 André Erdmann
2013-08-13 8:56 André Erdmann
2013-08-13 8:56 André Erdmann
2013-08-13 8:56 André Erdmann
2013-08-12 8:28 André Erdmann
2013-08-12 8:18 André Erdmann
2013-08-07 16:10 André Erdmann
2013-08-02 14:30 André Erdmann
2013-08-02 10:34 André Erdmann
2013-08-02 10:34 André Erdmann
2013-08-01 12:44 André Erdmann
2013-08-01 12:44 André Erdmann
2013-07-29 14:56 André Erdmann
2013-07-29 8:55 André Erdmann
2013-07-26 13:02 André Erdmann
2013-07-23 7:51 André Erdmann
2013-07-23 7:51 André Erdmann
2013-07-19 18:00 [gentoo-commits] proj/R_overlay:gsoc13/next " André Erdmann
2013-07-23 7:51 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2013-07-17 18:05 [gentoo-commits] proj/R_overlay:gsoc13/next " André Erdmann
2013-07-17 18:05 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2013-07-15 22:31 [gentoo-commits] proj/R_overlay:gsoc13/next " André Erdmann
2013-07-16 16:36 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2013-07-12 13:57 André Erdmann
2013-06-22 15:24 André Erdmann
2013-06-22 15:24 André Erdmann
2013-06-22 15:24 André Erdmann
2013-06-22 15:24 André Erdmann
2013-06-19 18:58 [gentoo-commits] proj/R_overlay:gsoc13/next " André Erdmann
2013-06-22 15:24 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2013-06-19 18:58 [gentoo-commits] proj/R_overlay:gsoc13/next " André Erdmann
2013-06-19 18:59 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2013-06-13 16:34 André Erdmann
2013-06-05 18:08 [gentoo-commits] proj/R_overlay:gsoc13/next " André Erdmann
2013-06-13 16:34 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2013-06-05 18:08 [gentoo-commits] proj/R_overlay:gsoc13/next " André Erdmann
2013-06-13 16:34 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2013-06-04 21:06 André Erdmann
2013-04-25 16:44 André Erdmann
2013-04-25 16:44 André Erdmann
2013-03-05 11:27 André Erdmann
2013-02-09 20:45 André Erdmann
2013-02-05 17:48 André Erdmann
2013-02-05 17:48 André Erdmann
2013-01-30 20:16 André Erdmann
2013-01-30 20:16 André Erdmann
2013-01-28 23:54 André Erdmann
2013-01-28 23:54 André Erdmann
2013-01-28 23:54 André Erdmann
2012-10-02 10:04 André Erdmann
2012-08-20 11:16 André Erdmann
2012-08-13 18:07 André Erdmann
2012-08-09 9:26 André Erdmann
2012-08-08 23:46 André Erdmann
2012-08-08 23:46 André Erdmann
2012-08-07 8:50 André Erdmann
2012-08-02 15:14 André Erdmann
2012-08-01 7:25 André Erdmann
2012-07-31 17:51 André Erdmann
2012-07-30 8:52 André Erdmann
2012-07-30 8:52 André Erdmann
2012-07-24 16:59 [gentoo-commits] proj/R_overlay:overlay_wip " André Erdmann
2012-07-30 8:52 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2012-07-18 16:49 [gentoo-commits] proj/R_overlay:overlay_wip " André Erdmann
2012-07-30 8:52 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2012-07-16 16:15 André Erdmann
2012-07-16 16:15 André Erdmann
2012-07-16 16:15 [gentoo-commits] proj/R_overlay:depres_wip " André Erdmann
2012-07-16 16:15 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2012-07-10 17:43 André Erdmann
2012-07-09 17:19 André Erdmann
2012-07-04 18:21 André Erdmann
2012-07-04 18:21 André Erdmann
2012-07-03 17:48 André Erdmann
2012-06-28 13:29 André Erdmann
2012-06-26 15:42 André Erdmann
2012-06-25 18:19 André Erdmann
2012-06-21 16:55 André Erdmann
2012-06-20 19:03 André Erdmann
2012-06-20 19:03 André Erdmann
2012-06-18 16:27 André Erdmann
2012-06-15 20:34 André Erdmann
2012-06-15 20:34 André Erdmann
2012-06-15 20:34 André Erdmann
2012-06-15 20:34 André Erdmann
2012-06-15 20:34 André Erdmann
2012-06-15 20:34 André Erdmann
2012-06-12 17:17 André Erdmann
2012-06-06 19:52 André Erdmann
2012-06-06 19:52 André Erdmann
2012-06-06 19:52 André Erdmann
2012-06-05 17:30 André Erdmann
2012-06-04 19:07 André Erdmann
2012-06-04 19:07 André Erdmann
2012-06-04 15:43 André Erdmann
2012-06-01 16:19 André Erdmann
2012-06-01 16:19 André Erdmann
2012-06-01 15:46 André Erdmann
2012-05-31 18:24 André Erdmann
2012-05-30 20:15 André Erdmann
2012-05-30 19:36 André Erdmann
2012-05-30 19:36 André Erdmann
2012-05-30 16:09 André Erdmann
2012-05-30 16:09 André Erdmann
2012-05-30 16:09 André Erdmann
2012-05-30 16:09 André Erdmann
2012-05-30 10:58 André Erdmann
2012-05-30 10:58 André Erdmann
2012-05-30 10:58 André Erdmann
2012-05-30 10:58 André Erdmann
2012-05-29 17:09 André Erdmann
2012-05-29 17:09 André Erdmann
2012-05-29 17:09 André Erdmann
2012-05-29 17:09 André Erdmann
2012-05-26 13:14 André Erdmann
2012-05-26 13:14 André Erdmann
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1338311023.a60a7f76d1a2dd2d5f4d1bb3d9766a2e803f2655.dywi@gentoo \
--to=dywi@mailerd.de \
--cc=gentoo-commits@lists.gentoo.org \
--cc=gentoo-dev@lists.gentoo.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox