Skip to content

Commit 633b2a2

Browse files
committed
create netstandard2.0 targets
* Spring.Aop * Spring.Core * Spring.Data * Spring.Messaging * Spring.Testing.NUnit
1 parent fda8281 commit 633b2a2

File tree

210 files changed

+2306
-3855
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

210 files changed

+2306
-3855
lines changed

Spring.build

+30-4
Original file line numberDiff line numberDiff line change
@@ -375,7 +375,7 @@ Commandline Examples:
375375
</items>
376376
</in>
377377
<do>
378-
<echo message="Running tests for ${path}" />
378+
<echo message="Running .NET Framework tests for ${path}" />
379379
<property name="test.bin.dir" value="${path}/net452" />
380380
<property name="test.assemblyname" value="${string::substring(path, string::last-index-of(path, '\') + 1, string::get-length(path) - string::last-index-of(path, '\') - 1)}" />
381381
<property name="test.assemblyfile" value="${test.assemblyname}.dll" />
@@ -384,6 +384,9 @@ Commandline Examples:
384384
</do>
385385
</foreach>
386386

387+
<!-- run .NET Core separately for now -->
388+
<call target="compile-test-netcore" />
389+
387390
<!-- build coverage summary -->
388391
<exec program="${tool.dir}/ncoverexplorer/ncoverexplorer.console.exe" workingdir="${current.bin.dir}" failonerror="false" if="${test.coverage.tool == 'ncover' and test.withcoverage}">
389392
<arg value="/xml:&quot;${current.bin.dir}/TestCoverageSummary.xml&quot;" />
@@ -400,8 +403,32 @@ Commandline Examples:
400403
</exec>
401404
</target>
402405

406+
<target name="compile-test-netcore">
407+
<foreach item="File" property="file">
408+
<in>
409+
<items>
410+
<include name="${spring.basedir}/test/Spring/Spring.Core.Tests/Spring.Core.Tests.2010.csproj" />
411+
<include name="${spring.basedir}/test/Spring/Spring.Aop.Tests/Spring.Aop.Tests.2010.csproj" />
412+
<include name="${spring.basedir}/test/Spring/Spring.Data.Tests/Spring.Data.Tests.2010.csproj" />
413+
<include name="${spring.basedir}/test/Spring/Spring.Testing.NUnit.Tests/Spring.Testing.NUnit.Tests.2010.csproj" />
414+
</items>
415+
</in>
416+
<do>
417+
<echo message="Running .NET Core tests for ${file}" />
418+
419+
<exec program="dotnet" verbose="true">
420+
<arg line="test" />
421+
<arg line="/nodeReuse:false" />
422+
<arg line="-c ${current.build.config}" />
423+
<arg line="-f netcoreapp2.1" />
424+
<arg line="${file}" />
425+
</exec>
426+
</do>
427+
</foreach>
428+
</target>
429+
403430
<target name="compile-net-4.5" description="Builds .NET Framework 4.5 version"
404-
depends="set-net-4.5-runtime-configuration, check-spring-basedir, clean-current-bin-dir, restore-nuget-packages">
431+
depends="set-net-4.5-runtime-configuration, check-spring-basedir, restore-nuget-packages">
405432

406433
<property name="test.withcoverage" value="false" overwrite="true"/>
407434

@@ -445,7 +472,7 @@ Commandline Examples:
445472
</target>
446473

447474
<target name="compile-mono-2.0" description="Builds MONO Framework 2.0 version"
448-
depends="set-mono-2.0-runtime-configuration, check-spring-basedir, clean-current-bin-dir">
475+
depends="set-mono-2.0-runtime-configuration, check-spring-basedir">
449476
<call target="copykeys" if="${project.build.sign}"/>
450477
<call target="common.generate-assemblyinfo"/>
451478
<property name="build-ems" value="false" overwrite="true" />
@@ -853,7 +880,6 @@ Commandline Examples:
853880
<include name="**/nunit.*.xml"/>
854881
<include name="**/NUnitAsp.dll"/>
855882
<include name="**/NUnitAspEx.dll"/>
856-
<include name="**/Rhino.Mocks.dll"/>
857883
<include if="${not net-4.0}" name="**/System.Web.Extensions.dll"/>
858884
<include name="**/Apache.NMS.dll"/>
859885
<include name="**/Apache.NMS.pdb"/>

