diff options
| author | Joseph Hunkeler <jhunkeler@gmail.com> | 2015-06-24 09:16:12 -0400 | 
|---|---|---|
| committer | Joseph Hunkeler <jhunkeler@gmail.com> | 2015-06-24 09:16:12 -0400 | 
| commit | 5cb744903073bbd005f28ea89e1e2b591668d9b8 (patch) | |
| tree | 41dceb6433e3c4bc880a6061def27f188873b14f /cbc | |
| parent | 43de08e21160ee71c25fcd1451efc6e27f5615b3 (diff) | |
| download | cbc-5cb744903073bbd005f28ea89e1e2b591668d9b8.tar.gz | |
Implement list converstion on requirements section, requirements are REQUIRED
Diffstat (limited to 'cbc')
| -rw-r--r-- | cbc/meta.py | 39 | 
1 files changed, 36 insertions, 3 deletions
| diff --git a/cbc/meta.py b/cbc/meta.py index 222d5d0..def9b1e 100644 --- a/cbc/meta.py +++ b/cbc/meta.py @@ -5,7 +5,7 @@ And yeah, conda supports Jinja2, but ugh... No.  import os
  import conda_build.metadata
  import yaml
 -from configparser import SafeConfigParser, ExtendedInterpolation
 +from configparser import SafeConfigParser, ExtendedInterpolation, ConfigParser
  from collections import OrderedDict
  from .environment import Environment
  from .exceptions import MetaDataError
 @@ -27,14 +27,22 @@ class MetaData(object):          self.fields = self.convert_conda_fields(conda_build.metadata.FIELDS)
 -        self.config = SafeConfigParser(interpolation=ExtendedInterpolation(), allow_no_value=True)
 +        #self.config = SafeConfigParser(interpolation=ExtendedInterpolation(), allow_no_value=True)
 +        self.config = CBCConfigParser(interpolation=ExtendedInterpolation(), allow_no_value=True)
          # Include built-in Conda metadata fields
          self.config.read_dict(self.fields)
          # Include user-defined build fields
          self.config.read(self.filename)
 +        
          # Convert ConfigParser -> dict
          self.local = self.as_dict(self.config)
 +        #if not self.local['requirements']['build']:
 +        #    raise MetaDataError('Incomplete or missing "requirements" section: self.local[\'requirements\'] ', self.local['requirements']['build'])
 +            
 +        self.local['requirements']['build'] = self.config.getlist('requirements', 'build')
 +        self.local['requirements']['run'] = self.config.getlist('requirements', 'run')
 +        
          self.local_metadata = {}
          for keyword in self.keywords:
              if keyword in self.local:
 @@ -96,4 +104,29 @@ class MetaData(object):          return the_dict
 -    
\ No newline at end of file +
 +def aslist_cronly(value):
 +    if isinstance(value, str):
 +        value = filter(None, [x.strip() for x in value.splitlines()])
 +    return list(value)
 +
 +def aslist(value, flatten=True):
 +    """ Return a list of strings, separating the input based on newlines
 +    and, if flatten=True (the default), also split on spaces within
 +    each line."""
 +    values = aslist_cronly(value)
 +    if not flatten:
 +        return values
 +    result = []
 +    for value in values:
 +        subvalues = value.split()
 +        result.extend(subvalues)
 +    return result
 +
 +class CBCConfigParser(SafeConfigParser):
 +    def getlist(self,section,option):
 +        value = self.get(section,option)
 +        return list(filter(None, (x.strip() for x in value.splitlines())))
 +
 +    def getlistint(self,section,option):
 +        return [int(x) for x in self.getlist(section,option)]
\ No newline at end of file | 
