public inbox for gentoo-commits@lists.gentoo.org
 help / color / mirror / Atom feed
From: "André Erdmann" <dywi@mailerd.de>
To: gentoo-commits@lists.gentoo.org
Subject: [gentoo-commits] proj/R_overlay:master commit in: roverlay/
Date: Thu, 25 Apr 2013 16:44:18 +0000 (UTC)	[thread overview]
Message-ID: <1366678573.311ac182bba51393153f1c4de4b2580461023608.dywi@gentoo> (raw)

commit:     311ac182bba51393153f1c4de4b2580461023608
Author:     André Erdmann <dywi <AT> mailerd <DOT> de>
AuthorDate: Tue Apr 23 00:56:13 2013 +0000
Commit:     André Erdmann <dywi <AT> mailerd <DOT> de>
CommitDate: Tue Apr 23 00:56:13 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/R_overlay.git;a=commit;h=311ac182

roverlay/main: apply_rules command

This command applies the package rules to all packages and prints the result
(package filtered out, package modifed: evar...) to stdout (or to --dump-file).

---
 roverlay/argutil.py |   26 ++++++++++++++
 roverlay/main.py    |   92 +++++++++++++++++++++++++++++++++++++++++----------
 2 files changed, 100 insertions(+), 18 deletions(-)

diff --git a/roverlay/argutil.py b/roverlay/argutil.py
index 23804b6..7237eba 100644
--- a/roverlay/argutil.py
+++ b/roverlay/argutil.py
@@ -29,6 +29,19 @@ def get_parser ( command_map, default_config_file, default_command='create' ):
 			)
 		return f
 
+	def couldbe_fs_file ( value ):
+		if value:
+			f = os.path.abspath ( value )
+			if not os.path.exists ( f ) or os.path.isfile ( f ):
+				return f
+
+		raise argparse.ArgumentTypeError (
+			"{!r} is not a file.".format ( value )
+		)
+
+	def couldbe_stdout_or_file ( value ):
+		return value if value == "-" else couldbe_fs_file ( value )
+
 	def is_fs_dir ( value ):
 		d = os.path.abspath ( value )
 		if not os.path.isdir ( d ):
@@ -283,6 +296,18 @@ def get_parser ( command_map, default_config_file, default_command='create' ):
 		action='store_false',
 	)
 
+	arg (
+		'--dump-file',
+		help='''
+			standard file or stdout target for dumping information
+			(defaults to '-'). Used by the 'apply_rules' action.
+		''',
+		dest="dump_file",
+		default="-",
+		metavar="<file>",
+		type=couldbe_stdout_or_file,
+	)
+
 #	# TODO
 #	arg (
 #		'--debug',
@@ -339,6 +364,7 @@ def parse_argv ( command_map, **kw ):
 		skip_manifest           = p.no_manifest,
 		incremental             = p.incremental,
 		immediate_ebuild_writes = p.immediate_ebuild_writes,
+		dump_file               = p.dump_file,
 	)
 
 	if given ( 'overlay' ):

