Jump to content

SomGetInitFunction: Difference between revisions

From EDM2
Created page with "{{DISPLAYTITLE:somGetInitFunction}} This method obtains the name of the function that initializes the SOM classes in a class library. For backward compatibility, this method ..."
 
Ak120 (talk | contribs)
mNo edit summary
 
Line 4: Line 4:
For backward compatibility, this method does not take an Environment parameter.
For backward compatibility, this method does not take an Environment parameter.


; Original Class : [[SOMClassMgr]]
;Original Class : [[SOMClassMgr]]


==Syntax==
==Syntax==
Line 10: Line 10:


==Parameters==
==Parameters==
; receiver (SOMClassMgr) : Usually SOMClassMgrObject (or a pointer to an instance of a user-supplied subclass of SOMClassMgr).  
;receiver (SOMClassMgr) : Usually SOMClassMgrObject (or a pointer to an instance of a user-supplied subclass of SOMClassMgr).
 
==Return Code==
==Return Code==
; rc (string) : Returns a string that names the initialization function of class libraries. By default, this name is the value of the global variable SOMClassInitFuncName, the default value of which is SOMInitModule.  
;rc (string) : Returns a string that names the initialization function of class libraries. By default, this name is the value of the global variable SOMClassInitFuncName, the default value of which is SOMInitModule.


==Remarks==
==Remarks==
Line 30: Line 31:


==Example Code==
==Example Code==
<PRE>
</PRE>


==Related==
==Related==
===Methods===
;Methods
* [[somFindClass]]
* [[somFindClass]]
* [[somFindClsInFile]]  
* [[somFindClsInFile]]  
===Functions===
;Functions
* [[SOMInitModule]]
* [[SOMInitModule]]
===Macros===
;Macros
* [[SOM_ClassLibrary]]
* [[SOM_ClassLibrary]]


[[Category:SOMClassMgr]]
[[Category:SOMClassMgr]]

Latest revision as of 17:17, 12 October 2022

This method obtains the name of the function that initializes the SOM classes in a class library.

For backward compatibility, this method does not take an Environment parameter.

Original Class
SOMClassMgr

Syntax

string somGetInitFunction (SOMClassMgr receiver)

Parameters

receiver (SOMClassMgr)
Usually SOMClassMgrObject (or a pointer to an instance of a user-supplied subclass of SOMClassMgr).

Return Code

rc (string)
Returns a string that names the initialization function of class libraries. By default, this name is the value of the global variable SOMClassInitFuncName, the default value of which is SOMInitModule.

Remarks

The somGetInitFunction method supplies the name of the initialization function for OS/2 class libraries (DLLs) that contain more than one SOM class. The default implementation returns the value of the global variable SOMClassInitFuncName, which by default is set to the value "SOMInitModule".

For AIX, the name of the class initialization function is not important, since AIX class libraries should always be constructed as shared libraries with a designated entry point which can be executed automatically by the loader when the class is loaded. Consequently, the result of this method is not significant on AIX.

Similarly, if an OS/2 class library (DLL) has been constructed with a DLL initialization function assigned by the linker, you can choose to invoke the <className>NewClass functions for all of the classes in the DLL during DLL initialization. In this case (as on AIX), there is no need to export a "SOMInitModule" function. On the other hand, if your compiler does not provide a convenient mechanism for creating a DLL initialization function, you can elect to export a function named "SOMInitModule" (or whatever name is ultimately returned by the somGetInitFunction method).

The OS/2 SOMClassMgrObject, after loading a class library, will invoke the method somGetInitFunction to obtain the name of a possible initialization function. If this name has been exported by the class library just loaded, the SOMClassMgrObject calls this function to initialize the classes in the library. If the name has not been exported by the DLL, the SOMClassMgrObject then looks for an exported name of the form <className>NewClass, where <className> is the name of the class supplied with the method that caused the DLL to be loaded. If the DLL exports this name, it is invoked to create the named class.

On Windows, the SOM class manager does not call SOMInitModule. It must be called from the default Windows DLL initialization function, LibMain. This call is made indirectly through the SOM_ClassLibrary macro.

Regardless of the technique employed, the SOMClassMgrObject expects that all classes packaged in a single class library will be created during this sequence.

This method is generally not invoked directly by users. User-defined subclasses of SOMClassMgr, however, can override this method.

Example Code

Related

Methods
Functions
Macros