Merge pull request #292 from gkhanna79/MacDNC

Initial support for Mac dotnet-compile-native
This commit is contained in:
Gaurav Khanna 2015-11-25 10:03:30 -08:00
commit a6d62b1610
7 changed files with 137 additions and 31 deletions

View file

@ -7,11 +7,6 @@ SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
source $SCRIPT_DIR/../_common.sh source $SCRIPT_DIR/../_common.sh
# Dotnet-compile-native doesn't work for mac yet
if [[ "$(uname)" != "Linux" ]]; then
exit 0
fi
REPO_ROOT="$SCRIPT_DIR/../.." REPO_ROOT="$SCRIPT_DIR/../.."
APPDEPS_PROJECT_DIR=$REPO_ROOT/src/Microsoft.DotNet.Tools.Compiler.Native/appdep APPDEPS_PROJECT_DIR=$REPO_ROOT/src/Microsoft.DotNet.Tools.Compiler.Native/appdep

View file

@ -42,6 +42,11 @@ namespace Microsoft.DotNet.Tools.Compiler.Native
var argsList = new List<string>(); var argsList = new List<string>();
var managedPath = Path.Combine(config.IlcPath, ILCompiler); var managedPath = Path.Combine(config.IlcPath, ILCompiler);
if (!File.Exists(managedPath))
{
throw new FileNotFoundException("Unable to find ILCompiler at " + managedPath);
}
argsList.Add($"\"{managedPath}\""); argsList.Add($"\"{managedPath}\"");
// Input File // Input File

View file

@ -50,7 +50,7 @@ namespace Microsoft.DotNet.Tools.Compiler.Native
} }
else if (config.OS == OSMode.Mac) else if (config.OS == OSMode.Mac)
{ {
throw new NotImplementedException("Mac not yet supported."); stepList.Add(new MacCppCompileStep(config));
} }
else else
{ {

View file

@ -87,10 +87,11 @@ namespace Microsoft.DotNet.Tools.Compiler.Native
} }
// AppDep Libs // AppDep Libs
var baseAppDeplibPath = Path.Combine(config.AppDepSDKPath, "CPPSdk/ubuntu.14.04/x64");
foreach (var lib in appdeplibs) foreach (var lib in appdeplibs)
{ {
var libPath = Path.Combine(config.AppDepSDKPath, lib); var appDeplibPath = Path.Combine(baseAppDeplibPath, lib);
argsList.Add(libPath); argsList.Add(appDeplibPath);
} }
argsList.Add(cLibsFlags); argsList.Add(cLibsFlags);

View file

@ -12,29 +12,134 @@ namespace Microsoft.DotNet.Tools.Compiler.Native
{ {
public class MacCppCompileStep : IPlatformNativeStep public class MacCppCompileStep : IPlatformNativeStep
{ {
private readonly string CompilerName = "clang";
private readonly string InputExtension = ".cpp";
// TODO: debug/release support
private readonly string cflags = "-g -lstdc++ -Wno-invalid-offsetof -pthread";
// Link to iconv APIs
private readonly string libFlags = "-liconv";
private readonly string[] libs = new string[]
{
"libbootstrappercpp.a",
"libPortableRuntime.a",
"libSystem.Private.CoreLib.Native.a"
};
private readonly string[] appdeplibs = new string[]
{
"libSystem.Native.a"
};
private string CompilerArgStr { get; set; }
private NativeCompileSettings config;
public MacCppCompileStep(NativeCompileSettings config) public MacCppCompileStep(NativeCompileSettings config)
{ {
throw new NotImplementedException("Mac Cpp Not Supported Yet"); this.config = config;
InitializeArgs(config);
} }
public int Invoke() public int Invoke()
{ {
throw new NotImplementedException("mac cpp Not supported yet."); var result = InvokeCompiler();
if (result != 0)
{
Reporter.Error.WriteLine("Compilation of intermediate files failed.");
}
return result;
} }
public bool CheckPreReqs() public bool CheckPreReqs()
{ {
throw new NotImplementedException("mac cpp Not supported yet."); // TODO check for clang
return true;
}
private void InitializeArgs(NativeCompileSettings config)
{
var argsList = new List<string>();
// Flags
argsList.Add(cflags);
// Add Includes
argsList.Add("-I");
argsList.Add(Path.Combine(config.AppDepSDKPath, "CPPSdk/osx.10.10"));
argsList.Add("-I");
argsList.Add(Path.Combine(config.AppDepSDKPath, "CPPSdk"));
// Input File
var inCppFile = DetermineInFile(config);
argsList.Add(inCppFile);
// Add Stubs
argsList.Add(Path.Combine(config.AppDepSDKPath, "CPPSdk/osx.10.10/osxstubs.cpp"));
// Lib flags
argsList.Add(libFlags);
// Libs
foreach (var lib in libs)
{
var libPath = Path.Combine(config.IlcPath, lib);
// Forward the library to linked to the linker
argsList.Add("-Xlinker");
argsList.Add(libPath);
}
// AppDep Libs
var baseAppDeplibPath = Path.Combine(config.AppDepSDKPath, "CPPSdk/osx.10.10/x64");
foreach (var lib in appdeplibs)
{
var appDeplibPath = Path.Combine(baseAppDeplibPath, lib);
argsList.Add("-Xlinker");
argsList.Add(appDeplibPath);
}
// Output
var libOut = DetermineOutputFile(config);
argsList.Add($"-o \"{libOut}\"");
this.CompilerArgStr = string.Join(" ", argsList);
}
private int InvokeCompiler()
{
var result = Command.Create(CompilerName, CompilerArgStr)
.ForwardStdErr()
.ForwardStdOut()
.Execute();
return result.ExitCode;
}
private string DetermineInFile(NativeCompileSettings config)
{
var intermediateDirectory = config.IntermediateDirectory;
var filename = Path.GetFileNameWithoutExtension(config.InputManagedAssemblyPath);
var infile = Path.Combine(intermediateDirectory, filename + InputExtension);
return infile;
} }
public string DetermineOutputFile(NativeCompileSettings config) public string DetermineOutputFile(NativeCompileSettings config)
{ {
throw new NotImplementedException("Mac cpp Not supported yet."); var intermediateDirectory = config.OutputDirectory;
}
public bool RequiresLinkStep() var filename = Path.GetFileNameWithoutExtension(config.InputManagedAssemblyPath);
{
return false; var outfile = Path.Combine(intermediateDirectory, filename);
return outfile;
} }
} }
} }

View file

@ -5,7 +5,7 @@
"emitEntryPoint": true "emitEntryPoint": true
}, },
"dependencies": { "dependencies": {
"Microsoft.DotNet.AppDep":"1.0.1-*" "Microsoft.DotNet.AppDep":"1.0.2-*"
}, },
"frameworks": { "frameworks": {
"dnxcore50": { } "dnxcore50": { }

View file

@ -23,7 +23,7 @@
"type": "build", "type": "build",
"version": "1.0.0-*" "version": "1.0.0-*"
}, },
"Microsoft.DotNet.ILCompiler": "1.0.1-*", "Microsoft.DotNet.ILCompiler": "1.0.2-*",
"Microsoft.DotNet.ObjectWriter": "1.0.2-*", "Microsoft.DotNet.ObjectWriter": "1.0.2-*",
"Microsoft.DotNet.RyuJit": "1.0.0-*", "Microsoft.DotNet.RyuJit": "1.0.0-*",
"Microsoft.DotNet.Compiler.Common": "1.0.0-*" "Microsoft.DotNet.Compiler.Common": "1.0.0-*"