Solved

HWND and HMODULE

Posted on 2008-06-16
19
1,889 Views
Last Modified: 2010-04-21
Hello
I have a code where, following is written for a GUI C/C++ app(VC++ .NET2003):

typedef struct tagAPPINFO {
   INT      iVersion;
   INT      iFiller;

   HWND     hAppInst;
   INT      iAppType;

   HWND     hWndFrame;
   HWND     hWndMDIClient;
   HWND     hWndToolbar;
   HWND     hWndStatbar;

   UINT     uMemBlocks;
   UINT     uMemBlockSize;

   char     szAppName  [MAXOBJNAME      + 2];
   char     szFileName [FILENAME_LENGTH + 2];
   char     szHelpFile [PATHNAME_LENGTH + 2];
   char     szPathName [PATHNAME_LENGTH + 2];
   BOOL     bDeltaMode;
   char     szSysPathName[PATHNAME_LENGTH + 2];
   } APPINFO;

static HMODULE hResourceModuke;
main()
{
APPINFO appinfo;
appinfo.hAppInst=hResourceModuke;
}

As a beginner, I would like to understand the purpose of HWND and HMODULE?

Regards
Sham
0
Comment
Question by:sham_ibmgs
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 11
  • 8
19 Comments
 
LVL 40

Expert Comment

by:evilrix
ID: 21791999
They are both handles. HWND is a window handle and HMODULE is a module handle. They are used to represent, internally to the WIN32 API, a windows and a module respectively. I'm sure you've already figure this out though, so is there anything specific you don't get?
0
 

Author Comment

by:sham_ibmgs
ID: 21792046
@evil: I already figure this out but, i would like to know, when shoule i use HWND and when should i use HMODULE from application perspective? and any difference between HWND and HMODULE?

am new to this kind of GUI programming!!!!!!

Regards
Sham
0
 

Author Comment

by:sham_ibmgs
ID: 21792059
@evil: What do u mean, when u say, "internally to the WIN32 API, a windows and a module respectively"


Regards
Sham
0
Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
LVL 40

Accepted Solution

by:
evilrix earned 100 total points
ID: 21792121
I'm not sure what you mean in so far as when to use which. The documentation for a specific WIN32 API function will tell you whether it expects a handle to a window to a handle to a module. Generally, if the function is manipulating a window it will expect a HWND and if it is working with a module it will expect a HMODULE. For example, GetWindowText(), given a HWND to a window will give you the title for that window.

>> What do u mean, when u say, "internally to the WIN32 API, a windows and a module respectively"
The handle is just an opaque 32 bit value that is created by the API to reference an object. The relationship between this and the object it represents is managed by the API, you just need to pass it the handle to the object you wish to reference. For example, when you call CreateWindow, you'll get a handle to the window created. You can then reference that window using this handle. How this handle gets created or what it actually represents internally (it might be a pointer or an index into a table for example) to the API is not relevant to you (this is by design, you shouldn't need to know!), you just need to know that it references the window you've created.
0
 

Author Comment

by:sham_ibmgs
ID: 21792168
@evil: WHat about HMODULE? As u said HWND points to any window kind of object, To which type of object does HMODULE point?

Regards
Sham
0
 
LVL 40

Expert Comment

by:evilrix
ID: 21792185
HMODULE represent a module... a module would be a DLL or an executable (EXE).
See the help for GetModuleHandle() and GetModuleFilename()
http://msdn.microsoft.com/en-us/library/ms683199(VS.85).aspx
http://msdn.microsoft.com/en-us/library/ms683197(VS.85).aspx
0
 

Author Comment

by:sham_ibmgs
ID: 21792191
@evil: what do u mean by term module here: "  if it is working with a module it will expect a HMODULE"

module mean a function?

Regards
Sham
0
 
LVL 40

Expert Comment

by:evilrix
ID: 21792195
>> if it is working with a module it will expect a HMODULE
If the function is used to work with or manupulate a module, for example GetModuleFilename() returns the filename of a module (see my post above).
0
 

Author Closing Comment

by:sham_ibmgs
ID: 31467526
Done
0
 

Author Comment

by:sham_ibmgs
ID: 21792370
Hello

We have a code where  HMODULE object is asssigned to HWND object as below:

hAPPINST=hResourceModule;

hAPPINST is of type HWND and hResourceModule is of type HMODULE

Regards
Sham
 


0
 

Author Comment

by:sham_ibmgs
ID: 21792376
@evil: How can a module type handle be assigned to window type handle?

Regards
Sham
0
 
LVL 40

Expert Comment

by:evilrix
ID: 21792386
Without seeing the code and the context I can't answer that... a HWND and a HMODULE are not related types, I presume there is a cast involved in this otherwise it shouldn't compile?
#include <windows.h>
 
int main()
{
	HWND hWnd = 0;
	HMODULE hModule = hWnd;
}
 
1>------ Build started: Project: testr, Configuration: Debug Win32 ------
1>Compiling...
1>main.cpp
1>main.cpp(6) : error C2440: 'initializing' : cannot convert from 'HWND' to 'HMODULE'
1>        Types pointed to are unrelated; conversion requires reinterpret_cast, C-style cast or function-style cast
1>Build log was saved at "file:BuildLog.htm"
1>testr - 1 error(s), 0 warning(s)
========== Build: 0 succeeded, 1 failed, 0 up-to-date, 0 skipped ==========

Open in new window

0
 

Author Comment

by:sham_ibmgs
ID: 21792439
@evil: Here is the code
typedef struct tagAPPINFO {
   INT      iVersion;
   INT      iFiller;

   HWND     hAppInst;
   INT      iAppType;

   HWND     hWndFrame;
   HWND     hWndMDIClient;
   HWND     hWndToolbar;
   HWND     hWndStatbar;

   UINT     uMemBlocks;
   UINT     uMemBlockSize;

   char     szAppName  [MAXOBJNAME      + 2];
   char     szFileName [FILENAME_LENGTH + 2];
   char     szHelpFile [PATHNAME_LENGTH + 2];
   char     szPathName [PATHNAME_LENGTH + 2];
   BOOL     bDeltaMode;
   char     szSysPathName[PATHNAME_LENGTH + 2];
   } APPINFO;

static HMODULE hResourceModuke;
APPINFO  appInfo;
#define hAPPINST  appInfo.hAppInst  // this is header file  

int WINAPI TNGMain (LPSTR lpszCmdLine, ULONG TNGContext, int nCmdShow, HWND hParent)
{
/* clear application information structure */
   memset  (&appInfo, '\0', sizeof (APPINFO));

   /* save instance handle in structure */
   hAPPINST = hResourceModule;
   hWndParent = hParent;

   /* set other application information in structure */
   appInfo.iVersion      = iVERSION;
   appInfo.uMemBlocks    = NUMMEMBLOCKS;
   appInfo.uMemBlockSize = MEMBLOCKSIZE;
   strncpy(appInfo.szAppName,  szAPPNAME, MAXOBJNAME);
   strcpy(appInfo.szFileName, szFILENAME);
   strcpy(appInfo.szHelpFile, sz2DHELPFILE);

   /* register window classes if this is the first instance */
   if (!RegisterClasses (hAPPINST))
      return FALSE;
.
.
.
}

Regards
Sham

0
 
LVL 40

Expert Comment

by:evilrix
ID: 21792470
Are you sure that...

#define hAPPINST  appInfo.hAppInst  // this is header file  

...isn't being conditionally precompile to be either a HWND or a HMODULE depending upon build settings? Try changing hAPPINST = hResourceModule to be appInfo.hAppInst = hResourceModule and also, put a break point on this line to confirm the type is HWND. As you an see above, the types are not compatible under normal circumstances.
0
 

Author Comment

by:sham_ibmgs
ID: 21792682
am sure about it.

i wrote:

appInfo.hAppInst = hResourceModule; and compiled, it worked

Regards
Sham
 
0
 

Author Comment

by:sham_ibmgs
ID: 21792697
@evil: i placed another question with subject "wndclass and registerclass", Can u please look into that?

Regards
Sham
0
 
LVL 40

Expert Comment

by:evilrix
ID: 21792718
Then, I have to be honest, I don't know. I tested this in VS2005 and the types are not compatible.
0
 

Author Comment

by:sham_ibmgs
ID: 21792720
@evil: How do i know, whether, currently HWND/HMODULE pointer is pointed to some object or is NULL? can we write some debug statement?

Regards
Sham


0
 
LVL 40

Expert Comment

by:evilrix
ID: 21792750
>> How do i know, whether, currently HWND/HMODULE pointer is pointed to some object or is NULL?
Something like this maybe?
#include <windows.h>
 
int main()
{
	HWND hWnd = NULL;
	HMODULE hModule = NULL;
 
	if(NULL == hWnd) { /* it's null */ }
	if(NULL == hModule) { /* it's null */ }
 
	if(NULL != hWnd) { /* it's not null */ }
	if(NULL != hModule) { /* it's not null */ }
}

Open in new window

0

Featured Post

Free Tool: Subnet Calculator

The subnet calculator helps you design networks by taking an IP address and network mask and returning information such as network, broadcast address, and host range.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

The following diagram presents a diamond class hierarchy: As depicted, diamond inheritance denotes when two classes (e.g., CDerived1 and CDerived2), separately extending a common base class (e.g., CBase), are sub classed simultaneously by a fourt…
Go is an acronym of golang, is a programming language developed Google in 2007. Go is a new language that is mostly in the C family, with significant input from Pascal/Modula/Oberon family. Hence Go arisen as low-level language with fast compilation…
The viewer will learn how to pass data into a function in C++. This is one step further in using functions. Instead of only printing text onto the console, the function will be able to perform calculations with argumentents given by the user.
The viewer will be introduced to the member functions push_back and pop_back of the vector class. The video will teach the difference between the two as well as how to use each one along with its functionality.

759 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question