From: "André Erdmann" <dywi@mailerd.de>
To: gentoo-commits@lists.gentoo.org
Subject: [gentoo-commits] proj/R_overlay:master commit in: roverlay/
Date: Wed, 6 Jun 2012 19:52:35 +0000 (UTC) [thread overview]
Message-ID: <1339012032.f0a5ee703f0d23a4968963f57817336486806451.dywi@gentoo> (raw)
commit: f0a5ee703f0d23a4968963f57817336486806451
Author: André Erdmann <dywi <AT> mailerd <DOT> de>
AuthorDate: Wed Jun 6 19:47:12 2012 +0000
Commit: André Erdmann <dywi <AT> mailerd <DOT> de>
CommitDate: Wed Jun 6 19:47:12 2012 +0000
URL: http://git.overlays.gentoo.org/gitweb/?p=proj/R_overlay.git;a=commit;h=f0a5ee70
add dependency resolution to ebuild creation
modified: roverlay/ebuildcreator.py
modified: roverlay/ebuildjob.py
---
roverlay/ebuildcreator.py | 11 +++--
roverlay/ebuildjob.py | 111 ++++++++++++++++++++++++++++-----------------
2 files changed, 75 insertions(+), 47 deletions(-)
diff --git a/roverlay/ebuildcreator.py b/roverlay/ebuildcreator.py
index bc74490..3713c3b 100644
--- a/roverlay/ebuildcreator.py
+++ b/roverlay/ebuildcreator.py
@@ -3,6 +3,8 @@
# Distributed under the terms of the GNU General Public License v2
from roverlay.ebuildjob import EbuildJob
+from roverlay.depres import depresolver
+from roverlay.depres.communication import EbuildJobChannel
class EbuildCreator:
@@ -12,7 +14,7 @@ class EbuildCreator:
every R package added.
"""
self.ebuild_headers = dict ()
- self.depresolve_main = None # TODO
+ self.depresolve_main = depresolver.DependencyResolver ()
self.ebuild_jobs = []
# --- end of init (...) ---
@@ -26,7 +28,7 @@ class EbuildCreator:
* package_file -- path R package file
"""
- new_job = EbuildJob ( package_file, self.get_resolver ( False ) )
+ new_job = EbuildJob ( package_file, self.get_resolver_channel )
self.ebuild_jobs.append ( new_job )
@@ -34,15 +36,14 @@ class EbuildCreator:
# --- end of add_package (...) ---
- def get_resolver ( self, readonly=True ):
+ def get_resolver_channel ( self, name=None ):
"""Returns a communication channel to the dependency resolver.
arguments:
readonly -- whether the channel is listen-only (no write methods) or not
defaults to True
"""
- # <TODO>
- return None
+ return self.depresolve_main.register_channel ( EbuildJobChannel ( name=name ) )
#return self.depresolve_main.get_channel()
# --- end of get_resolver (...) ---
diff --git a/roverlay/ebuildjob.py b/roverlay/ebuildjob.py
index be8e5e3..fa13a48 100644
--- a/roverlay/ebuildjob.py
+++ b/roverlay/ebuildjob.py
@@ -36,7 +36,7 @@ class EbuildJob:
FAIL = [],
)
- def __init__ ( self, package_file, dep_resolver=None ):
+ def __init__ ( self, package_file, depres_channel_spawner=None ):
"""Initializes an EbuildJob, which creates an ebuild for an R package.
arguments:
@@ -49,8 +49,6 @@ class EbuildJob:
dep resolver 'communication channel', status codes etc.
"""
- #self.package_file = package_file
- self.dep_resolver = dep_resolver
# get description reader from args?
self.description_reader = DescriptionReader ( package_file )
@@ -58,10 +56,26 @@ class EbuildJob:
self.ebuild = None
+ # only allow a function (at least callable) for self.get_resolver
+ if hasattr ( depres_channel_spawner, '__call__' ):
+ self.request_resolver = depres_channel_spawner
+ # _depres contains (almost) dependency resolution data/.., including
+ # communication channels and should only be modified in run()
+ self._depres = dict ()
+ else:
+ self.request_resolver = None
+
self.status = 'INIT'
# --- end of __init__ (...) ---
+ def get_resolver ( self, dependency_type ):
+ if not dependency_type in self._depres:
+ self._depres [dependency_type] = self.request_resolver ()
+
+ return self._depres [dependency_type]
+
+
def get_ebuild ( self ):
"""Returns the Ebuild that is created by this object. Note that you should
check the status with status ( $TODO::EBUILD_READY ) before trying to use
@@ -148,73 +162,86 @@ class EbuildJob:
False
)
- if self.dep_resolver and self.dep_resolver.enabled():
+ if not self.request_resolver is None:
+
+ dep_type = desc_field = None
- # collect depdencies from desc and add them to the resolver
- raw_depends = dict ()
- dep_type = field = None
+ for dep_type in EbuildJob.DEPENDENCY_FIELDS:
- for dep_type in EbuildJob.DEPENDENCY_FIELDS.keys():
+ resolver = None
- raw_depends [dep_type] = []
+ for desc_field in EbuildJob.DEPENDENCY_FIELDS [dep_type]:
- for field in EbuildJob.DEPENDENCY_FIELDS [dep_type]:
+ if desc_field in desc:
+ if not resolver:
+ resolver = self.get_resolver ( dep_type )
- if field in desc:
- if isinstance ( desc [field], list ):
- raw_depends.extend ( desc [field] )
- self.dep_resolver.add_dependencies ( desc [field] )
+ if isinstance ( desc [desc_field], list ):
+ resolver.add_dependencies ( desc [desc_field] )
else:
- raw_depends.append ( desc [field] )
- self.dep_resolver.add_depency ( desc [field] )
+ resolver.add_depency ( desc [desc_field] )
- del field, dep_type
+ del resolver
- while not self.dep_resolver.done():
+ # wait
+ resolver_list = self._depres.values()
+ wait_resolve = True
+ while wait_resolve:
+ wait_resolve = False
if not self._set_status ( 'WAIT_RESOLVE' ): return
+ self.logger.debug ( "WAITING" )
+
# tell the resolver to run (again)
- self.dep_resolver.run()
+ for r in resolver_list : r.trigger_run ()
if not self._set_status ( 'BUSY' ): return
- if self.dep_resolver.satisfy_request():
+ for r in resolver_list :
+ if not r.done ():
+ wait_resolve = True
+ break
- dep_type = dep_str = dep = None
+ # check if all deps resolved
+ deps_resolved = True
+ for r in resolver_list:
+ if not r.satisfy_request():
+ deps_resolved = False
+ break
+
+ if deps_resolved:
# dependencies resolved, add them to the ebuild
- for dep_type in raw_depends.keys():
-
- for dep_str in raw_depends [dep_type]:
- # lookup (str) should return a str here
- dep = self.dep_resolver.lookup ( dep_str )
- if dep is None:
- raise Exception (
- "dep_resolver is broken: lookup() returns None but satisfy_request() says ok."
- )
- else:
- # add depencies in append mode
- dep = self.dep_resolver.lookup ( dep_str )
- ebuild.add ( dep_type,
- self.dep_resolver.lookup ( dep_str ),
- True
- )
+ for dep_type, resolver in self._depres.items():
+
+ deplist = resolver.collect_dependencies ()
- del dep, dep_str, dep_type
+ if deplist is None or not isinstance ( deplist, list ):
+ ## false positive: "empty" channel
+ raise Exception (
+ "dep_resolver is broken: lookup() returns None but satisfy_request() says ok."
+ )
+ else:
+ # add dependencies in no_append/override mode
+ ebuild.add ( dep_type, deplist, False )
- # tell the dep resolver that we're done here
- self.dep_resolver.close()
+ # tell the dep resolver channels that we're done
+ for r in resolver_list: r.close ()
else:
- # ebuild is not creatable, set status to FAIL and close dep resolver
+ # ebuild is not creatable, set status to FAIL and close dep resolvers
+ self.logger.info ( "Failed to resolve dependencies for this package." )
+ for r in resolver_list: r.close ()
self._set_status ( 'FAIL' )
- self.dep_resolver.close()
return
+ # --- end dep resolution
+
+
## finalize self.ebuild: forced text creation + make it readonly
if ebuild.prepare ( True, True ):
self.ebuild = ebuild
next reply other threads:[~2012-06-06 19:53 UTC|newest]
Thread overview: 159+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-06-06 19:52 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-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-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=1339012032.f0a5ee703f0d23a4968963f57817336486806451.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