Spring.include

-7
Original file line numberDiff line numberDiff line change
@@ -151,12 +151,6 @@
151151
</if>
152152
</target>
153153
<!-- Targets for cleaning up -->
154-
<target name="clean-current-bin-dir" depends="check-current-bin-dir"
155-
description="Cleans the current binaries directory">
156-
<echo message="Cleaning the ${current.bin.dir} binaries directory."/>
157-
<delete dir="${current.bin.dir}" if="${directory::exists(current.bin.dir)}"/>
158-
<mkdir dir="${current.bin.dir}"/>
159-
</target>
160154
<target name="clean-current-sdkdoc-dir" depends="check-current-sdkdoc-dir"
161155
description="Cleans the current SDK documentation directory">
162156
<echo message="Cleaning the ${current.sdkdoc.dir} SDK documentation directory."/>
@@ -257,7 +251,6 @@
257251
<import namespace="System.Reflection" />
258252
</imports>
259253
<attributes>
260-
<attribute type="CLSCompliantAttribute" value="${assembly.is-cls-compliant}" />
261254
<attribute type="AssemblyConfigurationAttribute" value="${assembly.configuration}" />
262255
<attribute type="AssemblyProductAttribute" value="${assembly.product}" />
263256
<attribute type="AssemblyCompanyAttribute" value="${assembly.company}" />

build-support/solutions.build.nant

+1
Original file line numberDiff line numberDiff line change
@@ -31,6 +31,7 @@ Rebuilding Solutions using Nant and "solutions.build":
3131
<exclude name="examples/**/Spring.EmsQuickStart/*" />
3232
<exclude name="examples/**/Spring.Examples.Pool/*" />
3333
<exclude name="examples/**/SpringAir/*" />
34+
<exclude name="examples/**/Spring.WebQuickStart/*" />
3435
</items>
3536
</in>
3637
<do>

src/Directory.Build.props

+1-1
Original file line numberDiff line numberDiff line change
@@ -36,14 +36,14 @@
3636

3737
<TreatWarningsAsErrors>True</TreatWarningsAsErrors>
3838

39-
<CLSCompliant>True</CLSCompliant>
4039
<ComVisible>False</ComVisible>
4140

4241
<DebugSymbols>True</DebugSymbols>
4342
<PlatformTarget>AnyCPU</PlatformTarget>
4443
<AllowedOutputExtensionsInPackageBuildOutputFolder>$(AllowedOutputExtensionsInPackageBuildOutputFolder);.pdb</AllowedOutputExtensionsInPackageBuildOutputFolder>
4544

4645
<LangVersion>latest</LangVersion>
46+
<TargetFullFrameworkVersion>net452</TargetFullFrameworkVersion>
4747

4848
</PropertyGroup>
4949

src/Spring/Spring.Aop/Aop/Framework/Adapter/UnknownAdviceTypeException.cs

+6-17
Original file line numberDiff line numberDiff line change
@@ -41,18 +41,18 @@ public class UnknownAdviceTypeException : ArgumentException
4141
/// Creates a new instance of the
4242
/// <see cref="Spring.Aop.Framework.Adapter.UnknownAdviceTypeException"/> class.
4343
/// </summary>
44-
/// <param name="advice">The advice that caused the exception.</param>
45-
public UnknownAdviceTypeException(object advice)
46-
: base("No adapter for IAdvice of type ["
47-
+ (advice != null ? advice.GetType().FullName : "null") + "].")
44+
public UnknownAdviceTypeException()
4845
{
4946
}
5047

