commit
534c5d27d5
@ -0,0 +1 @@
|
|||||||
|
0a579bbbae526f8ab90b57f7e365060d9bf9c527 SOURCES/dotnet-v6.0.109.tar.gz
|
@ -0,0 +1 @@
|
|||||||
|
SOURCES/dotnet-v6.0.109.tar.gz
|
@ -0,0 +1,36 @@
|
|||||||
|
Index: a/src/Microsoft.DotNet.GitSync.CommitManager/Microsoft.DotNet.GitSync.CommitManager.csproj
|
||||||
|
===================================================================
|
||||||
|
--- a/src/Microsoft.DotNet.GitSync.CommitManager/Microsoft.DotNet.GitSync.CommitManager.csproj
|
||||||
|
+++ b/src/Microsoft.DotNet.GitSync.CommitManager/Microsoft.DotNet.GitSync.CommitManager.csproj
|
||||||
|
@@ -5,6 +5,7 @@
|
||||||
|
<TargetFramework>netcoreapp3.1</TargetFramework>
|
||||||
|
<LangVersion>latest</LangVersion>
|
||||||
|
<ExcludeFromSourceBuild>true</ExcludeFromSourceBuild>
|
||||||
|
+ <UseAppHost>false</UseAppHost>
|
||||||
|
</PropertyGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
Index: a/src/Microsoft.DotNet.SwaggerGenerator/Microsoft.DotNet.SwaggerGenerator.CmdLine/Microsoft.DotNet.SwaggerGenerator.CmdLine.csproj
|
||||||
|
===================================================================
|
||||||
|
--- a/src/Microsoft.DotNet.SwaggerGenerator/Microsoft.DotNet.SwaggerGenerator.CmdLine/Microsoft.DotNet.SwaggerGenerator.CmdLine.csproj
|
||||||
|
+++ b/src/Microsoft.DotNet.SwaggerGenerator/Microsoft.DotNet.SwaggerGenerator.CmdLine/Microsoft.DotNet.SwaggerGenerator.CmdLine.csproj
|
||||||
|
@@ -9,6 +9,7 @@
|
||||||
|
<ToolCommandName>dotnet-swaggergen</ToolCommandName>
|
||||||
|
<SignAssembly>false</SignAssembly>
|
||||||
|
<ExcludeFromSourceBuild>true</ExcludeFromSourceBuild>
|
||||||
|
+ <UseAppHost>false</UseAppHost>
|
||||||
|
</PropertyGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
Index: a/src/Microsoft.DotNet.XUnitConsoleRunner/src/Microsoft.DotNet.XUnitConsoleRunner.csproj
|
||||||
|
===================================================================
|
||||||
|
--- a/src/Microsoft.DotNet.XUnitConsoleRunner/src/Microsoft.DotNet.XUnitConsoleRunner.csproj
|
||||||
|
+++ b/src/Microsoft.DotNet.XUnitConsoleRunner/src/Microsoft.DotNet.XUnitConsoleRunner.csproj
|
||||||
|
@@ -11,6 +11,7 @@
|
||||||
|
<VersionPrefix>2.5.1</VersionPrefix>
|
||||||
|
<ExcludeFromSourceBuild>true</ExcludeFromSourceBuild>
|
||||||
|
<RollForward>Major</RollForward>
|
||||||
|
+ <UseAppHost>false</UseAppHost>
|
||||||
|
</PropertyGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
@ -0,0 +1,136 @@
|
|||||||
|
#!/usr/bin/python3
|
||||||
|
|
||||||
|
"""
|
||||||
|
Check debug symbols are present in shared object and can identify
|
||||||
|
code.
|
||||||
|
|
||||||
|
It starts scanning from a directory and recursively scans all ELF
|
||||||
|
files found in it for various symbols to ensure all debuginfo is
|
||||||
|
present and nothing has been stripped.
|
||||||
|
|
||||||
|
Usage:
|
||||||
|
|
||||||
|
./check-debug-symbols /path/of/dir/to/scan/
|
||||||
|
|
||||||
|
|
||||||
|
Example:
|
||||||
|
|
||||||
|
./check-debug-symbols /usr/lib64
|
||||||
|
"""
|
||||||
|
|
||||||
|
# This technique was explained to me by Mark Wielaard (mjw).
|
||||||
|
|
||||||
|
import collections
|
||||||
|
import os
|
||||||
|
import re
|
||||||
|
import subprocess
|
||||||
|
import sys
|
||||||
|
|
||||||
|
ScanResult = collections.namedtuple('ScanResult',
|
||||||
|
'file_name debug_info debug_abbrev file_symbols gnu_debuglink')
|
||||||
|
|
||||||
|
|
||||||
|
def scan_file(file):
|
||||||
|
"Scan the provided file and return a ScanResult containing results of the scan."
|
||||||
|
|
||||||
|
# Test for .debug_* sections in the shared object. This is the main test.
|
||||||
|
# Stripped objects will not contain these.
|
||||||
|
readelf_S_result = subprocess.run(['eu-readelf', '-S', file],
|
||||||
|
stdout=subprocess.PIPE, encoding='utf-8', check=True)
|
||||||
|
has_debug_info = any(line for line in readelf_S_result.stdout.split('\n') if '] .debug_info' in line)
|
||||||
|
|
||||||
|
has_debug_abbrev = any(line for line in readelf_S_result.stdout.split('\n') if '] .debug_abbrev' in line)
|
||||||
|
|
||||||
|
# Test FILE symbols. These will most likely be removed by anyting that
|
||||||
|
# manipulates symbol tables because it's generally useless. So a nice test
|
||||||
|
# that nothing has messed with symbols.
|
||||||
|
def contains_file_symbols(line):
|
||||||
|
parts = line.split()
|
||||||
|
if len(parts) < 8:
|
||||||
|
return False
|
||||||
|
return \
|
||||||
|
parts[2] == '0' and parts[3] == 'FILE' and parts[4] == 'LOCAL' and parts[5] == 'DEFAULT' and \
|
||||||
|
parts[6] == 'ABS' and re.match(r'((.*/)?[-_a-zA-Z0-9]+\.(c|cc|cpp|cxx))?', parts[7])
|
||||||
|
|
||||||
|
readelf_s_result = subprocess.run(["eu-readelf", '-s', file],
|
||||||
|
stdout=subprocess.PIPE, encoding='utf-8', check=True)
|
||||||
|
has_file_symbols = any(line for line in readelf_s_result.stdout.split('\n') if contains_file_symbols(line))
|
||||||
|
|
||||||
|
# Test that there are no .gnu_debuglink sections pointing to another
|
||||||
|
# debuginfo file. There shouldn't be any debuginfo files, so the link makes
|
||||||
|
# no sense either.
|
||||||
|
has_gnu_debuglink = any(line for line in readelf_s_result.stdout.split('\n') if '] .gnu_debuglink' in line)
|
||||||
|
|
||||||
|
return ScanResult(file, has_debug_info, has_debug_abbrev, has_file_symbols, has_gnu_debuglink)
|
||||||
|
|
||||||
|
def is_elf(file):
|
||||||
|
result = subprocess.run(['file', file], stdout=subprocess.PIPE, encoding='utf-8', check=True)
|
||||||
|
return re.search('ELF 64-bit LSB (?:pie )(?:executable|shared object)', result.stdout)
|
||||||
|
|
||||||
|
def scan_file_if_sensible(file):
|
||||||
|
if is_elf(file):
|
||||||
|
# print(file)
|
||||||
|
return scan_file(file)
|
||||||
|
return None
|
||||||
|
|
||||||
|
def scan_dir(dir):
|
||||||
|
results = []
|
||||||
|
for root, _, files in os.walk(dir):
|
||||||
|
for name in files:
|
||||||
|
result = scan_file_if_sensible(os.path.join(root, name))
|
||||||
|
if result:
|
||||||
|
results.append(result)
|
||||||
|
return results
|
||||||
|
|
||||||
|
def scan(file):
|
||||||
|
file = os.path.abspath(file)
|
||||||
|
if os.path.isdir(file):
|
||||||
|
return scan_dir(file)
|
||||||
|
elif os.path.isfile(file):
|
||||||
|
return [scan_file_if_sensible(file)]
|
||||||
|
|
||||||
|
def is_bad_result(result):
|
||||||
|
return not result.debug_info or not result.debug_abbrev or not result.file_symbols or result.gnu_debuglink
|
||||||
|
|
||||||
|
def print_scan_results(results, verbose):
|
||||||
|
# print(results)
|
||||||
|
for result in results:
|
||||||
|
file_name = result.file_name
|
||||||
|
found_issue = False
|
||||||
|
if not result.debug_info:
|
||||||
|
found_issue = True
|
||||||
|
print('error: missing .debug_info section in', file_name)
|
||||||
|
if not result.debug_abbrev:
|
||||||
|
found_issue = True
|
||||||
|
print('error: missing .debug_abbrev section in', file_name)
|
||||||
|
if not result.file_symbols:
|
||||||
|
found_issue = True
|
||||||
|
print('error: missing FILE symbols in', file_name)
|
||||||
|
if result.gnu_debuglink:
|
||||||
|
found_issue = True
|
||||||
|
print('error: unexpected .gnu_debuglink section in', file_name)
|
||||||
|
if verbose and not found_issue:
|
||||||
|
print('OK: ', file_name)
|
||||||
|
|
||||||
|
def main(args):
|
||||||
|
verbose = False
|
||||||
|
files = []
|
||||||
|
for arg in args:
|
||||||
|
if arg == '--verbose' or arg == '-v':
|
||||||
|
verbose = True
|
||||||
|
else:
|
||||||
|
files.append(arg)
|
||||||
|
|
||||||
|
results = []
|
||||||
|
for file in files:
|
||||||
|
results.extend(scan(file))
|
||||||
|
|
||||||
|
print_scan_results(results, verbose)
|
||||||
|
|
||||||
|
if any(is_bad_result(result) for result in results):
|
||||||
|
return 1
|
||||||
|
return 0
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
sys.exit(main(sys.argv[1:]))
|
@ -0,0 +1,14 @@
|
|||||||
|
|
||||||
|
# Set location for AppHost lookup
|
||||||
|
[ -z "$DOTNET_ROOT" ] && export DOTNET_ROOT=@LIBDIR@/dotnet
|
||||||
|
|
||||||
|
# Add dotnet tools directory to PATH
|
||||||
|
DOTNET_TOOLS_PATH="$HOME/.dotnet/tools"
|
||||||
|
case "$PATH" in
|
||||||
|
*"$DOTNET_TOOLS_PATH"* ) true ;;
|
||||||
|
* ) PATH="$PATH:$DOTNET_TOOLS_PATH" ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# Extract self-contained executables under HOME
|
||||||
|
# to avoid multi-user issues from using the default '/var/tmp'.
|
||||||
|
[ -z "$DOTNET_BUNDLE_EXTRACT_BASE_DIR" ] && export DOTNET_BUNDLE_EXTRACT_BASE_DIR="${XDG_CACHE_HOME:-"$HOME"/.cache}/dotnet_bundle_extract"
|
@ -0,0 +1,21 @@
|
|||||||
|
--- a/tests/benchmarks/MicroPerf/MicroPerf.fsproj
|
||||||
|
+++ b/tests/benchmarks/MicroPerf/MicroPerf.fsproj
|
||||||
|
@@ -9,6 +9,7 @@
|
||||||
|
<OtherFlags>$(OtherFlags) --nowarn:57</OtherFlags>
|
||||||
|
<OtherFlags>$(OtherFlags) --langversion:preview</OtherFlags>
|
||||||
|
<OtherFlags>$(OtherFlags) --define:PREVIEW</OtherFlags>
|
||||||
|
+ <UseAppHost>false</UseAppHost>
|
||||||
|
<!-- By default this project will compile with the proto compiler -->
|
||||||
|
<!-- Uncommenting this will build with a previous installed compiler -->
|
||||||
|
<!--
|
||||||
|
--- a/tests/benchmarks/TaskPerf/TaskPerf.fsproj
|
||||||
|
+++ b/tests/benchmarks/TaskPerf/TaskPerf.fsproj
|
||||||
|
@@ -4,6 +4,7 @@
|
||||||
|
<TargetFramework>net5.0</TargetFramework>
|
||||||
|
<OutputType>Exe</OutputType>
|
||||||
|
<DisableImplicitFSharpCoreReference>true</DisableImplicitFSharpCoreReference>
|
||||||
|
+ <UseAppHost>false</UseAppHost>
|
||||||
|
<!-- Turn off "This function is for use by compiled F# code and should not be used directly" -->
|
||||||
|
<OtherFlags>$(OtherFlags) --nowarn:1204</OtherFlags>
|
||||||
|
<!-- Turn off "Experimental" -->
|
||||||
|
|
@ -0,0 +1,23 @@
|
|||||||
|
From 892222071f73062f969f4f6ed1df8f759b9327b7 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Tom Deseyn <tom.deseyn@gmail.com>
|
||||||
|
Date: Wed, 3 Nov 2021 15:12:59 +0100
|
||||||
|
Subject: [PATCH] GetRuntimeInformation.targets: determine
|
||||||
|
PortableProductMonikerRid based on HostOSName and Architecture.
|
||||||
|
|
||||||
|
---
|
||||||
|
src/redist/targets/GetRuntimeInformation.targets | 2 ++
|
||||||
|
1 file changed, 2 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/src/redist/targets/GetRuntimeInformation.targets b/src/redist/targets/GetRuntimeInformation.targets
|
||||||
|
index 5133c3a3841..01f704c7d8e 100644
|
||||||
|
--- a/src/redist/targets/GetRuntimeInformation.targets
|
||||||
|
+++ b/src/redist/targets/GetRuntimeInformation.targets
|
||||||
|
@@ -28,6 +28,8 @@
|
||||||
|
'$(Rid)' == 'linux-musl-x64' ">$(Rid)</ProductMonikerRid>
|
||||||
|
<ProductMonikerRid Condition=" '$(ProductMonikerRid)' == '' ">$(OSName)-$(Architecture)</ProductMonikerRid>
|
||||||
|
|
||||||
|
+ <PortableProductMonikerRid Condition=" '$(PortableProductMonikerRid)' == '' ">$(HostOSName)-$(Architecture)</PortableProductMonikerRid>
|
||||||
|
+
|
||||||
|
<ArtifactNameSdk>dotnet-sdk-internal$(PgoTerm)</ArtifactNameSdk>
|
||||||
|
<ArtifactNameCombinedHostHostFxrFrameworkSdk>dotnet-sdk$(PgoTerm)</ArtifactNameCombinedHostHostFxrFrameworkSdk>
|
||||||
|
|
@ -0,0 +1,46 @@
|
|||||||
|
--- a/src/Build/Definition/ProjectCollection.cs
|
||||||
|
+++ b/src/Build/Definition/ProjectCollection.cs
|
||||||
|
@@ -1754,7 +1754,11 @@ namespace Microsoft.Build.Evaluation
|
||||||
|
#if FEATURE_WIN32_REGISTRY
|
||||||
|
ToolsetRegistryReader registryReader = null,
|
||||||
|
#endif
|
||||||
|
+#if FEATURE_SYSTEM_CONFIGURATION
|
||||||
|
ToolsetConfigurationReader configReader = null
|
||||||
|
+#else
|
||||||
|
+ object configReader = null
|
||||||
|
+#endif
|
||||||
|
)
|
||||||
|
{
|
||||||
|
_toolsets = new Dictionary<string, Toolset>(StringComparer.OrdinalIgnoreCase);
|
||||||
|
--- a/src/Build/Definition/ToolsetReader.cs
|
||||||
|
+++ b/src/Build/Definition/ToolsetReader.cs
|
||||||
|
@@ -101,7 +101,11 @@ namespace Microsoft.Build.Evaluation
|
||||||
|
#if FEATURE_WIN32_REGISTRY
|
||||||
|
ToolsetRegistryReader registryReader,
|
||||||
|
#endif
|
||||||
|
+#if FEATURE_SYSTEM_CONFIGURATION
|
||||||
|
ToolsetConfigurationReader configurationReader,
|
||||||
|
+#else
|
||||||
|
+ object _configurationReader,
|
||||||
|
+#endif
|
||||||
|
PropertyDictionary<ProjectPropertyInstance> environmentProperties,
|
||||||
|
PropertyDictionary<ProjectPropertyInstance> globalProperties,
|
||||||
|
ToolsetDefinitionLocations locations
|
||||||
|
@@ -120,6 +124,7 @@ namespace Microsoft.Build.Evaluation
|
||||||
|
|
||||||
|
if ((locations & ToolsetDefinitionLocations.ConfigurationFile) == ToolsetDefinitionLocations.ConfigurationFile)
|
||||||
|
{
|
||||||
|
+#if FEATURE_SYSTEM_CONFIGURATION
|
||||||
|
if (configurationReader == null)
|
||||||
|
{
|
||||||
|
configurationReader = new ToolsetConfigurationReader(environmentProperties, globalProperties);
|
||||||
|
@@ -129,6 +134,9 @@ namespace Microsoft.Build.Evaluation
|
||||||
|
defaultToolsVersionFromConfiguration = configurationReader.ReadToolsets(toolsets, globalProperties,
|
||||||
|
initialProperties, true /* accumulate properties */, out overrideTasksPathFromConfiguration,
|
||||||
|
out defaultOverrideToolsVersionFromConfiguration);
|
||||||
|
+#else
|
||||||
|
+ throw new InvalidOperationException("ToolsetDefinitionLocations.ConfigurationFile not supported");
|
||||||
|
+#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
string defaultToolsVersionFromRegistry = null;
|
@ -0,0 +1,12 @@
|
|||||||
|
--- a/src/Shared/ExceptionHandling.cs
|
||||||
|
+++ b/src/Shared/ExceptionHandling.cs
|
||||||
|
@@ -153,7 +153,9 @@ namespace Microsoft.Build.Shared
|
||||||
|
internal static bool IsXmlException(Exception e)
|
||||||
|
{
|
||||||
|
return e is XmlException
|
||||||
|
+#if FEATURE_SECURITY_PERMISSIONS
|
||||||
|
|| e is XmlSyntaxException
|
||||||
|
+#endif
|
||||||
|
|| e is XmlSchemaException
|
||||||
|
|| e is UriFormatException; // XmlTextReader for example uses this under the covers
|
||||||
|
}
|
@ -0,0 +1,453 @@
|
|||||||
|
Index: tarball.6.0.1-rc2-6.0.100-rc2/src/roslyn.8e1779e16298415843e85029d8b52a1ae9bb4c30/src/Compilers/Core/Portable/InternalUtilities/PlatformInformation.cs
|
||||||
|
===================================================================
|
||||||
|
--- tarball.6.0.1-rc2-6.0.100-rc2.orig/src/roslyn.8e1779e16298415843e85029d8b52a1ae9bb4c30/src/Compilers/Core/Portable/InternalUtilities/PlatformInformation.cs
|
||||||
|
+++ tarball.6.0.1-rc2-6.0.100-rc2/src/roslyn.8e1779e16298415843e85029d8b52a1ae9bb4c30/src/Compilers/Core/Portable/InternalUtilities/PlatformInformation.cs
|
||||||
|
@@ -31,5 +31,24 @@ namespace Roslyn.Utilities
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
+ /// <summary>
|
||||||
|
+ /// Are we running on .NET 5 or later using the Mono runtime?
|
||||||
|
+ /// Will also return true when running on Mono itself; if necessary
|
||||||
|
+ /// we can use IsRunningOnMono to distinguish.
|
||||||
|
+ /// </summary>
|
||||||
|
+ public static bool IsUsingMonoRuntime
|
||||||
|
+ {
|
||||||
|
+ get
|
||||||
|
+ {
|
||||||
|
+ try
|
||||||
|
+ {
|
||||||
|
+ return !(Type.GetType("Mono.RuntimeStructs", throwOnError: false) is null);
|
||||||
|
+ }
|
||||||
|
+ catch
|
||||||
|
+ {
|
||||||
|
+ return false;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Index: tarball.6.0.1-rc2-6.0.100-rc2/src/roslyn.8e1779e16298415843e85029d8b52a1ae9bb4c30/src/Compilers/Server/VBCSCompilerTests/BuildClientTests.cs
|
||||||
|
===================================================================
|
||||||
|
--- tarball.6.0.1-rc2-6.0.100-rc2.orig/src/roslyn.8e1779e16298415843e85029d8b52a1ae9bb4c30/src/Compilers/Server/VBCSCompilerTests/BuildClientTests.cs
|
||||||
|
+++ tarball.6.0.1-rc2-6.0.100-rc2/src/roslyn.8e1779e16298415843e85029d8b52a1ae9bb4c30/src/Compilers/Server/VBCSCompilerTests/BuildClientTests.cs
|
||||||
|
@@ -79,7 +79,7 @@ namespace Microsoft.CodeAnalysis.Compile
|
||||||
|
// to connect. When it fails it should fall back to in-proc
|
||||||
|
// compilation.
|
||||||
|
bool holdsMutex;
|
||||||
|
- using (var serverMutex = new Mutex(initiallyOwned: true,
|
||||||
|
+ using (var serverMutex = BuildServerConnection.OpenOrCreateMutex(
|
||||||
|
name: BuildServerConnection.GetServerMutexName(_pipeName),
|
||||||
|
createdNew: out holdsMutex))
|
||||||
|
{
|
||||||
|
Index: tarball.6.0.1-rc2-6.0.100-rc2/src/roslyn.8e1779e16298415843e85029d8b52a1ae9bb4c30/src/Compilers/Server/VBCSCompilerTests/CompilerServerApiTest.cs
|
||||||
|
===================================================================
|
||||||
|
--- tarball.6.0.1-rc2-6.0.100-rc2.orig/src/roslyn.8e1779e16298415843e85029d8b52a1ae9bb4c30/src/Compilers/Server/VBCSCompilerTests/CompilerServerApiTest.cs
|
||||||
|
+++ tarball.6.0.1-rc2-6.0.100-rc2/src/roslyn.8e1779e16298415843e85029d8b52a1ae9bb4c30/src/Compilers/Server/VBCSCompilerTests/CompilerServerApiTest.cs
|
||||||
|
@@ -103,7 +103,7 @@ class Hello
|
||||||
|
var mutexName = BuildServerConnection.GetServerMutexName(pipeName);
|
||||||
|
|
||||||
|
bool holdsMutex;
|
||||||
|
- using (var mutex = new Mutex(initiallyOwned: true,
|
||||||
|
+ using (var mutex = BuildServerConnection.OpenOrCreateMutex(
|
||||||
|
name: mutexName,
|
||||||
|
createdNew: out holdsMutex))
|
||||||
|
{
|
||||||
|
@@ -119,7 +119,7 @@ class Hello
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
- mutex.ReleaseMutex();
|
||||||
|
+ mutex.Dispose();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Index: tarball.6.0.1-rc2-6.0.100-rc2/src/roslyn.8e1779e16298415843e85029d8b52a1ae9bb4c30/src/Compilers/Server/VBCSCompilerTests/CompilerServerTests.cs
|
||||||
|
===================================================================
|
||||||
|
--- tarball.6.0.1-rc2-6.0.100-rc2.orig/src/roslyn.8e1779e16298415843e85029d8b52a1ae9bb4c30/src/Compilers/Server/VBCSCompilerTests/CompilerServerTests.cs
|
||||||
|
+++ tarball.6.0.1-rc2-6.0.100-rc2/src/roslyn.8e1779e16298415843e85029d8b52a1ae9bb4c30/src/Compilers/Server/VBCSCompilerTests/CompilerServerTests.cs
|
||||||
|
@@ -304,7 +304,7 @@ End Module")
|
||||||
|
var newTempDir = _tempDirectory.CreateDirectory(new string('a', 100 - _tempDirectory.Path.Length));
|
||||||
|
await ApplyEnvironmentVariables(
|
||||||
|
new[] { new KeyValuePair<string, string>("TMPDIR", newTempDir.Path) },
|
||||||
|
- async () =>
|
||||||
|
+ async () => await Task.Run(async () =>
|
||||||
|
{
|
||||||
|
using var serverData = await ServerUtil.CreateServer(_logger);
|
||||||
|
var result = RunCommandLineCompiler(
|
||||||
|
@@ -317,7 +317,7 @@ End Module")
|
||||||
|
|
||||||
|
var listener = await serverData.Complete();
|
||||||
|
Assert.Equal(CompletionData.RequestCompleted, listener.CompletionDataList.Single());
|
||||||
|
- });
|
||||||
|
+ }));
|
||||||
|
}
|
||||||
|
|
||||||
|
[Fact]
|
||||||
|
Index: tarball.6.0.1-rc2-6.0.100-rc2/src/roslyn.8e1779e16298415843e85029d8b52a1ae9bb4c30/src/Compilers/Server/VBCSCompilerTests/VBCSCompilerServerTests.cs
|
||||||
|
===================================================================
|
||||||
|
--- tarball.6.0.1-rc2-6.0.100-rc2.orig/src/roslyn.8e1779e16298415843e85029d8b52a1ae9bb4c30/src/Compilers/Server/VBCSCompilerTests/VBCSCompilerServerTests.cs
|
||||||
|
+++ tarball.6.0.1-rc2-6.0.100-rc2/src/roslyn.8e1779e16298415843e85029d8b52a1ae9bb4c30/src/Compilers/Server/VBCSCompilerTests/VBCSCompilerServerTests.cs
|
||||||
|
@@ -101,7 +101,7 @@ namespace Microsoft.CodeAnalysis.Compile
|
||||||
|
|
||||||
|
var thread = new Thread(() =>
|
||||||
|
{
|
||||||
|
- using (var mutex = new Mutex(initiallyOwned: true, name: mutexName, createdNew: out created))
|
||||||
|
+ using (var mutex = BuildServerConnection.OpenOrCreateMutex(name: mutexName, createdNew: out created))
|
||||||
|
using (var stream = NamedPipeUtil.CreateServer(pipeName))
|
||||||
|
{
|
||||||
|
readyMre.Set();
|
||||||
|
@@ -112,7 +112,7 @@ namespace Microsoft.CodeAnalysis.Compile
|
||||||
|
stream.Close();
|
||||||
|
|
||||||
|
doneMre.WaitOne();
|
||||||
|
- mutex.ReleaseMutex();
|
||||||
|
+ mutex.Dispose();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
@@ -153,7 +153,7 @@ namespace Microsoft.CodeAnalysis.Compile
|
||||||
|
{
|
||||||
|
using (var stream = NamedPipeUtil.CreateServer(pipeName))
|
||||||
|
{
|
||||||
|
- var mutex = new Mutex(initiallyOwned: true, name: mutexName, createdNew: out created);
|
||||||
|
+ var mutex = BuildServerConnection.OpenOrCreateMutex(name: mutexName, createdNew: out created);
|
||||||
|
readyMre.Set();
|
||||||
|
|
||||||
|
stream.WaitForConnection();
|
||||||
|
@@ -161,7 +161,6 @@ namespace Microsoft.CodeAnalysis.Compile
|
||||||
|
|
||||||
|
// Client is waiting for a response. Close the mutex now. Then close the connection
|
||||||
|
// so the client gets an error.
|
||||||
|
- mutex.ReleaseMutex();
|
||||||
|
mutex.Dispose();
|
||||||
|
stream.Close();
|
||||||
|
|
||||||
|
Index: tarball.6.0.1-rc2-6.0.100-rc2/src/roslyn.8e1779e16298415843e85029d8b52a1ae9bb4c30/src/Compilers/Shared/BuildServerConnection.cs
|
||||||
|
===================================================================
|
||||||
|
--- tarball.6.0.1-rc2-6.0.100-rc2.orig/src/roslyn.8e1779e16298415843e85029d8b52a1ae9bb4c30/src/Compilers/Shared/BuildServerConnection.cs
|
||||||
|
+++ tarball.6.0.1-rc2-6.0.100-rc2/src/roslyn.8e1779e16298415843e85029d8b52a1ae9bb4c30/src/Compilers/Shared/BuildServerConnection.cs
|
||||||
|
@@ -543,19 +543,10 @@ namespace Microsoft.CodeAnalysis.Command
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
- if (PlatformInformation.IsRunningOnMono)
|
||||||
|
+ if (PlatformInformation.IsUsingMonoRuntime)
|
||||||
|
{
|
||||||
|
- IServerMutex? mutex = null;
|
||||||
|
- bool createdNew = false;
|
||||||
|
- try
|
||||||
|
- {
|
||||||
|
- mutex = new ServerFileMutexPair(mutexName, false, out createdNew);
|
||||||
|
- return !createdNew;
|
||||||
|
- }
|
||||||
|
- finally
|
||||||
|
- {
|
||||||
|
- mutex?.Dispose();
|
||||||
|
- }
|
||||||
|
+ using var mutex = new ServerFileMutex(mutexName);
|
||||||
|
+ return !mutex.CouldLock();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
@@ -572,9 +563,11 @@ namespace Microsoft.CodeAnalysis.Command
|
||||||
|
|
||||||
|
internal static IServerMutex OpenOrCreateMutex(string name, out bool createdNew)
|
||||||
|
{
|
||||||
|
- if (PlatformInformation.IsRunningOnMono)
|
||||||
|
+ if (PlatformInformation.IsUsingMonoRuntime)
|
||||||
|
{
|
||||||
|
- return new ServerFileMutexPair(name, initiallyOwned: true, out createdNew);
|
||||||
|
+ var mutex = new ServerFileMutex(name);
|
||||||
|
+ createdNew = mutex.TryLock(0);
|
||||||
|
+ return mutex;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
@@ -648,19 +641,22 @@ namespace Microsoft.CodeAnalysis.Command
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
- /// An interprocess mutex abstraction based on OS advisory locking (FileStream.Lock/Unlock).
|
||||||
|
+ /// An interprocess mutex abstraction based on file sharing permission (FileShare.None).
|
||||||
|
/// If multiple processes running as the same user create FileMutex instances with the same name,
|
||||||
|
/// those instances will all point to the same file somewhere in a selected temporary directory.
|
||||||
|
- /// The TryLock method can be used to attempt to acquire the mutex, with Unlock or Dispose used to release.
|
||||||
|
+ /// The TryLock method can be used to attempt to acquire the mutex, with Dispose used to release.
|
||||||
|
+ /// The CouldLock method can be used to check whether an attempt to acquire the mutex would have
|
||||||
|
+ /// succeeded at the current time, without actually acquiring it.
|
||||||
|
/// Unlike Win32 named mutexes, there is no mechanism for detecting an abandoned mutex. The file
|
||||||
|
/// will simply revert to being unlocked but remain where it is.
|
||||||
|
/// </summary>
|
||||||
|
- internal sealed class FileMutex : IDisposable
|
||||||
|
+ internal sealed class ServerFileMutex : IServerMutex
|
||||||
|
{
|
||||||
|
- public readonly FileStream Stream;
|
||||||
|
+ public FileStream? Stream;
|
||||||
|
public readonly string FilePath;
|
||||||
|
+ public readonly string GuardPath;
|
||||||
|
|
||||||
|
- public bool IsLocked { get; private set; }
|
||||||
|
+ public bool IsDisposed { get; private set; }
|
||||||
|
|
||||||
|
internal static string GetMutexDirectory()
|
||||||
|
{
|
||||||
|
@@ -670,61 +666,176 @@ namespace Microsoft.CodeAnalysis.Command
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
- public FileMutex(string name)
|
||||||
|
+ public ServerFileMutex(string name)
|
||||||
|
{
|
||||||
|
- FilePath = Path.Combine(GetMutexDirectory(), name);
|
||||||
|
- Stream = new FileStream(FilePath, FileMode.OpenOrCreate, FileAccess.ReadWrite, FileShare.None);
|
||||||
|
+ var mutexDirectory = GetMutexDirectory();
|
||||||
|
+ FilePath = Path.Combine(mutexDirectory, name);
|
||||||
|
+ GuardPath = Path.Combine(mutexDirectory, ".guard");
|
||||||
|
}
|
||||||
|
|
||||||
|
- public bool TryLock(int timeoutMs)
|
||||||
|
+ /// <summary>
|
||||||
|
+ /// Acquire the guard by opening the guard file with FileShare.None. The guard must only ever
|
||||||
|
+ /// be held for very brief amounts of time, so we can simply spin until it is acquired. The
|
||||||
|
+ /// guard must be released by disposing the FileStream returned from this routine. Note the
|
||||||
|
+ /// guard file is never deleted; this is a leak, but only of a single file.
|
||||||
|
+ /// </summary>
|
||||||
|
+ internal FileStream LockGuard()
|
||||||
|
{
|
||||||
|
- if (IsLocked)
|
||||||
|
- throw new InvalidOperationException("Lock already held");
|
||||||
|
-
|
||||||
|
- var sw = Stopwatch.StartNew();
|
||||||
|
- do
|
||||||
|
+ // We should be able to acquire the guard quickly. Limit the number of retries anyway
|
||||||
|
+ // by some arbitrary bound to avoid getting hung up in a possibly infinite loop.
|
||||||
|
+ for (var i = 0; i < 100; i++)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
- Stream.Lock(0, 0);
|
||||||
|
- IsLocked = true;
|
||||||
|
- return true;
|
||||||
|
+ return new FileStream(GuardPath, FileMode.OpenOrCreate, FileAccess.ReadWrite, FileShare.None);
|
||||||
|
}
|
||||||
|
catch (IOException)
|
||||||
|
{
|
||||||
|
- // Lock currently held by someone else.
|
||||||
|
+ // Guard currently held by someone else.
|
||||||
|
// We want to sleep for a short period of time to ensure that other processes
|
||||||
|
// have an opportunity to finish their work and relinquish the lock.
|
||||||
|
// Spinning here (via Yield) would work but risks creating a priority
|
||||||
|
// inversion if the lock is held by a lower-priority process.
|
||||||
|
Thread.Sleep(1);
|
||||||
|
}
|
||||||
|
+ }
|
||||||
|
+ // Handle unexpected failure to acquire guard as error.
|
||||||
|
+ throw new InvalidOperationException("Unable to acquire guard");
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /// <summary>
|
||||||
|
+ /// Attempt to acquire the lock by opening the lock file with FileShare.None. Sets "Stream"
|
||||||
|
+ /// and returns true if successful, returns false if the lock is already held by another
|
||||||
|
+ /// thread or process. Guard must be held when calling this routine.
|
||||||
|
+ /// </summary>
|
||||||
|
+ internal bool TryLockFile()
|
||||||
|
+ {
|
||||||
|
+ Debug.Assert(Stream is null);
|
||||||
|
+ FileStream? stream = null;
|
||||||
|
+ try
|
||||||
|
+ {
|
||||||
|
+ stream = new FileStream(FilePath, FileMode.OpenOrCreate, FileAccess.ReadWrite, FileShare.None);
|
||||||
|
+ // On some targets, the file locking used to implement FileShare.None may not be
|
||||||
|
+ // atomic with opening/creating the file. This creates a race window when another
|
||||||
|
+ // thread holds the lock and is just about to unlock: we may be able to open the
|
||||||
|
+ // file here, then the other thread unlocks and deletes the file, and then we
|
||||||
|
+ // acquire the lock on our file handle - but the actual file is already deleted.
|
||||||
|
+ // To close this race, we verify that the file does in fact still exist now that
|
||||||
|
+ // we have successfull acquired the locked FileStream. (Note that this check is
|
||||||
|
+ // safe because we cannot race with an other attempt to create the file since we
|
||||||
|
+ // hold the guard, and after the FileStream constructor returned we can no race
|
||||||
|
+ // with file deletion because we hold the lock.)
|
||||||
|
+ if (!File.Exists(FilePath))
|
||||||
|
+ {
|
||||||
|
+ // To simplify the logic, we treat this case as "unable to acquire the lock"
|
||||||
|
+ // because it we caught another process while it owned the lock and was just
|
||||||
|
+ // giving it up. If the caller retries, we'll likely acquire the lock then.
|
||||||
|
+ stream.Dispose();
|
||||||
|
+ return false;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ catch (Exception)
|
||||||
|
+ {
|
||||||
|
+ stream?.Dispose();
|
||||||
|
+ return false;
|
||||||
|
+ }
|
||||||
|
+ Stream = stream;
|
||||||
|
+ return true;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /// <summary>
|
||||||
|
+ /// Release the lock by deleting the lock file and disposing "Stream".
|
||||||
|
+ /// </summary>
|
||||||
|
+ internal void UnlockFile()
|
||||||
|
+ {
|
||||||
|
+ Debug.Assert(Stream is not null);
|
||||||
|
+ try
|
||||||
|
+ {
|
||||||
|
+ // Delete the lock file while the stream is not yet disposed
|
||||||
|
+ // and we therefore still hold the FileShare.None exclusion.
|
||||||
|
+ // There may still be a race with another thread attempting a
|
||||||
|
+ // TryLockFile in parallel, but that is safely handled there.
|
||||||
|
+ File.Delete(FilePath);
|
||||||
|
+ }
|
||||||
|
+ finally
|
||||||
|
+ {
|
||||||
|
+ Stream.Dispose();
|
||||||
|
+ Stream = null;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public bool TryLock(int timeoutMs)
|
||||||
|
+ {
|
||||||
|
+ if (IsDisposed)
|
||||||
|
+ throw new ObjectDisposedException("Mutex");
|
||||||
|
+ if (Stream is not null)
|
||||||
|
+ throw new InvalidOperationException("Lock already held");
|
||||||
|
+
|
||||||
|
+ var sw = Stopwatch.StartNew();
|
||||||
|
+ do
|
||||||
|
+ {
|
||||||
|
+ try
|
||||||
|
+ {
|
||||||
|
+ // Attempt to acquire lock while holding guard.
|
||||||
|
+ using var guard = LockGuard();
|
||||||
|
+ if (TryLockFile())
|
||||||
|
+ return true;
|
||||||
|
+ }
|
||||||
|
catch (Exception)
|
||||||
|
{
|
||||||
|
- // Something else went wrong.
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+ // See comment in LockGuard.
|
||||||
|
+ Thread.Sleep(1);
|
||||||
|
} while (sw.ElapsedMilliseconds < timeoutMs);
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
- public void Unlock()
|
||||||
|
+ public bool CouldLock()
|
||||||
|
{
|
||||||
|
- if (!IsLocked)
|
||||||
|
- return;
|
||||||
|
- Stream.Unlock(0, 0);
|
||||||
|
- IsLocked = false;
|
||||||
|
+ if (IsDisposed)
|
||||||
|
+ return false;
|
||||||
|
+ if (Stream is not null)
|
||||||
|
+ return false;
|
||||||
|
+
|
||||||
|
+ try
|
||||||
|
+ {
|
||||||
|
+ // Attempt to acquire lock while holding guard, and if successful
|
||||||
|
+ // immediately unlock again while still holding guard. This ensures
|
||||||
|
+ // no other thread will spuriously observe the lock as held due to
|
||||||
|
+ // the lock attempt here.
|
||||||
|
+ using var guard = LockGuard();
|
||||||
|
+ if (TryLockFile())
|
||||||
|
+ {
|
||||||
|
+ UnlockFile();
|
||||||
|
+ return true;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ catch (Exception)
|
||||||
|
+ {
|
||||||
|
+ return false;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Dispose()
|
||||||
|
{
|
||||||
|
- var wasLocked = IsLocked;
|
||||||
|
- if (wasLocked)
|
||||||
|
- Unlock();
|
||||||
|
- Stream.Dispose();
|
||||||
|
- // We do not delete the lock file here because there is no reliable way to perform a
|
||||||
|
- // 'delete if no one has the file open' operation atomically on *nix. This is a leak.
|
||||||
|
+ if (IsDisposed)
|
||||||
|
+ return;
|
||||||
|
+ IsDisposed = true;
|
||||||
|
+ if (Stream is not null)
|
||||||
|
+ {
|
||||||
|
+ try
|
||||||
|
+ {
|
||||||
|
+ UnlockFile();
|
||||||
|
+ }
|
||||||
|
+ catch (Exception)
|
||||||
|
+ {
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -792,56 +903,4 @@ namespace Microsoft.CodeAnalysis.Command
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
-
|
||||||
|
- /// <summary>
|
||||||
|
- /// Approximates a named mutex with 'locked', 'unlocked' and 'abandoned' states.
|
||||||
|
- /// There is no reliable way to detect whether a mutex has been abandoned on some target platforms,
|
||||||
|
- /// so we use the AliveMutex to manually track whether the creator of a mutex is still running,
|
||||||
|
- /// while the HeldMutex represents the actual lock state of the mutex.
|
||||||
|
- /// </summary>
|
||||||
|
- internal sealed class ServerFileMutexPair : IServerMutex
|
||||||
|
- {
|
||||||
|
- public readonly FileMutex AliveMutex;
|
||||||
|
- public readonly FileMutex HeldMutex;
|
||||||
|
-
|
||||||
|
- public bool IsDisposed { get; private set; }
|
||||||
|
-
|
||||||
|
- public ServerFileMutexPair(string mutexName, bool initiallyOwned, out bool createdNew)
|
||||||
|
- {
|
||||||
|
- AliveMutex = new FileMutex(mutexName + "-alive");
|
||||||
|
- HeldMutex = new FileMutex(mutexName + "-held");
|
||||||
|
- createdNew = AliveMutex.TryLock(0);
|
||||||
|
- if (initiallyOwned && createdNew)
|
||||||
|
- {
|
||||||
|
- if (!TryLock(0))
|
||||||
|
- throw new Exception("Failed to lock mutex after creating it");
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- public bool TryLock(int timeoutMs)
|
||||||
|
- {
|
||||||
|
- if (IsDisposed)
|
||||||
|
- throw new ObjectDisposedException("Mutex");
|
||||||
|
- return HeldMutex.TryLock(timeoutMs);
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- public void Dispose()
|
||||||
|
- {
|
||||||
|
- if (IsDisposed)
|
||||||
|
- return;
|
||||||
|
- IsDisposed = true;
|
||||||
|
-
|
||||||
|
- try
|
||||||
|
- {
|
||||||
|
- HeldMutex.Unlock();
|
||||||
|
- AliveMutex.Unlock();
|
||||||
|
- }
|
||||||
|
- finally
|
||||||
|
- {
|
||||||
|
- AliveMutex.Dispose();
|
||||||
|
- HeldMutex.Dispose();
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
}
|
@ -0,0 +1,10 @@
|
|||||||
|
--- a/src/Tools/ReleaseNotesUtil/ReleaseNotesUtil.csproj
|
||||||
|
+++ b/src/Tools/ReleaseNotesUtil/ReleaseNotesUtil.csproj
|
||||||
|
@@ -4,6 +4,7 @@
|
||||||
|
<TargetFramework>netcoreapp3.1</TargetFramework>
|
||||||
|
<NonShipping>true</NonShipping>
|
||||||
|
<ExcludeFromSourceBuild>true</ExcludeFromSourceBuild>
|
||||||
|
+ <UseAppHost>false</UseAppHost>
|
||||||
|
</PropertyGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<PackageReference Include="Microsoft.CodeAnalysis" Version="$(MicrosoftCodeAnalysisVersion)" />
|
@ -0,0 +1,10 @@
|
|||||||
|
--- a/src/Workspaces/Remote/ServiceHub.CoreComponents/Microsoft.CodeAnalysis.Remote.ServiceHub.CoreComponents.csproj
|
||||||
|
+++ b/src/Workspaces/Remote/ServiceHub.CoreComponents/Microsoft.CodeAnalysis.Remote.ServiceHub.CoreComponents.csproj
|
||||||
|
@@ -5,6 +5,7 @@
|
||||||
|
<OutputType>Exe</OutputType>
|
||||||
|
<TargetFramework>netcoreapp3.1</TargetFramework>
|
||||||
|
<!-- The purpose of this project is to include all dependecies of Microsoft.CodeAnalysis.Remote.ServiceHub targeting .Net Core -->
|
||||||
|
+ <UseAppHost>false</UseAppHost>
|
||||||
|
<IsShipping>false</IsShipping>
|
||||||
|
</PropertyGroup>
|
||||||
|
<ItemGroup>
|
@ -0,0 +1,29 @@
|
|||||||
|
diff --git a/src/mono/mono.proj b/src/mono/mono.proj
|
||||||
|
index fb98ffc1896..d6a0c9a8ec2 100644
|
||||||
|
--- a/src/mono/mono.proj
|
||||||
|
+++ b/src/mono/mono.proj
|
||||||
|
@@ -519,17 +519,17 @@
|
||||||
|
<!-- if all else fails in finding a valid objcopy, fall back to no-prefix from $PATH (used for x64 on CentOS) -->
|
||||||
|
<_Objcopy Condition="'$(_ObjcopyFound)' != '0'">objcopy</_Objcopy>
|
||||||
|
</PropertyGroup>
|
||||||
|
- <ItemGroup>
|
||||||
|
+ <ItemGroup Condition="'$(KeepNativeSymbols)' != 'true'">
|
||||||
|
<FilesToStrip Include="$(_MonoRuntimeFilePath)" />
|
||||||
|
<FilesToStrip Include="$([System.IO.Directory]::GetParent($(_MonoRuntimeFilePath)))\libmono-component-*$(SharedLibExt)" />
|
||||||
|
<FilesToStrip Include="$([System.IO.Directory]::GetParent($(_MonoRuntimeFilePath)))\Mono*framework\**\Mono*" Exclude="$([System.IO.Directory]::GetParent($(_MonoRuntimeFilePath)))\Mono*framework\**\*.dwarf" />
|
||||||
|
</ItemGroup>
|
||||||
|
- <Message Condition="'$(BuildMonoAOTCrossCompilerOnly)' != 'true' and ($([MSBuild]::IsOSPlatform('OSX')) or $([MSBuild]::IsOSPlatform('Linux')))" Text="Stripping debug symbols from %(FilesToStrip.Identity)" Importance="High"/>
|
||||||
|
- <Exec Condition="!$([System.String]::Copy(%(FilesToStrip.Identity)).EndsWith('.a')) and '$(BuildMonoAOTCrossCompilerOnly)' != 'true' and ('$(TargetsOSX)' == 'true' or '$(TargetsMacCatalyst)' == 'true' or '$(TargetsiOS)' == 'true' or '$(TargetstvOS)' == 'true')" Command="dsymutil --flat --minimize %(FilesToStrip.Identity)" IgnoreStandardErrorWarningFormat="true" WorkingDirectory="$(MonoObjDir)"/>
|
||||||
|
- <Exec Condition="!$([System.String]::Copy(%(FilesToStrip.Identity)).EndsWith('.a')) and '$(BuildMonoAOTCrossCompilerOnly)' != 'true' and ('$(TargetsOSX)' == 'true' or '$(TargetsMacCatalyst)' == 'true' or '$(TargetsiOS)' == 'true' or '$(TargetstvOS)' == 'true')" Command="strip -no_code_signature_warning -S %(FilesToStrip.Identity)" IgnoreStandardErrorWarningFormat="true" WorkingDirectory="$(MonoObjDir)"/>
|
||||||
|
- <Exec Condition="!$([System.String]::Copy(%(FilesToStrip.Identity)).EndsWith('.a')) and '$(BuildMonoAOTCrossCompilerOnly)' != 'true' and ('$(TargetsLinux)' == 'true' or '$(TargetsAndroid)' == 'true')" Command="$(_Objcopy) --only-keep-debug %(FilesToStrip.Identity) %(FilesToStrip.Identity).dbg" IgnoreStandardErrorWarningFormat="true" WorkingDirectory="$(MonoObjDir)"/>
|
||||||
|
- <Exec Condition="!$([System.String]::Copy(%(FilesToStrip.Identity)).EndsWith('.a')) and '$(BuildMonoAOTCrossCompilerOnly)' != 'true' and ('$(TargetsLinux)' == 'true' or '$(TargetsAndroid)' == 'true')" Command="$(_Objcopy) --strip-unneeded %(FilesToStrip.Identity)" IgnoreStandardErrorWarningFormat="true" WorkingDirectory="$(MonoObjDir)"/>
|
||||||
|
- <Exec Condition="!$([System.String]::Copy(%(FilesToStrip.Identity)).EndsWith('.a')) and '$(BuildMonoAOTCrossCompilerOnly)' != 'true' and ('$(TargetsLinux)' == 'true' or '$(TargetsAndroid)' == 'true')" Command="$(_Objcopy) --add-gnu-debuglink=%(FilesToStrip.Identity).dbg %(FilesToStrip.Identity)" IgnoreStandardErrorWarningFormat="true" WorkingDirectory="$(MonoObjDir)"/>
|
||||||
|
+ <Message Condition="'@(FilesToStrip)' != '' and '$(BuildMonoAOTCrossCompilerOnly)' != 'true' and ($([MSBuild]::IsOSPlatform('OSX')) or $([MSBuild]::IsOSPlatform('Linux')))" Text="Stripping debug symbols from %(FilesToStrip.Identity)" Importance="High"/>
|
||||||
|
+ <Exec Condition="'@(FilesToStrip)' != '' and !$([System.String]::Copy(%(FilesToStrip.Identity)).EndsWith('.a')) and '$(BuildMonoAOTCrossCompilerOnly)' != 'true' and ('$(TargetsOSX)' == 'true' or '$(TargetsMacCatalyst)' == 'true' or '$(TargetsiOS)' == 'true' or '$(TargetstvOS)' == 'true')" Command="dsymutil --flat --minimize %(FilesToStrip.Identity)" IgnoreStandardErrorWarningFormat="true" WorkingDirectory="$(MonoObjDir)"/>
|
||||||
|
+ <Exec Condition="'@(FilesToStrip)' != '' and !$([System.String]::Copy(%(FilesToStrip.Identity)).EndsWith('.a')) and '$(BuildMonoAOTCrossCompilerOnly)' != 'true' and ('$(TargetsOSX)' == 'true' or '$(TargetsMacCatalyst)' == 'true' or '$(TargetsiOS)' == 'true' or '$(TargetstvOS)' == 'true')" Command="strip -no_code_signature_warning -S %(FilesToStrip.Identity)" IgnoreStandardErrorWarningFormat="true" WorkingDirectory="$(MonoObjDir)"/>
|
||||||
|
+ <Exec Condition="'@(FilesToStrip)' != '' and !$([System.String]::Copy(%(FilesToStrip.Identity)).EndsWith('.a')) and '$(BuildMonoAOTCrossCompilerOnly)' != 'true' and ('$(TargetsLinux)' == 'true' or '$(TargetsAndroid)' == 'true')" Command="$(_Objcopy) --only-keep-debug %(FilesToStrip.Identity) %(FilesToStrip.Identity).dbg" IgnoreStandardErrorWarningFormat="true" WorkingDirectory="$(MonoObjDir)"/>
|
||||||
|
+ <Exec Condition="'@(FilesToStrip)' != '' and !$([System.String]::Copy(%(FilesToStrip.Identity)).EndsWith('.a')) and '$(BuildMonoAOTCrossCompilerOnly)' != 'true' and ('$(TargetsLinux)' == 'true' or '$(TargetsAndroid)' == 'true')" Command="$(_Objcopy) --strip-unneeded %(FilesToStrip.Identity)" IgnoreStandardErrorWarningFormat="true" WorkingDirectory="$(MonoObjDir)"/>
|
||||||
|
+ <Exec Condition="'@(FilesToStrip)' != '' and !$([System.String]::Copy(%(FilesToStrip.Identity)).EndsWith('.a')) and '$(BuildMonoAOTCrossCompilerOnly)' != 'true' and ('$(TargetsLinux)' == 'true' or '$(TargetsAndroid)' == 'true')" Command="$(_Objcopy) --add-gnu-debuglink=%(FilesToStrip.Identity).dbg %(FilesToStrip.Identity)" IgnoreStandardErrorWarningFormat="true" WorkingDirectory="$(MonoObjDir)"/>
|
||||||
|
</Target>
|
||||||
|
|
||||||
|
<!-- Build AOT cross compiler (if available) -->
|
@ -0,0 +1,18 @@
|
|||||||
|
diff --git a/eng/native/init-compiler.sh b/eng/native/init-compiler.sh
|
||||||
|
index 567d18da474..927b3071e92 100755
|
||||||
|
--- a/eng/native/init-compiler.sh
|
||||||
|
+++ b/eng/native/init-compiler.sh
|
||||||
|
@@ -108,11 +108,8 @@
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "$compiler" == "clang" ]]; then
|
||||||
|
- if command -v "lld$desired_version" > /dev/null; then
|
||||||
|
- # Only lld version >= 9 can be considered stable
|
||||||
|
- if [[ "$majorVersion" -ge 9 ]]; then
|
||||||
|
- LDFLAGS="-fuse-ld=lld"
|
||||||
|
- fi
|
||||||
|
+ if "$CC" -fuse-ld=lld -Wl,--version >/dev/null 2>&1; then
|
||||||
|
+ LDFLAGS="-fuse-ld=lld"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
@ -0,0 +1,33 @@
|
|||||||
|
diff --git a/src/mono/nuget/Microsoft.NET.Runtime.MonoTargets.Sdk/Microsoft.NET.Runtime.MonoTargets.Sdk.pkgproj b/src/mono/nuget/Microsoft.NET.Runtime.MonoTargets.Sdk/Microsoft.NET.Runtime.MonoTargets.Sdk.pkgproj
|
||||||
|
index 724b704f864..3dabdc81dae 100644
|
||||||
|
--- a/src/mono/nuget/Microsoft.NET.Runtime.MonoTargets.Sdk/Microsoft.NET.Runtime.MonoTargets.Sdk.pkgproj
|
||||||
|
+++ b/src/mono/nuget/Microsoft.NET.Runtime.MonoTargets.Sdk/Microsoft.NET.Runtime.MonoTargets.Sdk.pkgproj
|
||||||
|
@@ -6,7 +6,7 @@
|
||||||
|
</PropertyGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
- <ProjectReference Include="$(RepoTasksDir)ILStripTask\ILStrip.csproj" />
|
||||||
|
+ <ProjectReference Include="$(RepoTasksDir)ILStripTask\ILStrip.csproj" Condition="'$(DotNetBuildFromSource)' != 'true'" />
|
||||||
|
<ProjectReference Include="$(RepoTasksDir)RuntimeConfigParser\RuntimeConfigParser.csproj" />
|
||||||
|
<ProjectReference Include="$(RepoTasksDir)JsonToItemsTaskFactory\JsonToItemsTaskFactory.csproj" />
|
||||||
|
</ItemGroup>
|
||||||
|
@@ -15,7 +15,7 @@
|
||||||
|
<PackageFile Include="Sdk\Sdk.props" TargetPath="Sdk" />
|
||||||
|
<PackageFile Include="Sdk\Sdk.targets" TargetPath="Sdk" />
|
||||||
|
<PackageFile Include="build\$(MSBuildProjectName).props" TargetPath="build" />
|
||||||
|
- <PackageFile Include="Sdk\ILStripTask.props" TargetPath="Sdk" />
|
||||||
|
+ <PackageFile Include="Sdk\ILStripTask.props" TargetPath="Sdk" Condition="'$(DotNetBuildFromSource)' != 'true'" />
|
||||||
|
<PackageFile Include="Sdk\RuntimeConfigParserTask.props" TargetPath="Sdk" />
|
||||||
|
<PackageFile Include="Sdk\RuntimeComponentManifest.props" TargetPath="Sdk" />
|
||||||
|
<PackageFile Include="Sdk\RuntimeComponentManifest.targets" TargetPath="Sdk" />
|
||||||
|
diff --git a/src/mono/nuget/Microsoft.NET.Runtime.MonoTargets.Sdk/Sdk/Sdk.props b/src/mono/nuget/Microsoft.NET.Runtime.MonoTargets.Sdk/Sdk/Sdk.props
|
||||||
|
index 8a7ede79242..cfd515eeca9 100644
|
||||||
|
--- a/src/mono/nuget/Microsoft.NET.Runtime.MonoTargets.Sdk/Sdk/Sdk.props
|
||||||
|
+++ b/src/mono/nuget/Microsoft.NET.Runtime.MonoTargets.Sdk/Sdk/Sdk.props
|
||||||
|
@@ -1,5 +1,5 @@
|
||||||
|
<Project>
|
||||||
|
- <Import Project="$(MSBuildThisFileDirectory)\ILStripTask.props" />
|
||||||
|
+ <Import Project="$(MSBuildThisFileDirectory)\ILStripTask.props" Condition="'$(DotNetBuildFromSource)' != 'true'" />
|
||||||
|
<Import Project="$(MSBuildThisFileDirectory)\RuntimeConfigParserTask.props" />
|
||||||
|
<Import Project="$(MSBuildThisFileDirectory)\RuntimeComponentManifest.props" />
|
||||||
|
</Project>
|
@ -0,0 +1,22 @@
|
|||||||
|
From 499fcf6e3b0e4b01a9c340a06f00cfc3e1fcc5d2 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Tom Deseyn <tom.deseyn@gmail.com>
|
||||||
|
Date: Tue, 5 Oct 2021 09:04:14 +0200
|
||||||
|
Subject: [PATCH] Use the portable rid for --use-current-runtime.
|
||||||
|
|
||||||
|
---
|
||||||
|
.../targets/Microsoft.NET.RuntimeIdentifierInference.targets | 2 +-
|
||||||
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/src/Tasks/Microsoft.NET.Build.Tasks/targets/Microsoft.NET.RuntimeIdentifierInference.targets b/src/Tasks/Microsoft.NET.Build.Tasks/targets/Microsoft.NET.RuntimeIdentifierInference.targets
|
||||||
|
index 17308aa9160..e764b2d9845 100644
|
||||||
|
--- a/src/Tasks/Microsoft.NET.Build.Tasks/targets/Microsoft.NET.RuntimeIdentifierInference.targets
|
||||||
|
+++ b/src/Tasks/Microsoft.NET.Build.Tasks/targets/Microsoft.NET.RuntimeIdentifierInference.targets
|
||||||
|
@@ -62,7 +62,7 @@ Copyright (c) .NET Foundation. All rights reserved.
|
||||||
|
</PropertyGroup>
|
||||||
|
|
||||||
|
<PropertyGroup Condition="'$(UseCurrentRuntimeIdentifier)' == 'true'">
|
||||||
|
- <RuntimeIdentifier>$(NETCoreSdkRuntimeIdentifier)</RuntimeIdentifier>
|
||||||
|
+ <RuntimeIdentifier>$(NETCoreSdkPortableRuntimeIdentifier)</RuntimeIdentifier>
|
||||||
|
</PropertyGroup>
|
||||||
|
|
||||||
|
<PropertyGroup Condition="'$(PlatformTarget)' == ''">
|
@ -0,0 +1,18 @@
|
|||||||
|
diff --git a/src/Cli/dotnet/Program.cs b/src/Cli/dotnet/Program.cs
|
||||||
|
index de1ebb9e6..6bbf479de 100644
|
||||||
|
--- a/src/Cli/dotnet/Program.cs
|
||||||
|
+++ b/src/Cli/dotnet/Program.cs
|
||||||
|
@@ -28,6 +28,13 @@ public class Program
|
||||||
|
|
||||||
|
public static int Main(string[] args)
|
||||||
|
{
|
||||||
|
+ // opt out of telemetry by default if the env var is unset
|
||||||
|
+ string telemetryValue = Environment.GetEnvironmentVariable("DOTNET_CLI_TELEMETRY_OPTOUT");
|
||||||
|
+ if (String.IsNullOrEmpty(telemetryValue))
|
||||||
|
+ {
|
||||||
|
+ Environment.SetEnvironmentVariable("DOTNET_CLI_TELEMETRY_OPTOUT", "1");
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
DebugHelper.HandleDebugSwitch(ref args);
|
||||||
|
|
||||||
|
// Capture the current timestamp to calculate the host overhead.
|
@ -0,0 +1,956 @@
|
|||||||
|
%bcond_with bootstrap
|
||||||
|
|
||||||
|
# Avoid provides/requires from private libraries
|
||||||
|
%global privlibs libhostfxr
|
||||||
|
%global privlibs %{privlibs}|libclrjit
|
||||||
|
%global privlibs %{privlibs}|libcoreclr
|
||||||
|
%global privlibs %{privlibs}|libcoreclrtraceptprovider
|
||||||
|
%global privlibs %{privlibs}|libdbgshim
|
||||||
|
%global privlibs %{privlibs}|libhostpolicy
|
||||||
|
%global privlibs %{privlibs}|libmscordaccore
|
||||||
|
%global privlibs %{privlibs}|libmscordbi
|
||||||
|
%global privlibs %{privlibs}|libsos
|
||||||
|
%global privlibs %{privlibs}|libsosplugin
|
||||||
|
%global __provides_exclude ^(%{privlibs})\\.so
|
||||||
|
%global __requires_exclude ^(%{privlibs})\\.so
|
||||||
|
|
||||||
|
# LTO triggers a compilation error for a source level issue. Given that LTO should not
|
||||||
|
# change the validity of any given source and the nature of the error (undefined enum), I
|
||||||
|
# suspect a generator program is mis-behaving in some way. This needs further debugging,
|
||||||
|
# until that's done, disable LTO. This has to happen before setting the flags below.
|
||||||
|
%define _lto_cflags %{nil}
|
||||||
|
|
||||||
|
%global host_version 6.0.9
|
||||||
|
%global runtime_version 6.0.9
|
||||||
|
%global aspnetcore_runtime_version %{runtime_version}
|
||||||
|
%global sdk_version 6.0.109
|
||||||
|
%global sdk_feature_band_version %(echo %{sdk_version} | sed -e 's|[[:digit:]][[:digit:]]$|00|')
|
||||||
|
%global templates_version %{runtime_version}
|
||||||
|
#%%global templates_version %%(echo %%{runtime_version} | awk 'BEGIN { FS="."; OFS="." } {print $1, $2, $3+1 }')
|
||||||
|
|
||||||
|
%global host_rpm_version %{host_version}
|
||||||
|
%global runtime_rpm_version %{runtime_version}
|
||||||
|
%global aspnetcore_runtime_rpm_version %{aspnetcore_runtime_version}
|
||||||
|
%global sdk_rpm_version %{sdk_version}
|
||||||
|
|
||||||
|
# upstream can update releases without revving the SDK version so these don't always match
|
||||||
|
%global upstream_tag v%{sdk_version}
|
||||||
|
|
||||||
|
%if 0%{?fedora} || 0%{?rhel} < 8
|
||||||
|
%global use_bundled_libunwind 0
|
||||||
|
%else
|
||||||
|
%global use_bundled_libunwind 1
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%ifarch aarch64 s390x
|
||||||
|
%global use_bundled_libunwind 1
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%ifarch x86_64
|
||||||
|
%global runtime_arch x64
|
||||||
|
%endif
|
||||||
|
%ifarch aarch64
|
||||||
|
%global runtime_arch arm64
|
||||||
|
%endif
|
||||||
|
%ifarch s390x
|
||||||
|
%global runtime_arch s390x
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%{!?runtime_id:%global runtime_id %(. /etc/os-release ; echo "${ID}.${VERSION_ID%%.*}")-%{runtime_arch}}
|
||||||
|
|
||||||
|
Name: dotnet6.0
|
||||||
|
Version: %{sdk_rpm_version}
|
||||||
|
Release: 3%{?dist}
|
||||||
|
Summary: .NET Runtime and SDK
|
||||||
|
License: MIT and ASL 2.0 and BSD and LGPLv2+ and CC-BY and CC0 and MS-PL and EPL-1.0 and GPL+ and GPLv2 and ISC and OFL and zlib
|
||||||
|
URL: https://github.com/dotnet/
|
||||||
|
|
||||||
|
%if %{with bootstrap}
|
||||||
|
# The source is generated on a RHEL box via:
|
||||||
|
# ./build-dotnet-tarball --bootstrap %%{upstream_tag}
|
||||||
|
Source0: dotnet-%{upstream_tag}-x64-bootstrap.tar.xz
|
||||||
|
# Generated via ./build-arm64-bootstrap-tarball
|
||||||
|
Source1: dotnet-arm64-prebuilts-2021-10-29.tar.gz
|
||||||
|
# Generated manually, same pattern as the arm64 tarball
|
||||||
|
Source2: dotnet-s390x-prebuilts-2021-10-29.tar.gz
|
||||||
|
%else
|
||||||
|
# The source is generated on a RHEL box via:
|
||||||
|
# ./build-dotnet-tarball %%{upstream_tag}
|
||||||
|
Source0: dotnet-%{upstream_tag}.tar.gz
|
||||||
|
%endif
|
||||||
|
|
||||||
|
Source10: check-debug-symbols.py
|
||||||
|
Source11: dotnet.sh.in
|
||||||
|
|
||||||
|
# Fix using lld on RHEL
|
||||||
|
Patch100: runtime-arm64-lld-fix.patch
|
||||||
|
# Mono still has a dependency on (now unbuildable) ILStrip which was removed from CoreCLR: https://github.com/dotnet/runtime/pull/60315
|
||||||
|
Patch101: runtime-mono-remove-ilstrip.patch
|
||||||
|
# https://github.com/dotnet/runtime/pull/66594
|
||||||
|
Patch102: runtime-66594-s390x-debuginfo.patch
|
||||||
|
|
||||||
|
# Disable apphost, needed for s390x
|
||||||
|
Patch500: fsharp-no-apphost.patch
|
||||||
|
|
||||||
|
# Disable apphost, needed for s390x
|
||||||
|
Patch700: arcade-no-apphost.patch
|
||||||
|
|
||||||
|
# Named mutex fix for mono, needed for s390x. https://github.com/dotnet/roslyn/pull/57003
|
||||||
|
Patch800: roslyn-57003-mono-named-mutex.patch
|
||||||
|
# Disable apphost, needed for s390x
|
||||||
|
Patch801: roslyn-no-apphost.patch
|
||||||
|
|
||||||
|
# Disable apphost, needed for s390x
|
||||||
|
Patch900: roslyn-analyzers-no-apphost.patch
|
||||||
|
|
||||||
|
# Fix mono-specific runtime crashes running msbuild. CoreCLR does not
|
||||||
|
# load types that are not actually used/invoked at runtime, while mono
|
||||||
|
# does. System.Configuration and System.Security are missing in
|
||||||
|
# source-build builds, which breaks msbuild.
|
||||||
|
Patch1000: msbuild-no-systemsecurity.patch
|
||||||
|
Patch1001: msbuild-no-systemconfiguration.patch
|
||||||
|
|
||||||
|
# Disable telemetry by default; make it opt-in
|
||||||
|
Patch1500: sdk-telemetry-optout.patch
|
||||||
|
# https://github.com/dotnet/sdk/pull/22373
|
||||||
|
Patch1501: sdk-22373-portablerid.patch
|
||||||
|
|
||||||
|
# https://github.com/dotnet/installer/pull/12516
|
||||||
|
Patch1600: installer-12516-portablerid.patch
|
||||||
|
|
||||||
|
|
||||||
|
%if 0%{?fedora} || 0%{?rhel} >= 8
|
||||||
|
ExclusiveArch: aarch64 x86_64 s390x
|
||||||
|
%else
|
||||||
|
ExclusiveArch: x86_64
|
||||||
|
%endif
|
||||||
|
|
||||||
|
|
||||||
|
BuildRequires: clang
|
||||||
|
BuildRequires: cmake
|
||||||
|
BuildRequires: coreutils
|
||||||
|
%if %{without bootstrap}
|
||||||
|
BuildRequires: dotnet-sdk-6.0
|
||||||
|
BuildRequires: dotnet-sdk-6.0-source-built-artifacts
|
||||||
|
%endif
|
||||||
|
BuildRequires: findutils
|
||||||
|
BuildRequires: git
|
||||||
|
%if 0%{?fedora} || 0%{?rhel} > 7
|
||||||
|
BuildRequires: glibc-langpack-en
|
||||||
|
%endif
|
||||||
|
BuildRequires: hostname
|
||||||
|
BuildRequires: krb5-devel
|
||||||
|
BuildRequires: libicu-devel
|
||||||
|
%if ! %{use_bundled_libunwind}
|
||||||
|
BuildRequires: libunwind-devel
|
||||||
|
%endif
|
||||||
|
%ifarch aarch64
|
||||||
|
BuildRequires: lld
|
||||||
|
%endif
|
||||||
|
BuildRequires: llvm
|
||||||
|
BuildRequires: lttng-ust-devel
|
||||||
|
BuildRequires: make
|
||||||
|
BuildRequires: openssl-devel
|
||||||
|
BuildRequires: python3
|
||||||
|
BuildRequires: tar
|
||||||
|
BuildRequires: util-linux
|
||||||
|
BuildRequires: zlib-devel
|
||||||
|
|
||||||
|
%description
|
||||||
|
.NET is a fast, lightweight and modular platform for creating
|
||||||
|
cross platform applications that work on Linux, macOS and Windows.
|
||||||
|
|
||||||
|
It particularly focuses on creating console applications, web
|
||||||
|
applications and micro-services.
|
||||||
|
|
||||||
|
.NET contains a runtime conforming to .NET Standards a set of
|
||||||
|
framework libraries, an SDK containing compilers and a 'dotnet'
|
||||||
|
application to drive everything.
|
||||||
|
|
||||||
|
|
||||||
|
%package -n dotnet-host
|
||||||
|
|
||||||
|
Version: %{host_rpm_version}
|
||||||
|
Summary: .NET command line launcher
|
||||||
|
|
||||||
|
%description -n dotnet-host
|
||||||
|
The .NET host is a command line program that runs a standalone
|
||||||
|
.NET application or launches the SDK.
|
||||||
|
|
||||||
|
.NET is a fast, lightweight and modular platform for creating
|
||||||
|
cross platform applications that work on Linux, Mac and Windows.
|
||||||
|
|
||||||
|
It particularly focuses on creating console applications, web
|
||||||
|
applications and micro-services.
|
||||||
|
|
||||||
|
|
||||||
|
%package -n dotnet-hostfxr-6.0
|
||||||
|
|
||||||
|
Version: %{host_rpm_version}
|
||||||
|
Summary: .NET command line host resolver
|
||||||
|
|
||||||
|
# Theoretically any version of the host should work. But lets aim for the one
|
||||||
|
# provided by this package, or from a newer version of .NET
|
||||||
|
Requires: dotnet-host%{?_isa} >= %{host_rpm_version}-%{release}
|
||||||
|
|
||||||
|
%description -n dotnet-hostfxr-6.0
|
||||||
|
The .NET host resolver contains the logic to resolve and select
|
||||||
|
the right version of the .NET SDK or runtime to use.
|
||||||
|
|
||||||
|
.NET is a fast, lightweight and modular platform for creating
|
||||||
|
cross platform applications that work on Linux, Mac and Windows.
|
||||||
|
|
||||||
|
It particularly focuses on creating console applications, web
|
||||||
|
applications and micro-services.
|
||||||
|
|
||||||
|
|
||||||
|
%package -n dotnet-runtime-6.0
|
||||||
|
|
||||||
|
Version: %{runtime_rpm_version}
|
||||||
|
Summary: NET 6.0 runtime
|
||||||
|
|
||||||
|
Requires: dotnet-hostfxr-6.0%{?_isa} >= %{host_rpm_version}-%{release}
|
||||||
|
|
||||||
|
# libicu is dlopen()ed
|
||||||
|
Requires: libicu%{?_isa}
|
||||||
|
|
||||||
|
# See src/runtime/src/libraries/Native/AnyOS/brotli-version.txt
|
||||||
|
Provides: bundled(libbrotli) = 1.0.9
|
||||||
|
%if %{use_bundled_libunwind}
|
||||||
|
# See src/runtime/src/coreclr/pal/src/libunwind/libunwind-version.txt
|
||||||
|
Provides: bundled(libunwind) = 1.5.rc1.28.g9165d2a1
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%description -n dotnet-runtime-6.0
|
||||||
|
The .NET runtime contains everything needed to run .NET applications.
|
||||||
|
It includes a high performance Virtual Machine as well as the framework
|
||||||
|
libraries used by .NET applications.
|
||||||
|
|
||||||
|
.NET is a fast, lightweight and modular platform for creating
|
||||||
|
cross platform applications that work on Linux, Mac and Windows.
|
||||||
|
|
||||||
|
It particularly focuses on creating console applications, web
|
||||||
|
applications and micro-services.
|
||||||
|
|
||||||
|
|
||||||
|
%package -n aspnetcore-runtime-6.0
|
||||||
|
|
||||||
|
Version: %{aspnetcore_runtime_rpm_version}
|
||||||
|
Summary: ASP.NET Core 6.0 runtime
|
||||||
|
|
||||||
|
Requires: dotnet-runtime-6.0%{?_isa} >= %{runtime_rpm_version}-%{release}
|
||||||
|
|
||||||
|
%description -n aspnetcore-runtime-6.0
|
||||||
|
The ASP.NET Core runtime contains everything needed to run .NET
|
||||||
|
web applications. It includes a high performance Virtual Machine as
|
||||||
|
well as the framework libraries used by .NET applications.
|
||||||
|
|
||||||
|
ASP.NET Core is a fast, lightweight and modular platform for creating
|
||||||
|
cross platform web applications that work on Linux, Mac and Windows.
|
||||||
|
|
||||||
|
It particularly focuses on creating console applications, web
|
||||||
|
applications and micro-services.
|
||||||
|
|
||||||
|
|
||||||
|
%package -n dotnet-templates-6.0
|
||||||
|
|
||||||
|
Version: %{sdk_rpm_version}
|
||||||
|
Summary: .NET 6.0 templates
|
||||||
|
|
||||||
|
# Theoretically any version of the host should work. But lets aim for the one
|
||||||
|
# provided by this package, or from a newer version of .NET
|
||||||
|
Requires: dotnet-host%{?_isa} >= %{host_rpm_version}-%{release}
|
||||||
|
|
||||||
|
%description -n dotnet-templates-6.0
|
||||||
|
This package contains templates used by the .NET SDK.
|
||||||
|
|
||||||
|
.NET is a fast, lightweight and modular platform for creating
|
||||||
|
cross platform applications that work on Linux, Mac and Windows.
|
||||||
|
|
||||||
|
It particularly focuses on creating console applications, web
|
||||||
|
applications and micro-services.
|
||||||
|
|
||||||
|
|
||||||
|
%package -n dotnet-sdk-6.0
|
||||||
|
|
||||||
|
Version: %{sdk_rpm_version}
|
||||||
|
Summary: .NET 6.0 Software Development Kit
|
||||||
|
|
||||||
|
Provides: bundled(js-jquery)
|
||||||
|
|
||||||
|
Requires: dotnet-runtime-6.0%{?_isa} >= %{runtime_rpm_version}-%{release}
|
||||||
|
Requires: aspnetcore-runtime-6.0%{?_isa} >= %{aspnetcore_runtime_rpm_version}-%{release}
|
||||||
|
|
||||||
|
Requires: dotnet-apphost-pack-6.0%{?_isa} >= %{runtime_rpm_version}-%{release}
|
||||||
|
Requires: dotnet-targeting-pack-6.0%{?_isa} >= %{runtime_rpm_version}-%{release}
|
||||||
|
Requires: aspnetcore-targeting-pack-6.0%{?_isa} >= %{aspnetcore_runtime_rpm_version}-%{release}
|
||||||
|
Requires: netstandard-targeting-pack-2.1%{?_isa} >= %{sdk_rpm_version}-%{release}
|
||||||
|
|
||||||
|
Requires: dotnet-templates-6.0%{?_isa} >= %{sdk_rpm_version}-%{release}
|
||||||
|
|
||||||
|
%description -n dotnet-sdk-6.0
|
||||||
|
The .NET SDK is a collection of command line applications to
|
||||||
|
create, build, publish and run .NET applications.
|
||||||
|
|
||||||
|
.NET is a fast, lightweight and modular platform for creating
|
||||||
|
cross platform applications that work on Linux, Mac and Windows.
|
||||||
|
|
||||||
|
It particularly focuses on creating console applications, web
|
||||||
|
applications and micro-services.
|
||||||
|
|
||||||
|
|
||||||
|
%global dotnet_targeting_pack() %{expand:
|
||||||
|
%package -n %{1}
|
||||||
|
|
||||||
|
Version: %{2}
|
||||||
|
Summary: Targeting Pack for %{3} %{4}
|
||||||
|
|
||||||
|
Requires: dotnet-host%{?_isa}
|
||||||
|
|
||||||
|
%description -n %{1}
|
||||||
|
This package provides a targeting pack for %{3} %{4}
|
||||||
|
that allows developers to compile against and target %{3} %{4}
|
||||||
|
applications using the .NET SDK.
|
||||||
|
|
||||||
|
%files -n %{1}
|
||||||
|
%dir %{_libdir}/dotnet/packs
|
||||||
|
%{_libdir}/dotnet/packs/%{5}
|
||||||
|
}
|
||||||
|
|
||||||
|
%dotnet_targeting_pack dotnet-apphost-pack-6.0 %{runtime_rpm_version} Microsoft.NETCore.App 6.0 Microsoft.NETCore.App.Host.%{runtime_id}
|
||||||
|
%dotnet_targeting_pack dotnet-targeting-pack-6.0 %{runtime_rpm_version} Microsoft.NETCore.App 6.0 Microsoft.NETCore.App.Ref
|
||||||
|
%dotnet_targeting_pack aspnetcore-targeting-pack-6.0 %{aspnetcore_runtime_rpm_version} Microsoft.AspNetCore.App 6.0 Microsoft.AspNetCore.App.Ref
|
||||||
|
#%%dotnet_targeting_pack netstandard-targeting-pack-2.1 %%{sdk_rpm_version} NETStandard.Library 2.1 NETStandard.Library.Ref
|
||||||
|
|
||||||
|
|
||||||
|
%package -n dotnet-sdk-6.0-source-built-artifacts
|
||||||
|
|
||||||
|
Version: %{sdk_rpm_version}
|
||||||
|
Summary: Internal package for building .NET 6.0 Software Development Kit
|
||||||
|
|
||||||
|
%description -n dotnet-sdk-6.0-source-built-artifacts
|
||||||
|
The .NET source-built archive is a collection of packages needed
|
||||||
|
to build the .NET SDK itself.
|
||||||
|
|
||||||
|
These are not meant for general use.
|
||||||
|
|
||||||
|
|
||||||
|
%prep
|
||||||
|
%if %{without bootstrap}
|
||||||
|
%setup -q -n dotnet-%{upstream_tag}
|
||||||
|
%else
|
||||||
|
|
||||||
|
%setup -q -T -b 0 -n dotnet-%{upstream_tag}-x64-bootstrap
|
||||||
|
|
||||||
|
%ifnarch x86_64
|
||||||
|
|
||||||
|
rm -rf .dotnet
|
||||||
|
%ifarch aarch64
|
||||||
|
tar -x --strip-components=1 -f %{SOURCE1} -C packages/prebuilt
|
||||||
|
%endif
|
||||||
|
%ifarch s390x
|
||||||
|
tar -x --strip-components=1 -f %{SOURCE2} -C packages/prebuilt
|
||||||
|
%endif
|
||||||
|
mkdir -p .dotnet
|
||||||
|
tar xf packages/prebuilt/dotnet-sdk*.tar.gz -C .dotnet/
|
||||||
|
rm packages/prebuilt/dotnet-sdk*.tar.gz
|
||||||
|
boot_sdk_version=$(ls -1 .dotnet/sdk/)
|
||||||
|
sed -i -E 's|"dotnet": "[^"]+"|"dotnet" : "'$boot_sdk_version'"|' global.json
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%if %{without bootstrap}
|
||||||
|
# Remove all prebuilts
|
||||||
|
find -iname '*.dll' -type f -delete
|
||||||
|
find -iname '*.so' -type f -delete
|
||||||
|
find -iname '*.tar.gz' -type f -delete
|
||||||
|
find -iname '*.nupkg' -type f -delete
|
||||||
|
find -iname '*.zip' -type f -delete
|
||||||
|
rm -rf .dotnet/
|
||||||
|
rm -rf packages/source-built
|
||||||
|
|
||||||
|
mkdir -p packages/archive
|
||||||
|
ln -s %{_libdir}/dotnet/source-built-artifacts/Private.SourceBuilt.Artifacts.*.tar.gz packages/archive/
|
||||||
|
ln -s %{_libdir}/dotnet/reference-packages/Private.SourceBuild.ReferencePackages*.tar.gz packages/archive/
|
||||||
|
%endif
|
||||||
|
|
||||||
|
# Fix bad hardcoded path in build
|
||||||
|
sed -i 's|/usr/share/dotnet|%{_libdir}/dotnet|' src/runtime/src/native/corehost/hostmisc/pal.unix.cpp
|
||||||
|
|
||||||
|
pushd src/runtime
|
||||||
|
%patch100 -p1
|
||||||
|
%patch101 -p1
|
||||||
|
%patch102 -p1
|
||||||
|
popd
|
||||||
|
|
||||||
|
pushd src/fsharp
|
||||||
|
%patch500 -p1
|
||||||
|
popd
|
||||||
|
|
||||||
|
pushd src/arcade
|
||||||
|
%patch700 -p1
|
||||||
|
popd
|
||||||
|
|
||||||
|
pushd src/roslyn
|
||||||
|
%patch800 -p3
|
||||||
|
%patch801 -p1
|
||||||
|
popd
|
||||||
|
|
||||||
|
pushd src/roslyn-analyzers
|
||||||
|
%patch900 -p1
|
||||||
|
popd
|
||||||
|
|
||||||
|
pushd src/msbuild
|
||||||
|
|
||||||
|
# These are mono-specific fixes. Mono is only used on s390x. Restrict
|
||||||
|
# patch to s390x to avoid potential risk in other architectures.
|
||||||
|
%ifarch s390x
|
||||||
|
%patch1000 -p1
|
||||||
|
%patch1001 -p1
|
||||||
|
%endif
|
||||||
|
|
||||||
|
popd
|
||||||
|
|
||||||
|
pushd src/sdk
|
||||||
|
%patch1500 -p1
|
||||||
|
%patch1501 -p1
|
||||||
|
popd
|
||||||
|
|
||||||
|
pushd src/installer
|
||||||
|
%patch1600 -p1
|
||||||
|
popd
|
||||||
|
|
||||||
|
%if ! %{use_bundled_libunwind}
|
||||||
|
sed -i -E 's|( /p:BuildDebPackage=false)|\1 --cmakeargs -DCLR_CMAKE_USE_SYSTEM_LIBUNWIND=TRUE|' src/runtime/eng/SourceBuild.props
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%build
|
||||||
|
cat /etc/os-release
|
||||||
|
|
||||||
|
%if %{without bootstrap}
|
||||||
|
# We need to create a copy because we will mutate this
|
||||||
|
cp -a %{_libdir}/dotnet previously-built-dotnet
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%if 0%{?fedora} > 32 || 0%{?rhel} > 8
|
||||||
|
# Setting this macro ensures that only clang supported options will be
|
||||||
|
# added to ldflags and cflags.
|
||||||
|
%global toolchain clang
|
||||||
|
%set_build_flags
|
||||||
|
%else
|
||||||
|
# Filter flags not supported by clang
|
||||||
|
%global dotnet_cflags %(echo %optflags | sed -re 's/-specs=[^ ]*//g')
|
||||||
|
%global dotnet_ldflags %(echo %{__global_ldflags} | sed -re 's/-specs=[^ ]*//g')
|
||||||
|
export CFLAGS="%{dotnet_cflags}"
|
||||||
|
export CXXFLAGS="%{dotnet_cflags}"
|
||||||
|
export LDFLAGS="%{dotnet_ldflags}"
|
||||||
|
%endif
|
||||||
|
|
||||||
|
# -fstack-clash-protection breaks CoreCLR
|
||||||
|
CFLAGS=$(echo $CFLAGS | sed -e 's/-fstack-clash-protection//' )
|
||||||
|
CXXFLAGS=$(echo $CXXFLAGS | sed -e 's/-fstack-clash-protection//' )
|
||||||
|
|
||||||
|
%ifarch aarch64
|
||||||
|
# -mbranch-protection=standard breaks unwinding in CoreCLR through libunwind
|
||||||
|
CFLAGS=$(echo $CFLAGS | sed -e 's/-mbranch-protection=standard //')
|
||||||
|
CXXFLAGS=$(echo $CXXFLAGS | sed -e 's/-mbranch-protection=standard //')
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%ifarch s390x
|
||||||
|
# -march=z13 -mtune=z14 makes clang crash while compiling .NET
|
||||||
|
CFLAGS=$(echo $CFLAGS | sed -e 's/ -march=z13//')
|
||||||
|
CFLAGS=$(echo $CFLAGS | sed -e 's/ -mtune=z14//')
|
||||||
|
CXXFLAGS=$(echo $CXXFLAGS | sed -e 's/ -march=z13//')
|
||||||
|
CXXFLAGS=$(echo $CXXFLAGS | sed -e 's/ -mtune=z14//')
|
||||||
|
%endif
|
||||||
|
|
||||||
|
export EXTRA_CFLAGS="$CFLAGS"
|
||||||
|
export EXTRA_CXXFLAGS="$CXXFLAGS"
|
||||||
|
export EXTRA_LDFLAGS="$LDFLAGS"
|
||||||
|
|
||||||
|
# Disable tracing, which is incompatible with certain versions of
|
||||||
|
# lttng See https://github.com/dotnet/runtime/issues/57784. The
|
||||||
|
# suggested compile-time change doesn't work, unfrotunately.
|
||||||
|
export COMPlus_LTTng=0
|
||||||
|
|
||||||
|
%if 0%{?rhel} > 8
|
||||||
|
# OpenSSL 3.0 in RHEL 9 has disabled SHA1, used by .NET for strong
|
||||||
|
# name signing. See https://github.com/dotnet/runtime/issues/67304
|
||||||
|
# https://gitlab.com/redhat/centos-stream/rpms/openssl/-/commit/78fb78d30755ae18fdaef28ef392f4e67c662ff6
|
||||||
|
export OPENSSL_ENABLE_SHA1_SIGNATURES=1
|
||||||
|
%endif
|
||||||
|
|
||||||
|
CheckEolTargetFramework=false VERBOSE=1 ./build.sh \
|
||||||
|
%if %{without bootstrap}
|
||||||
|
--with-sdk previously-built-dotnet \
|
||||||
|
%endif
|
||||||
|
-- \
|
||||||
|
|
||||||
|
echo \
|
||||||
|
/v:n \
|
||||||
|
/p:SkipPortableRuntimeBuild=true \
|
||||||
|
/p:LogVerbosity=n \
|
||||||
|
/p:MinimalConsoleLogOutput=false \
|
||||||
|
/p:ContinueOnPrebuiltBaselineError=true \
|
||||||
|
|
||||||
|
|
||||||
|
sed -e 's|[@]LIBDIR[@]|%{_libdir}|g' %{SOURCE11} > dotnet.sh
|
||||||
|
|
||||||
|
|
||||||
|
%install
|
||||||
|
install -dm 0755 %{buildroot}%{_libdir}/dotnet
|
||||||
|
ls artifacts/%{runtime_arch}/Release
|
||||||
|
tar xf artifacts/%{runtime_arch}/Release/dotnet-sdk-%{sdk_version}-%{runtime_id}.tar.gz -C %{buildroot}%{_libdir}/dotnet/
|
||||||
|
|
||||||
|
# See https://github.com/dotnet/source-build/issues/2579
|
||||||
|
find %{buildroot}%{_libdir}/dotnet/ -type f -name 'testhost.x86' -delete
|
||||||
|
find %{buildroot}%{_libdir}/dotnet/ -type f -name 'vstest.console' -delete
|
||||||
|
|
||||||
|
# Install managed symbols: disabled because they don't contain sources
|
||||||
|
# but point to the paths the sources would have been at in the build
|
||||||
|
# servers. The end user experience is pretty bad atm.
|
||||||
|
# tar xf artifacts/%%{runtime_arch}/Release/runtime/dotnet-runtime-symbols-%%{runtime_id}-%%{runtime_version}.tar.gz \
|
||||||
|
# -C %%{buildroot}/%%{_libdir}/dotnet/shared/Microsoft.NETCore.App/%%{runtime_version}/
|
||||||
|
|
||||||
|
# Fix executable permissions on files
|
||||||
|
find %{buildroot}%{_libdir}/dotnet/ -type f -name 'apphost' -exec chmod +x {} \;
|
||||||
|
find %{buildroot}%{_libdir}/dotnet/ -type f -name 'singlefilehost' -exec chmod +x {} \;
|
||||||
|
find %{buildroot}%{_libdir}/dotnet/ -type f -name 'lib*so' -exec chmod +x {} \;
|
||||||
|
find %{buildroot}%{_libdir}/dotnet/ -type f -name '*.a' -exec chmod -x {} \;
|
||||||
|
find %{buildroot}%{_libdir}/dotnet/ -type f -name '*.dll' -exec chmod -x {} \;
|
||||||
|
find %{buildroot}%{_libdir}/dotnet/ -type f -name '*.h' -exec chmod 0644 {} \;
|
||||||
|
find %{buildroot}%{_libdir}/dotnet/ -type f -name '*.json' -exec chmod -x {} \;
|
||||||
|
find %{buildroot}%{_libdir}/dotnet/ -type f -name '*.pdb' -exec chmod -x {} \;
|
||||||
|
find %{buildroot}%{_libdir}/dotnet/ -type f -name '*.props' -exec chmod -x {} \;
|
||||||
|
find %{buildroot}%{_libdir}/dotnet/ -type f -name '*.pubxml' -exec chmod -x {} \;
|
||||||
|
find %{buildroot}%{_libdir}/dotnet/ -type f -name '*.targets' -exec chmod -x {} \;
|
||||||
|
find %{buildroot}%{_libdir}/dotnet/ -type f -name '*.txt' -exec chmod -x {} \;
|
||||||
|
find %{buildroot}%{_libdir}/dotnet/ -type f -name '*.xml' -exec chmod -x {} \;
|
||||||
|
|
||||||
|
# Provided by dotnet-host from another SRPM
|
||||||
|
#install -dm 0755 %%{buildroot}%%{_sysconfdir}/profile.d/
|
||||||
|
#install dotnet.sh %%{buildroot}%%{_sysconfdir}/profile.d/
|
||||||
|
|
||||||
|
# Provided by dotnet-host from another SRPM
|
||||||
|
#install -dm 0755 %%{buildroot}/%%{_datadir}/bash-completion/completions
|
||||||
|
# dynamic completion needs the file to be named the same as the base command
|
||||||
|
#install src/sdk/scripts/register-completions.bash %%{buildroot}/%%{_datadir}/bash-completion/completions/dotnet
|
||||||
|
|
||||||
|
# TODO: the zsh completion script needs to be ported to use #compdef
|
||||||
|
#install -dm 755 %%{buildroot}/%%{_datadir}/zsh/site-functions
|
||||||
|
#install src/cli/scripts/register-completions.zsh %%{buildroot}/%%{_datadir}/zsh/site-functions/_dotnet
|
||||||
|
|
||||||
|
# Provided by dotnet-host from another SRPM
|
||||||
|
#install -dm 0755 %%{buildroot}%%{_bindir}
|
||||||
|
#ln -s ../../%%{_libdir}/dotnet/dotnet %%{buildroot}%%{_bindir}/
|
||||||
|
|
||||||
|
# Provided by dotnet-host from another SRPM
|
||||||
|
#install -dm 0755 %%{buildroot}%%{_mandir}/man1/
|
||||||
|
#find -iname 'dotnet*.1' -type f -exec cp {} %%{buildroot}%%{_mandir}/man1/ \;
|
||||||
|
|
||||||
|
# Provided by dotnet-host from another SRPM
|
||||||
|
#install -dm 0755 %%{buildroot}%%{_sysconfdir}/dotnet
|
||||||
|
#echo "%%{_libdir}/dotnet" >> install_location
|
||||||
|
#install install_location %%{buildroot}%%{_sysconfdir}/dotnet/
|
||||||
|
#echo "%%{_libdir}/dotnet" >> install_location_%%{runtime_arch}
|
||||||
|
#install install_location_%%{runtime_arch} %%{buildroot}%%{_sysconfdir}/dotnet/
|
||||||
|
|
||||||
|
install -dm 0755 %{buildroot}%{_libdir}/dotnet/source-built-artifacts
|
||||||
|
install -m 0644 artifacts/%{runtime_arch}/Release/Private.SourceBuilt.Artifacts.*.tar.gz %{buildroot}/%{_libdir}/dotnet/source-built-artifacts/
|
||||||
|
|
||||||
|
|
||||||
|
# Quick and dirty check for https://github.com/dotnet/source-build/issues/2731
|
||||||
|
test -f %{buildroot}%{_libdir}/dotnet/sdk/%{sdk_version}/Sdks/Microsoft.NET.Sdk/Sdk/Sdk.props
|
||||||
|
|
||||||
|
# Check debug symbols in all elf objects. This is not in %%check
|
||||||
|
# because native binaries are stripped by rpm-build after %%install.
|
||||||
|
# So we need to do this check earlier.
|
||||||
|
echo "Testing build results for debug symbols..."
|
||||||
|
%{SOURCE10} -v %{buildroot}%{_libdir}/dotnet/
|
||||||
|
|
||||||
|
# Self-check
|
||||||
|
%if 0%{?fedora} > 35
|
||||||
|
# lttng in Fedora > 35 is incompatible with .NET
|
||||||
|
export COMPlus_LTTng=0
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%{buildroot}%{_libdir}/dotnet/dotnet --info
|
||||||
|
%{buildroot}%{_libdir}/dotnet/dotnet --version
|
||||||
|
|
||||||
|
# Provided by dotnet-host from another SRPM
|
||||||
|
rm %{buildroot}%{_libdir}/dotnet/LICENSE.txt
|
||||||
|
rm %{buildroot}%{_libdir}/dotnet/ThirdPartyNotices.txt
|
||||||
|
rm %{buildroot}%{_libdir}/dotnet/dotnet
|
||||||
|
|
||||||
|
# Provided by netstandard-targeting-pack-2.1 from another SRPM
|
||||||
|
rm -rf %{buildroot}%{_libdir}/dotnet/packs/NETStandard.Library.Ref/2.1.0
|
||||||
|
|
||||||
|
%files -n dotnet-hostfxr-6.0
|
||||||
|
%dir %{_libdir}/dotnet/host/fxr
|
||||||
|
%{_libdir}/dotnet/host/fxr/%{host_version}
|
||||||
|
|
||||||
|
%files -n dotnet-runtime-6.0
|
||||||
|
%dir %{_libdir}/dotnet/shared
|
||||||
|
%dir %{_libdir}/dotnet/shared/Microsoft.NETCore.App
|
||||||
|
%{_libdir}/dotnet/shared/Microsoft.NETCore.App/%{runtime_version}
|
||||||
|
|
||||||
|
%files -n aspnetcore-runtime-6.0
|
||||||
|
%dir %{_libdir}/dotnet/shared
|
||||||
|
%dir %{_libdir}/dotnet/shared/Microsoft.AspNetCore.App
|
||||||
|
%{_libdir}/dotnet/shared/Microsoft.AspNetCore.App/%{aspnetcore_runtime_version}
|
||||||
|
|
||||||
|
%files -n dotnet-templates-6.0
|
||||||
|
%dir %{_libdir}/dotnet/templates
|
||||||
|
%{_libdir}/dotnet/templates/%{templates_version}
|
||||||
|
|
||||||
|
%files -n dotnet-sdk-6.0
|
||||||
|
%dir %{_libdir}/dotnet/sdk
|
||||||
|
%{_libdir}/dotnet/sdk/%{sdk_version}
|
||||||
|
%dir %{_libdir}/dotnet/sdk-manifests
|
||||||
|
%{_libdir}/dotnet/sdk-manifests/%{sdk_feature_band_version}
|
||||||
|
%{_libdir}/dotnet/metadata
|
||||||
|
%dir %{_libdir}/dotnet/packs
|
||||||
|
|
||||||
|
%files -n dotnet-sdk-6.0-source-built-artifacts
|
||||||
|
%dir %{_libdir}/dotnet
|
||||||
|
%{_libdir}/dotnet/source-built-artifacts
|
||||||
|
|
||||||
|
|
||||||
|
%changelog
|
||||||
|
* Tue Sep 20 2022 Omair Majid <omajid@redhat.com> - 6.0.109-3
|
||||||
|
- Disable packages now produced by another SRPM
|
||||||
|
- Related: RHBZ#2123788
|
||||||
|
|
||||||
|
* Wed Sep 14 2022 Omair Majid <omajid@redhat.com> - 6.0.109-2
|
||||||
|
- Update to .NET SDK 6.0.109 and Runtime 6.0.9
|
||||||
|
- Resolves: RHBZ#2123788
|
||||||
|
|
||||||
|
* Tue Aug 09 2022 Omair Majid <omajid@redhat.com> - 6.0.108-1
|
||||||
|
- Update to .NET SDK 6.0.108 and Runtime 6.0.8
|
||||||
|
- Resolves: RHBZ#2112409
|
||||||
|
|
||||||
|
* Thu Jul 21 2022 Omair Majid <omajid@redhat.com> - 6.0.107-2
|
||||||
|
- Update to .NET SDK 6.0.107 and Runtime 6.0.7
|
||||||
|
- Resolves: RHBZ#2103269
|
||||||
|
|
||||||
|
* Thu Jun 23 2022 Omair Majid <omajid@redhat.com> - 6.0.106-1
|
||||||
|
- Update to .NET SDK 6.0.106 and Runtime 6.0.6
|
||||||
|
- Resolves: RHBZ#2093431
|
||||||
|
|
||||||
|
* Wed May 25 2022 Omair Majid <omajid@redhat.com> - 6.0.105-1
|
||||||
|
- Update to .NET SDK 6.0.105 and Runtime 6.0.5
|
||||||
|
- Resolves: RHBZ#2082266
|
||||||
|
|
||||||
|
* Sat Apr 30 2022 Omair Majid <omajid@redhat.com> - 6.0.104-1
|
||||||
|
- Update to .NET SDK 6.0.104 and Runtime 6.0.4
|
||||||
|
- Resolves: RHBZ#2078604
|
||||||
|
|
||||||
|
* Mon Apr 25 2022 Omair Majid <omajid@redhat.com> - 6.0.103-2
|
||||||
|
- Update to .NET SDK 6.0.103 and Runtime 6.0.3
|
||||||
|
- Resolves: RHBZ#2072015
|
||||||
|
|
||||||
|
* Tue Feb 15 2022 Omair Majid <omajid@redhat.com> - 6.0.102-3
|
||||||
|
- Disable bootstrap
|
||||||
|
- Related: RHBZ#1986211
|
||||||
|
|
||||||
|
* Fri Feb 04 2022 Omair Majid <omajid@redhat.com> - 6.0.100-2
|
||||||
|
- Rebuild and check SDK to avoid an incomplete SDK
|
||||||
|
- Related: RHBZ#1986211
|
||||||
|
|
||||||
|
* Wed Nov 10 2021 Omair Majid <omajid@redhat.com> - 6.0.100-1
|
||||||
|
- Update to .NET 6
|
||||||
|
- Resolves: RHBZ#1986211
|
||||||
|
|
||||||
|
* Fri Oct 22 2021 Omair Majid <omajid@redhat.com> - 6.0.0-0.7.rc2
|
||||||
|
- Update to .NET 6 RC2
|
||||||
|
|
||||||
|
* Fri Oct 08 2021 Omair Majid <omajid@redhat.com> - 6.0.0-0.6.28be3e9a006d90d8c6e87d4353b77882829df718
|
||||||
|
- Enable building on arm64
|
||||||
|
- Related: RHBZ#1986017
|
||||||
|
|
||||||
|
* Sun Oct 03 2021 Omair Majid <omajid@redhat.com> - 6.0.0-0.5.28be3e9a006d90d8c6e87d4353b77882829df718
|
||||||
|
- Enable building on s390x
|
||||||
|
- Related: RHBZ#1986017
|
||||||
|
|
||||||
|
* Sun Oct 03 2021 Omair Majid <omajid@redhat.com> - 6.0.0-0.4.28be3e9a006d90d8c6e87d4353b77882829df718
|
||||||
|
- Clean up tarball and add initial support for s390x
|
||||||
|
- Related: RHBZ#1986017
|
||||||
|
|
||||||
|
* Sun Sep 26 2021 Omair Majid <omajid@redhat.com> - 6.0.0-0.3.28be3e9a006d90d8c6e87d4353b77882829df718
|
||||||
|
- Update to work-in-progress RC2 release
|
||||||
|
|
||||||
|
* Wed Aug 25 2021 Omair Majid <omajid@redhat.com> - 6.0.0-0.2.preview6
|
||||||
|
- Updated to build the latest source-build preview
|
||||||
|
|
||||||
|
* Fri Jul 23 2021 Omair Majid <omajid@redhat.com> - 6.0.0-0.1.preview6
|
||||||
|
- Initial package for .NET 6
|
||||||
|
|
||||||
|
* Thu Jun 10 2021 Omair Majid <omajid@redhat.com> - 5.0.204-1
|
||||||
|
- Update to .NET SDK 5.0.204 and Runtime 5.0.7
|
||||||
|
|
||||||
|
* Wed May 12 2021 Omair Majid <omajid@redhat.com> - 5.0.203-1
|
||||||
|
- Update to .NET SDK 5.0.203 and Runtime 5.0.6
|
||||||
|
|
||||||
|
* Wed Apr 14 2021 Omair Majid <omajid@redhat.com> - 5.0.202-1
|
||||||
|
- Update to .NET SDK 5.0.202 and Runtime 5.0.5
|
||||||
|
|
||||||
|
* Tue Apr 06 2021 Omair Majid <omajid@redhat.com> - 5.0.104-2
|
||||||
|
- Mark files under /etc/ as config(noreplace)
|
||||||
|
- Add an rpm-inspect configuration file
|
||||||
|
- Add an rpmlintrc file
|
||||||
|
- Enable gating for release branches and ELN too
|
||||||
|
|
||||||
|
* Tue Mar 16 2021 Omair Majid <omajid@redhat.com> - 5.0.104-1
|
||||||
|
- Update to .NET SDK 5.0.104 and Runtime 5.0.4
|
||||||
|
- Drop unneeded/upstreamed patches
|
||||||
|
|
||||||
|
* Wed Feb 17 2021 Omair Majid <omajid@redhat.com> - 5.0.103-2
|
||||||
|
- Add Fedora 35 RIDs
|
||||||
|
|
||||||
|
* Thu Feb 11 2021 Omair Majid <omajid@redhat.com> - 5.0.103-1
|
||||||
|
- Update to .NET SDK 5.0.103 and Runtime 5.0.3
|
||||||
|
|
||||||
|
* Fri Jan 29 2021 Omair Majid <omajid@redhat.com> - 5.0.102-2
|
||||||
|
- Disable bootstrap
|
||||||
|
|
||||||
|
* Fri Dec 18 2020 Omair Majid <omajid@redhat.com> - 5.0.100-2
|
||||||
|
- Update to .NET Core Runtime 5.0.0 and SDK 5.0.100 commit 9c4e5de
|
||||||
|
|
||||||
|
* Fri Dec 04 2020 Omair Majid <omajid@redhat.com> - 5.0.100-1
|
||||||
|
- Update to .NET Core Runtime 5.0.0 and SDK 5.0.100
|
||||||
|
|
||||||
|
* Thu Dec 03 2020 Omair Majid <omajid@redhat.com> - 5.0.100-0.4.20201202git337413b
|
||||||
|
- Update to latest 5.0 pre-GA commit
|
||||||
|
|
||||||
|
* Tue Nov 24 2020 Omair Majid <omajid@redhat.com> - 5.0.100-0.4.20201123gitdee899c
|
||||||
|
- Update to 5.0 pre-GA commit
|
||||||
|
|
||||||
|
* Mon Sep 14 2020 Omair Majid <omajid@redhat.com> - 5.0.100-0.3.preview8
|
||||||
|
- Update to Preview 8
|
||||||
|
|
||||||
|
* Fri Jul 10 2020 Omair Majid <omajid@redhat.com> - 5.0.100-0.2.preview4
|
||||||
|
- Fix building with custom CFLAGS/CXXFLAGS/LDFLAGS
|
||||||
|
- Clean up patches
|
||||||
|
|
||||||
|
* Mon Jul 06 2020 Omair Majid <omajid@redhat.com> - 5.0.100-0.1.preview4
|
||||||
|
- Initial build
|
||||||
|
|
||||||
|
* Sat Jun 27 2020 Omair Majid <omajid@redhat.com> - 3.1.105-4
|
||||||
|
- Disable bootstrap
|
||||||
|
|
||||||
|
* Fri Jun 26 2020 Omair Majid <omajid@redhat.com> - 3.1.105-3
|
||||||
|
- Re-bootstrap aarch64
|
||||||
|
|
||||||
|
* Fri Jun 19 2020 Omair Majid <omajid@redhat.com> - 3.1.105-3
|
||||||
|
- Disable bootstrap
|
||||||
|
|
||||||
|
* Thu Jun 18 2020 Omair Majid <omajid@redhat.com> - 3.1.105-1
|
||||||
|
- Bootstrap aarch64
|
||||||
|
|
||||||
|
* Tue Jun 16 2020 Chris Rummel <crummel@microsoft.com> - 3.1.105-1
|
||||||
|
- Update to .NET Core Runtime 3.1.5 and SDK 3.1.105
|
||||||
|
|
||||||
|
* Fri Jun 05 2020 Chris Rummel <crummel@microsoft.com> - 3.1.104-1
|
||||||
|
- Update to .NET Core Runtime 3.1.4 and SDK 3.1.104
|
||||||
|
|
||||||
|
* Thu Apr 09 2020 Chris Rummel <crummel@microsoft.com> - 3.1.103-1
|
||||||
|
- Update to .NET Core Runtime 3.1.3 and SDK 3.1.103
|
||||||
|
|
||||||
|
* Mon Mar 16 2020 Omair Majid <omajid@redhat.com> - 3.1.102-1
|
||||||
|
- Update to .NET Core Runtime 3.1.2 and SDK 3.1.102
|
||||||
|
|
||||||
|
* Fri Feb 28 2020 Omair Majid <omajid@redhat.com> - 3.1.101-4
|
||||||
|
- Disable bootstrap
|
||||||
|
|
||||||
|
* Fri Feb 28 2020 Omair Majid <omajid@redhat.com> - 3.1.101-3
|
||||||
|
- Enable bootstrap
|
||||||
|
- Add Fedora 33 runtime ids
|
||||||
|
|
||||||
|
* Thu Feb 27 2020 Omair Majid <omajid@redhat.com> - 3.1.101-2
|
||||||
|
- Disable bootstrap
|
||||||
|
|
||||||
|
* Tue Jan 21 2020 Omair Majid <omajid@redhat.com> - 3.1.101-1
|
||||||
|
- Update to .NET Core Runtime 3.1.1 and SDK 3.1.101
|
||||||
|
|
||||||
|
* Thu Dec 05 2019 Omair Majid <omajid@redhat.com> - 3.1.100-1
|
||||||
|
- Update to .NET Core Runtime 3.1.0 and SDK 3.1.100
|
||||||
|
|
||||||
|
* Mon Nov 18 2019 Omair Majid <omajid@redhat.com> - 3.1.100-0.4.preview3
|
||||||
|
- Fix apphost permissions
|
||||||
|
|
||||||
|
* Fri Nov 15 2019 Omair Majid <omajid@redhat.com> - 3.1.100-0.3.preview3
|
||||||
|
- Update to .NET Core Runtime 3.1.0-preview3.19553.2 and SDK
|
||||||
|
3.1.100-preview3-014645
|
||||||
|
|
||||||
|
* Wed Nov 06 2019 Omair Majid <omajid@redhat.com> - 3.1.100-0.2
|
||||||
|
- Update to .NET Core 3.1 Preview 2
|
||||||
|
|
||||||
|
* Wed Oct 30 2019 Omair Majid <omajid@redhat.com> - 3.1.100-0.1
|
||||||
|
- Update to .NET Core 3.1 Preview 1
|
||||||
|
|
||||||
|
* Thu Oct 24 2019 Omair Majid <omajid@redhat.com> - 3.0.100-5
|
||||||
|
- Add cgroupv2 support to .NET Core
|
||||||
|
|
||||||
|
* Wed Oct 16 2019 Omair Majid <omajid@redhat.com> - 3.0.100-4
|
||||||
|
- Include fix from coreclr for building on Fedora 32
|
||||||
|
|
||||||
|
* Wed Oct 16 2019 Omair Majid <omajid@redhat.com> - 3.0.100-3
|
||||||
|
- Harden built binaries to pass annocheck
|
||||||
|
|
||||||
|
* Fri Oct 11 2019 Omair Majid <omajid@redhat.com> - 3.0.100-2
|
||||||
|
- Export DOTNET_ROOT in profile to make apphost lookup work
|
||||||
|
|
||||||
|
* Fri Sep 27 2019 Omair Majid <omajid@redhat.com> - 3.0.100-1
|
||||||
|
- Update to .NET Core Runtime 3.0.0 and SDK 3.0.100
|
||||||
|
|
||||||
|
* Wed Sep 25 2019 Omair Majid <omajid@redhat.com> - 3.0.100-0.18.rc1
|
||||||
|
- Update to .NET Core Runtime 3.0.0-rc1-19456-20 and SDK 3.0.100-rc1-014190
|
||||||
|
|
||||||
|
* Tue Sep 17 2019 Omair Majid <omajid@redhat.com> - 3.0.100-0.16.preview9
|
||||||
|
- Fix files duplicated between dotnet-apphost-pack-3.0 and dotnet-targeting-pack-3.0
|
||||||
|
- Fix dependencies between .NET SDK and the targeting packs
|
||||||
|
|
||||||
|
* Mon Sep 16 2019 Omair Majid <omajid@redhat.com> - 3.0.100-0.15.preview9
|
||||||
|
- Update to .NET Core Runtime 3.0.0-preview 9 and SDK 3.0.100-preview9
|
||||||
|
|
||||||
|
* Mon Aug 19 2019 Omair Majid <omajid@redhat.com> - 3.0.100-0.11.preview8
|
||||||
|
- Update to .NET Core Runtime 3.0.0-preview8-28405-07 and SDK
|
||||||
|
3.0.100-preview8-013656
|
||||||
|
|
||||||
|
* Tue Jul 30 2019 Omair Majid <omajid@redhat.com> - 3.0.100-0.9.preview7
|
||||||
|
- Update to .NET Core Runtime 3.0.0-preview7-27912-14 and SDK
|
||||||
|
3.0.100-preview7-012821
|
||||||
|
|
||||||
|
* Fri Jul 26 2019 Omair Majid <omajid@redhat.com> - 3.0.100-0.8.preview7
|
||||||
|
- Update to .NET Core Runtime 3.0.0-preview7-27902-19 and SDK
|
||||||
|
3.0.100-preview7-012802
|
||||||
|
|
||||||
|
* Wed Jun 26 2019 Omair Majid <omajid@redhat.com> - 3.0.0-0.7.preview6
|
||||||
|
- Obsolete dotnet-sdk-3.0.1xx
|
||||||
|
- Add supackages for targeting packs
|
||||||
|
- Add -fcf-protection to CFLAGS
|
||||||
|
|
||||||
|
* Wed Jun 26 2019 Omair Majid <omajid@redhat.com> - 3.0.0-0.6.preview6
|
||||||
|
- Update to .NET Core Runtime 3.0.0-preview6-27804-01 and SDK 3.0.100-preview6-012264
|
||||||
|
- Set dotnet installation location in /etc/dotnet/install_location
|
||||||
|
- Update targeting packs
|
||||||
|
- Install managed symbols
|
||||||
|
- Completely conditionalize libunwind bundling
|
||||||
|
|
||||||
|
* Tue May 07 2019 Omair Majid <omajid@redhat.com> - 3.0.0-0.3.preview4
|
||||||
|
- Update to .NET Core 3.0 preview 4
|
||||||
|
|
||||||
|
* Tue Dec 18 2018 Omair Majid <omajid@redhat.com> - 3.0.0-0.1.preview1
|
||||||
|
- Update to .NET Core 3.0 preview 1
|
||||||
|
|
||||||
|
* Fri Dec 07 2018 Omair Majid <omajid@redhat.com> - 2.2.100
|
||||||
|
- Update to .NET Core 2.2.0
|
||||||
|
|
||||||
|
* Wed Nov 07 2018 Omair Majid <omajid@redhat.com> - 2.2.100-0.2.preview3
|
||||||
|
- Update to .NET Core 2.2.0-preview3
|
||||||
|
|
||||||
|
* Fri Nov 02 2018 Omair Majid <omajid@redhat.com> - 2.1.403-3
|
||||||
|
- Add host-fxr-2.1 subpackage
|
||||||
|
|
||||||
|
* Mon Oct 15 2018 Omair Majid <omajid@redhat.com> - 2.1.403-2
|
||||||
|
- Disable telemetry by default
|
||||||
|
- Users have to manually export DOTNET_CLI_TELEMETRY_OPTOUT=0 to enable
|
||||||
|
|
||||||
|
* Tue Oct 02 2018 Omair Majid <omajid@redhat.com> - 2.1.403-1
|
||||||
|
- Update to .NET Core Runtime 2.1.5 and SDK 2.1.403
|
||||||
|
|
||||||
|
* Wed Sep 26 2018 Omair Majid <omajid@redhat.com> - 2.1.402-2
|
||||||
|
- Add ~/.dotnet/tools to $PATH to make it easier to use dotnet tools
|
||||||
|
|
||||||
|
* Thu Sep 13 2018 Omair Majid <omajid@redhat.com> - 2.1.402-1
|
||||||
|
- Update to .NET Core Runtime 2.1.4 and SDK 2.1.402
|
||||||
|
|
||||||
|
* Wed Sep 05 2018 Omair Majid <omajid@redhat.com> - 2.1.401-2
|
||||||
|
- Use distro-standard flags when building .NET Core
|
||||||
|
|
||||||
|
* Tue Aug 21 2018 Omair Majid <omajid@redhat.com> - 2.1.401-1
|
||||||
|
- Update to .NET Core Runtime 2.1.3 and SDK 2.1.401
|
||||||
|
|
||||||
|
* Mon Aug 20 2018 Omair Majid <omajid@redhat.com> - 2.1.302-1
|
||||||
|
- Update to .NET Core Runtime 2.1.2 and SDK 2.1.302
|
||||||
|
|
||||||
|
* Fri Jul 20 2018 Omair Majid <omajid@redhat.com> - 2.1.301-1
|
||||||
|
- Update to .NET Core 2.1
|
||||||
|
|
||||||
|
* Thu May 03 2018 Omair Majid <omajid@redhat.com> - 2.0.7-1
|
||||||
|
- Update to .NET Core 2.0.7
|
||||||
|
|
||||||
|
* Wed Mar 28 2018 Omair Majid <omajid@redhat.com> - 2.0.6-2
|
||||||
|
- Enable bash completion for dotnet
|
||||||
|
- Remove redundant buildrequires and requires
|
||||||
|
|
||||||
|
* Wed Mar 14 2018 Omair Majid <omajid@redhat.com> - 2.0.6-1
|
||||||
|
- Update to .NET Core 2.0.6
|
||||||
|
|
||||||
|
* Fri Feb 23 2018 Omair Majid <omajid@redhat.com> - 2.0.5-1
|
||||||
|
- Update to .NET Core 2.0.5
|
||||||
|
|
||||||
|
* Wed Jan 24 2018 Omair Majid <omajid@redhat.com> - 2.0.3-5
|
||||||
|
- Don't apply corefx clang warnings fix on clang < 5
|
||||||
|
|
||||||
|
* Fri Jan 19 2018 Omair Majid <omajid@redhat.com> - 2.0.3-4
|
||||||
|
- Add a test script to sanity check debug and symbol info.
|
||||||
|
- Build with clang 5.0
|
||||||
|
- Make main package real instead of using a virtual provides (see RHBZ 1519325)
|
||||||
|
|
||||||
|
* Wed Nov 29 2017 Omair Majid <omajid@redhat.com> - 2.0.3-3
|
||||||
|
- Add a Provides for 'dotnet'
|
||||||
|
- Fix conditional macro
|
||||||
|
|
||||||
|
* Tue Nov 28 2017 Omair Majid <omajid@redhat.com> - 2.0.3-2
|
||||||
|
- Fix build on Fedora 27
|
||||||
|
|
||||||
|
* Fri Nov 17 2017 Omair Majid <omajid@redhat.com> - 2.0.3-1
|
||||||
|
- Update to .NET Core 2.0.3
|
||||||
|
|
||||||
|
* Thu Oct 19 2017 Omair Majid <omajid@redhat.com> - 2.0.0-4
|
||||||
|
- Add a hack to let omnisharp work
|
||||||
|
|
||||||
|
* Wed Aug 30 2017 Omair Majid <omajid@redhat.com> - 2.0.0-3
|
||||||
|
- Add a patch for building coreclr and core-setup correctly on Fedora >= 27
|
||||||
|
|
||||||
|
* Fri Aug 25 2017 Omair Majid <omajid@redhat.com> - 2.0.0-2
|
||||||
|
- Move libicu/libcurl/libunwind requires to runtime package
|
||||||
|
- Make sdk depend on the exact version of the runtime package
|
||||||
|
|
||||||
|
* Thu Aug 24 2017 Omair Majid <omajid@redhat.com> - 2.0.0-1
|
||||||
|
- Update to 2.0.0 final release
|
||||||
|
|
||||||
|
* Wed Jul 26 2017 Omair Majid <omajid@redhat.com> - 2.0.0-0.3.preview2
|
||||||
|
- Add man pages
|
||||||
|
|
||||||
|
* Tue Jul 25 2017 Omair Majid <omajid@redhat.com> - 2.0.0-0.2.preview2
|
||||||
|
- Add Requires on libicu
|
||||||
|
- Split into multiple packages
|
||||||
|
- Do not repeat first-run message
|
||||||
|
|
||||||
|
* Fri Jul 21 2017 Omair Majid <omajid@redhat.com> - 2.0.0-0.1.preview2
|
||||||
|
- Update to .NET Core 2.0 Preview 2
|
||||||
|
|
||||||
|
* Thu Mar 16 2017 Nemanja Milošević <nmilosevnm@gmail.com> - 1.1.0-7
|
||||||
|
- rebuilt with latest libldb
|
||||||
|
* Wed Feb 22 2017 Nemanja Milosevic <nmilosev@fedoraproject.org> - 1.1.0-6
|
||||||
|
- compat-openssl 1.0 for F26 for now
|
||||||
|
* Sun Feb 19 2017 Nemanja Milosevic <nmilosev@fedoraproject.org> - 1.1.0-5
|
||||||
|
- Fix wrong commit id's
|
||||||
|
* Sat Feb 18 2017 Nemanja Milosevic <nmilosev@fedoraproject.org> - 1.1.0-4
|
||||||
|
- Use commit id's instead of branch names
|
||||||
|
* Sat Feb 18 2017 Nemanja Milosevic <nmilosev@fedoraproject.org> - 1.1.0-3
|
||||||
|
- Improper patch5 fix
|
||||||
|
* Sat Feb 18 2017 Nemanja Milosevic <nmilosev@fedoraproject.org> - 1.1.0-2
|
||||||
|
- SPEC cleanup
|
||||||
|
- git removal (using all tarballs for reproducible builds)
|
||||||
|
- more reasonable versioning
|
||||||
|
* Thu Feb 09 2017 Nemanja Milosevic <nmilosev@fedoraproject.org> - 1.1.0-1
|
||||||
|
- Fixed debuginfo going to separate package (Patch1)
|
||||||
|
- Added F25/F26 RIL and fixed the version info (Patch2)
|
||||||
|
- Added F25/F26 RIL in Microsoft.NETCore.App suported runtime graph (Patch3)
|
||||||
|
- SPEC file cleanup
|
||||||
|
* Wed Jan 11 2017 Nemanja Milosevic <nmilosev@fedoraproject.org> - 1.1.0-0
|
||||||
|
- Initial RPM for Fedora 25/26.
|
Loading…
Reference in new issue