* 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,301 +47,311 @@ using Prebuild.Core.Utilities;
|
||||||
namespace Prebuild.Core.Targets
|
namespace Prebuild.Core.Targets
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
///
|
///
|
||||||
/// </summary>
|
/// </summary>
|
||||||
[Target("nant")]
|
[Target("nant")]
|
||||||
public class NAntTarget : ITarget
|
public class NAntTarget : ITarget
|
||||||
{
|
|
||||||
#region Fields
|
|
||||||
|
|
||||||
private Kernel m_Kernel;
|
|
||||||
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
#region Private Methods
|
|
||||||
|
|
||||||
private static string PrependPath(string path)
|
|
||||||
{
|
{
|
||||||
string tmpPath = Helper.NormalizePath(path, '/');
|
#region Fields
|
||||||
Regex regex = new Regex(@"(\w):/(\w+)");
|
|
||||||
Match match = regex.Match(tmpPath);
|
|
||||||
//if(match.Success || tmpPath[0] == '.' || tmpPath[0] == '/')
|
|
||||||
//{
|
|
||||||
tmpPath = Helper.NormalizePath(tmpPath);
|
|
||||||
//}
|
|
||||||
// else
|
|
||||||
// {
|
|
||||||
// tmpPath = Helper.NormalizePath("./" + tmpPath);
|
|
||||||
// }
|
|
||||||
|
|
||||||
return tmpPath;
|
private Kernel m_Kernel;
|
||||||
}
|
|
||||||
|
|
||||||
private static string BuildReference(SolutionNode solution, ProjectNode currentProject, ReferenceNode refr)
|
#endregion
|
||||||
{
|
|
||||||
string ret = "";
|
#region Private Methods
|
||||||
if(solution.ProjectsTable.ContainsKey(refr.Name))
|
|
||||||
|
private static string PrependPath(string path)
|
||||||
|
{
|
||||||
|
string tmpPath = Helper.NormalizePath(path, '/');
|
||||||
|
Regex regex = new Regex(@"(\w):/(\w+)");
|
||||||
|
Match match = regex.Match(tmpPath);
|
||||||
|
//if(match.Success || tmpPath[0] == '.' || tmpPath[0] == '/')
|
||||||
|
//{
|
||||||
|
tmpPath = Helper.NormalizePath(tmpPath);
|
||||||
|
//}
|
||||||
|
// else
|
||||||
|
// {
|
||||||
|
// tmpPath = Helper.NormalizePath("./" + tmpPath);
|
||||||
|
// }
|
||||||
|
|
||||||
|
return tmpPath;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static string BuildReference(SolutionNode solution, ProjectNode currentProject, ReferenceNode refr)
|
||||||
|
{
|
||||||
|
string ret = "";
|
||||||
|
if (solution.ProjectsTable.ContainsKey(refr.Name))
|
||||||
{
|
{
|
||||||
ProjectNode project = (ProjectNode)solution.ProjectsTable[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;
|
return finalPath;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ProjectNode project = (ProjectNode)refr.Parent;
|
ProjectNode project = (ProjectNode)refr.Parent;
|
||||||
string fileRef = FindFileReference(refr.Name, project);
|
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;
|
ret += finalPath;
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
//Assembly assem = Assembly.Load(refr.Name);
|
//Assembly assem = Assembly.Load(refr.Name);
|
||||||
//if (assem != null)
|
//if (assem != null)
|
||||||
//{
|
//{
|
||||||
//ret += (refr.Name + ".dll");
|
//ret += (refr.Name + ".dll");
|
||||||
//}
|
//}
|
||||||
//else
|
//else
|
||||||
//{
|
//{
|
||||||
ret += (refr.Name + ".dll");
|
ret += (refr.Name + GetProjectExtension(project));
|
||||||
//}
|
//}
|
||||||
}
|
}
|
||||||
catch (System.NullReferenceException e)
|
catch (System.NullReferenceException e)
|
||||||
{
|
{
|
||||||
e.ToString();
|
e.ToString();
|
||||||
ret += refr.Name + ".dll";
|
ret += refr.Name + GetProjectExtension(project);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static string BuildReferencePath(SolutionNode solution, ReferenceNode refr)
|
private static string GetProjectExtension(ProjectNode project)
|
||||||
{
|
{
|
||||||
string ret = "";
|
string extension = ".dll";
|
||||||
if(solution.ProjectsTable.ContainsKey(refr.Name))
|
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))
|
||||||
{
|
{
|
||||||
ProjectNode project = (ProjectNode)solution.ProjectsTable[refr.Name];
|
ProjectNode project = (ProjectNode)solution.ProjectsTable[refr.Name];
|
||||||
string finalPath = Helper.NormalizePath(((ReferencePathNode)project.ReferencePaths[0]).Path, '/');
|
string finalPath = Helper.NormalizePath(((ReferencePathNode)project.ReferencePaths[0]).Path, '/');
|
||||||
|
|
||||||
return finalPath;
|
return finalPath;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ProjectNode project = (ProjectNode)refr.Parent;
|
ProjectNode project = (ProjectNode)refr.Parent;
|
||||||
string fileRef = FindFileReference(refr.Name, project);
|
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;
|
string finalPath = (refr.Path != null) ? Helper.NormalizePath(refr.Path, '/') : fileRef;
|
||||||
ret += finalPath;
|
ret += finalPath;
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
try
|
try
|
||||||
|
{
|
||||||
|
Assembly assem = Assembly.Load(refr.Name);
|
||||||
|
if (assem != null)
|
||||||
{
|
{
|
||||||
Assembly assem = Assembly.Load(refr.Name);
|
|
||||||
if (assem != null)
|
|
||||||
{
|
|
||||||
ret += "";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
ret += "";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch (System.NullReferenceException e)
|
|
||||||
{
|
|
||||||
e.ToString();
|
|
||||||
ret += "";
|
ret += "";
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ret += "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (System.NullReferenceException e)
|
||||||
|
{
|
||||||
|
e.ToString();
|
||||||
|
ret += "";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static string FindFileReference(string refName, ProjectNode project)
|
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");
|
string fullPath = Helper.MakeFilePath(refPath.Path, refName, "dll");
|
||||||
|
|
||||||
if(File.Exists(fullPath))
|
if (File.Exists(fullPath))
|
||||||
{
|
{
|
||||||
return fullPath;
|
return fullPath;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Gets the XML doc file.
|
/// Gets the XML doc file.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="project">The project.</param>
|
/// <param name="project">The project.</param>
|
||||||
/// <param name="conf">The conf.</param>
|
/// <param name="conf">The conf.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public static string GetXmlDocFile(ProjectNode project, ConfigurationNode conf)
|
public static string GetXmlDocFile(ProjectNode project, ConfigurationNode conf)
|
||||||
{
|
{
|
||||||
if( conf == null )
|
if (conf == null)
|
||||||
{
|
{
|
||||||
throw new ArgumentNullException("conf");
|
throw new ArgumentNullException("conf");
|
||||||
}
|
}
|
||||||
if( project == null )
|
if (project == null)
|
||||||
{
|
{
|
||||||
throw new ArgumentNullException("project");
|
throw new ArgumentNullException("project");
|
||||||
}
|
}
|
||||||
string docFile = (string)conf.Options["XmlDocFile"];
|
string docFile = (string)conf.Options["XmlDocFile"];
|
||||||
// if(docFile != null && docFile.Length == 0)//default to assembly name if not specified
|
// if(docFile != null && docFile.Length == 0)//default to assembly name if not specified
|
||||||
// {
|
// {
|
||||||
// return Path.GetFileNameWithoutExtension(project.AssemblyName) + ".xml";
|
// return Path.GetFileNameWithoutExtension(project.AssemblyName) + ".xml";
|
||||||
// }
|
// }
|
||||||
return docFile;
|
return docFile;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void WriteProject(SolutionNode solution, ProjectNode project)
|
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);
|
StreamWriter ss = new StreamWriter(projFile);
|
||||||
|
|
||||||
m_Kernel.CurrentWorkingDirectory.Push();
|
m_Kernel.CurrentWorkingDirectory.Push();
|
||||||
Helper.SetCurrentDir(Path.GetDirectoryName(projFile));
|
Helper.SetCurrentDir(Path.GetDirectoryName(projFile));
|
||||||
bool hasDoc = false;
|
bool hasDoc = false;
|
||||||
|
|
||||||
using(ss)
|
using (ss)
|
||||||
{
|
{
|
||||||
ss.WriteLine("<?xml version=\"1.0\" ?>");
|
ss.WriteLine("<?xml version=\"1.0\" ?>");
|
||||||
ss.WriteLine("<project name=\"{0}\" default=\"build\">", project.Name);
|
ss.WriteLine("<project name=\"{0}\" default=\"build\">", project.Name);
|
||||||
ss.WriteLine(" <target name=\"{0}\">", "build");
|
ss.WriteLine(" <target name=\"{0}\">", "build");
|
||||||
ss.WriteLine(" <echo message=\"Build Directory is ${project::get-base-directory()}/${build.dir}\" />");
|
ss.WriteLine(" <echo message=\"Build Directory is ${project::get-base-directory()}/${build.dir}\" />");
|
||||||
ss.WriteLine(" <mkdir dir=\"${project::get-base-directory()}/${build.dir}\" />");
|
ss.WriteLine(" <mkdir dir=\"${project::get-base-directory()}/${build.dir}\" />");
|
||||||
ss.WriteLine(" <copy todir=\"${project::get-base-directory()}/${build.dir}\">");
|
ss.WriteLine(" <copy todir=\"${project::get-base-directory()}/${build.dir}\">");
|
||||||
ss.WriteLine(" <fileset basedir=\"${project::get-base-directory()}\">");
|
ss.WriteLine(" <fileset basedir=\"${project::get-base-directory()}\">");
|
||||||
foreach(ReferenceNode refr in project.References)
|
foreach (ReferenceNode refr in project.References)
|
||||||
|
{
|
||||||
|
if (refr.LocalCopy)
|
||||||
{
|
{
|
||||||
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>");
|
ss.WriteLine(" </fileset>");
|
||||||
ss.WriteLine(" </copy>");
|
ss.WriteLine(" </copy>");
|
||||||
ss.Write(" <csc");
|
ss.Write(" <csc");
|
||||||
ss.Write(" target=\"{0}\"", project.Type.ToString().ToLower());
|
ss.Write(" target=\"{0}\"", project.Type.ToString().ToLower());
|
||||||
ss.Write(" debug=\"{0}\"", "${build.debug}");
|
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);
|
||||||
{
|
|
||||||
ss.Write(" keyfile=\"{0}\"", conf.Options.KeyFile);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
foreach(ConfigurationNode conf in project.Configurations)
|
|
||||||
{
|
|
||||||
ss.Write(" unsafe=\"{0}\"", conf.Options.AllowUnsafe);
|
|
||||||
break;
|
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)
|
||||||
|
{
|
||||||
|
ss.Write(" define=\"{0}\"", conf.Options.CompilerDefines);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
foreach (ConfigurationNode conf in project.Configurations)
|
||||||
|
{
|
||||||
|
if (GetXmlDocFile(project, conf) != "")
|
||||||
{
|
{
|
||||||
ss.Write(" define=\"{0}\"", conf.Options.CompilerDefines);
|
ss.Write(" doc=\"{0}\"", "${project::get-base-directory()}/${build.dir}/" + GetXmlDocFile(project, conf));
|
||||||
break;
|
hasDoc = true;
|
||||||
}
|
|
||||||
foreach(ConfigurationNode conf in project.Configurations)
|
|
||||||
{
|
|
||||||
if (GetXmlDocFile(project, conf) !="")
|
|
||||||
{
|
|
||||||
ss.Write(" doc=\"{0}\"", "${project::get-base-directory()}/${build.dir}/" + GetXmlDocFile(project, conf));
|
|
||||||
hasDoc = true;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
ss.Write(" output=\"{0}", "${project::get-base-directory()}/${build.dir}/${project::get-name()}");
|
ss.Write(" output=\"{0}", "${project::get-base-directory()}/${build.dir}/${project::get-name()}");
|
||||||
if (project.Type == ProjectType.Library)
|
if (project.Type == ProjectType.Library)
|
||||||
{
|
{
|
||||||
ss.Write(".dll\"");
|
ss.Write(".dll\"");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ss.Write(".exe\"");
|
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(">");
|
||||||
ss.WriteLine(" <resources prefix=\"{0}\" dynamicprefix=\"true\" >", project.RootNamespace);
|
ss.WriteLine(" <resources prefix=\"{0}\" dynamicprefix=\"true\" >", project.RootNamespace);
|
||||||
foreach (string file in project.Files)
|
foreach (string file in project.Files)
|
||||||
|
{
|
||||||
|
switch (project.Files.GetBuildAction(file))
|
||||||
{
|
{
|
||||||
switch (project.Files.GetBuildAction(file))
|
case BuildAction.EmbeddedResource:
|
||||||
|
ss.WriteLine(" {0}", "<include name=\"" + Helper.NormalizePath(PrependPath(file), '/') + "\" />");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
if (project.Files.GetSubType(file) != SubType.Code && project.Files.GetSubType(file) != SubType.Settings)
|
||||||
{
|
{
|
||||||
case BuildAction.EmbeddedResource:
|
ss.WriteLine(" <include name=\"{0}\" />", file.Substring(0, file.LastIndexOf('.')) + ".resx");
|
||||||
ss.WriteLine(" {0}", "<include name=\"" + Helper.NormalizePath(PrependPath(file), '/') + "\" />");
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
if (project.Files.GetSubType(file) != SubType.Code && project.Files.GetSubType(file) != SubType.Settings)
|
|
||||||
{
|
|
||||||
ss.WriteLine(" <include name=\"{0}\" />", file.Substring(0, file.LastIndexOf('.')) + ".resx");
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
//if (project.Files.GetSubType(file).ToString() != "Code")
|
//if (project.Files.GetSubType(file).ToString() != "Code")
|
||||||
//{
|
//{
|
||||||
// ps.WriteLine(" <EmbeddedResource Include=\"{0}\">", file.Substring(0, file.LastIndexOf('.')) + ".resx");
|
// ps.WriteLine(" <EmbeddedResource Include=\"{0}\">", file.Substring(0, file.LastIndexOf('.')) + ".resx");
|
||||||
|
|
||||||
ss.WriteLine(" </resources>");
|
ss.WriteLine(" </resources>");
|
||||||
ss.WriteLine(" <sources failonempty=\"true\">");
|
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), '/') + "\" />");
|
||||||
case BuildAction.Compile:
|
break;
|
||||||
ss.WriteLine(" <include name=\"" + Helper.NormalizePath(PrependPath(file), '/') + "\" />");
|
default:
|
||||||
break;
|
break;
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
ss.WriteLine(" </sources>");
|
ss.WriteLine(" </sources>");
|
||||||
ss.WriteLine(" <references basedir=\"${project::get-base-directory()}\">");
|
ss.WriteLine(" <references basedir=\"${project::get-base-directory()}\">");
|
||||||
ss.WriteLine(" <lib>");
|
ss.WriteLine(" <lib>");
|
||||||
ss.WriteLine(" <include name=\"${project::get-base-directory()}\" />");
|
ss.WriteLine(" <include name=\"${project::get-base-directory()}\" />");
|
||||||
ss.WriteLine(" <include name=\"${project::get-base-directory()}/${build.dir}\" />");
|
ss.WriteLine(" <include name=\"${project::get-base-directory()}/${build.dir}\" />");
|
||||||
ss.WriteLine(" </lib>");
|
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)), '/');
|
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>");
|
ss.WriteLine(" </references>");
|
||||||
|
|
||||||
ss.WriteLine(" </csc>");
|
ss.WriteLine(" </csc>");
|
||||||
|
|
||||||
foreach (ConfigurationNode conf in project.Configurations)
|
foreach (ConfigurationNode conf in project.Configurations)
|
||||||
|
{
|
||||||
|
if (!String.IsNullOrEmpty(conf.Options.OutputPath))
|
||||||
{
|
{
|
||||||
if (!String.IsNullOrEmpty(conf.Options.OutputPath))
|
string targetDir = Helper.NormalizePath(conf.Options.OutputPath, '/');
|
||||||
{
|
|
||||||
string targetDir = Helper.NormalizePath(conf.Options.OutputPath, '/');
|
|
||||||
|
|
||||||
ss.WriteLine(" <echo message=\"Copying from [${project::get-base-directory()}/${build.dir}/] to [${project::get-base-directory()}/" + targetDir + "\" />");
|
|
||||||
|
|
||||||
ss.WriteLine(" <mkdir dir=\"${project::get-base-directory()}/" + targetDir + "\"/>");
|
ss.WriteLine(" <echo message=\"Copying from [${project::get-base-directory()}/${build.dir}/] to [${project::get-base-directory()}/" + targetDir + "\" />");
|
||||||
|
|
||||||
ss.WriteLine(" <copy todir=\"${project::get-base-directory()}/" + targetDir + "\">");
|
ss.WriteLine(" <mkdir dir=\"${project::get-base-directory()}/" + targetDir + "\"/>");
|
||||||
ss.WriteLine(" <fileset basedir=\"${project::get-base-directory()}/${build.dir}/\" >");
|
|
||||||
ss.WriteLine(" <include name=\"*.dll\"/>");
|
ss.WriteLine(" <copy todir=\"${project::get-base-directory()}/" + targetDir + "\">");
|
||||||
ss.WriteLine(" <include name=\"*.exe\"/>");
|
ss.WriteLine(" <fileset basedir=\"${project::get-base-directory()}/${build.dir}/\" >");
|
||||||
ss.WriteLine(" </fileset>");
|
ss.WriteLine(" <include name=\"*.dll\"/>");
|
||||||
ss.WriteLine(" </copy>");
|
ss.WriteLine(" <include name=\"*.exe\"/>");
|
||||||
break;
|
ss.WriteLine(" </fileset>");
|
||||||
}
|
ss.WriteLine(" </copy>");
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
ss.WriteLine(" </target>");
|
ss.WriteLine(" </target>");
|
||||||
|
|
||||||
ss.WriteLine(" <target name=\"clean\">");
|
ss.WriteLine(" <target name=\"clean\">");
|
||||||
|
@ -351,89 +361,89 @@ public class NAntTarget : ITarget
|
||||||
|
|
||||||
ss.WriteLine(" <target name=\"doc\" description=\"Creates documentation.\">");
|
ss.WriteLine(" <target name=\"doc\" description=\"Creates documentation.\">");
|
||||||
if (hasDoc)
|
if (hasDoc)
|
||||||
|
{
|
||||||
|
ss.WriteLine(" <property name=\"doc.target\" value=\"\" />");
|
||||||
|
ss.WriteLine(" <if test=\"${platform::is-unix()}\">");
|
||||||
|
ss.WriteLine(" <property name=\"doc.target\" value=\"Web\" />");
|
||||||
|
ss.WriteLine(" </if>");
|
||||||
|
ss.WriteLine(" <ndoc failonerror=\"false\" verbose=\"true\">");
|
||||||
|
ss.WriteLine(" <assemblies basedir=\"${project::get-base-directory()}\">");
|
||||||
|
ss.Write(" <include name=\"${build.dir}/${project::get-name()}");
|
||||||
|
if (project.Type == ProjectType.Library)
|
||||||
{
|
{
|
||||||
ss.WriteLine(" <property name=\"doc.target\" value=\"\" />");
|
ss.WriteLine(".dll\" />");
|
||||||
ss.WriteLine(" <if test=\"${platform::is-unix()}\">");
|
|
||||||
ss.WriteLine(" <property name=\"doc.target\" value=\"Web\" />");
|
|
||||||
ss.WriteLine(" </if>");
|
|
||||||
ss.WriteLine(" <ndoc failonerror=\"false\" verbose=\"true\">");
|
|
||||||
ss.WriteLine(" <assemblies basedir=\"${project::get-base-directory()}\">");
|
|
||||||
ss.Write(" <include name=\"${build.dir}/${project::get-name()}");
|
|
||||||
if (project.Type == ProjectType.Library)
|
|
||||||
{
|
|
||||||
ss.WriteLine(".dll\" />");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
ss.WriteLine(".exe\" />");
|
|
||||||
}
|
|
||||||
|
|
||||||
ss.WriteLine(" </assemblies>");
|
|
||||||
ss.WriteLine(" <summaries basedir=\"${project::get-base-directory()}\">");
|
|
||||||
ss.WriteLine(" <include name=\"${build.dir}/${project::get-name()}.xml\"/>");
|
|
||||||
ss.WriteLine(" </summaries>");
|
|
||||||
ss.WriteLine(" <referencepaths basedir=\"${project::get-base-directory()}\">");
|
|
||||||
ss.WriteLine(" <include name=\"${build.dir}\" />");
|
|
||||||
// foreach(ReferenceNode refr in project.References)
|
|
||||||
// {
|
|
||||||
// string path = Helper.NormalizePath(Helper.MakePathRelativeTo(project.FullPath, BuildReferencePath(solution, refr)), '/');
|
|
||||||
// if (path != "")
|
|
||||||
// {
|
|
||||||
// ss.WriteLine(" <include name=\"{0}\" />", path);
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
ss.WriteLine(" </referencepaths>");
|
|
||||||
ss.WriteLine(" <documenters>");
|
|
||||||
ss.WriteLine(" <documenter name=\"MSDN\">");
|
|
||||||
ss.WriteLine(" <property name=\"OutputDirectory\" value=\"${project::get-base-directory()}/${build.dir}/doc/${project::get-name()}\" />");
|
|
||||||
ss.WriteLine(" <property name=\"OutputTarget\" value=\"${doc.target}\" />");
|
|
||||||
ss.WriteLine(" <property name=\"HtmlHelpName\" value=\"${project::get-name()}\" />");
|
|
||||||
ss.WriteLine(" <property name=\"IncludeFavorites\" value=\"False\" />");
|
|
||||||
ss.WriteLine(" <property name=\"Title\" value=\"${project::get-name()} SDK Documentation\" />");
|
|
||||||
ss.WriteLine(" <property name=\"SplitTOCs\" value=\"False\" />");
|
|
||||||
ss.WriteLine(" <property name=\"DefaulTOC\" value=\"\" />");
|
|
||||||
ss.WriteLine(" <property name=\"ShowVisualBasic\" value=\"True\" />");
|
|
||||||
ss.WriteLine(" <property name=\"AutoDocumentConstructors\" value=\"True\" />");
|
|
||||||
ss.WriteLine(" <property name=\"ShowMissingSummaries\" value=\"${build.debug}\" />");
|
|
||||||
ss.WriteLine(" <property name=\"ShowMissingRemarks\" value=\"${build.debug}\" />");
|
|
||||||
ss.WriteLine(" <property name=\"ShowMissingParams\" value=\"${build.debug}\" />");
|
|
||||||
ss.WriteLine(" <property name=\"ShowMissingReturns\" value=\"${build.debug}\" />");
|
|
||||||
ss.WriteLine(" <property name=\"ShowMissingValues\" value=\"${build.debug}\" />");
|
|
||||||
ss.WriteLine(" <property name=\"DocumentInternals\" value=\"False\" />");
|
|
||||||
ss.WriteLine(" <property name=\"DocumentPrivates\" value=\"False\" />");
|
|
||||||
ss.WriteLine(" <property name=\"DocumentProtected\" value=\"True\" />");
|
|
||||||
ss.WriteLine(" <property name=\"DocumentEmptyNamespaces\" value=\"${build.debug}\" />");
|
|
||||||
ss.WriteLine(" <property name=\"IncludeAssemblyVersion\" value=\"True\" />");
|
|
||||||
ss.WriteLine(" </documenter>");
|
|
||||||
ss.WriteLine(" </documenters>");
|
|
||||||
ss.WriteLine(" </ndoc>");
|
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ss.WriteLine(".exe\" />");
|
||||||
|
}
|
||||||
|
|
||||||
|
ss.WriteLine(" </assemblies>");
|
||||||
|
ss.WriteLine(" <summaries basedir=\"${project::get-base-directory()}\">");
|
||||||
|
ss.WriteLine(" <include name=\"${build.dir}/${project::get-name()}.xml\"/>");
|
||||||
|
ss.WriteLine(" </summaries>");
|
||||||
|
ss.WriteLine(" <referencepaths basedir=\"${project::get-base-directory()}\">");
|
||||||
|
ss.WriteLine(" <include name=\"${build.dir}\" />");
|
||||||
|
// foreach(ReferenceNode refr in project.References)
|
||||||
|
// {
|
||||||
|
// string path = Helper.NormalizePath(Helper.MakePathRelativeTo(project.FullPath, BuildReferencePath(solution, refr)), '/');
|
||||||
|
// if (path != "")
|
||||||
|
// {
|
||||||
|
// ss.WriteLine(" <include name=\"{0}\" />", path);
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
ss.WriteLine(" </referencepaths>");
|
||||||
|
ss.WriteLine(" <documenters>");
|
||||||
|
ss.WriteLine(" <documenter name=\"MSDN\">");
|
||||||
|
ss.WriteLine(" <property name=\"OutputDirectory\" value=\"${project::get-base-directory()}/${build.dir}/doc/${project::get-name()}\" />");
|
||||||
|
ss.WriteLine(" <property name=\"OutputTarget\" value=\"${doc.target}\" />");
|
||||||
|
ss.WriteLine(" <property name=\"HtmlHelpName\" value=\"${project::get-name()}\" />");
|
||||||
|
ss.WriteLine(" <property name=\"IncludeFavorites\" value=\"False\" />");
|
||||||
|
ss.WriteLine(" <property name=\"Title\" value=\"${project::get-name()} SDK Documentation\" />");
|
||||||
|
ss.WriteLine(" <property name=\"SplitTOCs\" value=\"False\" />");
|
||||||
|
ss.WriteLine(" <property name=\"DefaulTOC\" value=\"\" />");
|
||||||
|
ss.WriteLine(" <property name=\"ShowVisualBasic\" value=\"True\" />");
|
||||||
|
ss.WriteLine(" <property name=\"AutoDocumentConstructors\" value=\"True\" />");
|
||||||
|
ss.WriteLine(" <property name=\"ShowMissingSummaries\" value=\"${build.debug}\" />");
|
||||||
|
ss.WriteLine(" <property name=\"ShowMissingRemarks\" value=\"${build.debug}\" />");
|
||||||
|
ss.WriteLine(" <property name=\"ShowMissingParams\" value=\"${build.debug}\" />");
|
||||||
|
ss.WriteLine(" <property name=\"ShowMissingReturns\" value=\"${build.debug}\" />");
|
||||||
|
ss.WriteLine(" <property name=\"ShowMissingValues\" value=\"${build.debug}\" />");
|
||||||
|
ss.WriteLine(" <property name=\"DocumentInternals\" value=\"False\" />");
|
||||||
|
ss.WriteLine(" <property name=\"DocumentPrivates\" value=\"False\" />");
|
||||||
|
ss.WriteLine(" <property name=\"DocumentProtected\" value=\"True\" />");
|
||||||
|
ss.WriteLine(" <property name=\"DocumentEmptyNamespaces\" value=\"${build.debug}\" />");
|
||||||
|
ss.WriteLine(" <property name=\"IncludeAssemblyVersion\" value=\"True\" />");
|
||||||
|
ss.WriteLine(" </documenter>");
|
||||||
|
ss.WriteLine(" </documenters>");
|
||||||
|
ss.WriteLine(" </ndoc>");
|
||||||
|
}
|
||||||
ss.WriteLine(" </target>");
|
ss.WriteLine(" </target>");
|
||||||
ss.WriteLine("</project>");
|
ss.WriteLine("</project>");
|
||||||
}
|
}
|
||||||
m_Kernel.CurrentWorkingDirectory.Pop();
|
m_Kernel.CurrentWorkingDirectory.Pop();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void WriteCombine(SolutionNode solution)
|
private void WriteCombine(SolutionNode solution)
|
||||||
{
|
{
|
||||||
m_Kernel.Log.Write("Creating NAnt build files");
|
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);
|
m_Kernel.Log.Write("...Creating project: {0}", project.Name);
|
||||||
WriteProject(solution, project);
|
WriteProject(solution, project);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
m_Kernel.Log.Write("");
|
m_Kernel.Log.Write("");
|
||||||
string combFile = Helper.MakeFilePath(solution.FullPath, solution.Name, "build");
|
string combFile = Helper.MakeFilePath(solution.FullPath, solution.Name, "build");
|
||||||
StreamWriter ss = new StreamWriter(combFile);
|
StreamWriter ss = new StreamWriter(combFile);
|
||||||
|
|
||||||
m_Kernel.CurrentWorkingDirectory.Push();
|
m_Kernel.CurrentWorkingDirectory.Push();
|
||||||
Helper.SetCurrentDir(Path.GetDirectoryName(combFile));
|
Helper.SetCurrentDir(Path.GetDirectoryName(combFile));
|
||||||
|
|
||||||
using(ss)
|
using (ss)
|
||||||
{
|
{
|
||||||
ss.WriteLine("<?xml version=\"1.0\" ?>");
|
ss.WriteLine("<?xml version=\"1.0\" ?>");
|
||||||
ss.WriteLine("<project name=\"{0}\" default=\"build\">", solution.Name);
|
ss.WriteLine("<project name=\"{0}\" default=\"build\">", solution.Name);
|
||||||
|
@ -447,26 +457,26 @@ public class NAntTarget : ITarget
|
||||||
ss.WriteLine(" <property name=\"doc.dir\" value=\"doc\" />");
|
ss.WriteLine(" <property name=\"doc.dir\" value=\"doc\" />");
|
||||||
ss.WriteLine(" <property name=\"project.main.dir\" value=\"${project::get-base-directory()}\" />");
|
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")
|
||||||
{
|
{
|
||||||
// Set the project.config to a non-debug configuration
|
ss.WriteLine(" <property name=\"project.config\" value=\"{0}\" />", conf.Name);
|
||||||
if( conf.Options["DebugInformation"].ToString().ToLower() != "true" )
|
|
||||||
{
|
|
||||||
ss.WriteLine(" <property name=\"project.config\" value=\"{0}\" />", conf.Name);
|
|
||||||
}
|
|
||||||
ss.WriteLine();
|
|
||||||
ss.WriteLine(" <target name=\"{0}\" description=\"\">", conf.Name);
|
|
||||||
ss.WriteLine(" <property name=\"project.config\" value=\"{0}\" />", conf.Name);
|
|
||||||
ss.WriteLine(" <property name=\"build.debug\" value=\"{0}\" />", conf.Options["DebugInformation"].ToString().ToLower());
|
|
||||||
ss.WriteLine(" </target>");
|
|
||||||
ss.WriteLine();
|
|
||||||
}
|
}
|
||||||
|
ss.WriteLine();
|
||||||
|
ss.WriteLine(" <target name=\"{0}\" description=\"\">", conf.Name);
|
||||||
|
ss.WriteLine(" <property name=\"project.config\" value=\"{0}\" />", conf.Name);
|
||||||
|
ss.WriteLine(" <property name=\"build.debug\" value=\"{0}\" />", conf.Options["DebugInformation"].ToString().ToLower());
|
||||||
|
ss.WriteLine(" </target>");
|
||||||
|
ss.WriteLine();
|
||||||
|
}
|
||||||
|
|
||||||
ss.WriteLine(" <target name=\"net-1.1\" description=\"Sets framework to .NET 1.1\">");
|
ss.WriteLine(" <target name=\"net-1.1\" description=\"Sets framework to .NET 1.1\">");
|
||||||
ss.WriteLine(" <property name=\"nant.settings.currentframework\" value=\"net-1.1\" />");
|
ss.WriteLine(" <property name=\"nant.settings.currentframework\" value=\"net-1.1\" />");
|
||||||
ss.WriteLine(" </target>");
|
ss.WriteLine(" </target>");
|
||||||
ss.WriteLine();
|
ss.WriteLine();
|
||||||
|
|
||||||
ss.WriteLine(" <target name=\"net-2.0\" description=\"Sets framework to .NET 2.0\">");
|
ss.WriteLine(" <target name=\"net-2.0\" description=\"Sets framework to .NET 2.0\">");
|
||||||
ss.WriteLine(" <property name=\"nant.settings.currentframework\" value=\"net-2.0\" />");
|
ss.WriteLine(" <property name=\"nant.settings.currentframework\" value=\"net-2.0\" />");
|
||||||
ss.WriteLine(" </target>");
|
ss.WriteLine(" </target>");
|
||||||
|
@ -497,28 +507,31 @@ public class NAntTarget : ITarget
|
||||||
// created files from all .nant/*include files. This
|
// created files from all .nant/*include files. This
|
||||||
// lets us keep using prebuild, but allows for
|
// lets us keep using prebuild, but allows for
|
||||||
// extended nant targets to do build and the like.
|
// extended nant targets to do build and the like.
|
||||||
|
|
||||||
try {
|
try
|
||||||
|
{
|
||||||
Regex re = new Regex(".include$");
|
Regex re = new Regex(".include$");
|
||||||
DirectoryInfo nantdir = new DirectoryInfo(".nant");
|
DirectoryInfo nantdir = new DirectoryInfo(".nant");
|
||||||
foreach (FileSystemInfo item in nantdir.GetFileSystemInfos())
|
foreach (FileSystemInfo item in nantdir.GetFileSystemInfos())
|
||||||
{
|
{
|
||||||
if (item is DirectoryInfo) {}
|
if (item is DirectoryInfo) { }
|
||||||
else if (item is FileInfo)
|
else if (item is FileInfo)
|
||||||
{
|
{
|
||||||
if (re.Match(((FileInfo)item).FullName) !=
|
if (re.Match(((FileInfo)item).FullName) !=
|
||||||
System.Text.RegularExpressions.Match.Empty) {
|
System.Text.RegularExpressions.Match.Empty)
|
||||||
|
{
|
||||||
Console.WriteLine("Including file: " + ((FileInfo)item).FullName);
|
Console.WriteLine("Including file: " + ((FileInfo)item).FullName);
|
||||||
|
|
||||||
using (FileStream fs = new FileStream(((FileInfo)item).FullName,
|
using (FileStream fs = new FileStream(((FileInfo)item).FullName,
|
||||||
FileMode.Open,
|
FileMode.Open,
|
||||||
FileAccess.Read,
|
FileAccess.Read,
|
||||||
FileShare.None))
|
FileShare.None))
|
||||||
{
|
{
|
||||||
using (StreamReader sr = new StreamReader(fs))
|
using (StreamReader sr = new StreamReader(fs))
|
||||||
{
|
{
|
||||||
ss.WriteLine("<!-- included from {0} -->", ((FileInfo)item).FullName);
|
ss.WriteLine("<!-- included from {0} -->", ((FileInfo)item).FullName);
|
||||||
while (sr.Peek() != -1) {
|
while (sr.Peek() != -1)
|
||||||
|
{
|
||||||
ss.WriteLine(sr.ReadLine());
|
ss.WriteLine(sr.ReadLine());
|
||||||
}
|
}
|
||||||
ss.WriteLine();
|
ss.WriteLine();
|
||||||
|
@ -527,45 +540,46 @@ public class NAntTarget : ITarget
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch {}
|
}
|
||||||
|
catch { }
|
||||||
// ss.WriteLine(" <include buildfile=\".nant/local.include\" />");
|
// ss.WriteLine(" <include buildfile=\".nant/local.include\" />");
|
||||||
// ss.WriteLine(" <target name=\"zip\" description=\"\">");
|
// ss.WriteLine(" <target name=\"zip\" description=\"\">");
|
||||||
// ss.WriteLine(" <zip zipfile=\"{0}-{1}.zip\">", solution.Name, solution.Version);
|
// ss.WriteLine(" <zip zipfile=\"{0}-{1}.zip\">", solution.Name, solution.Version);
|
||||||
// ss.WriteLine(" <fileset basedir=\"${project::get-base-directory()}\">");
|
// ss.WriteLine(" <fileset basedir=\"${project::get-base-directory()}\">");
|
||||||
|
|
||||||
// ss.WriteLine(" <include name=\"${project::get-base-directory()}/**/*.cs\" />");
|
// ss.WriteLine(" <include name=\"${project::get-base-directory()}/**/*.cs\" />");
|
||||||
// // ss.WriteLine(" <include name=\"${project.main.dir}/**/*\" />");
|
// // ss.WriteLine(" <include name=\"${project.main.dir}/**/*\" />");
|
||||||
// ss.WriteLine(" </fileset>");
|
// ss.WriteLine(" </fileset>");
|
||||||
// ss.WriteLine(" </zip>");
|
// ss.WriteLine(" </zip>");
|
||||||
// ss.WriteLine(" <echo message=\"Building zip target\" />");
|
// ss.WriteLine(" <echo message=\"Building zip target\" />");
|
||||||
// ss.WriteLine(" </target>");
|
// ss.WriteLine(" </target>");
|
||||||
ss.WriteLine();
|
ss.WriteLine();
|
||||||
|
|
||||||
|
|
||||||
ss.WriteLine(" <target name=\"clean\" description=\"\">");
|
ss.WriteLine(" <target name=\"clean\" description=\"\">");
|
||||||
ss.WriteLine(" <echo message=\"Deleting all builds from all configurations\" />");
|
ss.WriteLine(" <echo message=\"Deleting all builds from all configurations\" />");
|
||||||
//ss.WriteLine(" <delete dir=\"${dist.dir}\" failonerror=\"false\" />");
|
//ss.WriteLine(" <delete dir=\"${dist.dir}\" failonerror=\"false\" />");
|
||||||
ss.WriteLine(" <delete dir=\"${bin.dir}\" failonerror=\"false\" />");
|
ss.WriteLine(" <delete dir=\"${bin.dir}\" failonerror=\"false\" />");
|
||||||
ss.WriteLine(" <delete dir=\"${obj.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);
|
string path = Helper.MakePathRelativeTo(solution.FullPath, project.FullPath);
|
||||||
ss.Write(" <nant buildfile=\"{0}\"",
|
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=\"clean\" />");
|
||||||
}
|
}
|
||||||
ss.WriteLine(" </target>");
|
ss.WriteLine(" </target>");
|
||||||
ss.WriteLine();
|
ss.WriteLine();
|
||||||
|
|
||||||
ss.WriteLine(" <target name=\"build\" depends=\"init\" description=\"\">");
|
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);
|
string path = Helper.MakePathRelativeTo(solution.FullPath, project.FullPath);
|
||||||
ss.Write(" <nant buildfile=\"{0}\"",
|
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=\"build\" />");
|
||||||
}
|
}
|
||||||
ss.WriteLine(" </target>");
|
ss.WriteLine(" </target>");
|
||||||
ss.WriteLine();
|
ss.WriteLine();
|
||||||
|
|
||||||
|
@ -580,94 +594,94 @@ public class NAntTarget : ITarget
|
||||||
ss.WriteLine(" <target name=\"doc\" depends=\"build-release\">");
|
ss.WriteLine(" <target name=\"doc\" depends=\"build-release\">");
|
||||||
ss.WriteLine(" <echo message=\"Generating all documentation from all builds\" />");
|
ss.WriteLine(" <echo message=\"Generating all documentation from all builds\" />");
|
||||||
foreach (ProjectNode project in solution.Projects)
|
foreach (ProjectNode project in solution.Projects)
|
||||||
{
|
{
|
||||||
string path = Helper.MakePathRelativeTo(solution.FullPath, project.FullPath);
|
string path = Helper.MakePathRelativeTo(solution.FullPath, project.FullPath);
|
||||||
ss.Write(" <nant buildfile=\"{0}\"",
|
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=\"doc\" />");
|
||||||
}
|
}
|
||||||
ss.WriteLine(" </target>");
|
ss.WriteLine(" </target>");
|
||||||
ss.WriteLine();
|
ss.WriteLine();
|
||||||
ss.WriteLine("</project>");
|
ss.WriteLine("</project>");
|
||||||
}
|
}
|
||||||
|
|
||||||
m_Kernel.CurrentWorkingDirectory.Pop();
|
m_Kernel.CurrentWorkingDirectory.Pop();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void CleanProject(ProjectNode project)
|
private void CleanProject(ProjectNode project)
|
||||||
{
|
{
|
||||||
m_Kernel.Log.Write("...Cleaning project: {0}", project.Name);
|
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);
|
Helper.DeleteIfExists(projectFile);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void CleanSolution(SolutionNode solution)
|
private void CleanSolution(SolutionNode solution)
|
||||||
{
|
{
|
||||||
m_Kernel.Log.Write("Cleaning NAnt build files for", solution.Name);
|
m_Kernel.Log.Write("Cleaning NAnt build files for", solution.Name);
|
||||||
|
|
||||||
string slnFile = Helper.MakeFilePath(solution.FullPath, solution.Name, "build");
|
string slnFile = Helper.MakeFilePath(solution.FullPath, solution.Name, "build");
|
||||||
Helper.DeleteIfExists(slnFile);
|
Helper.DeleteIfExists(slnFile);
|
||||||
|
|
||||||
foreach(ProjectNode project in solution.Projects)
|
foreach (ProjectNode project in solution.Projects)
|
||||||
{
|
{
|
||||||
CleanProject(project);
|
CleanProject(project);
|
||||||
}
|
}
|
||||||
|
|
||||||
m_Kernel.Log.Write("");
|
|
||||||
}
|
|
||||||
|
|
||||||
#endregion
|
m_Kernel.Log.Write("");
|
||||||
|
}
|
||||||
|
|
||||||
#region ITarget Members
|
#endregion
|
||||||
|
|
||||||
/// <summary>
|
#region ITarget Members
|
||||||
/// Writes the specified kern.
|
|
||||||
/// </summary>
|
/// <summary>
|
||||||
/// <param name="kern">The kern.</param>
|
/// Writes the specified kern.
|
||||||
public void Write(Kernel kern)
|
/// </summary>
|
||||||
{
|
/// <param name="kern">The kern.</param>
|
||||||
if( kern == null )
|
public void Write(Kernel kern)
|
||||||
|
{
|
||||||
|
if (kern == null)
|
||||||
{
|
{
|
||||||
throw new ArgumentNullException("kern");
|
throw new ArgumentNullException("kern");
|
||||||
}
|
}
|
||||||
m_Kernel = kern;
|
m_Kernel = kern;
|
||||||
foreach(SolutionNode solution in kern.Solutions)
|
foreach (SolutionNode solution in kern.Solutions)
|
||||||
{
|
{
|
||||||
WriteCombine(solution);
|
WriteCombine(solution);
|
||||||
}
|
}
|
||||||
m_Kernel = null;
|
m_Kernel = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Cleans the specified kern.
|
/// Cleans the specified kern.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="kern">The kern.</param>
|
/// <param name="kern">The kern.</param>
|
||||||
public virtual void Clean(Kernel kern)
|
public virtual void Clean(Kernel kern)
|
||||||
{
|
{
|
||||||
if( kern == null )
|
if (kern == null)
|
||||||
{
|
{
|
||||||
throw new ArgumentNullException("kern");
|
throw new ArgumentNullException("kern");
|
||||||
}
|
}
|
||||||
m_Kernel = kern;
|
m_Kernel = kern;
|
||||||
foreach(SolutionNode sol in kern.Solutions)
|
foreach (SolutionNode sol in kern.Solutions)
|
||||||
{
|
{
|
||||||
CleanSolution(sol);
|
CleanSolution(sol);
|
||||||
}
|
}
|
||||||
m_Kernel = null;
|
m_Kernel = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Gets the name.
|
/// Gets the name.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <value>The name.</value>
|
/// <value>The name.</value>
|
||||||
public string Name
|
public string Name
|
||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
return "nant";
|
return "nant";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#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" ?>
|
<?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">
|
<Solution name="OpenSim" activeConfig="Debug" path="./" version="0.4.0-svn">
|
||||||
<Configuration name="Debug">
|
<Configuration name="Debug">
|
||||||
<Options>
|
<Options>
|
||||||
|
|
Loading…
Reference in New Issue