diff --git a/build/common.props b/build/common.props index cd34524487..68774db1cd 100644 --- a/build/common.props +++ b/build/common.props @@ -8,6 +8,9 @@ $(MSBuildThisFileDirectory)Key.snk true true + + + false diff --git a/makefile.shade b/makefile.shade index f5ea5ac9eb..bcd566d0d0 100644 --- a/makefile.shade +++ b/makefile.shade @@ -4,5 +4,42 @@ var FULL_VERSION='0.1' use-standard-lifecycle k-standard-goals +#restore-nuget-packages target='initialize' + exec program='${Path.Combine(Directory.GetCurrentDirectory(), ".build", "nuget.exe")}' commandline='restore' + +#build-vsix-core + @{ + var programFilesx86 = Environment.GetFolderPath(Environment.SpecialFolder.ProgramFilesX86); + // Microsoft Visual Studio\2017 + var buildToolsDirectory = Path.Combine(programFilesx86, "Microsoft Visual Studio", "2017"); + if (!Directory.Exists(buildToolsDirectory)) + { + throw new Exception("MSBuild 15.0 installation directory could not be located."); + } + + var msBuildDirectory = Directory.EnumerateDirectories(buildToolsDirectory).FirstOrDefault(); + // If VS 2017 is installed, look for MSBuild under Enterprise \ Professional \ Community directory + // If the MSBuild tools are separately installed, look for MSBuild under the BuildTools directory + if (msBuildDirectory == null) + { + throw new Exception("MSBuild 15.0 installation directory could not be located."); + } + + var msbuildPath = Path.Combine(msBuildDirectory, "MSBuild", "15.0", "bin", "MSBuild.exe"); + var toolsDirectory = Path.Combine(Directory.GetCurrentDirectory(), "tooling", "Microsoft.VisualStudio.RazorExtension"); + var artifactsDirectory = Path.Combine(Directory.GetCurrentDirectory(), "artifacts"); + Directory.CreateDirectory(artifactsDirectory); + var logFilePath = Path.Combine(artifactsDirectory, "msbuild.log"); + } + exec program='${msbuildPath}' commandline='/p:DeployExtension=false /fl /flp:v=D /flp:LogFile=${logFilePath}' workingdir='${toolsDirectory}' + +#build-vsix .initialize .compile .build-vsix-core + @{ + var baseDirectory = Directory.GetCurrentDirectory(); + var buildPath = Path.Combine(baseDirectory, "artifacts", "build"); + var vsixPath = Directory.EnumerateFiles(baseDirectory, "*.vsix", SearchOption.AllDirectories).First(); + File.Copy(vsixPath, Path.Combine(buildPath, Path.GetFileName(vsixPath))); + } + #pack-sources target='build-pack' dotnet command='msbuild shared/build.proj /t:Pack /v:n' diff --git a/src/Microsoft.CodeAnalysis.Razor.Workspaces/Microsoft.CodeAnalysis.Razor.Workspaces.csproj b/src/Microsoft.CodeAnalysis.Razor.Workspaces/Microsoft.CodeAnalysis.Razor.Workspaces.csproj index 92b13d0e05..7b5a78ef5b 100644 --- a/src/Microsoft.CodeAnalysis.Razor.Workspaces/Microsoft.CodeAnalysis.Razor.Workspaces.csproj +++ b/src/Microsoft.CodeAnalysis.Razor.Workspaces/Microsoft.CodeAnalysis.Razor.Workspaces.csproj @@ -1,6 +1,7 @@ + 1.0.0 Razor is a markup syntax for adding server-side logic to web pages. This package contains the Razor design-time infrastructure. net451;netstandard1.3 $(NoWarn);CS1591 diff --git a/src/Microsoft.CodeAnalysis.Remote.Razor/Microsoft.CodeAnalysis.Remote.Razor.csproj b/src/Microsoft.CodeAnalysis.Remote.Razor/Microsoft.CodeAnalysis.Remote.Razor.csproj index 231bd5b142..abe17ecb37 100644 --- a/src/Microsoft.CodeAnalysis.Remote.Razor/Microsoft.CodeAnalysis.Remote.Razor.csproj +++ b/src/Microsoft.CodeAnalysis.Remote.Razor/Microsoft.CodeAnalysis.Remote.Razor.csproj @@ -1,6 +1,7 @@  + 1.0.0 Razor is a markup syntax for adding server-side logic to web pages. This package contains the Razor design-time infrastructure. net46 $(NoWarn);CS1591 diff --git a/tooling/Microsoft.VisualStudio.RazorExtension/source.extension.vsixmanifest b/tooling/Microsoft.VisualStudio.RazorExtension/source.extension.vsixmanifest index 0fd9ea10e6..e952576d9c 100644 --- a/tooling/Microsoft.VisualStudio.RazorExtension/source.extension.vsixmanifest +++ b/tooling/Microsoft.VisualStudio.RazorExtension/source.extension.vsixmanifest @@ -1,9 +1,9 @@  - + Microsoft.VisualStudio.RazorExtension - + Language services for AspNetCore Razor