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: Tue, 13 Aug 2013 08:56:36 +0000 (UTC)	[thread overview]
Message-ID: <1376383374.4cef51017af1d97fa4c75625fcabc351486804cb.dywi@gentoo> (raw)

commit:     4cef51017af1d97fa4c75625fcabc351486804cb
Author:     André Erdmann <dywi <AT> mailerd <DOT> de>
AuthorDate: Tue Aug 13 08:42:54 2013 +0000
Commit:     André Erdmann <dywi <AT> mailerd <DOT> de>
CommitDate: Tue Aug 13 08:42:54 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/R_overlay.git;a=commit;h=4cef5101

roverlay/runtime: make runtime object modular

split RuntimeEnvironment into a common (RuntimeEnvironmentBase) and a "main
script"-specific part (RuntimeEnvironment, as before).

The runtime object does no longer set up itself in __init__(), setup() has to be
called manually now.

---
 roverlay/defaultscript.py |   1 +
 roverlay/runtime.py       | 144 +++++++++++++++++++++++++++-------------------
 2 files changed, 85 insertions(+), 60 deletions(-)

diff --git a/roverlay/defaultscript.py b/roverlay/defaultscript.py
index dfbe29d..8c629f8 100644
--- a/roverlay/defaultscript.py
+++ b/roverlay/defaultscript.py
@@ -35,6 +35,7 @@ def main_installed ( *args, **kw ):
 
 def main ( installed, *args, **kw ):
    main_env = roverlay.runtime.RuntimeEnvironment ( installed, *args, **kw )
+   main_env.setup()
 
    if main_env.want_command ( 'setupdirs' ):
       sys.exit ( run_setupdirs ( main_env ) )

diff --git a/roverlay/runtime.py b/roverlay/runtime.py
index 81a7726..a65555d 100644
--- a/roverlay/runtime.py
+++ b/roverlay/runtime.py
@@ -18,113 +18,137 @@ import roverlay.stats.collector
 
 from roverlay.core import DIE, die
 
+class RuntimeEnvironmentBase ( object ):
+
+   ARG_PARSER_CLS  = None
+   KEEP_ARG_PARSER = False
 
-class RuntimeEnvironment ( object ):
    def __init__ ( self,
       installed,
       hide_exceptions=False,
       config_file_name=roverlay.core.DEFAULT_CONFIG_FILE_NAME
    ):
-      super ( RuntimeEnvironment, self ).__init__()
-
+      super ( RuntimeEnvironmentBase, self ).__init__()
       self.logger            = logging.getLogger()
+      self.installed         = bool ( installed )
+      self.hide_exceptions   = bool ( hide_exceptions )
+      self.config_file_name  = str ( config_file_name )
       self.HLINE             = 79 * '-'
+
       self.stats             = roverlay.stats.collector.static
       self.config            = None
       self.additional_config = None
       self.options           = None
-      self.actions_done      = set()
       self.command           = None
+   # --- end of __init__ (...) ---
 
-      self._repo_list        = None
-      self._overlay_creator  = None
-      self.stats_db_file     = None
-
-      self.want_db_commit    = False
-
-      self.hide_exceptions = hide_exceptions
-      if hide_exceptions:
+   def setup ( self ):
+      roverlay.core.setup_initial_logger()
+      self.stats.time.begin ( "setup" )
+      if self.hide_exceptions:
          try:
-            self.setup ( installed, config_file_name )
+            self.do_setup()
          except:
             die ( "failed to initialize runtime environment." )
       else:
-         self.setup ( installed, config_file_name )
-   # --- end of __init__ (...) ---
-
-   def get_repo_list ( self ):
-      if self._repo_list is None:
-         self._repo_list = roverlay.remote.repolist.RepoList (
-            sync_enabled   = not self.config.get_or_fail ( 'nosync' ),
-            force_distroot = self.options.get ( 'force_distroot' )
-         )
-      return self._repo_list
-   # --- end of get_repo_list (...) ---
-
-   def get_overlay_creator ( self ):
-      if self._overlay_creator is None:
-         self._overlay_creator = roverlay.overlay.creator.OverlayCreator (
-            skip_manifest           = not self.options ['manifest'],
-            incremental             = self.options ['incremental'],
-            allow_write             = self.options ['write_overlay'],
-            immediate_ebuild_writes = self.options ['immediate_ebuild_writes'],
-         )
-      return self._overlay_creator
-   # --- end of get_overlay_creator (...) ---
-
-   def setup ( self, installed, config_file_name ):
-      roverlay.core.setup_initial_logger()
-      self.stats.time.begin ( "setup" )
+         self.do_setup()
+      self.stats.time.end ( "setup" )
+   # --- end of setup (...) ---
 
