|
|
@@ -0,0 +1,74 @@ |
|
|
|
# -*- coding: utf-8 -*- |
|
|
|
""" |
|
|
|
Contains classes to combine files into one |
|
|
|
""" |
|
|
|
|
|
|
|
from fnmatch import fnmatch |
|
|
|
|
|
|
|
from hyde.model import Expando |
|
|
|
from hyde.plugin import Plugin |
|
|
|
|
|
|
|
class CombinePlugin(Plugin): |
|
|
|
""" |
|
|
|
To use this combine, the following configuration should be added |
|
|
|
to meta data:: |
|
|
|
combine: |
|
|
|
files: |
|
|
|
- ns1.*.js |
|
|
|
- ns2.*.js |
|
|
|
where: top |
|
|
|
|
|
|
|
`files` is a list of resources (or just a resource) that should be |
|
|
|
combined. Globbing is performed. `where` indicate where the |
|
|
|
combination should be done. This could be `top` or `bottom` of the |
|
|
|
file. |
|
|
|
""" |
|
|
|
|
|
|
|
def __init__(self, site): |
|
|
|
super(CombinePlugin, self).__init__(site) |
|
|
|
|
|
|
|
def begin_text_resource(self, resource, text): |
|
|
|
""" |
|
|
|
When generating a resource, add combined file if needed. |
|
|
|
""" |
|
|
|
# Grab configuration |
|
|
|
try: |
|
|
|
config = resource.meta.combine |
|
|
|
except AttributeError: |
|
|
|
return |
|
|
|
# Grab file list |
|
|
|
try: |
|
|
|
files = config.files |
|
|
|
except AttributeError: |
|
|
|
raise "No resources to combine for [%s]" % resource |
|
|
|
if type(files) is str: |
|
|
|
files = [ files ] |
|
|
|
where = "bottom" |
|
|
|
try: |
|
|
|
where = config.where |
|
|
|
except AttributeError: |
|
|
|
pass |
|
|
|
|
|
|
|
if where not in [ "top", "bottom" ]: |
|
|
|
raise ValueError("%r should be either `top` or `bottom`" % where) |
|
|
|
|
|
|
|
resources = [] |
|
|
|
for r in resource.node.resources: |
|
|
|
for f in files: |
|
|
|
if fnmatch(r.name, f): |
|
|
|
resources.append(r) |
|
|
|
break |
|
|
|
if not resources: |
|
|
|
self.logger.debug("No resources to combine for [%s]" % resource) |
|
|
|
return |
|
|
|
self.logger.debug( |
|
|
|
"Combining %d resources for [%s]" % (len(resources), |
|
|
|
resource)) |
|
|
|
if not hasattr(resource, 'depends'): |
|
|
|
resource.depends = [] |
|
|
|
resource.depends.extend([r.relative_path for r in resources |
|
|
|
if r.relative_path not in resource.depends]) |
|
|
|
if where == "top": |
|
|
|
return "".join([r.source.read_all() for r in resources] + [text]) |
|
|
|
else: |
|
|
|
return "".join([text] + [r.source.read_all() for r in resources]) |