huangcm
2025-09-01 53d8e046ac1bf2ebe94f671983e3d3be059df91a
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
// Copyright 2017 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 python
 
import (
   "android/soong/android"
   "fmt"
   "io"
   "path/filepath"
   "strings"
)
 
type subAndroidMkProvider interface {
   AndroidMk(*Module, *android.AndroidMkData)
}
 
func (p *Module) subAndroidMk(data *android.AndroidMkData, obj interface{}) {
   if p.subAndroidMkOnce == nil {
       p.subAndroidMkOnce = make(map[subAndroidMkProvider]bool)
   }
   if androidmk, ok := obj.(subAndroidMkProvider); ok {
       if !p.subAndroidMkOnce[androidmk] {
           p.subAndroidMkOnce[androidmk] = true
           androidmk.AndroidMk(p, data)
       }
   }
}
 
func (p *Module) AndroidMk() android.AndroidMkData {
   ret := android.AndroidMkData{OutputFile: p.installSource}
 
   p.subAndroidMk(&ret, p.installer)
 
   return ret
}
 
func (p *binaryDecorator) AndroidMk(base *Module, ret *android.AndroidMkData) {
   ret.Class = "EXECUTABLES"
 
   ret.Extra = append(ret.Extra, func(w io.Writer, outputFile android.Path) {
       if len(p.binaryProperties.Test_suites) > 0 {
           fmt.Fprintln(w, "LOCAL_COMPATIBILITY_SUITE :=",
               strings.Join(p.binaryProperties.Test_suites, " "))
       }
   })
   base.subAndroidMk(ret, p.pythonInstaller)
}
 
func (p *testDecorator) AndroidMk(base *Module, ret *android.AndroidMkData) {
   ret.Class = "NATIVE_TESTS"
 
   ret.Extra = append(ret.Extra, func(w io.Writer, outputFile android.Path) {
       if len(p.binaryDecorator.binaryProperties.Test_suites) > 0 {
           fmt.Fprintln(w, "LOCAL_COMPATIBILITY_SUITE :=",
               strings.Join(p.binaryDecorator.binaryProperties.Test_suites, " "))
       }
       // If the test config has an explicit config specified use it.
       if p.testProperties.Test_config != nil {
           fmt.Fprintln(w, "LOCAL_TEST_CONFIG :=",
               *p.testProperties.Test_config)
       } else {
           if p.testConfig != nil {
               fmt.Fprintln(w, "LOCAL_FULL_TEST_CONFIG :=",
                   p.testConfig.String())
           }
       }
   })
   base.subAndroidMk(ret, p.binaryDecorator.pythonInstaller)
}
 
func (installer *pythonInstaller) AndroidMk(base *Module, ret *android.AndroidMkData) {
   // Soong installation is only supported for host modules. Have Make
   // installation trigger Soong installation.
   if base.Target().Os.Class == android.Host {
       ret.OutputFile = android.OptionalPathForPath(installer.path)
   }
 
   ret.Required = append(ret.Required, "libc++")
   ret.Extra = append(ret.Extra, func(w io.Writer, outputFile android.Path) {
       path := installer.path.RelPathString()
       dir, file := filepath.Split(path)
       stem := strings.TrimSuffix(file, filepath.Ext(file))
 
       fmt.Fprintln(w, "LOCAL_MODULE_SUFFIX := "+filepath.Ext(file))
       fmt.Fprintln(w, "LOCAL_MODULE_PATH := $(OUT_DIR)/"+filepath.Clean(dir))
       fmt.Fprintln(w, "LOCAL_MODULE_STEM := "+stem)
       fmt.Fprintln(w, "LOCAL_SHARED_LIBRARIES := "+strings.Join(installer.androidMkSharedLibs, " "))
   })
}