diff --git a/roverlay/main.py b/roverlay/main.py
index b525ffe..7090689 100644
--- a/roverlay/main.py
+++ b/roverlay/main.py
@@ -119,6 +119,56 @@ def main (
 				raise
 	# --- end of run_sync() ---
 
+	def run_apply_package_rules():
+		if "apply_rules" in actions_done: return
+
+		dump_file = OPTION ( "dump_file" )
+		FH        = None
+
+		prules = PackageRules.get_configured()
+
+		# track package rules
+		prules.add_trace_actions()
+
+
+		BEGIN_RECEIVE_PACKAGE = ( 8 * '-' ) + " {header} " + ( 8 * '-' ) + '\n'
+		END_RECEIVE_PACKAGE   = ( 31 * '-' ) + '\n\n'
+
+		get_header = lambda p : BEGIN_RECEIVE_PACKAGE.format (
+			header = ( p ['name'] + ' ' + p ['ebuild_verstr'] )
+		)
+
+		def receive_package ( P ):
+			if prules.apply_actions ( P ):
+				if hasattr ( P, 'modified_by_package_rules' ):
+					# ^ that check is sufficient here
+					#if P.modified_by_package_rules
+
+					FH.write ( get_header ( P ) )
+
+					evars = P.get_evars()
+					if evars:
+						FH.write ( "evars applied:\n" )
+						for evar in evars:
+							FH.write ( "* {}\n".format ( evar ) )
+
+					FH.write ( END_RECEIVE_PACKAGE )
+			else:
+				FH.write ( get_header ( P ) )
+				FH.write ( "filtered out!\n" )
+				FH.write ( END_RECEIVE_PACKAGE )
+
+		# --- end of receive_package (...) ---
+
+		if dump_file == "-":
+			FH = sys.stdout
+			repo_list.add_packages ( receive_package )
+		else:
+			with open ( dump_file, 'wt' ) as FH:
+				repo_list.add_packages ( receive_package )
+
+	# --- end of run_apply_package_rules (...) ---
+
 	def run_overlay_create():
 		if "create" in actions_done: return
 		#run_sync()
@@ -182,6 +232,7 @@ def main (
 			'run an interactive depres console (highly experimental)',
 		'depres'         : 'this is an alias to \'depres_console\'',
 		'nop'            : 'does nothing',
+		'apply_rules'    : 'apply package rules verbosely and exit afterwards',
 	}
 
 
@@ -217,6 +268,8 @@ def main (
 	# imports roverlay.remote, roverlay.overlay.creator
 
 	actions = set ( filter ( lambda x : x != 'nop', commands ) )
+	actions_done = set()
+	set_action_done = actions_done.add
 
 	if 'sync' in actions and OPTION ( 'nosync' ):
 		die ( "sync command blocked by --nosync opt.", DIE.ARG )
@@ -282,11 +335,13 @@ def main (
 
 		import roverlay.packagerules.rules
 
+		package_rules = (
+			roverlay.packagerules.rules.PackageRules.get_configured()
+		)
+
 		HLINE = "".rjust ( 79, '-' )
 		print ( HLINE )
-		print (
-			str ( roverlay.packagerules.rules.PackageRules.get_configured() )
-		)
+		print ( str ( package_rules ) )
 		print ( HLINE )
 
 		EXIT_AFTER_CONFIG = True
@@ -294,8 +349,7 @@ def main (
 	# -- end of EXIT_AFTER_CONFIG entries
 
 	if 'EXIT_AFTER_CONFIG' in locals() and EXIT_AFTER_CONFIG:
-		pass
-		#sys.exit ( os.EX_OK )
+		sys.exit ( os.EX_OK )
 
 	# switch to depres console
 	elif 'depres_console' in actions or 'depres' in actions:
@@ -306,7 +360,7 @@ def main (
 			from roverlay.depres.simpledeprule.console import DepResConsole
 			con = DepResConsole()
 			con.run()
-			sys.exit ( os.EX_OK )
+			set_action_done ( "depres_console" )
 		except ImportError:
 			if HIDE_EXCEPTIONS:
 				die ( "Cannot import depres console!", DIE.IMPORT )
@@ -332,25 +386,27 @@ def main (
 				raise
 
 		# -- run methods (and some vars)
-		# imports: nothing
+		# imports: package rules
 
 		#repo_list       = None
 		#overlay_creator = None
 
-		actions_done = set()
-		set_action_done = actions_done.add
-
 		# -- run
 
-		# always run sync 'cause commands = {create,sync}
-		# and create implies (no)sync
+		# always run sync 'cause commands = {create,sync,apply_rules}
+		# and create,apply_rules implies (no)sync
 		run_sync()
 
-		if 'create' in actions: run_overlay_create()
+		if "apply_rules" in actions:
+			from roverlay.packagerules.rules import PackageRules
+			run_apply_package_rules()
+		elif 'create' in actions:
+			run_overlay_create()
 
-		if len ( actions ) > len ( actions_done ):
-			die (
-				"Some actions (out of {!r}) could not be performed!".format (
-					actions ), DIE.CMD_LEFTOVER
-			)
+
+	if len ( actions ) > len ( actions_done ):
+		die (
+			"Some actions (out of {!r}) could not be performed!".format (
+				actions ), DIE.CMD_LEFTOVER
+		)
 # --- end of main (...) ---


             reply	other threads:[~2013-04-25 16:44 UTC|newest]

Thread overview: 159+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-04-25 16:44 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-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-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=1366678573.311ac182bba51393153f1c4de4b2580461023608.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