tags:

views:

329

answers:

4

Hello,

I am new to c, and I have some been given some source code that someone else has written that was compiled on windows.

After trying to make in compile on linux I have errors because linux doesn't support DWORD, WORD, AND UINT32. I have 6 files for example. A.h, A.c, B.h, B.c, C.h, C.c. These keyword are in all the files.

So I am thinking of 2 possible solutions. Which is better #define or typedef.

1)

typedef unsigned long DWORD;
typedef unsigned short WORD;
typedef unsigned int UNINT32;

2)

#define DWORD unsigned long 
#define WORD unsigned short 
#define UINT32 unsigned int

For the second part I am wondering where should I put these declarations. Should they go in the header files, or should they go in the source files?

For example should I do something like this in the header files, or in the source files?

#ifdef WIN32
/* windows stuff */
#else
typedef unsigned long DWORD;
typedef unsigned short WORD;
typedef unsigned int UNINT32;
#endif

Many thanks for the above suggestions,

+7  A: 

You have found the solution yourself:

#ifdef WIN32
/* windows stuff */
#else
typedef unsigned long DWORD;
typedef unsigned short WORD;
typedef unsigned int UNINT32;
#endif

Put this in a separate header file (typedefs.h) and include it from everywhere. Typedef are always preferred over pre-processor macros.

My recommendation: Do not use DWORD, WORD or other Win32 types. I usually prefer to use C99 standard types: uint_t, int_t or uint16_t, uint32_t

kgiannakakis
Beat me to it .. thats what I get for slow typing
Peter M
If you're going to maintain cross platform compilability, you might want to just put it in a file named windows.h that you keep in a standard location, since that's the file on windows that gets you those declarations.
Rob K
+4  A: 

Typedefs are definitely nicer. #defines are preprocessor macro's and can have unintended consequences, because basically the C preprocessor performs a global search-and-replace for defines. Typedefs are instructions to the compiler, and much better suited for what you want to do.

Emiel
+2  A: 

typedef would be better in this instance because #define is just a generic mechanism but typedef is for defining types which is what you are doing.

I would say put your code:

#ifdef WIN32
/* windows stuff */
#else
typedef unsigned long DWORD;
typedef unsigned short WORD;
typedef unsigned int UNINT32;
#endif

into a new header file (with #define guards/#pragma once), then include that from the header or source files as necessary.

danio
+1  A: 

Using a typedef turns the result into an actual type that gets put into the syntax tree. (In other words, the compilers knows about it and recognizes it as a part of the language.)

#define, in contrast, is just a text-substitution. So the compiler never gets to know about it, it instead just sees whatever it is that gets substituted. This can make finding compile errors harder.

For your case, I would probably recommend typedef. #define has it's place, but I can't see any reason why you wouldn't want to use typedef here.

Be aware that other libraries may have defined these types, so you may have collisions. If you really want to be cross-platform, you might think about defining types with your app's namespace somehow. Like

myapp_dword
myapp_word

in order to minimize collisions with other libraries.

Finally, I would actually recommend against the entire approach you are taking. If at all possible, it is best to use only the typenames defined in the language and in the C standard library (like size_t, etc.) Your code will be more portable, and you will have less headaches.

Christopher
Hello. When you say typenames defined in the language and in the C standard library. Should I change all the DWORD, WORD, and UINT32 these to unsigned long, unsigned short and unsigned int. Instead of using the DWORD, WORD, etc. Is that because those types will work on both windows and linux? Many thanks.
robUK
Yes, generally that is what I am saying. However, the standard C library ALSO defines types that have specific guarantees about range. size_t is a good example of such a type.
Christopher