Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

WIP: Fix dotnetcore #2252

Closed
wants to merge 18 commits into from
Closed
Show file tree
Hide file tree
Changes from 7 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
20 changes: 14 additions & 6 deletions src/Paket.Core/Files/ProjectFile.fs
Original file line number Diff line number Diff line change
Expand Up @@ -744,12 +744,20 @@ module ProjectFile =
model.GetReferenceFolders()
|> List.map (fun lib -> lib.Targets)

// Just in case anyone wants to compile FOR netcore in the old format...
// I don't think there is anyone actually using this part, but it's there for backwards compat.
let netCoreRestricted =
model.ApplyFrameworkRestrictions
[ FrameworkRestriction.AtLeast (FrameworkIdentifier.DotNetStandard DotNetStandardVersion.V1_0);
FrameworkRestriction.AtLeast (FrameworkIdentifier.DotNetCore DotNetCoreVersion.V1_0) ]

// handle legacy conditions
let conditions =
model.GetReferenceFolders()
|> List.sortBy (fun libFolder -> libFolder.Name)
|> List.collect (fun libFolder ->
((model.GetReferenceFolders() |> List.sortBy (fun libFolder -> libFolder.Name)) @
netCoreRestricted.CompileRefFolders |> List.sortBy (fun libFolder -> libFolder.Name))
|> List.collect (fun libFolder ->
match libFolder with
| x when (match x.Targets with | [SinglePlatform(Runtimes(_))] -> true | _ -> false) -> [] // TODO: Add reference to custom task instead
//| x when (match x.Targets with | [SinglePlatform(Runtimes(_))] -> true | _ -> false) -> [] // TODO: Add reference to custom task instead
| _ ->
match PlatformMatching.getCondition referenceCondition allTargets libFolder.Targets with
| "" -> []
Expand Down Expand Up @@ -788,7 +796,7 @@ module ProjectFile =
[lowerCondition,createItemGroup !assemblyTargets frameworkAssemblies,true
condition,createItemGroup libFolder.Targets rest,false]
)

// global targets are targets, that are either directly in the /build folder,
// or, if there is a framework-restriction, specific to the framework(s).
// (ref https://docs.microsoft.com/en-us/nuget/create-packages/creating-a-package#including-msbuild-props-and-targets-in-a-package).
Expand All @@ -797,7 +805,7 @@ module ProjectFile =
let sortedTargets = model.TargetsFileFolders |> List.sortBy (fun lib -> lib.Name)
sortedTargets
|> List.partition (fun lib -> allTargetProfiles = set lib.Targets )

let frameworkSpecificTargetsFileConditions =
frameworkSpecificTargets
|> List.map (fun lib -> PlatformMatching.getCondition referenceCondition allTargets lib.Targets,createPropertyGroup lib.Files.References)
Expand Down
38 changes: 19 additions & 19 deletions src/Paket.Core/FrameworkHandling.fs
Original file line number Diff line number Diff line change
Expand Up @@ -156,7 +156,7 @@ type FrameworkIdentifier =
| MonoTouch
| MonoMac
| Native of string * string
| Runtimes of string
//| Runtimes of string
| XamariniOS
| XamarinMac
| Windows of string
Expand All @@ -176,7 +176,7 @@ type FrameworkIdentifier =
| MonoTouch -> "monotouch"
| MonoMac -> "monomac"
| Native(_) -> "native"
| Runtimes(_) -> "runtimes"
//| Runtimes(_) -> "runtimes"
| XamariniOS -> "xamarinios"
| UAP v -> "uap" + v.ShortString()
| XamarinMac -> "xamarinmac"
Expand All @@ -193,7 +193,7 @@ type FrameworkIdentifier =
| MonoTouch -> [ ]
| MonoMac -> [ ]
| Native(_) -> [ ]
| Runtimes(_) -> [ ]
//| Runtimes(_) -> [ ]
| XamariniOS -> [ ]
| XamarinMac -> [ ]
| UAP UAPVersion.V10 -> [ ]
Expand Down Expand Up @@ -253,7 +253,7 @@ type FrameworkIdentifier =
| DNXCore _, DNXCore _ -> true
| MonoAndroid _, MonoAndroid _ -> true
| MonoMac _, MonoMac _ -> true
| Runtimes _, Runtimes _ -> true
//| Runtimes _, Runtimes _ -> true
| MonoTouch _, MonoTouch _ -> true
| Windows _, Windows _ -> true
| WindowsPhoneApp _, WindowsPhoneApp _ -> true
Expand Down Expand Up @@ -314,7 +314,7 @@ module FrameworkDetection =
// Each time the parsing is changed, NuGetPackageCache.CurrentCacheVersion should be bumped.
let result =
match path with
| x when x.StartsWith "runtimes/" -> Some(Runtimes(x.Substring(9)))
//| x when x.StartsWith "runtimes/" -> Some(Runtimes(x.Substring(9)))
| "net10" | "net1" | "10" -> Some (DotNetFramework FrameworkVersion.V1)
| "net11" | "11" -> Some (DotNetFramework FrameworkVersion.V1_1)
| "net20" | "net2" | "net" | "net20-full" | "net20-client" | "20" -> Some (DotNetFramework FrameworkVersion.V2)
Expand Down Expand Up @@ -619,20 +619,20 @@ module KnownTargetProfiles =
Native("Release","x64")
Native("Release","arm")]

let AllRuntimes =
[ Runtimes("win7-x64")
Runtimes("win7-x86")
Runtimes("win7-arm")
Runtimes("debian-x64")
Runtimes("aot")
Runtimes("win")
Runtimes("linux")
Runtimes("unix")
Runtimes("osx") ]

let AllProfiles =
(AllNativeProfiles |> List.map SinglePlatform) @
(AllRuntimes |> List.map SinglePlatform) @
//let AllRuntimes =
// [ Runtimes("win7-x64")
// Runtimes("win7-x86")
// Runtimes("win7-arm")
// Runtimes("debian-x64")
// Runtimes("aot")
// Runtimes("win")
// Runtimes("linux")
// Runtimes("unix")
// Runtimes("osx") ]

let AllProfiles =
(AllNativeProfiles |> List.map SinglePlatform) @
//(AllRuntimes |> List.map SinglePlatform) @
AllDotNetStandardProfiles @
AllDotNetProfiles

Expand Down
Loading