* prebuild now creates .exe references in NAntTarget
* prebuild now uses local copy of schema (for future expansions)afrisby
parent
7fb9665cf5
commit
ce33db72cb
|
@ -0,0 +1,258 @@
|
|||
<?xml version="1.0" encoding="utf-8" ?>
|
||||
<xs:schema elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema" targetNamespace="http://dnpb.sourceforge.net/schemas/prebuild-1.7.xsd"
|
||||
xmlns="http://dnpb.sourceforge.net/schemas/prebuild-1.7.xsd">
|
||||
<xs:annotation>
|
||||
<xs:documentation>
|
||||
Copyright (c) 2004-2005 Matthew Holmes (calefaction at houston . rr . com), Dan Moorehead (dan05a at gmail . com), David Hudson (jendave at yahoo dot com)
|
||||
|
||||
.NET Prebuild is a cross-platform XML-driven pre-build tool which
|
||||
allows developers to easily generate project or make files for major
|
||||
IDE's and .NET development tools including: Visual Studio .NET 2002 and
|
||||
2003, SharpDevelop, MonoDevelop, and NAnt.
|
||||
|
||||
BSD License:
|
||||
|
||||
Redistribution and use in source and binary forms, with or without modification, are permitted
|
||||
provided that the following conditions are met:
|
||||
|
||||
* Redistributions of source code must retain the above copyright notice, this list of conditions
|
||||
and the following disclaimer.
|
||||
* Redistributions in binary form must reproduce the above copyright notice, this list of conditions
|
||||
and the following disclaimer in the documentation and/or other materials provided with the
|
||||
distribution.
|
||||
* The name of the author may not be used to endorse or promote products derived from this software
|
||||
without specific prior written permission.
|
||||
|
||||
THIS SOFTWARE IS PROVIDED BY THE AUTHOR 'AS IS' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING,
|
||||
BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||
ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||
OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
|
||||
OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
|
||||
IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
</xs:documentation>
|
||||
</xs:annotation>
|
||||
<xs:element name="Prebuild">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element ref="Process" minOccurs="0" maxOccurs="unbounded" />
|
||||
<xs:element ref="Solution" minOccurs="0" maxOccurs="unbounded" />
|
||||
</xs:sequence>
|
||||
<xs:attribute name="version" />
|
||||
<xs:attribute name="checkOsVars" />
|
||||
</xs:complexType>
|
||||
</xs:element>
|
||||
<xs:element name="Process" type="xs:string" />
|
||||
<xs:element name="Solution">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element ref="Options" minOccurs="0" />
|
||||
<xs:element ref="Configuration" minOccurs="1" maxOccurs="unbounded" />
|
||||
<xs:element ref="Files" minOccurs="0" />
|
||||
<xs:element ref="Project" minOccurs="1" maxOccurs="unbounded" />
|
||||
</xs:sequence>
|
||||
<xs:attribute name="name" type="xs:string" use="required" />
|
||||
<xs:attribute name="activeConfig" type="xs:string" default="Debug" />
|
||||
<xs:attribute name="path" type="xs:string" default="" />
|
||||
</xs:complexType>
|
||||
</xs:element>
|
||||
<xs:element name="Project">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element ref="Configuration" minOccurs="0" maxOccurs="unbounded" />
|
||||
<xs:element name="ReferencePath" type="xs:string" minOccurs="0" maxOccurs="unbounded" />
|
||||
<xs:element name="Reference" minOccurs="0" maxOccurs="unbounded">
|
||||
<xs:complexType>
|
||||
<xs:attribute name="name" type="xs:string" use="required" />
|
||||
<xs:attribute name="path" type="xs:string" />
|
||||
<xs:attribute name="localCopy" type="xs:boolean" />
|
||||
<xs:attribute name="version" type="xs:string" />
|
||||
</xs:complexType>
|
||||
</xs:element>
|
||||
<xs:element ref="Files" />
|
||||
</xs:sequence>
|
||||
<xs:attribute name="name" type="xs:string" use="required" />
|
||||
<xs:attribute name="designerFolder" type="xs:string" default="" />
|
||||
<xs:attribute name="filterGroups" type="xs:string" default="" />
|
||||
<xs:attribute name="path" type="xs:string" default="" />
|
||||
<xs:attribute name="icon" type="xs:string" default="" />
|
||||
<xs:attribute name="language" default="C#">
|
||||
<xs:simpleType>
|
||||
<xs:restriction base="xs:string">
|
||||
<xs:enumeration value="C#" />
|
||||
<xs:enumeration value="VB.NET" />
|
||||
</xs:restriction>
|
||||
</xs:simpleType>
|
||||
</xs:attribute>
|
||||
<xs:attribute name="type" default="Exe">
|
||||
<xs:simpleType>
|
||||
<xs:restriction base="xs:string">
|
||||
<xs:enumeration value="Exe" />
|
||||
<xs:enumeration value="WinExe" />
|
||||
<xs:enumeration value="Library" />
|
||||
</xs:restriction>
|
||||
</xs:simpleType>
|
||||
</xs:attribute>
|
||||
<xs:attribute name="runtime" default="Microsoft">
|
||||
<xs:simpleType>
|
||||
<xs:restriction base="xs:string">
|
||||
<xs:enumeration value="Microsoft" />
|
||||
<xs:enumeration value="Mono" />
|
||||
</xs:restriction>
|
||||
</xs:simpleType>
|
||||
</xs:attribute>
|
||||
<xs:attribute name="startupObject" type="xs:string" default="" />
|
||||
<xs:attribute name="rootNamespace" type="xs:string" />
|
||||
<xs:attribute name="assemblyName" type="xs:string" />
|
||||
</xs:complexType>
|
||||
</xs:element>
|
||||
<xs:element name="Configuration">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element ref="Options" minOccurs="0" />
|
||||
</xs:sequence>
|
||||
<xs:attribute name="name" type="xs:string" use="required" />
|
||||
</xs:complexType>
|
||||
</xs:element>
|
||||
<xs:element name="Options">
|
||||
<xs:complexType>
|
||||
<xs:all>
|
||||
<xs:element name="CompilerDefines" type="xs:string" minOccurs="0" />
|
||||
<xs:element name="OptimizeCode" type="xs:boolean" minOccurs="0" />
|
||||
<xs:element name="CheckUnderflowOverflow" type="xs:boolean" minOccurs="0" />
|
||||
<xs:element name="AllowUnsafe" type="xs:boolean" minOccurs="0" />
|
||||
<xs:element name="PreBuildEvent" type="xs:string" minOccurs="0" />
|
||||
<xs:element name="PostBuildEvent" type="xs:string" minOccurs="0" />
|
||||
<xs:element name="RunPostBuildEvent" minOccurs="0" default="OnBuildSuccess">
|
||||
<xs:simpleType>
|
||||
<xs:restriction base="xs:string">
|
||||
<xs:enumeration value="OnBuildSuccess" />
|
||||
<xs:enumeration value="Always" />
|
||||
<xs:enumeration value="OnOutputUpdated" />
|
||||
</xs:restriction>
|
||||
</xs:simpleType>
|
||||
</xs:element>
|
||||
<xs:element name="RunScript" type="xs:string" minOccurs="0" />
|
||||
<xs:element name="PreBuildEventArgs" type="xs:string" minOccurs="0" />
|
||||
<xs:element name="PostBuildEventArgs" type="xs:string" minOccurs="0" />
|
||||
<xs:element name="WarningLevel" minOccurs="0">
|
||||
<xs:simpleType>
|
||||
<xs:restriction base="xs:integer">
|
||||
<xs:minInclusive value="0" />
|
||||
<xs:maxInclusive value="4" />
|
||||
</xs:restriction>
|
||||
</xs:simpleType>
|
||||
</xs:element>
|
||||
<xs:element name="WarningsAsErrors" type="xs:boolean" minOccurs="0" />
|
||||
<xs:element name="SuppressWarnings" type="xs:string" minOccurs="0" />
|
||||
<xs:element name="OutputPath" type="xs:string" minOccurs="0" />
|
||||
<xs:element name="XmlDocFile" type="xs:string" minOccurs="0" />
|
||||
<xs:element name="DebugInformation" type="xs:boolean" minOccurs="0" />
|
||||
<xs:element name="RegisterComInterop" type="xs:boolean" minOccurs="0" />
|
||||
<xs:element name="RemoveIntegerChecks" type="xs:boolean" minOccurs="0" />
|
||||
<xs:element name="IncrementalBuild" type="xs:boolean" minOccurs="0" />
|
||||
<xs:element name="BaseAddress" type="xs:string" minOccurs="0" />
|
||||
<xs:element name="FileAlignment" type="xs:integer" minOccurs="0" />
|
||||
<xs:element name="NoStdLib" type="xs:boolean" minOccurs="0" />
|
||||
<xs:element name="KeyFile" type="xs:string" minOccurs="0" />
|
||||
</xs:all>
|
||||
</xs:complexType>
|
||||
</xs:element>
|
||||
<xs:element name="Files">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element ref="File" minOccurs="0" maxOccurs="unbounded" />
|
||||
<xs:element ref="Match" minOccurs="0" maxOccurs="unbounded" />
|
||||
</xs:sequence>
|
||||
</xs:complexType>
|
||||
</xs:element>
|
||||
<xs:element name="File">
|
||||
<xs:complexType>
|
||||
<xs:simpleContent>
|
||||
<xs:extension base="xs:string">
|
||||
<xs:attribute name="resourceName" type="xs:string" default="" />
|
||||
<xs:attribute name="buildAction" default="Compile">
|
||||
<xs:simpleType>
|
||||
<xs:restriction base="xs:string">
|
||||
<xs:enumeration value="None" />
|
||||
<xs:enumeration value="Compile" />
|
||||
<xs:enumeration value="Content" />
|
||||
<xs:enumeration value="EmbeddedResource" />
|
||||
</xs:restriction>
|
||||
</xs:simpleType>
|
||||
</xs:attribute>
|
||||
<xs:attribute name="subType" default="Code">
|
||||
<xs:simpleType>
|
||||
<xs:restriction base="xs:string">
|
||||
<xs:enumeration value="Code" />
|
||||
<xs:enumeration value="Component" />
|
||||
<xs:enumeration value="Form" />
|
||||
<xs:enumeration value="Settings" />
|
||||
<xs:enumeration value="UserControl" />
|
||||
</xs:restriction>
|
||||
</xs:simpleType>
|
||||
</xs:attribute>
|
||||
<xs:attribute name="link" type="xs:boolean" />
|
||||
<xs:attribute name="copyToOutput" default="Never">
|
||||
<xs:simpleType>
|
||||
<xs:restriction base="xs:string">
|
||||
<xs:enumeration value="Never" />
|
||||
<xs:enumeration value="Always" />
|
||||
<xs:enumeration value="PreserveNewest" />
|
||||
</xs:restriction>
|
||||
</xs:simpleType>
|
||||
</xs:attribute>
|
||||
</xs:extension>
|
||||
</xs:simpleContent>
|
||||
</xs:complexType>
|
||||
</xs:element>
|
||||
<xs:element name="Match">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element ref="Exclude" minOccurs="0" maxOccurs="unbounded" />
|
||||
</xs:sequence>
|
||||
<xs:attribute name="path" type="xs:string" />
|
||||
<xs:attribute name="pattern" type="xs:string" use="required" />
|
||||
<xs:attribute name="recurse" type="xs:boolean" default="false" />
|
||||
<xs:attribute name="useRegex" type="xs:boolean" default="false" />
|
||||
<xs:attribute name="buildAction" default="Compile">
|
||||
<xs:simpleType>
|
||||
<xs:restriction base="xs:string">
|
||||
<xs:enumeration value="None" />
|
||||
<xs:enumeration value="Compile" />
|
||||
<xs:enumeration value="Content" />
|
||||
<xs:enumeration value="EmbeddedResource" />
|
||||
</xs:restriction>
|
||||
</xs:simpleType>
|
||||
</xs:attribute>
|
||||
<xs:attribute name="resourceName" type="xs:string" default="" />
|
||||
<xs:attribute name="subType" default="Code">
|
||||
<xs:simpleType>
|
||||
<xs:restriction base="xs:string">
|
||||
<xs:enumeration value="Code" />
|
||||
<xs:enumeration value="Component" />
|
||||
<xs:enumeration value="Form" />
|
||||
<xs:enumeration value="Settings" />
|
||||
<xs:enumeration value="UserControl" />
|
||||
</xs:restriction>
|
||||
</xs:simpleType>
|
||||
</xs:attribute>
|
||||
<xs:attribute name="link" type="xs:boolean" />
|
||||
<xs:attribute name="copyToOutput" default="Never">
|
||||
<xs:simpleType>
|
||||
<xs:restriction base="xs:string">
|
||||
<xs:enumeration value="Never" />
|
||||
<xs:enumeration value="Always" />
|
||||
<xs:enumeration value="PreserveNewest" />
|
||||
</xs:restriction>
|
||||
</xs:simpleType>
|
||||
</xs:attribute>
|
||||
</xs:complexType>
|
||||
</xs:element>
|
||||
<xs:element name="Exclude">
|
||||
<xs:complexType>
|
||||
<xs:attribute name="name" type="xs:string" use="required" />
|
||||
</xs:complexType>
|
||||
</xs:element>
|
||||
|
||||
</xs:schema>
|
|
@ -47,18 +47,18 @@ using Prebuild.Core.Utilities;
|
|||
namespace Prebuild.Core.Targets
|
||||
{
|
||||
/// <summary>
|
||||
///
|
||||
/// </summary>
|
||||
[Target("nant")]
|
||||
public class NAntTarget : ITarget
|
||||
{
|
||||
#region Fields
|
||||
///
|
||||
/// </summary>
|
||||
[Target("nant")]
|
||||
public class NAntTarget : ITarget
|
||||
{
|
||||
#region Fields
|
||||
|
||||
private Kernel m_Kernel;
|
||||
|
||||
#endregion
|
||||
#endregion
|
||||
|
||||
#region Private Methods
|
||||
#region Private Methods
|
||||
|
||||
private static string PrependPath(string path)
|
||||
{
|
||||
|
@ -80,11 +80,11 @@ public class NAntTarget : ITarget
|
|||
private static string BuildReference(SolutionNode solution, ProjectNode currentProject, ReferenceNode refr)
|
||||
{
|
||||
string ret = "";
|
||||
if(solution.ProjectsTable.ContainsKey(refr.Name))
|
||||
if (solution.ProjectsTable.ContainsKey(refr.Name))
|
||||
{
|
||||
ProjectNode project = (ProjectNode)solution.ProjectsTable[refr.Name];
|
||||
|
||||
string finalPath = Helper.NormalizePath(((ReferencePathNode)currentProject.ReferencePaths[0]).Path + refr.Name + ".dll", '/');
|
||||
string finalPath = Helper.NormalizePath(((ReferencePathNode)currentProject.ReferencePaths[0]).Path + refr.Name + GetProjectExtension(project), '/');
|
||||
|
||||
return finalPath;
|
||||
}
|
||||
|
@ -93,9 +93,9 @@ public class NAntTarget : ITarget
|
|||
ProjectNode project = (ProjectNode)refr.Parent;
|
||||
string fileRef = FindFileReference(refr.Name, project);
|
||||
|
||||
if(refr.Path != null || fileRef != null)
|
||||
if (refr.Path != null || fileRef != null)
|
||||
{
|
||||
string finalPath = (refr.Path != null) ? Helper.NormalizePath(refr.Path + "/" + refr.Name + ".dll", '/') : fileRef;
|
||||
string finalPath = (refr.Path != null) ? Helper.NormalizePath(refr.Path + "/" + refr.Name + GetProjectExtension(project), '/') : fileRef;
|
||||
ret += finalPath;
|
||||
return ret;
|
||||
}
|
||||
|
@ -109,22 +109,32 @@ public class NAntTarget : ITarget
|
|||
//}
|
||||
//else
|
||||
//{
|
||||
ret += (refr.Name + ".dll");
|
||||
ret += (refr.Name + GetProjectExtension(project));
|
||||
//}
|
||||
}
|
||||
catch (System.NullReferenceException e)
|
||||
{
|
||||
e.ToString();
|
||||
ret += refr.Name + ".dll";
|
||||
ret += refr.Name + GetProjectExtension(project);
|
||||
}
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
private static string GetProjectExtension(ProjectNode project)
|
||||
{
|
||||
string extension = ".dll";
|
||||
if (project.Type == ProjectType.Exe)
|
||||
{
|
||||
extension = ".exe";
|
||||
}
|
||||
return extension;
|
||||
}
|
||||
|
||||
private static string BuildReferencePath(SolutionNode solution, ReferenceNode refr)
|
||||
{
|
||||
string ret = "";
|
||||
if(solution.ProjectsTable.ContainsKey(refr.Name))
|
||||
if (solution.ProjectsTable.ContainsKey(refr.Name))
|
||||
{
|
||||
ProjectNode project = (ProjectNode)solution.ProjectsTable[refr.Name];
|
||||
string finalPath = Helper.NormalizePath(((ReferencePathNode)project.ReferencePaths[0]).Path, '/');
|
||||
|
@ -136,7 +146,7 @@ public class NAntTarget : ITarget
|
|||
ProjectNode project = (ProjectNode)refr.Parent;
|
||||
string fileRef = FindFileReference(refr.Name, project);
|
||||
|
||||
if(refr.Path != null || fileRef != null)
|
||||
if (refr.Path != null || fileRef != null)
|
||||
{
|
||||
string finalPath = (refr.Path != null) ? Helper.NormalizePath(refr.Path, '/') : fileRef;
|
||||
ret += finalPath;
|
||||
|
@ -166,11 +176,11 @@ public class NAntTarget : ITarget
|
|||
|
||||
private static string FindFileReference(string refName, ProjectNode project)
|
||||
{
|
||||
foreach(ReferencePathNode refPath in project.ReferencePaths)
|
||||
foreach (ReferencePathNode refPath in project.ReferencePaths)
|
||||
{
|
||||
string fullPath = Helper.MakeFilePath(refPath.Path, refName, "dll");
|
||||
|
||||
if(File.Exists(fullPath))
|
||||
if (File.Exists(fullPath))
|
||||
{
|
||||
return fullPath;
|
||||
}
|
||||
|
@ -187,11 +197,11 @@ public class NAntTarget : ITarget
|
|||
/// <returns></returns>
|
||||
public static string GetXmlDocFile(ProjectNode project, ConfigurationNode conf)
|
||||
{
|
||||
if( conf == null )
|
||||
if (conf == null)
|
||||
{
|
||||
throw new ArgumentNullException("conf");
|
||||
}
|
||||
if( project == null )
|
||||
if (project == null)
|
||||
{
|
||||
throw new ArgumentNullException("project");
|
||||
}
|
||||
|
@ -205,14 +215,14 @@ public class NAntTarget : ITarget
|
|||
|
||||
private void WriteProject(SolutionNode solution, ProjectNode project)
|
||||
{
|
||||
string projFile = Helper.MakeFilePath(project.FullPath, project.Name + (project.Type == ProjectType.Library ? ".dll" : ".exe"), "build");
|
||||
string projFile = Helper.MakeFilePath(project.FullPath, project.Name + GetProjectExtension(project), "build");
|
||||
StreamWriter ss = new StreamWriter(projFile);
|
||||
|
||||
m_Kernel.CurrentWorkingDirectory.Push();
|
||||
Helper.SetCurrentDir(Path.GetDirectoryName(projFile));
|
||||
bool hasDoc = false;
|
||||
|
||||
using(ss)
|
||||
using (ss)
|
||||
{
|
||||
ss.WriteLine("<?xml version=\"1.0\" ?>");
|
||||
ss.WriteLine("<project name=\"{0}\" default=\"build\">", project.Name);
|
||||
|
@ -221,11 +231,11 @@ public class NAntTarget : ITarget
|
|||
ss.WriteLine(" <mkdir dir=\"${project::get-base-directory()}/${build.dir}\" />");
|
||||
ss.WriteLine(" <copy todir=\"${project::get-base-directory()}/${build.dir}\">");
|
||||
ss.WriteLine(" <fileset basedir=\"${project::get-base-directory()}\">");
|
||||
foreach(ReferenceNode refr in project.References)
|
||||
foreach (ReferenceNode refr in project.References)
|
||||
{
|
||||
if (refr.LocalCopy)
|
||||
{
|
||||
ss.WriteLine(" <include name=\"{0}", Helper.NormalizePath(Helper.MakePathRelativeTo(project.FullPath, BuildReference(solution, project, refr))+"\" />", '/'));
|
||||
ss.WriteLine(" <include name=\"{0}", Helper.NormalizePath(Helper.MakePathRelativeTo(project.FullPath, BuildReference(solution, project, refr)) + "\" />", '/'));
|
||||
}
|
||||
}
|
||||
ss.WriteLine(" </fileset>");
|
||||
|
@ -233,27 +243,27 @@ public class NAntTarget : ITarget
|
|||
ss.Write(" <csc");
|
||||
ss.Write(" target=\"{0}\"", project.Type.ToString().ToLower());
|
||||
ss.Write(" debug=\"{0}\"", "${build.debug}");
|
||||
foreach(ConfigurationNode conf in project.Configurations)
|
||||
foreach (ConfigurationNode conf in project.Configurations)
|
||||
{
|
||||
if (conf.Options.KeyFile !="")
|
||||
if (conf.Options.KeyFile != "")
|
||||
{
|
||||
ss.Write(" keyfile=\"{0}\"", conf.Options.KeyFile);
|
||||
break;
|
||||
}
|
||||
}
|
||||
foreach(ConfigurationNode conf in project.Configurations)
|
||||
foreach (ConfigurationNode conf in project.Configurations)
|
||||
{
|
||||
ss.Write(" unsafe=\"{0}\"", conf.Options.AllowUnsafe);
|
||||
break;
|
||||
}
|
||||
foreach(ConfigurationNode conf in project.Configurations)
|
||||
foreach (ConfigurationNode conf in project.Configurations)
|
||||
{
|
||||
ss.Write(" define=\"{0}\"", conf.Options.CompilerDefines);
|
||||
break;
|
||||
}
|
||||
foreach(ConfigurationNode conf in project.Configurations)
|
||||
foreach (ConfigurationNode conf in project.Configurations)
|
||||
{
|
||||
if (GetXmlDocFile(project, conf) !="")
|
||||
if (GetXmlDocFile(project, conf) != "")
|
||||
{
|
||||
ss.Write(" doc=\"{0}\"", "${project::get-base-directory()}/${build.dir}/" + GetXmlDocFile(project, conf));
|
||||
hasDoc = true;
|
||||
|
@ -269,9 +279,9 @@ public class NAntTarget : ITarget
|
|||
{
|
||||
ss.Write(".exe\"");
|
||||
}
|
||||
if(project.AppIcon != null && project.AppIcon.Length != 0)
|
||||
if (project.AppIcon != null && project.AppIcon.Length != 0)
|
||||
{
|
||||
ss.Write(" win32icon=\"{0}\"", Helper.NormalizePath(project.AppIcon,'/'));
|
||||
ss.Write(" win32icon=\"{0}\"", Helper.NormalizePath(project.AppIcon, '/'));
|
||||
}
|
||||
ss.WriteLine(">");
|
||||
ss.WriteLine(" <resources prefix=\"{0}\" dynamicprefix=\"true\" >", project.RootNamespace);
|
||||
|
@ -296,9 +306,9 @@ public class NAntTarget : ITarget
|
|||
|
||||
ss.WriteLine(" </resources>");
|
||||
ss.WriteLine(" <sources failonempty=\"true\">");
|
||||
foreach(string file in project.Files)
|
||||
foreach (string file in project.Files)
|
||||
{
|
||||
switch(project.Files.GetBuildAction(file))
|
||||
switch (project.Files.GetBuildAction(file))
|
||||
{
|
||||
case BuildAction.Compile:
|
||||
ss.WriteLine(" <include name=\"" + Helper.NormalizePath(PrependPath(file), '/') + "\" />");
|
||||
|
@ -313,10 +323,10 @@ public class NAntTarget : ITarget
|
|||
ss.WriteLine(" <include name=\"${project::get-base-directory()}\" />");
|
||||
ss.WriteLine(" <include name=\"${project::get-base-directory()}/${build.dir}\" />");
|
||||
ss.WriteLine(" </lib>");
|
||||
foreach(ReferenceNode refr in project.References)
|
||||
foreach (ReferenceNode refr in project.References)
|
||||
{
|
||||
string path = Helper.NormalizePath(Helper.MakePathRelativeTo(project.FullPath, BuildReference(solution, project, refr)), '/');
|
||||
ss.WriteLine(" <include name=\""+ path + "\" />" );
|
||||
ss.WriteLine(" <include name=\"" + path + "\" />");
|
||||
}
|
||||
ss.WriteLine(" </references>");
|
||||
|
||||
|
@ -417,9 +427,9 @@ public class NAntTarget : ITarget
|
|||
private void WriteCombine(SolutionNode solution)
|
||||
{
|
||||
m_Kernel.Log.Write("Creating NAnt build files");
|
||||
foreach(ProjectNode project in solution.Projects)
|
||||
foreach (ProjectNode project in solution.Projects)
|
||||
{
|
||||
if(m_Kernel.AllowProject(project.FilterGroups))
|
||||
if (m_Kernel.AllowProject(project.FilterGroups))
|
||||
{
|
||||
m_Kernel.Log.Write("...Creating project: {0}", project.Name);
|
||||
WriteProject(solution, project);
|
||||
|
@ -433,7 +443,7 @@ public class NAntTarget : ITarget
|
|||
m_Kernel.CurrentWorkingDirectory.Push();
|
||||
Helper.SetCurrentDir(Path.GetDirectoryName(combFile));
|
||||
|
||||
using(ss)
|
||||
using (ss)
|
||||
{
|
||||
ss.WriteLine("<?xml version=\"1.0\" ?>");
|
||||
ss.WriteLine("<project name=\"{0}\" default=\"build\">", solution.Name);
|
||||
|
@ -447,10 +457,10 @@ public class NAntTarget : ITarget
|
|||
ss.WriteLine(" <property name=\"doc.dir\" value=\"doc\" />");
|
||||
ss.WriteLine(" <property name=\"project.main.dir\" value=\"${project::get-base-directory()}\" />");
|
||||
|
||||
foreach(ConfigurationNode conf in solution.Configurations)
|
||||
foreach (ConfigurationNode conf in solution.Configurations)
|
||||
{
|
||||
// Set the project.config to a non-debug configuration
|
||||
if( conf.Options["DebugInformation"].ToString().ToLower() != "true" )
|
||||
if (conf.Options["DebugInformation"].ToString().ToLower() != "true")
|
||||
{
|
||||
ss.WriteLine(" <property name=\"project.config\" value=\"{0}\" />", conf.Name);
|
||||
}
|
||||
|
@ -498,16 +508,18 @@ public class NAntTarget : ITarget
|
|||
// lets us keep using prebuild, but allows for
|
||||
// extended nant targets to do build and the like.
|
||||
|
||||
try {
|
||||
try
|
||||
{
|
||||
Regex re = new Regex(".include$");
|
||||
DirectoryInfo nantdir = new DirectoryInfo(".nant");
|
||||
foreach (FileSystemInfo item in nantdir.GetFileSystemInfos())
|
||||
{
|
||||
if (item is DirectoryInfo) {}
|
||||
if (item is DirectoryInfo) { }
|
||||
else if (item is FileInfo)
|
||||
{
|
||||
if (re.Match(((FileInfo)item).FullName) !=
|
||||
System.Text.RegularExpressions.Match.Empty) {
|
||||
System.Text.RegularExpressions.Match.Empty)
|
||||
{
|
||||
Console.WriteLine("Including file: " + ((FileInfo)item).FullName);
|
||||
|
||||
using (FileStream fs = new FileStream(((FileInfo)item).FullName,
|
||||
|
@ -518,7 +530,8 @@ public class NAntTarget : ITarget
|
|||
using (StreamReader sr = new StreamReader(fs))
|
||||
{
|
||||
ss.WriteLine("<!-- included from {0} -->", ((FileInfo)item).FullName);
|
||||
while (sr.Peek() != -1) {
|
||||
while (sr.Peek() != -1)
|
||||
{
|
||||
ss.WriteLine(sr.ReadLine());
|
||||
}
|
||||
ss.WriteLine();
|
||||
|
@ -527,18 +540,19 @@ public class NAntTarget : ITarget
|
|||
}
|
||||
}
|
||||
}
|
||||
} catch {}
|
||||
}
|
||||
catch { }
|
||||
// ss.WriteLine(" <include buildfile=\".nant/local.include\" />");
|
||||
// ss.WriteLine(" <target name=\"zip\" description=\"\">");
|
||||
// ss.WriteLine(" <zip zipfile=\"{0}-{1}.zip\">", solution.Name, solution.Version);
|
||||
// ss.WriteLine(" <fileset basedir=\"${project::get-base-directory()}\">");
|
||||
// ss.WriteLine(" <target name=\"zip\" description=\"\">");
|
||||
// ss.WriteLine(" <zip zipfile=\"{0}-{1}.zip\">", solution.Name, solution.Version);
|
||||
// ss.WriteLine(" <fileset basedir=\"${project::get-base-directory()}\">");
|
||||
|
||||
// ss.WriteLine(" <include name=\"${project::get-base-directory()}/**/*.cs\" />");
|
||||
// // ss.WriteLine(" <include name=\"${project.main.dir}/**/*\" />");
|
||||
// ss.WriteLine(" </fileset>");
|
||||
// ss.WriteLine(" </zip>");
|
||||
// ss.WriteLine(" <echo message=\"Building zip target\" />");
|
||||
// ss.WriteLine(" </target>");
|
||||
// ss.WriteLine(" <include name=\"${project::get-base-directory()}/**/*.cs\" />");
|
||||
// // ss.WriteLine(" <include name=\"${project.main.dir}/**/*\" />");
|
||||
// ss.WriteLine(" </fileset>");
|
||||
// ss.WriteLine(" </zip>");
|
||||
// ss.WriteLine(" <echo message=\"Building zip target\" />");
|
||||
// ss.WriteLine(" </target>");
|
||||
ss.WriteLine();
|
||||
|
||||
|
||||
|
@ -547,11 +561,11 @@ public class NAntTarget : ITarget
|
|||
//ss.WriteLine(" <delete dir=\"${dist.dir}\" failonerror=\"false\" />");
|
||||
ss.WriteLine(" <delete dir=\"${bin.dir}\" failonerror=\"false\" />");
|
||||
ss.WriteLine(" <delete dir=\"${obj.dir}\" failonerror=\"false\" />");
|
||||
foreach(ProjectNode project in solution.Projects)
|
||||
foreach (ProjectNode project in solution.Projects)
|
||||
{
|
||||
string path = Helper.MakePathRelativeTo(solution.FullPath, project.FullPath);
|
||||
ss.Write(" <nant buildfile=\"{0}\"",
|
||||
Helper.NormalizePath(Helper.MakeFilePath(path, project.Name + (project.Type == ProjectType.Library ? ".dll" : ".exe"), "build"),'/'));
|
||||
Helper.NormalizePath(Helper.MakeFilePath(path, project.Name + GetProjectExtension(project), "build"), '/'));
|
||||
ss.WriteLine(" target=\"clean\" />");
|
||||
}
|
||||
ss.WriteLine(" </target>");
|
||||
|
@ -559,11 +573,11 @@ public class NAntTarget : ITarget
|
|||
|
||||
ss.WriteLine(" <target name=\"build\" depends=\"init\" description=\"\">");
|
||||
|
||||
foreach(ProjectNode project in solution.ProjectsTableOrder)
|
||||
foreach (ProjectNode project in solution.ProjectsTableOrder)
|
||||
{
|
||||
string path = Helper.MakePathRelativeTo(solution.FullPath, project.FullPath);
|
||||
ss.Write(" <nant buildfile=\"{0}\"",
|
||||
Helper.NormalizePath(Helper.MakeFilePath(path, project.Name + (project.Type == ProjectType.Library ? ".dll" : ".exe"), "build"),'/'));
|
||||
Helper.NormalizePath(Helper.MakeFilePath(path, project.Name + GetProjectExtension(project), "build"), '/'));
|
||||
ss.WriteLine(" target=\"build\" />");
|
||||
}
|
||||
ss.WriteLine(" </target>");
|
||||
|
@ -583,7 +597,7 @@ public class NAntTarget : ITarget
|
|||
{
|
||||
string path = Helper.MakePathRelativeTo(solution.FullPath, project.FullPath);
|
||||
ss.Write(" <nant buildfile=\"{0}\"",
|
||||
Helper.NormalizePath(Helper.MakeFilePath(path, project.Name + (project.Type == ProjectType.Library ? ".dll" : ".exe"), "build"), '/'));
|
||||
Helper.NormalizePath(Helper.MakeFilePath(path, project.Name + GetProjectExtension(project), "build"), '/'));
|
||||
ss.WriteLine(" target=\"doc\" />");
|
||||
}
|
||||
ss.WriteLine(" </target>");
|
||||
|
@ -597,7 +611,7 @@ public class NAntTarget : ITarget
|
|||
private void CleanProject(ProjectNode project)
|
||||
{
|
||||
m_Kernel.Log.Write("...Cleaning project: {0}", project.Name);
|
||||
string projectFile = Helper.MakeFilePath(project.FullPath, project.Name + (project.Type == ProjectType.Library ? ".dll" : ".exe"), "build");
|
||||
string projectFile = Helper.MakeFilePath(project.FullPath, project.Name + GetProjectExtension(project), "build");
|
||||
Helper.DeleteIfExists(projectFile);
|
||||
}
|
||||
|
||||
|
@ -608,7 +622,7 @@ public class NAntTarget : ITarget
|
|||
string slnFile = Helper.MakeFilePath(solution.FullPath, solution.Name, "build");
|
||||
Helper.DeleteIfExists(slnFile);
|
||||
|
||||
foreach(ProjectNode project in solution.Projects)
|
||||
foreach (ProjectNode project in solution.Projects)
|
||||
{
|
||||
CleanProject(project);
|
||||
}
|
||||
|
@ -616,9 +630,9 @@ public class NAntTarget : ITarget
|
|||
m_Kernel.Log.Write("");
|
||||
}
|
||||
|
||||
#endregion
|
||||
#endregion
|
||||
|
||||
#region ITarget Members
|
||||
#region ITarget Members
|
||||
|
||||
/// <summary>
|
||||
/// Writes the specified kern.
|
||||
|
@ -626,12 +640,12 @@ public class NAntTarget : ITarget
|
|||
/// <param name="kern">The kern.</param>
|
||||
public void Write(Kernel kern)
|
||||
{
|
||||
if( kern == null )
|
||||
if (kern == null)
|
||||
{
|
||||
throw new ArgumentNullException("kern");
|
||||
}
|
||||
m_Kernel = kern;
|
||||
foreach(SolutionNode solution in kern.Solutions)
|
||||
foreach (SolutionNode solution in kern.Solutions)
|
||||
{
|
||||
WriteCombine(solution);
|
||||
}
|
||||
|
@ -644,12 +658,12 @@ public class NAntTarget : ITarget
|
|||
/// <param name="kern">The kern.</param>
|
||||
public virtual void Clean(Kernel kern)
|
||||
{
|
||||
if( kern == null )
|
||||
if (kern == null)
|
||||
{
|
||||
throw new ArgumentNullException("kern");
|
||||
}
|
||||
m_Kernel = kern;
|
||||
foreach(SolutionNode sol in kern.Solutions)
|
||||
foreach (SolutionNode sol in kern.Solutions)
|
||||
{
|
||||
CleanSolution(sol);
|
||||
}
|
||||
|
@ -668,6 +682,6 @@ public class NAntTarget : ITarget
|
|||
}
|
||||
}
|
||||
|
||||
#endregion
|
||||
}
|
||||
#endregion
|
||||
}
|
||||
}
|
||||
|
|
BIN
bin/Prebuild.exe
BIN
bin/Prebuild.exe
Binary file not shown.
|
@ -1,5 +1,5 @@
|
|||
<?xml version="1.0" encoding="utf-8" ?>
|
||||
<Prebuild xmlns="http://dnpb.sourceforge.net/schemas/prebuild-1.7.xsd" version="1.7">
|
||||
<Prebuild xmlns="./Prebuild/prebuild-opensim.xsd" version="1.7">
|
||||
<Solution name="OpenSim" activeConfig="Debug" path="./" version="0.4.0-svn">
|
||||
<Configuration name="Debug">
|
||||
<Options>
|
||||
|
|
Loading…
Reference in New Issue