|  | // Copyright 2016 Google Inc. All rights reserved. | 
|  | // | 
|  | // Licensed under the Apache License, Version 2.0 (the "License"); | 
|  | // you may not use this file except in compliance with the License. | 
|  | // You may obtain a copy of the License at | 
|  | // | 
|  | //     http://www.apache.org/licenses/LICENSE-2.0 | 
|  | // | 
|  | // Unless required by applicable law or agreed to in writing, software | 
|  | // distributed under the License is distributed on an "AS IS" BASIS, | 
|  | // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | // See the License for the specific language governing permissions and | 
|  | // limitations under the License. | 
|  |  | 
|  | package cc | 
|  |  | 
|  | import ( | 
|  | "strings" | 
|  |  | 
|  | "android/soong/android" | 
|  | ) | 
|  |  | 
|  | // StripProperties defines the type of stripping applied to the module. | 
|  | type StripProperties struct { | 
|  | Strip struct { | 
|  | // none forces all stripping to be disabled. | 
|  | // Device modules default to stripping enabled leaving mini debuginfo. | 
|  | // Host modules default to stripping disabled, but can be enabled by setting any other | 
|  | // strip boolean property. | 
|  | None *bool `android:"arch_variant"` | 
|  |  | 
|  | // all forces stripping everything, including the mini debug info. | 
|  | All *bool `android:"arch_variant"` | 
|  |  | 
|  | // keep_symbols enables stripping but keeps all symbols. | 
|  | Keep_symbols *bool `android:"arch_variant"` | 
|  |  | 
|  | // keep_symbols_list specifies a list of symbols to keep if keep_symbols is enabled. | 
|  | // If it is unset then all symbols are kept. | 
|  | Keep_symbols_list []string `android:"arch_variant"` | 
|  |  | 
|  | // keep_symbols_and_debug_frame enables stripping but keeps all symbols and debug frames. | 
|  | Keep_symbols_and_debug_frame *bool `android:"arch_variant"` | 
|  | } `android:"arch_variant"` | 
|  | } | 
|  |  | 
|  | // Stripper defines the stripping actions and properties for a module. | 
|  | type Stripper struct { | 
|  | StripProperties StripProperties | 
|  | } | 
|  |  | 
|  | // NeedsStrip determines if stripping is required for a module. | 
|  | func (stripper *Stripper) NeedsStrip(actx android.ModuleContext) bool { | 
|  | forceDisable := Bool(stripper.StripProperties.Strip.None) | 
|  | defaultEnable := (!actx.Config().KatiEnabled() || actx.Device()) | 
|  | forceEnable := Bool(stripper.StripProperties.Strip.All) || | 
|  | Bool(stripper.StripProperties.Strip.Keep_symbols) || | 
|  | Bool(stripper.StripProperties.Strip.Keep_symbols_and_debug_frame) | 
|  | return !forceDisable && (forceEnable || defaultEnable) | 
|  | } | 
|  |  | 
|  | func (stripper *Stripper) strip(actx android.ModuleContext, in android.Path, out android.ModuleOutPath, | 
|  | flags StripFlags, isStaticLib bool) { | 
|  | if actx.Darwin() { | 
|  | transformDarwinStrip(actx, in, out) | 
|  | } else { | 
|  | if Bool(stripper.StripProperties.Strip.Keep_symbols) { | 
|  | flags.StripKeepSymbols = true | 
|  | } else if Bool(stripper.StripProperties.Strip.Keep_symbols_and_debug_frame) { | 
|  | flags.StripKeepSymbolsAndDebugFrame = true | 
|  | } else if len(stripper.StripProperties.Strip.Keep_symbols_list) > 0 { | 
|  | flags.StripKeepSymbolsList = strings.Join(stripper.StripProperties.Strip.Keep_symbols_list, ",") | 
|  | } else if !Bool(stripper.StripProperties.Strip.All) { | 
|  | flags.StripKeepMiniDebugInfo = true | 
|  | } | 
|  | if actx.Config().Debuggable() && !flags.StripKeepMiniDebugInfo && !isStaticLib { | 
|  | flags.StripAddGnuDebuglink = true | 
|  | } | 
|  | transformStrip(actx, in, out, flags) | 
|  | } | 
|  | } | 
|  |  | 
|  | // StripExecutableOrSharedLib strips a binary or shared library from its debug | 
|  | // symbols and other debugging information. The helper function | 
|  | // flagsToStripFlags may be used to generate the flags argument. | 
|  | func (stripper *Stripper) StripExecutableOrSharedLib(actx android.ModuleContext, in android.Path, | 
|  | out android.ModuleOutPath, flags StripFlags) { | 
|  | stripper.strip(actx, in, out, flags, false) | 
|  | } | 
|  |  | 
|  | // StripStaticLib strips a static library from its debug symbols and other | 
|  | // debugging information. The helper function flagsToStripFlags may be used to | 
|  | // generate the flags argument. | 
|  | func (stripper *Stripper) StripStaticLib(actx android.ModuleContext, in android.Path, out android.ModuleOutPath, | 
|  | flags StripFlags) { | 
|  | stripper.strip(actx, in, out, flags, true) | 
|  | } |