//
// System.Web.Compilation.TemplateBuildProvider
//
// Authors:
// Chris Toshok (toshok@ximian.com)
// Marek Habersack (mhabersack@novell.com)
//
// (C) 2008 Novell, Inc
//
//
// Permission is hereby granted, free of charge, to any person obtaining
// a copy of this software and associated documentation files (the
// "Software"), to deal in the Software without restriction, including
// without limitation the rights to use, copy, modify, merge, publish,
// distribute, sublicense, and/or sell copies of the Software, and to
// permit persons to whom the Software is furnished to do so, subject to
// the following conditions:
//
// The above copyright notice and this permission notice shall be
// included in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
//
using System;
using System.CodeDom;
using System.CodeDom.Compiler;
using System.Collections;
using System.IO;
using System.Reflection;
using System.Web;
using System.Web.UI;
namespace System.Web.Compilation{
internal class ThemeDirectoryBuildProvider : TemplateBuildProvider
{
public ThemeDirectoryBuildProvider ()
{
}
protected override void OverrideAssemblyPrefix (TemplateParser parser, AssemblyBuilder assemblyBuilder)
{
if (parser == null || assemblyBuilder == null)
return;
string newPrefix = assemblyBuilder.OutputFilesPrefix + parser.ClassName + ".";
assemblyBuilder.OutputFilesPrefix = newPrefix;
}
protected override BaseCompiler CreateCompiler (TemplateParser parser)
{
return new PageThemeCompiler (parser as PageThemeParser);
}
protected override TemplateParser CreateParser (VirtualPath virtualPath, string inputFile, TextReader reader, HttpContext context)
{
return CreateParser (virtualPath, inputFile, context);
}
protected override TemplateParser CreateParser (VirtualPath virtualPath, string inputFile, HttpContext context)
{
string vp = VirtualPathUtility.AppendTrailingSlash (virtualPath.Original);
string physicalPath = virtualPath.PhysicalPath;
if (!Directory.Exists (physicalPath))
throw new HttpException (String.Concat ("Theme '", virtualPath.Original ,"' cannot be found in the application or global theme directories."));
PageThemeParser ptp = new PageThemeParser (virtualPath, context);
string[] css_files = Directory.GetFiles (physicalPath, "*.css");
string[] css_urls = new string [css_files.Length];
for (int i = 0; i < css_files.Length; i++) {
css_urls [i] = VirtualPathUtility.Combine (vp, Path.GetFileName (css_files [i]));
ptp.AddDependency (css_urls [i]);
}
ptp.LinkedStyleSheets = css_urls;
AspComponentFoundry shared_foundry = new AspComponentFoundry ();
ptp.RootBuilder = new RootBuilder ();
string [] skin_files = Directory.GetFiles (physicalPath, "*.skin");
string skin_file_url;
AspGenerator generator;
foreach (string skin_file in skin_files) {
skin_file_url = VirtualPathUtility.Combine (vp, Path.GetFileName (skin_file));
PageThemeFileParser ptfp = new PageThemeFileParser (new VirtualPath (skin_file_url), skin_file, context);
ptp.AddDependency (skin_file_url);
generator = new AspGenerator (ptfp, shared_foundry);
generator.Parse ();
if (ptfp.RootBuilder.Children != null)
foreach (object o in ptfp.RootBuilder.Children) {
if (!(o is ControlBuilder))
continue;
ptp.RootBuilder.AppendSubBuilder ((ControlBuilder)o);
}
foreach (string ass in ptfp.Assemblies)
if (!ptp.Assemblies.Contains (ass))
ptp.AddAssemblyByFileName (ass);
}
return ptp;
}
protected override bool IsDirectoryBuilder {
get { return true; }
}
}
}
|