Merge "Pass library kind when linking native libraries."
This commit is contained in:
13
rust/rust.go
13
rust/rust.go
@@ -623,21 +623,24 @@ func (mod *Module) depsToPaths(ctx android.ModuleContext) PathDeps {
|
|||||||
linkFile := ccDep.OutputFile()
|
linkFile := ccDep.OutputFile()
|
||||||
linkPath := linkPathFromFilePath(linkFile.Path())
|
linkPath := linkPathFromFilePath(linkFile.Path())
|
||||||
libName := libNameFromFilePath(linkFile.Path())
|
libName := libNameFromFilePath(linkFile.Path())
|
||||||
|
depFlag := "-l" + libName
|
||||||
|
|
||||||
if !linkFile.Valid() {
|
if !linkFile.Valid() {
|
||||||
ctx.ModuleErrorf("Invalid output file when adding dep %q to %q", depName, ctx.ModuleName())
|
ctx.ModuleErrorf("Invalid output file when adding dep %q to %q", depName, ctx.ModuleName())
|
||||||
}
|
}
|
||||||
|
|
||||||
exportDep := false
|
exportDep := false
|
||||||
|
|
||||||
switch depTag {
|
switch depTag {
|
||||||
case cc.StaticDepTag:
|
case cc.StaticDepTag:
|
||||||
|
depFlag = "-lstatic=" + libName
|
||||||
depPaths.linkDirs = append(depPaths.linkDirs, linkPath)
|
depPaths.linkDirs = append(depPaths.linkDirs, linkPath)
|
||||||
depPaths.depFlags = append(depPaths.depFlags, "-l"+libName)
|
depPaths.depFlags = append(depPaths.depFlags, depFlag)
|
||||||
directStaticLibDeps = append(directStaticLibDeps, ccDep)
|
directStaticLibDeps = append(directStaticLibDeps, ccDep)
|
||||||
mod.Properties.AndroidMkStaticLibs = append(mod.Properties.AndroidMkStaticLibs, depName)
|
mod.Properties.AndroidMkStaticLibs = append(mod.Properties.AndroidMkStaticLibs, depName)
|
||||||
case cc.SharedDepTag:
|
case cc.SharedDepTag:
|
||||||
|
depFlag = "-ldylib=" + libName
|
||||||
depPaths.linkDirs = append(depPaths.linkDirs, linkPath)
|
depPaths.linkDirs = append(depPaths.linkDirs, linkPath)
|
||||||
depPaths.depFlags = append(depPaths.depFlags, "-l"+libName)
|
depPaths.depFlags = append(depPaths.depFlags, depFlag)
|
||||||
directSharedLibDeps = append(directSharedLibDeps, ccDep)
|
directSharedLibDeps = append(directSharedLibDeps, ccDep)
|
||||||
mod.Properties.AndroidMkSharedLibs = append(mod.Properties.AndroidMkSharedLibs, depName)
|
mod.Properties.AndroidMkSharedLibs = append(mod.Properties.AndroidMkSharedLibs, depName)
|
||||||
exportDep = true
|
exportDep = true
|
||||||
@@ -650,10 +653,10 @@ func (mod *Module) depsToPaths(ctx android.ModuleContext) PathDeps {
|
|||||||
// Make sure these dependencies are propagated
|
// Make sure these dependencies are propagated
|
||||||
if lib, ok := mod.compiler.(*libraryDecorator); ok && exportDep {
|
if lib, ok := mod.compiler.(*libraryDecorator); ok && exportDep {
|
||||||
lib.linkDirs = append(lib.linkDirs, linkPath)
|
lib.linkDirs = append(lib.linkDirs, linkPath)
|
||||||
lib.depFlags = append(lib.depFlags, "-l"+libName)
|
lib.depFlags = append(lib.depFlags, depFlag)
|
||||||
} else if procMacro, ok := mod.compiler.(*procMacroDecorator); ok && exportDep {
|
} else if procMacro, ok := mod.compiler.(*procMacroDecorator); ok && exportDep {
|
||||||
procMacro.linkDirs = append(procMacro.linkDirs, linkPath)
|
procMacro.linkDirs = append(procMacro.linkDirs, linkPath)
|
||||||
procMacro.depFlags = append(procMacro.depFlags, "-l"+libName)
|
procMacro.depFlags = append(procMacro.depFlags, depFlag)
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user