diff options
author | Joseph Hunkeler <jhunkeler@gmail.com> | 2015-07-06 09:13:45 -0400 |
---|---|---|
committer | Joseph Hunkeler <jhunkeler@gmail.com> | 2015-07-06 09:13:45 -0400 |
commit | 8fe362df5f58d2d51270641ae9f9fb1566352f34 (patch) | |
tree | c882d26725b5b2f6e83dde2a0c6a3eb28dc8f25c /cbc | |
parent | bc9d2243a5260170a3f7c47d67646d7784fab4b3 (diff) | |
download | cbc-8fe362df5f58d2d51270641ae9f9fb1566352f34.tar.gz |
Add shell enviroment to Environment. Add copy_patches.
Diffstat (limited to 'cbc')
-rw-r--r-- | cbc/meta.py | 18 |
1 files changed, 15 insertions, 3 deletions
diff --git a/cbc/meta.py b/cbc/meta.py index 7203726..2a72148 100644 --- a/cbc/meta.py +++ b/cbc/meta.py @@ -4,7 +4,10 @@ And yeah, conda supports Jinja2, but ugh... No. import os
import conda_build.metadata
+import conda_build.environ
import yaml
+import shutil
+from glob import glob
from configparser import SafeConfigParser, ExtendedInterpolation
from collections import OrderedDict
from .environment import Environment
@@ -19,12 +22,13 @@ class MetaData(object): raise OSError('"{0}" does not exist.'.format(filename));
self.filename = filename
+ self.confdir = os.path.dirname(self.filename)
if not isinstance(env, Environment):
raise MetaDataError('Expecting instance of cbc.environment.Environment, got: "{0}"'.format(type(env)))
self.env = env
- self.builtins = ['cbc_build', 'cbc_cgi']
+ self.builtins = ['cbc_build', 'cbc_cgi', 'environ']
self.fields = self.convert_conda_fields(conda_build.metadata.FIELDS)
@@ -34,10 +38,12 @@ class MetaData(object): self.config.read_dict(self.fields)
# Include user-defined build fields
self.config.read(self.filename)
+ # Assimilate conda environment variables
+ self.config['environ'] = conda_build.environ.get_dict()
# Convert ConfigParser -> generic dictionary
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'])
@@ -63,7 +69,7 @@ class MetaData(object): # Convert dict to YAML-compatible dict
self.conda_metadata = self.scrub(self.local, self.builtins)
-
+
def run(self):
self.render_scripts()
@@ -76,6 +82,12 @@ class MetaData(object): with open(maskval, 'w+') as metafile:
metafile.write(metaval)
+ def copy_patches(self):
+ extensions = ['*.diff', '*.patch']
+ for extension in extensions:
+ path = os.path.join(self.confdir, extension)
+ for patch in glob(path):
+ shutil.copy2(patch, self.env.pkgdir)
def compile(self):
compiled = {}
|