5148
/// <summary>
5249
/// Creates a new instance of the
5350
/// <see cref="Spring.Aop.Framework.Adapter.UnknownAdviceTypeException"/> class.
5451
/// </summary>
55-
public UnknownAdviceTypeException()
52+
/// <param name="advice">The advice that caused the exception.</param>
53+
public UnknownAdviceTypeException(object advice)
54+
: base("No adapter for IAdvice of type ["
55+
+ (advice != null ? advice.GetType().FullName : "null") + "].")
5656
{
5757
}
5858

@@ -84,18 +84,7 @@ public UnknownAdviceTypeException(string message, Exception rootCause)
8484
{
8585
}
8686

87-
/// <summary>
88-
/// Creates a new instance of the
89-
/// <see cref="Spring.Aop.Framework.Adapter.UnknownAdviceTypeException"/> class.
90-
/// </summary>
91-
/// <param name="info">
92-
/// The <see cref="System.Runtime.Serialization.SerializationInfo"/>
93-
/// that holds the serialized object data about the exception being thrown.
94-
/// </param>
95-
/// <param name="context">
96-
/// The <see cref="System.Runtime.Serialization.StreamingContext"/>
97-
/// that contains contextual information about the source or destination.
98-
/// </param>
87+
/// <inheritdoc />
9988
protected UnknownAdviceTypeException(SerializationInfo info, StreamingContext context)
10089
: base(info, context)
10190
{

src/Spring/Spring.Aop/Aop/Framework/AdvisedSupport.cs

+41-23
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,3 @@
1-
#region License
2-
31
/*
42
* Copyright © 2002-2011 the original author or authors.
53
*
@@ -16,12 +14,11 @@
1614
* limitations under the License.
1715
*/
1816

19-
#endregion
20-
2117
using System;
2218
using System.Collections;
2319
using System.Collections.Generic;
2420
using System.Reflection;
21+
using System.Runtime.Serialization;
2522
using System.Text;
2623

2724
using AopAlliance.Aop;
@@ -56,8 +53,6 @@ namespace Spring.Aop.Framework
5653
[Serializable]
5754
public class AdvisedSupport : ProxyConfig, IAdvised
5855
{
59-
#region Fields
60-
6156
/// <summary>The list of advice.</summary>
6257
/// <remarks>
6358
/// <p>
@@ -108,7 +103,7 @@ public class AdvisedSupport : ProxyConfig, IAdvised
108103
/// <summary>
109104
/// The list of <see cref="Spring.Aop.Framework.AdvisedSupport"/> event listeners.
110105
/// </summary>
111-
private readonly IList<IAdvisedSupportListener> listeners = new List<IAdvisedSupportListener>();
106+
private readonly List<IAdvisedSupportListener> listeners = new List<IAdvisedSupportListener>();
112107

113108
/// <summary>
114109
/// The advisor chain factory.
@@ -121,10 +116,6 @@ public class AdvisedSupport : ProxyConfig, IAdvised
121116
/// </summary>
122117
private bool autoDetectInterfaces;
123118

124-
#endregion
125-
126-
#region Constructor(s)
127-
128119
/// <summary>
129120
/// Creates a new instance of the
130121
/// <see cref="Spring.Aop.Framework.AdvisedSupport"/> class using the
@@ -187,9 +178,46 @@ public AdvisedSupport(ITargetSource targetSource)
187178
TargetSource = targetSource;
188179
}
189180

190-
#endregion
181+
/// <inheritdoc />
182+
protected AdvisedSupport(SerializationInfo info, StreamingContext context)
183+
: base(info, context)
184+
{
185+
_advisors = (List<IAdvisor>) info.GetValue("advisors", typeof(List<IAdvisor>));
186+
_advisorsArray = (IAdvisor[]) info.GetValue("advisorsArray", typeof(IAdvisor[]));
187+
_introductions = (List<IIntroductionAdvisor>) info.GetValue("introductions", typeof(List<IIntroductionAdvisor>));
191188

192-
#region IAdvised implementation
189+
var map = (Dictionary<string, IIntroductionAdvisor>) info.GetValue("interfaceMap", typeof(Dictionary<string, IIntroductionAdvisor>));
190+
interfaceMap = new Dictionary<Type, IIntroductionAdvisor>();
191+
foreach (var pair in map)
192+
{
193+
interfaceMap[Type.GetType(pair.Key)] = pair.Value;
194+
}
195+
m_targetSource = (ITargetSource) info.GetValue("targetSource", typeof(ITargetSource));
196+
isActive = info.GetBoolean("isActive");
197+
listeners = (List<IAdvisedSupportListener>) info.GetValue("listeners", typeof(List<IAdvisedSupportListener>));
198+
advisorChainFactory = (IAdvisorChainFactory) info.GetValue("advisorChainFactory", typeof(IAdvisorChainFactory));
199+
autoDetectInterfaces = info.GetBoolean("autoDetectInterfaces");
200+
}
201+
202+
/// <inheritdoc />
203+
public override void GetObjectData(SerializationInfo info, StreamingContext context)
204+
{
205+
base.GetObjectData(info, context);
206+
info.AddValue("advisors", _advisors);
207+
info.AddValue("advisorsArray", _advisorsArray);
208+
info.AddValue("introductions", _introductions);
209+
var map = new Dictionary<string, IIntroductionAdvisor>();
210+
foreach (var pair in interfaceMap)
211+
{
212+
map.Add(pair.Key.AssemblyQualifiedName, pair.Value);
213+
}
214+
info.AddValue("interfaceMap", map);
215+
info.AddValue("targetSource", m_targetSource);
216+
info.AddValue("isActive", isActive);
217+
info.AddValue("listeners", listeners);
218+
info.AddValue("advisorChainFactory", advisorChainFactory);
219+
info.AddValue("autoDetectInterfaces", autoDetectInterfaces);
220+
}
193221

194222
/// <summary>
195223
/// Gets and sets the
@@ -943,10 +971,6 @@ protected virtual string ToProxyConfigStringInternal()
943971
return buffer.ToString();
944972
}
945973

