* [gentoo-commits] proj/R_overlay:master commit in: roverlay/depres/simpledeprule/, roverlay/
2014-08-23 19:03 [gentoo-commits] proj/R_overlay:master commit in: roverlay/depres/simpledeprule/, roverlay/ André Erdmann
@ 2014-07-29 18:29 ` André Erdmann
0 siblings, 0 replies; 2+ messages in thread
From: André Erdmann @ 2014-07-29 18:29 UTC (permalink / raw
To: gentoo-commits
commit: 768b134a4a388bc11175c5ff8975369fe01317fe
Author: André Erdmann <dywi <AT> mailerd <DOT> de>
AuthorDate: Tue Jul 29 17:39:14 2014 +0000
Commit: André Erdmann <dywi <AT> mailerd <DOT> de>
CommitDate: Tue Jul 29 17:39:14 2014 +0000
URL: http://git.overlays.gentoo.org/gitweb/?p=proj/R_overlay.git;a=commit;h=768b134a
roverlay/depres, rule constructor: accept bool value
The wide_match option accepts a boolean value now:
wide_match[=[1|y|yes|0|n|no|...]]
---
roverlay/depres/simpledeprule/rules.py | 10 +++++++---
roverlay/strutil.py | 17 +++++++++++++++++
2 files changed, 24 insertions(+), 3 deletions(-)
diff --git a/roverlay/depres/simpledeprule/rules.py b/roverlay/depres/simpledeprule/rules.py
index df767ba..797ba98 100644
--- a/roverlay/depres/simpledeprule/rules.py
+++ b/roverlay/depres/simpledeprule/rules.py
@@ -21,14 +21,16 @@ __all__ = (
)
+import roverlay.strutil
+import roverlay.depres.depenv
+
+
from roverlay.depres.simpledeprule.util import \
RuleFileSyntaxError, get_slot_restrict, get_slot_parser
from roverlay.depres.simpledeprule.abstractrules import \
SimpleRule, FuzzySimpleRule
-import roverlay.depres.depenv
-
@@ -106,7 +108,9 @@ class RuleConstructor ( object ):
if not has_value:
kwargs ['allow_wide_match'] = True
else:
- raise NotImplementedError("wide_match value")
+ kwargs ['allow_wide_match'] = bool (
+ roverlay.strutil.str_to_bool ( value )
+ )
elif opt == '*':
kwargs ['slot_operator'] = '*'
diff --git a/roverlay/strutil.py b/roverlay/strutil.py
index 9799477..76949fc 100644
--- a/roverlay/strutil.py
+++ b/roverlay/strutil.py
@@ -8,6 +8,7 @@
__all__ = [ 'ascii_filter', 'bytes_try_decode', 'fix_ebuild_name',
'pipe_lines', 'shorten_str', 'unquote', 'foreach_str',
+ 'str_to_bool',
]
import re
@@ -158,3 +159,19 @@ def foreach_str ( func, _str ):
else:
return [ func(str(s)) for s in _str ]
# --- end of foreach_str (...) ---
+
+def str_to_bool ( s, empty_return=None, nofail=False ):
+ if not s:
+ return empty_return
+
+ slow = s.lower()
+
+ if slow in { 'y', 'yes', '1', 'true', 'enabled', 'on' }:
+ return True
+ elif slow in { 'n', 'no', '0', 'false', 'disabled', 'off' }:
+ return False
+ elif nofail:
+ return None
+ else:
+ raise ValueError(s)
+# --- end of str_to_bool (...) ---
^ permalink raw reply related [flat|nested] 2+ messages in thread
* [gentoo-commits] proj/R_overlay:master commit in: roverlay/depres/simpledeprule/, roverlay/
@ 2014-08-23 19:03 André Erdmann
2014-07-29 18:29 ` André Erdmann
0 siblings, 1 reply; 2+ messages in thread
From: André Erdmann @ 2014-08-23 19:03 UTC (permalink / raw
To: gentoo-commits
commit: 768b134a4a388bc11175c5ff8975369fe01317fe
Author: André Erdmann <dywi <AT> mailerd <DOT> de>
AuthorDate: Tue Jul 29 17:39:14 2014 +0000
Commit: André Erdmann <dywi <AT> mailerd <DOT> de>
CommitDate: Tue Jul 29 17:39:14 2014 +0000
URL: http://sources.gentoo.org/gitweb/?p=proj/R_overlay.git;a=commit;h=768b134a
roverlay/depres, rule constructor: accept bool value
The wide_match option accepts a boolean value now:
wide_match[=[1|y|yes|0|n|no|...]]
---
roverlay/depres/simpledeprule/rules.py | 10 +++++++---
roverlay/strutil.py | 17 +++++++++++++++++
2 files changed, 24 insertions(+), 3 deletions(-)
diff --git a/roverlay/depres/simpledeprule/rules.py b/roverlay/depres/simpledeprule/rules.py
index df767ba..797ba98 100644
--- a/roverlay/depres/simpledeprule/rules.py
+++ b/roverlay/depres/simpledeprule/rules.py
@@ -21,14 +21,16 @@ __all__ = (
)
+import roverlay.strutil
+import roverlay.depres.depenv
+
+
from roverlay.depres.simpledeprule.util import \
RuleFileSyntaxError, get_slot_restrict, get_slot_parser
from roverlay.depres.simpledeprule.abstractrules import \
SimpleRule, FuzzySimpleRule
-import roverlay.depres.depenv
-
@@ -106,7 +108,9 @@ class RuleConstructor ( object ):
if not has_value:
kwargs ['allow_wide_match'] = True
else:
- raise NotImplementedError("wide_match value")
+ kwargs ['allow_wide_match'] = bool (
+ roverlay.strutil.str_to_bool ( value )
+ )
elif opt == '*':
kwargs ['slot_operator'] = '*'
diff --git a/roverlay/strutil.py b/roverlay/strutil.py
index 9799477..76949fc 100644
--- a/roverlay/strutil.py
+++ b/roverlay/strutil.py
@@ -8,6 +8,7 @@
__all__ = [ 'ascii_filter', 'bytes_try_decode', 'fix_ebuild_name',
'pipe_lines', 'shorten_str', 'unquote', 'foreach_str',
+ 'str_to_bool',
]
import re
@@ -158,3 +159,19 @@ def foreach_str ( func, _str ):
else:
return [ func(str(s)) for s in _str ]
# --- end of foreach_str (...) ---
+
+def str_to_bool ( s, empty_return=None, nofail=False ):
+ if not s:
+ return empty_return
+
+ slow = s.lower()
+
+ if slow in { 'y', 'yes', '1', 'true', 'enabled', 'on' }:
+ return True
+ elif slow in { 'n', 'no', '0', 'false', 'disabled', 'off' }:
+ return False
+ elif nofail:
+ return None
+ else:
+ raise ValueError(s)
+# --- end of str_to_bool (...) ---
^ permalink raw reply related [flat|nested] 2+ messages in thread
end of thread, other threads:[~2014-08-23 19:03 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-08-23 19:03 [gentoo-commits] proj/R_overlay:master commit in: roverlay/depres/simpledeprule/, roverlay/ André Erdmann
2014-07-29 18:29 ` André Erdmann
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox