--- a/Symbian3/PDK/Source/GUID-01E7AE98-024C-4119-87D0-5BB9D53DA119.dita Thu Mar 11 15:24:26 2010 +0000
+++ b/Symbian3/PDK/Source/GUID-01E7AE98-024C-4119-87D0-5BB9D53DA119.dita Thu Mar 11 18:02:22 2010 +0000
@@ -1,102 +1,102 @@
-<?xml version="1.0" encoding="utf-8"?>
-<!-- Copyright (c) 2007-2010 Nokia Corporation and/or its subsidiary(-ies) All rights reserved. -->
-<!-- This component and the accompanying materials are made available under the terms of the License
-"Eclipse Public License v1.0" which accompanies this distribution,
-and is available at the URL "http://www.eclipse.org/legal/epl-v10.html". -->
-<!-- Initial Contributors:
- Nokia Corporation - initial contribution.
-Contributors:
--->
-<!DOCTYPE concept
- PUBLIC "-//OASIS//DTD DITA Concept//EN" "concept.dtd">
-<concept id="GUID-01E7AE98-024C-4119-87D0-5BB9D53DA119" xml:lang="en"><title>Introduction
-to <codeph>libgmodule</codeph></title><shortdesc><codeph>libgmodule</codeph> has APIs that provide a portable method
-for dynamically loading 'plug-ins' or, in other words, DLLs. Any program that
-wants to dynamically load modules must be linked to <codeph>libgmodule</codeph>.</shortdesc><prolog><metadata><keywords/></metadata></prolog><conbody>
-<p>In order to use the <codeph>libgmodule</codeph> APIs, the user must check
-whether dynamic loading of DLLs is supported by the platform by using the <codeph>g_module_supported()</codeph> API
-which returns TRUE if the dynamic loading of modules is supported. P.I.P.S.
-provides the implementation of <codeph>libdl</codeph>, where dynamic loading
-of modules is supported, but to write code which runs across platforms the
-user must do a check before using the <codeph>libgmodule</codeph> APIs. </p>
-<p>If the dynamic loading of DLLs is supported, use <codeph>g_module_open()</codeph> to
-open the module. It takes the name of the module as the first argument and
-the flags as the second argument.</p>
-<note><codeph>G_MODULE_BIND_LOCAL</codeph> is the only flag currently supported.
-The other flags are not supported. If the user specifies any other flag, the
-module is loaded using the flag <codeph>G_MODULE_BIND_LOCAL</codeph> and not
-by the user-specified flag.</note>
-<p><b><codeph>GModule * g_module_open(const gchar *file_name, GModuleFlags
-flags);</codeph></b></p>
-<ul>
-<li><p><b><codeph>file_name</codeph>:</b> The name of the file containing
-the module.</p></li>
-<li><p><b><codeph>flags</codeph>:</b> The flags used for opening the module. </p></li>
-</ul>
-<p>Once the module is opened, the user can find the module symbols (for example,.
-function names) using the function </p>
-<p><codeph>g_module_symbol()</codeph>.</p>
-<p><b><codeph>gboolean g_module_symbol (GModule *module, const gchar *symbol_name,
-gpointer *symbol);</codeph></b></p>
-<ul>
-<li><p><b><codeph>*module</codeph>:</b> This is a pointer returned when a
-module is opened using <codeph>g_module_open()</codeph>.</p></li>
-<li><p><b><codeph>symbol_name</codeph>:</b> This is the ordinal number of
-the symbol that one wants to open. There is a difference between Symbian GLib
-and OSS GLib; as in Linux the <codeph>symbol_name</codeph> is the name of
-the symbol and not a number. The ordinal number must be passed as a string
-and not a number.</p></li>
-<li><p><b><codeph>symbol</codeph>:</b> This is the pointer to the symbol value </p></li>
-</ul>
-<p>The <codeph>GModule</codeph> can be closed by using the <codeph>g_module_close()</codeph> API.
-This API returns TRUE if it successfully closed the module; else it returns
-FALSE.</p>
-<p><b><codeph>gboolean g_module_close(GModule *module);</codeph></b></p>
-<ul>
-<li><p><b><codeph>*module</codeph></b> The <codeph>GModule</codeph> to close. </p></li>
-</ul>
-<p>The following example code explains the usage of the <codeph>libgmodule</codeph> APIs.
-It opens a module <filepath>libmoduletestplugin_a.dll</filepath> and uses
-its <codeph>gplugin_a_func1()</codeph> API which is ordinal number 1. Finally,
-the module is closed.</p>
-<codeblock xml:space="preserve">#include <gmodule.h>
-#include <glib.h>
-typedef int (*SimpleFunc) (void);
-
-int main()
-{
- GModule *module = NULL;
- gpointer func;
- SimpleFunc f_a;
- int retVal;
-
- if (!g_module_supported())
- {
- g_print ("Dynamic Opening of modules is not supported");
- return 1;
- }
-
- /* G_MODULE_BIND_LAZY is overridden and the module is opened with
- * flag G_MODULE_BIND_LOCAL
- */
- module = g_module_open("libmoduletestplugin_a.dll",G_MODULE_BIND_LAZY);
-
- // 1 is the ordinal number for gplugin_a_func1
- if(module && g_module_symbol(module, "1" ,&func))
- {
- f_a = (SimpleFunc)func;
- retVal = f_a();
- g_print("Function at ordinal number 1 of module libgmodule_a returns %d",retVal);
- }
- else
- {
- g_print("Error quering symbol at ordinal number 1");
- return 1;
- }
-
- return 0;
-}</codeblock>
-<p>See the <b>Libgmodule APIs</b> section in <xref href="GUID-4ADD8234-4AFD-4E80-94A4-AC018FE83276.dita">Differences
-between OSS and Symbian GLib</xref> for more details about <codeph>libgmodule</codeph> limitations
-in the Symbian GLib implementation. </p>
+<?xml version="1.0" encoding="utf-8"?>
+<!-- Copyright (c) 2007-2010 Nokia Corporation and/or its subsidiary(-ies) All rights reserved. -->
+<!-- This component and the accompanying materials are made available under the terms of the License
+"Eclipse Public License v1.0" which accompanies this distribution,
+and is available at the URL "http://www.eclipse.org/legal/epl-v10.html". -->
+<!-- Initial Contributors:
+ Nokia Corporation - initial contribution.
+Contributors:
+-->
+<!DOCTYPE concept
+ PUBLIC "-//OASIS//DTD DITA Concept//EN" "concept.dtd">
+<concept id="GUID-01E7AE98-024C-4119-87D0-5BB9D53DA119" xml:lang="en"><title>Introduction
+to <codeph>libgmodule</codeph></title><shortdesc><codeph>libgmodule</codeph> has APIs that provide a portable method
+for dynamically loading 'plug-ins' or, in other words, DLLs. Any program that
+wants to dynamically load modules must be linked to <codeph>libgmodule</codeph>.</shortdesc><prolog><metadata><keywords/></metadata></prolog><conbody>
+<p>In order to use the <codeph>libgmodule</codeph> APIs, the user must check
+whether dynamic loading of DLLs is supported by the platform by using the <codeph>g_module_supported()</codeph> API
+which returns TRUE if the dynamic loading of modules is supported. P.I.P.S.
+provides the implementation of <codeph>libdl</codeph>, where dynamic loading
+of modules is supported, but to write code which runs across platforms the
+user must do a check before using the <codeph>libgmodule</codeph> APIs. </p>
+<p>If the dynamic loading of DLLs is supported, use <codeph>g_module_open()</codeph> to
+open the module. It takes the name of the module as the first argument and
+the flags as the second argument.</p>
+<note><codeph>G_MODULE_BIND_LOCAL</codeph> is the only flag currently supported.
+The other flags are not supported. If the user specifies any other flag, the
+module is loaded using the flag <codeph>G_MODULE_BIND_LOCAL</codeph> and not
+by the user-specified flag.</note>
+<p><b><codeph>GModule * g_module_open(const gchar *file_name, GModuleFlags
+flags);</codeph></b></p>
+<ul>
+<li><p><b><codeph>file_name</codeph>:</b> The name of the file containing
+the module.</p></li>
+<li><p><b><codeph>flags</codeph>:</b> The flags used for opening the module. </p></li>
+</ul>
+<p>Once the module is opened, the user can find the module symbols (for example,.
+function names) using the function </p>
+<p><codeph>g_module_symbol()</codeph>.</p>
+<p><b><codeph>gboolean g_module_symbol (GModule *module, const gchar *symbol_name,
+gpointer *symbol);</codeph></b></p>
+<ul>
+<li><p><b><codeph>*module</codeph>:</b> This is a pointer returned when a
+module is opened using <codeph>g_module_open()</codeph>.</p></li>
+<li><p><b><codeph>symbol_name</codeph>:</b> This is the ordinal number of
+the symbol that one wants to open. There is a difference between Symbian GLib
+and OSS GLib; as in Linux the <codeph>symbol_name</codeph> is the name of
+the symbol and not a number. The ordinal number must be passed as a string
+and not a number.</p></li>
+<li><p><b><codeph>symbol</codeph>:</b> This is the pointer to the symbol value </p></li>
+</ul>
+<p>The <codeph>GModule</codeph> can be closed by using the <codeph>g_module_close()</codeph> API.
+This API returns TRUE if it successfully closed the module; else it returns
+FALSE.</p>
+<p><b><codeph>gboolean g_module_close(GModule *module);</codeph></b></p>
+<ul>
+<li><p><b><codeph>*module</codeph></b> The <codeph>GModule</codeph> to close. </p></li>
+</ul>
+<p>The following example code explains the usage of the <codeph>libgmodule</codeph> APIs.
+It opens a module <filepath>libmoduletestplugin_a.dll</filepath> and uses
+its <codeph>gplugin_a_func1()</codeph> API which is ordinal number 1. Finally,
+the module is closed.</p>
+<codeblock xml:space="preserve">#include <gmodule.h>
+#include <glib.h>
+typedef int (*SimpleFunc) (void);
+
+int main()
+{
+ GModule *module = NULL;
+ gpointer func;
+ SimpleFunc f_a;
+ int retVal;
+
+ if (!g_module_supported())
+ {
+ g_print ("Dynamic Opening of modules is not supported");
+ return 1;
+ }
+
+ /* G_MODULE_BIND_LAZY is overridden and the module is opened with
+ * flag G_MODULE_BIND_LOCAL
+ */
+ module = g_module_open("libmoduletestplugin_a.dll",G_MODULE_BIND_LAZY);
+
+ // 1 is the ordinal number for gplugin_a_func1
+ if(module && g_module_symbol(module, "1" ,&func))
+ {
+ f_a = (SimpleFunc)func;
+ retVal = f_a();
+ g_print("Function at ordinal number 1 of module libgmodule_a returns %d",retVal);
+ }
+ else
+ {
+ g_print("Error quering symbol at ordinal number 1");
+ return 1;
+ }
+
+ return 0;
+}</codeblock>
+<p>See the <b>Libgmodule APIs</b> section in <xref href="GUID-4ADD8234-4AFD-4E80-94A4-AC018FE83276.dita">Differences
+between OSS and Symbian GLib</xref> for more details about <codeph>libgmodule</codeph> limitations
+in the Symbian GLib implementation. </p>
</conbody></concept>
\ No newline at end of file