946-
#endregion
947-
948-
#region Properties
949-
950974
/// <summary>
951975
/// Gets the target type behind the implementing object.
952976
/// Ttypically a proxy configuration or an actual proxy.
@@ -992,8 +1016,6 @@ protected bool IsActive
9921016
get { return isActive; }
9931017
}
9941018

995-
#endregion
996-
9971019
/// <summary>
9981020
/// Specifies the <see cref="System.Type"/> of proxies that are to be
9991021
/// created for this instance of proxy config.
@@ -1342,8 +1364,6 @@ private void UpdateAdvisorsArray()
13421364
this._advisorsArray = advisorsArray;
13431365
}
13441366

1345-
#region IAdvisedSupportListener support
1346-
13471367
/// <summary>
13481368
/// Callback method that is invoked when the list of proxied interfaces
13491369
/// has changed.
@@ -1399,8 +1419,6 @@ protected void Activate()
13991419
}
14001420
}
14011421

1402-
#endregion
1403-
14041422
/// <summary>
14051423
/// Creates an AOP proxy using this instance's configuration data.
14061424
/// </summary>

src/Spring/Spring.Aop/Aop/Framework/AopConfigException.cs

+1-12
Original file line numberDiff line numberDiff line change
@@ -71,18 +71,7 @@ public AopConfigException (string message, Exception rootCause)
7171
{
7272
}
7373

74-
/// <summary>
75-
/// Creates a new instance of the
76-
/// <see cref="Spring.Aop.Framework.AopConfigException"/> class.
77-
/// </summary>
78-
/// <param name="info">
79-
/// The <see cref="System.Runtime.Serialization.SerializationInfo"/>
80-
/// that holds the serialized object data about the exception being thrown.
81-
/// </param>
82-
/// <param name="context">
83-
/// The <see cref="System.Runtime.Serialization.StreamingContext"/>
84-
/// that contains contextual information about the source or destination.
85-
/// </param>
74+
/// <inheritdoc />
8675
protected AopConfigException (
8776
SerializationInfo info, StreamingContext context)
8877
: base (info, context)

0 commit comments

Comments
 (0)