-      parser = roverlay.argparser.RoverlayMainArgumentParser (
+   def do_setup_parser ( self ):
+      parser = self.ARG_PARSER_CLS (
          defaults={
             'config_file': roverlay.core.locate_config_file (
-               installed, config_file_name
+               self.installed, self.config_file_name
             )
          }
       )
       parser.setup()
       parser.parse()
-      parser.do_extraconf ( installed, 'installed' )
-
-      command           = parser.command
-      options           = parser.parsed
-      additional_config = parser.extra_conf
+      parser.do_extraconf ( self.installed, 'installed' )
 
-      del parser
+      self.command           = getattr ( parser, 'command', None )
+      self.options           = parser.parsed
+      self.additional_config = parser.extra_conf
 
+      if self.KEEP_ARG_PARSER:
+         self.parser = parser
+   # --- end of do_setup_parser (...) ---
 
+   def do_setup_config ( self ):
       try:
          self.config = roverlay.core.load_config_file (
-            options ['config_file'],
-            extraconf      = additional_config,
-            setup_logger   = options ['want_logging'],
-            load_main_only = options ['load_main_only'],
+            self.options ['config_file'],
+            extraconf      = self.additional_config,
+            setup_logger   = self.options.get ( 'want_logging', False ),
+            load_main_only = self.options.get ( 'load_main_only', True ),
          )
       except:
          if self.hide_exceptions:
             die (
                "Cannot load config file {!r}".format (
-                  options ['config_file']
+                  self.options ['config_file']
                ),
                DIE.CONFIG
             )
          else:
             raise
+   # --- end of do_setup_config (...) ---
+
+   def do_setup ( self ):
+      self.do_setup_parser()
+      self.do_setup_config()
+   # --- end of do_setup (...) ---
+
+# --- end of RuntimeEnvironmentBase (...) ---
+
+class RuntimeEnvironment ( RuntimeEnvironmentBase ):
 
+   ARG_PARSER_CLS = roverlay.argparser.RoverlayMainArgumentParser
 
-      self.stats_db_file     = self.config.get ( 'RRD_DB.file', None )
-      self.command           = command
-      self.options           = options
-      self.additional_config = additional_config
+   def __init__ ( self, installed, *args, **kw ):
+      super ( RuntimeEnvironment, self ).__init__ ( installed, *args, **kw )
+
+      self.actions_done     = set()
+      self.command          = None
+
+      self.stats_db_file    = None
+      self.want_db_commit   = False
+
+      self._repo_list       = None
+      self._overlay_creator = None
+   # --- end of __init__ (...) ---
 
+   def get_repo_list ( self ):
+      if self._repo_list is None:
+         self._repo_list = roverlay.remote.repolist.RepoList (
+            sync_enabled   = not self.config.get_or_fail ( 'nosync' ),
+            force_distroot = self.options.get ( 'force_distroot' )
+         )
+      return self._repo_list
+   # --- end of get_repo_list (...) ---
+
+   def get_overlay_creator ( self ):
+      if self._overlay_creator is None:
+         self._overlay_creator = roverlay.overlay.creator.OverlayCreator (
+            skip_manifest           = not self.options ['manifest'],
+            incremental             = self.options ['incremental'],
+            allow_write             = self.options ['write_overlay'],
+            immediate_ebuild_writes = self.options ['immediate_ebuild_writes'],
+         )
+      return self._overlay_creator
+   # --- end of get_overlay_creator (...) ---
+
+   def do_setup ( self ):
+      self.do_setup_parser()
+      self.do_setup_config()
+
+      self.stats_db_file = self.config.get ( 'RRD_DB.file', None )
 
       # want_logging <=> <have a command that uses hooks>
-      if options ['want_logging']:
+      if self.options ['want_logging']:
          roverlay.hook.setup()
-
-      self.stats.time.end ( "setup" )
-   # --- end of setup (...) ---
+   # --- end of do_setup (...) ---
 
    def setup_database ( self ):
       if self.stats_db_file:


             reply	other threads:[~2013-08-13  8:56 UTC|newest]

Thread overview: 159+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-08-13  8:56 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-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-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=1376383374.4cef51017af1d97fa4c75625fcabc351486804cb.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