Files
geometry/doc/doxygen_output/html/x03__c__soci__example_8cpp-example.html
Barend Gehrels 363580fbf6 Added old doxygen docs
[SVN r59777]
2010-02-20 15:57:12 +00:00

182 lines
9.3 KiB
HTML

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Boost.Geometry (aka GGL, Generic Geometry Library)</title>
<link href="doxygen.css" rel="stylesheet" type="text/css">
<link href="tabs.css" rel="stylesheet" type="text/css">
</head>
<table cellpadding="2" width="100%">
<tbody>
<tr>
<td valign="top">
<img alt="Boost.Geometry" src="images/ggl-logo-big.png" height="80" width="200">
&nbsp;&nbsp;
</td>
<td valign="top" align="right">
<a href="http://www.boost.org">
<img alt="Boost C++ Libraries" src="images/accepted_by_boost.png" height="80" width="230" border="0">
</a>
</td>
</tr>
</tbody>
</table>
<!-- Generated by Doxygen 1.5.9 -->
<div class="navigation" id="top">
<div class="tabs">
<ul>
<li><a href="index.html"><span>Main&nbsp;Page</span></a></li>
<li><a href="pages.html"><span>Related&nbsp;Pages</span></a></li>
<li><a href="modules.html"><span>Modules</span></a></li>
<li><a href="namespaces.html"><span>Namespaces</span></a></li>
<li><a href="annotated.html"><span>Classes</span></a></li>
<li><a href="files.html"><span>Files</span></a></li>
<li><a href="examples.html"><span>Examples</span></a></li>
</ul>
</div>
</div>
<div class="contents">
<h1>x03_c_soci_example.cpp</h1>Example showing how to get polygons from PostGIS using SOCI and use them in GGL through WKB<p>
<div class="fragment"><pre class="fragment"><span class="comment">// Boost.Geometry (aka GGL, Generic Geometry Library)</span>
<span class="comment">//</span>
<span class="comment">// Copyright Mateusz Loskot 2009, mateusz@loskot.net</span>
<span class="comment">//</span>
<span class="comment">// Use, modification and distribution is subject to the Boost Software License,</span>
<span class="comment">// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at</span>
<span class="comment">// http://www.boost.org/LICENSE_1_0.txt)</span>
<span class="comment">// Boost.Geometry (aka GGL, Generic Geometry Library)</span>
<span class="comment">// SOCI example</span>
<span class="comment">// c: using WKB to retrieve geometries</span>
<span class="comment">// SOCI is a generic C++ template interface to access relational databases</span>
<span class="comment">// To build and run this example, see comments in example a</span>
<span class="comment">// Alternatively compile composing and executing compiler command directoy in examples directory,</span>
<span class="comment">// for example using GCC compiler:</span>
<span class="comment">// g++ -I../../../boost -I/home/mloskot/usr/include/soci \</span>
<span class="comment">// -I /home/mloskot/usr/include/soci/postgresql -I/usr/include/postgresql \</span>
<span class="comment">// -L/home/mloskot/usr/lib -lsoci_core-gcc-3_0 -lsoci_postgresql-gcc-3_0 x03_c_soci_example.cpp</span>
<span class="preprocessor">#include &lt;soci.h&gt;</span>
<span class="preprocessor">#include &lt;soci-postgresql.h&gt;</span>
<span class="preprocessor">#include &lt;exception&gt;</span>
<span class="preprocessor">#include &lt;iostream&gt;</span>
<span class="preprocessor">#include &lt;iterator&gt;</span>
<span class="preprocessor">#include &lt;string&gt;</span>
<span class="preprocessor">#include &lt;vector&gt;</span>
<span class="preprocessor">#include &lt;boost/geometry/geometry.hpp&gt;</span>
<span class="preprocessor">#include &lt;<a class="code" href="geometries_8hpp.html">boost/geometry/geometries/geometries.hpp</a>&gt;</span>
<span class="preprocessor">#include &lt;boost/geometry/extensions/gis/io/wkb/read_wkb.hpp&gt;</span>
<span class="preprocessor">#include &lt;boost/geometry/extensions/gis/io/wkb/utility.hpp&gt;</span>
<span class="preprocessor">#include &lt;boost/geometry/extensions/gis/io/wkt/wkt.hpp&gt;</span>
<span class="comment">// user-defined type with GGL geometry</span>
<span class="keyword">struct </span>tree
{
<span class="keywordtype">int</span> id;
<a name="_a0"></a><a class="code" href="classboost_1_1geometry_1_1point.html" title="Basic point class, having coordinates defined in a neutral way.">boost::geometry::point&lt;float, 2, boost::geometry::cs::geographic&lt;boost::geometry::degree&gt;</a> &gt; location;
};
<span class="comment">// conversion of row of result to user-defined type - performs WKB parsing</span>
<span class="keyword">namespace </span>soci
{
<span class="keyword">template</span> &lt;&gt;
<span class="keyword">struct </span>type_conversion&lt;tree&gt;
{
<span class="keyword">typedef</span> soci::values base_type;
<span class="keyword">static</span> <span class="keywordtype">void</span> from_base(base_type <span class="keyword">const</span>&amp; v, soci::indicator ind, tree&amp; value)
{
<span class="keywordflow">try</span>
{
value.id = v.get&lt;<span class="keywordtype">int</span>&gt;(<span class="stringliteral">"id"</span>);
<span class="comment">// intermediate step: hex-encoded binary string to raw WKB</span>
std::string <span class="keyword">const</span>&amp; hex = v.get&lt;std::string&gt;(<span class="stringliteral">"wkb"</span>);
std::vector&lt;unsigned char&gt; wkb;
<span class="keywordflow">if</span> (!boost::geometry::hex2wkb(hex, std::back_inserter(wkb)))
<span class="keywordflow">throw</span> std::runtime_error(<span class="stringliteral">"hex2wkb translation failed"</span>);
<span class="comment">// parse WKB and construct point geometry</span>
<span class="keywordflow">if</span> (!boost::geometry::read_wkb(wkb.begin(), wkb.end(), value.location))
<span class="keywordflow">throw</span> std::runtime_error(<span class="stringliteral">"read_wkb failed"</span>);
}
<span class="keywordflow">catch</span>(<span class="keyword">const</span> std::exception&amp; e)
{
std::cout &lt;&lt; e.what() &lt;&lt; std::endl;
}
}
<span class="keyword">static</span> <span class="keywordtype">void</span> to_base(tree <span class="keyword">const</span>&amp; value, base_type&amp; v, soci::indicator&amp; ind)
{
<span class="keywordflow">throw</span> std::runtime_error(<span class="stringliteral">"todo: wkb writer not yet implemented"</span>);
}
};
}
<span class="keywordtype">int</span> main()
{
<span class="keywordflow">try</span>
{
<span class="comment">// establish database connection</span>
soci::session sql(soci::postgresql, <span class="stringliteral">"dbname=ggl user=ggl password=ggl"</span>);
<span class="comment">// construct schema of table for trees (point geometries)</span>
sql &lt;&lt; <span class="stringliteral">"DELETE FROM geometry_columns WHERE f_table_name = 'trees'"</span>;
sql &lt;&lt; <span class="stringliteral">"DROP TABLE IF EXISTS trees CASCADE"</span>;
sql &lt;&lt; <span class="stringliteral">"CREATE TABLE trees (id INTEGER)"</span>;
sql &lt;&lt; <span class="stringliteral">"SELECT AddGeometryColumn('trees', 'geom', -1, 'POINT', 2)"</span>;
<span class="comment">// insert sample data using plain WKT input</span>
sql &lt;&lt; <span class="stringliteral">"INSERT INTO trees VALUES(1, ST_GeomFromText('POINT(1.23 2.34)', -1))"</span>;
sql &lt;&lt; <span class="stringliteral">"INSERT INTO trees VALUES(2, ST_GeomFromText('POINT(3.45 4.56)', -1))"</span>;
sql &lt;&lt; <span class="stringliteral">"INSERT INTO trees VALUES(3, ST_GeomFromText('POINT(5.67 6.78)', -1))"</span>;
sql &lt;&lt; <span class="stringliteral">"INSERT INTO trees VALUES(4, ST_GeomFromText('POINT(7.89 9.01)', -1))"</span>;
<span class="comment">// query data in WKB form and read to geometry object</span>
<span class="keyword">typedef</span> std::vector&lt;tree&gt; trees_t;
soci::rowset&lt;tree&gt; rows = (sql.prepare &lt;&lt; <span class="stringliteral">"SELECT id, encode(ST_AsBinary(geom), 'hex') AS wkb FROM trees"</span>);
trees_t trees;
std::copy(rows.begin(), rows.end(), std::back_inserter(trees));
<span class="comment">// print trees output</span>
<span class="keywordflow">for</span> (trees_t::const_iterator it = trees.begin(); it != trees.end(); ++it)
{
std::cout &lt;&lt; <span class="stringliteral">"Tree #"</span> &lt;&lt; it-&gt;id &lt;&lt; <span class="stringliteral">" located at\t"</span> &lt;&lt; boost::geometry::wkt(it-&gt;location) &lt;&lt; std::endl;
}
}
<span class="keywordflow">catch</span> (std::exception <span class="keyword">const</span> &amp;e)
{
std::cerr &lt;&lt; <span class="stringliteral">"Error: "</span> &lt;&lt; e.what() &lt;&lt; <span class="charliteral">'\n'</span>;
}
<span class="keywordflow">return</span> 0;
}
</pre></div> </div>
<hr size="1">
<table width="100%">
<tbody>
<tr>
<td align="left"><small>
<p>December 1, 2009</p>
</small></td>
<td align="right">
<small>Copyright © 1995-2009 Barend Gehrels, Geodan, Amsterdam<br>
Copyright © 2008-2009 Bruno Lalande, Paris<br>
Copyright © 2009 Mateusz Loskot, Cadcorp, London<br>
</small>
</td>
</tr>
</tbody>
</table>
<address style="text-align: right;"><small>
Documentation is generated by&nbsp;<a href="http://www.doxygen.org/index.html">Doxygen</a>
</small></address>
</body>
</html>