bash – 来自Android.mk的Shell脚本调用,标准输出和缺少的分隔符错误

前端之家收集整理的这篇文章主要介绍了bash – 来自Android.mk的Shell脚本调用,标准输出和缺少的分隔符错误前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个简单的Android.mk文件
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)

$(shell ($(LOCAL_PATH)/echo_test.sh))

LOCAL_MODULE := libecho_test
LOCAL_MODULE_TAGS := optional
include $(BUILD_SHARED_LIBRARY)

它有趣的是调用’echo_test.sh’bash脚本.在脚本的内容是的情况下

#!/bin/bash
echo 'echo is working' >&2

要么

#!/bin/bash
echo 'echo is working' >/dev/null

一切都好.

bash脚本出现问题

#!/bin/bash
echo 'echo is working'

要么

#!/bin/bash
echo 'echo is working' >&1

然后返回的错误

Android.mk:4: *** missing separator.  Stop.

Android NDK 7以及在Android Ice Cream Sandwich 4.0.3的构建过程中包含此模块时都会发生这种情况.

我真的无法理解标准输出和Android构建系统的处理方式.有没有人有解释?

Android NDK构建系统实际上是 @L_502_0@.Android.mk文件中的所有代码都必须是有效的.

当您运行$(shell)并且不将值存储在变量中时,就好像您将脚本的标准输出复制到Android.mk文件中一样.即,就好像你的文件包含以下内容

LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)

echo is working

LOCAL_MODULE := libecho_test
LOCAL_MODULE_TAGS := optional
include $(BUILD_SHARED_LIBRARY)

..这是无效的make语法.在脚本中重定向到>& 2是有效的,因为输出转到错误输出,然后显示在控制台上.

正如Vishrut所提到的,使用$(info)或$(警告)来打印消息.或者,如果您确实希望在构建期间运行脚本,请将其输出存储在变量中:

ECHO_RESULT := $(shell ($(LOCAL_PATH)/echo_test.sh))

在这里你不会看到脚本的echo输出,它会进入变量.

猜你在找的Bash相关文章