如果 GNU make 在 linux 操作系统或 windows 操作系统上运行,有没有办法在 makefile 中知道?
我已经构建了一个 bash 脚本,它生成了一个用于构建我的应用程序的 makefile,它在我的 Debian 机器上运行良好。我想尝试在 MinGW/MSYS 上构建它,但问题是我必须构建和运行一些测试程序来检查源代码中的错误,并且要在 Windows 上运行它,我必须添加 .exe 后缀。
如果 GNU make 在 linux 操作系统或 windows 操作系统上运行,有没有办法在 makefile 中知道?
我已经构建了一个 bash 脚本,它生成了一个用于构建我的应用程序的 makefile,它在我的 Debian 机器上运行良好。我想尝试在 MinGW/MSYS 上构建它,但问题是我必须构建和运行一些测试程序来检查源代码中的错误,并且要在 Windows 上运行它,我必须添加 .exe 后缀。
更新
请阅读这个类似但更好的答案:
https ://stackoverflow.com/a/14777895/938111
make
(和gcc
)可以使用Cygwin或MinGW轻松安装在 MS-Windows 上。
正如@ldigas 所说,make
可以检测使用的平台UNAME:=$(shell uname)
(该命令uname
也由 Cygwin 或 MinGW 安装程序安装)。
下面,我提供一个基于make
(和gcc
)的完整示例来解释如何构建共享库:*.so
或*.dll
取决于平台。
该示例是基本/简单的,易于理解:-)
让我们看看这五个文件:
├── app
│ └── Makefile
│ └── main.c
└── lib
└── Makefile
└── hello.h
└── hello.c
Makefiles
app/Makefile
app.exe: main.o
gcc -o $@ $^ -L../lib -lhello
# '-o $@' => output file => $@ = the target file (app.exe)
# ' $^' => no options => Link all depended files
# => $^ = main.o and other if any
# '-L../lib' => look for libraries in directory ../lib
# '-lhello => use shared library hello (libhello.so or hello.dll)
%.o: %.c
gcc -o $@ -c $< -I ../lib
# '-o $@' => output file => $@ = the target file (main.o)
# '-c $<' => COMPILE the first depended file (main.c)
# '-I ../lib' => look for headers (*.h) in directory ../lib
clean:
rm -f *.o *.so *.dll *.exe
lib/Makefile
UNAME := $(shell uname)
ifeq ($(UNAME), Linux)
TARGET = libhello.so
else
TARGET = hello.dll
endif
$(TARGET): hello.o
gcc -o $@ $^ -shared
# '-o $@' => output file => $@ = libhello.so or hello.dll
# ' $^' => no options => Link all depended files => $^ = hello.o
# '-shared' => generate shared library
%.o: %.c
gcc -o $@ -c $< -fPIC
# '-o $@' => output file => $@ = the target file (hello.o)
# '-c $<' => compile the first depended file (hello.c)
# '-fPIC' => Position-Independent Code (required for shared lib)
clean:
rm -f *.o *.so *.dll *.exe
app/main.c
#include "hello.h" //hello()
#include <stdio.h> //puts()
int main()
{
const char* str = hello();
puts(str);
}
lib/hello.h
#ifndef __HELLO_H__
#define __HELLO_H__
const char* hello();
#endif
lib/hello.c
#include "hello.h"
const char* hello()
{
return "hello";
}
修复Makefiles
副本(用制表符替换前导空格)。
> sed -i 's/^ */\t/' */Makefile
该make
命令在两个平台上是相同的。这是 MS-Windows 上的输出(删除了不必要的行)。
> cd lib
> make clean
> make
gcc -o hello.o -c hello.c -fPIC
gcc -o hello.dll hello.o -shared
> cd ../app
> make clean
> make
gcc -o main.o -c main.c -I ../lib
gcc -o app.exe main.o -L../lib -lhello
应用程序需要知道共享库在哪里。
在 MS-Windows 上,简单/基本/愚蠢的方法是复制应用程序所在的库:
> cp -v lib/hello.dll app
`lib/hello.dll' -> `app/hello.dll'
在 Linux 上,使用LD_LIBRARY_PATH
环境变量:
> export LD_LIBRARY_PATH=lib
两个平台上的运行命令行和输出是相同的:
> app/app.exe
hello
uname命令应该为您提供有关操作系统的基本信息。你可以使用它,然后根据返回值制作一个 IF 吗?
为了不重写所有内容,在这里 - 这两个问题可能会让您感兴趣
1. 操作系统检测 makefile
2. 区分 Windows 和类 Unix 系统的 Makefile