Automatically detect wrong lib-format for borland compiler?
data:image/s3,"s3://crabby-images/33250/33250af20922a831c31f7ef0da1e3e089214cd2b" alt=""
I just had the idea to make bcccompiler a little bit more robust. By default, python is delivered with pythonxx.lib and pythonxx_d.lib import libraries generated by MSVC, which are in COFF format. By inspection I found that these libraries start with the bytes '!<arch>./' (without the single quotes). Shouldn't we open these files and issue a warning or error if they start with these bytes? We could even invoke borland's coff2omf utility to convert them... Thomas
data:image/s3,"s3://crabby-images/61895/6189501b307830d8dc593878d934a86e9a6af803" alt=""
Thomas Heller wrote:
'!<arch>\012/'
But where to write the converted files, in the python libs directory is not a good idea and if you would write them in the build-temp directory you had to add code to find_library_file(). It might be better to have script(s) in the misc directory, which checks for a certain compiler the libraries and converts them if necessary. The compiler classes would print a warning/error message about the wrong format and could mention how to convert the library.
data:image/s3,"s3://crabby-images/e9278/e9278595335de2a1c80f256e56b102d21fb342c3" alt=""
On 29 September 2000, Rene Liebscher said:
I think I prefer this approach -- easy to go overboard here. Being smart enough to *detect* a possible bad situation is reasonable, but trying to be smart enough to *correct* it is asking for trouble. Greg -- Greg Ward gward@python.net http://starship.python.net/~gward/
data:image/s3,"s3://crabby-images/33250/33250af20922a831c31f7ef0da1e3e089214cd2b" alt=""
Also see the recent thread in c.l.p (which says, as I understand it: using the MSVC import libraries with borland-compiled extensions is at least dangerous, because the wrong C-runtime library may be used for stdoi) Thomas
data:image/s3,"s3://crabby-images/61895/6189501b307830d8dc593878d934a86e9a6af803" alt=""
Thomas Heller wrote:
'!<arch>\012/'
But where to write the converted files, in the python libs directory is not a good idea and if you would write them in the build-temp directory you had to add code to find_library_file(). It might be better to have script(s) in the misc directory, which checks for a certain compiler the libraries and converts them if necessary. The compiler classes would print a warning/error message about the wrong format and could mention how to convert the library.
data:image/s3,"s3://crabby-images/e9278/e9278595335de2a1c80f256e56b102d21fb342c3" alt=""
On 29 September 2000, Rene Liebscher said:
I think I prefer this approach -- easy to go overboard here. Being smart enough to *detect* a possible bad situation is reasonable, but trying to be smart enough to *correct* it is asking for trouble. Greg -- Greg Ward gward@python.net http://starship.python.net/~gward/
data:image/s3,"s3://crabby-images/33250/33250af20922a831c31f7ef0da1e3e089214cd2b" alt=""
Also see the recent thread in c.l.p (which says, as I understand it: using the MSVC import libraries with borland-compiled extensions is at least dangerous, because the wrong C-runtime library may be used for stdoi) Thomas
participants (3)
-
Greg Ward
-
Rene Liebscher
-
Thomas Heller