Include header path change from Windows to Linux

2019-01-18 12:57发布

I'm porting an application written in C++ from Windows to Linux. I have a problem with the header files path. Windows uses \ and Linux uses /. I am finding it cumbersome to change this in each and every source and header file. Is there some work around?

6条回答
对你真心纯属浪费
2楼-- · 2019-01-18 13:28

You people! Yes, you can, and should, always use forward slashes. I think the issue is how to get there from here!

If you have Perl installed, the following one liner will convert a C++ source file to use forward slashes, saving the original version in a file with extension .bak:

perl -i.bak -pe "tr!\\!/! if /^\s*#\s*include\b/" myfile.cpp

(The above command line is for Windows; if you're using Linux or other Unix-like shell, use single quotes around the 3rd parameter instead of double quotes.)

If you have a bunch of files you need to convert, say all files ending in .cpp:

for %f in (*.cpp) do perl -i.bak -pe "tr!\\!/! if /^\s*#\s*include\b/" %f

The corresponding command for a Bourne shell environment (typical Linux shell):

for f in *.cpp; do perl -i.bak -pe 'tr!\\!/! if /^\s*#\s*include\b/' $f; done

If you don't have Perl installed, you should be able to find a text editor that allows search and replace across files.

查看更多
孤傲高冷的网名
3楼-- · 2019-01-18 13:29

Always use forward slashes in #include directives. Some operating systems / compilers require it, and Windows / Visual Studio is smart enough to handle it correctly.

Since your starting with Windows code, I'm assuming that you have Visual Studio. Use the find and replace dialog and create a regular expression that will do the substitution for you. Run the find and replace on all files.

For example, use something like this:

#include:b+<{[^\\\>]}\\

for your search expression and

#include <\1

for the replace expression (warning: untested). Run this on all files until no replacements are made. Then switch the angled brackets to quotes and repeat.

查看更多
我命由我不由天
4楼-- · 2019-01-18 13:33

You can try this command based on previous perl command which do the work recusrively

find .  -type f -name \* | xargs grep '#include' | grep '\\' |awk -F: '{print $1}'|sort| uniq | xargs -n1 perl -i.bak -pe 'tr!\\!/! if /^\s*#\s*include\b/'
查看更多
唯我独甜
5楼-- · 2019-01-18 13:42

What version of Windows are you using? As far as I know, starting with Windows XP, forward-slashes do actually work as path delimiters.

查看更多
迷人小祖宗
6楼-- · 2019-01-18 13:45

Always use forward slashes in #include paths. It is the compiler's job to map the path to whatever slash/directory scheme the underlying OS supports.

查看更多
爱情/是我丢掉的垃圾
7楼-- · 2019-01-18 13:46

The Windows APIs has always supported forward slash as directory separator. And that is because as far back as at least DOS 3.1 it was supported as well. The problem has always been COMMAND.COM and CMD.EXE. They use forward slash as the option indicator (instead of dash as found in Unix). Never ever use backslashes for directory separators in languages where a backslash in a string is used to escape special characters.

If you lack a Unix shell, don't you have an editor that does search/replace across multiple files? Heck, write a small program to do it if you have to. Parsing C++ source code for its #include statements can't be hard.

查看更多
登录 后发表回答