Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
P
Postgres FD Implementation
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Abuhujair Javed
Postgres FD Implementation
Commits
3b19a459
Commit
3b19a459
authored
Jun 03, 2010
by
Bruce Momjian
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Document use of C++ for extension use.
parent
7dff7260
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
32 additions
and
19 deletions
+32
-19
doc/src/sgml/extend.sgml
doc/src/sgml/extend.sgml
+32
-19
No files found.
doc/src/sgml/extend.sgml
View file @
3b19a459
<!-- $PostgreSQL: pgsql/doc/src/sgml/extend.sgml,v 1.4
2 2010/06/01 03:19:36
momjian Exp $ -->
<!-- $PostgreSQL: pgsql/doc/src/sgml/extend.sgml,v 1.4
3 2010/06/03 14:39:58
momjian Exp $ -->
<chapter id="extend">
<chapter id="extend">
<title>Extending <acronym>SQL</acronym></title>
<title>Extending <acronym>SQL</acronym></title>
...
@@ -273,8 +273,6 @@
...
@@ -273,8 +273,6 @@
&xoper;
&xoper;
&xindex;
&xindex;
<!-- Use this someday when C++ is easier to use. bjm 2010-05-31
<sect1 id="extend-Cpp">
<sect1 id="extend-Cpp">
<title>Using C++ for Extensibility</title>
<title>Using C++ for Extensibility</title>
...
@@ -284,42 +282,57 @@
...
@@ -284,42 +282,57 @@
<para>
<para>
It is possible to use a compiler in C++ mode to build
It is possible to use a compiler in C++ mode to build
<productname>PostgreSQL</productname> extensions
; you must simply
<productname>PostgreSQL</productname> extensions
by following these
follow the standard methods for dynamically linking to C executabl
es:
guidelin
es:
<itemizedlist>
<itemizedlist>
<listitem>
<listitem>
<para>
<para>
Use <literal>extern C</> linkage for all functions that must
All functions accessed by the backend must present a C interface
be accessible by <function>dlopen()</>. This is also necessary
to the backend; these C functions can then call C++ functions.
for any functions that might be passed as pointers between
For example, <literal>extern C</> linkage is required for
the backend and C++ code.
backend-accessed functions. This is also necessary for any
functions that are passed as pointers between the backend and
C++ code.
</para>
</para>
</listitem>
</listitem>
<listitem>
<listitem>
<para>
<para>
Use <function>palloc()</> to allocate any memory that might be
Free memory using the appropriate deallocation method. For example,
freed by the backend C code (don't pass <function>new()</>-allocated
most backend memory is allocated using <function>palloc()</>, so use
memory).
<function>pfree()</> to free it, i.e. using C++
</para>
<function>delete()</> in such cases will fail.
</listitem>
</listitem>
<listitem>
<listitem>
<para>
<para>
Use <function>pfree()</> to free memory allocated by the backend
Prevent exceptions from propagating into the C code (use a
C code (do not use <function>delete()</> for such cases).
catch-all block at the top level of all <literal>extern C</>
functions). This is necessary even if the C++ code does not
throw any exceptions because events like out-of-memory still
throw exceptions. Any exceptions must be caught and appropriate
errors passed back to the C interface. If possible, compile C++
with <option>-fno-exceptions</> to eliminate exceptions entirely;
in such cases, you must check for failures in your C++ code, e.g.
check for NULL returned by <function>new()</>.
</para>
</para>
</listitem>
</listitem>
<listitem>
<listitem>
<para>
<para>
Prevent exceptions from propagating into the C code (use a
If calling backend functions from C++ code, be sure that the
catch-all block at the top level of all <literal>extern C</>
C++ call stack contains only plain old data structure
functions).
(<acronym>POD</>). This is necessary because backend errors
generate a distant <function>longjump()</> that does not properly
unroll a C++ call stack with non-POD objects.
</para>
</para>
</listitem>
</listitem>
</itemizedlist>
</itemizedlist>
</para>
</para>
<para>
In summary, it is best to place C++ code behind a wall of
<literal>extern C</> functions that interface to the backend,
and avoid exception, memory, and call stack leakage.
</para>
</sect1>
</sect1>
-->
</chapter>
</chapter>
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment