How would you do that? Most users extract the compiler that is mostly shipped as tar.gz to any place on their HDD. Should C::B really search across all your (320GB) HDD's to find MinGW if you know where it is? Any maybe you have two version of GCC installed (as I do) - should C::B just guess which one to use? No thanks. We look at the default "installation" path which is C:\MinGW. If it's not there - the user has to configure it. Period.
With regards, Morten.
I'm talking about cross compiling (look at topic title)
Like most crosscompilers I found, MinGW under Debian is installed under /usr/, more specifically, into /usr/i586-mingw32msvc. There we can find usual bin/, include/, lib/ folders. Nobody said anything about searching entire hard drive. Your statement about only C:\MinGW being supported is also incorrect -- I've seen many machines where MinGW was installed into C:\Dev-Cpp, and C::B properly detected it.
Something tells me that the MinGW compiler will be installed in:
1. /usr/*mingw*
2. /usr/local/*mingw*
3. /opt/*mingw*
Searching inside those folders for ./bin/gcc, perhaps also querying for gcc --version, should provide enough information to "claim" that MinGW
cross-compiler is installed into that folder, by virtues of autodetection.
Topic #2On the other hand, there's another thing that C::B may be lacking in. I am considering using it for PalmOS development, since I don't want to get Palm-customized version of bloat called Eclipse installed. It made me happy when I saw I can choose a custom Makefile. However, launching the program is a bit trickier thing.
There is a freely available PalmOS emulator "pose", and by agreeing to some additional License Agreements
it is possible to get ROMs for that emulator. PRC Tools generate a .prc file (the "executable" on Palm devices). I'd like to automatically transfer it to Palm emulator, by running some commands (more specifically initiate a transfer to the Palm) upon building.
Similar things are done for PocketPC, including running. Both things need custom commands that would be executed upon running. Only ways to remedy this for me are currently are adding a custom tool. That would make testing program a two step process: building (ctrl+f9) and running (alt+t, and then choosing tool).
Running with Wine only works because the Linux kernel can detect PE format and run Wine instead of directly running the application. Requiring such thing with .PRCs and PE/ARM is not very efficient, and probably not possible, since the application is not really executed on the machine (POSE requires a third step of launching the application inside the emulator, WINCE does not even have an emulator for GNU/Linux).
This could be remedied by simply adding another line in this dialog: Settings->Compiler and debugger->Global compiler settings->Toolchain executables. Adding line such as "Launcher" would do much to help me and others who consider C::B for embedded development. Then, when starting the executable, simply prepending the command line with the contents of the option would suffice.
Other possibility is adding a similar thing into Project->Properties->Build targets. Since the selection of "Selected build type options->Type" between GUI application and Console application already modifies the command line (the cb_console_runner), this might also be a logical place to put it, although it's more of platform ("toolchain") specific than project specific thing.
And before anyone suggests so, yes, it would be possible for me to modify the custom makefile, but let's pretend that I want to use C::B's UI for project file management wherever possible.