Symbian3/SDK/Source/GUID-38BE7105-309E-5372-98EE-BCA0ADD0ACBA.dita
changeset 7 51a74ef9ed63
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Symbian3/SDK/Source/GUID-38BE7105-309E-5372-98EE-BCA0ADD0ACBA.dita	Wed Mar 31 11:11:55 2010 +0100
@@ -0,0 +1,47 @@
+<?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-38BE7105-309E-5372-98EE-BCA0ADD0ACBA" xml:lang="en"><title>Hybrid
+Applications</title><prolog><metadata><keywords/></metadata></prolog><conbody>
+<p>P.I.P.S. applications can be written either as pure C or as hybrid applications
+which mix native Symbian C++ and Standard C. In addition to the core P.I.P.S.
+libraries, an application can also use P.I.P.S. extensions or third-party
+C shared libraries. Hybrid applications can also link against native Symbian
+platform libraries. </p>
+<p>The use cases for hybrid applications are as follows: </p>
+<ul>
+<li id="GUID-2FDE4170-7A71-5047-BC65-5089DB717746"><p>Native Symbian <codeph>EXE</codeph> using
+both Standard C and native Symbian platform C++ APIs </p> </li>
+<li id="GUID-8D102C96-50B5-51B1-884B-76F9646D7BBF"><p> <codeph>STDEXE</codeph> using
+both Standard C and native Symbian platform C++ APIs </p> </li>
+<li id="GUID-240056C6-0296-5C1C-BCB1-281E28F30841"><p>Native Symbian <codeph>EXE</codeph> depending
+on an <codeph>STDDLL</codeph> which uses Standard C APIs </p> </li>
+<li id="GUID-8CB831F1-FDB3-5B60-9652-3C2552B1D07C"><p> <codeph>STDEXE</codeph> using
+a native Symbian <codeph>DLL</codeph> which uses native Symbian platform C++
+APIs </p> </li>
+<li id="GUID-CDA31C5D-0FB0-532D-801F-0E365DD92E6D"><p> <codeph>STDDLL</codeph> using
+both Standard C and native Symbian platform C++ APIs </p> </li>
+<li id="GUID-5BB61F60-82AE-580C-82CB-AAADF30B3E75"><p>Native Symbian <codeph>DLL</codeph> using
+both Standard C and native Symbian platform C++ APIs </p> </li>
+</ul>
+<section id="GUID-CC6F2464-A914-4358-8AA6-929E2E41CDAC"><title>Threads and
+hybrid applications</title> <p>The <codeph>pthread</codeph> and <xref href="GUID-B0E661BC-4058-3256-B9C3-5A4FD52F6DE5.dita"><apiname>RThread</apiname></xref> APIs
+do not mix. Symbian platform heaps are managed thread-wise whereas P.I.P.S.
+heaps are managed process-wise. Mixing <codeph>pthread</codeph> and <codeph>RThread</codeph> <i>may</i> result
+in panics due to data being lost or orphaned. So, do not mix the two unless
+you know what you're doing. </p> <p>User libraries or executables
+written using P.I.P.S. must not allocate resources in the context of the calling
+thread as the thread might be using a private heap which is inaccessible to
+other threads and might have a different lifetime. </p> <p>To minimise the
+risks avoid using <codeph>RThread</codeph> APIs in primarily POSIX applications
+or libraries (those entering via <codeph>main()</codeph>), and avoid using <codeph>pthread</codeph> in
+primarily Symbian platform applications or libraries (those entering via <codeph>E32Main()</codeph>). </p> </section>
+</conbody></concept>
\ No newline at end of file