launcher. For Python2, we bundle embedded launcher as bootstrapper within every .par file. This feature is only enabled for linux_x86_64 for now. We provide a user flag: hermetic_enabled within bp file. By default, Pyhon2 still use classic bootstrapping way to construct .par file and relys on host interpreter. Once embedded_launcher is enabled, launcher will be used to bootstrap .par file and execute user program. For Python3, the launcher will be ready soon, and for now it still relys on classic bootstrapping. Test: Real example is used to test. Bug: b/63018041 Change-Id: I28deba413d8ad3af407595e46f77d663e79a3705
		
			
				
	
	
		
			76 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // 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{}
 | |
| 
 | |
| 	p.subAndroidMk(&ret, p.installer)
 | |
| 
 | |
| 	return ret
 | |
| }
 | |
| 
 | |
| func (p *binaryDecorator) AndroidMk(base *Module, ret *android.AndroidMkData) {
 | |
| 	ret.Class = "EXECUTABLES"
 | |
| 	base.subAndroidMk(ret, p.baseInstaller)
 | |
| }
 | |
| 
 | |
| func (p *testDecorator) AndroidMk(base *Module, ret *android.AndroidMkData) {
 | |
| 	ret.Class = "NATIVE_TESTS"
 | |
| 	base.subAndroidMk(ret, p.binaryDecorator.baseInstaller)
 | |
| }
 | |
| 
 | |
| 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.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)
 | |
| 	})
 | |
| }
 |