1
0
mirror of https://github.com/TREX-CoE/trexio.git synced 2025-01-12 22:18:35 +01:00

Deploying to gh-pages from @ TREX-CoE/trexio@f2c79827b5 🚀

This commit is contained in:
q-posev 2021-05-18 10:16:43 +00:00
parent 89d39f92f9
commit f57c47e78e
5 changed files with 163 additions and 154 deletions

View File

@ -3,7 +3,7 @@
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head>
<!-- 2021-05-07 Fri 22:44 -->
<!-- 2021-05-18 Tue 10:16 -->
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<title>TREXIO source code documentation</title>
@ -341,7 +341,7 @@ and bug reports should be submitted at
</div>
<div id="postamble" class="status">
<p class="author">Author: TREX-CoE</p>
<p class="date">Created: 2021-05-07 Fri 22:44</p>
<p class="date">Created: 2021-05-18 Tue 10:16</p>
<p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p>
</div>
</body>

View File

@ -3,7 +3,7 @@
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head>
<!-- 2021-05-07 Fri 22:44 -->
<!-- 2021-05-18 Tue 10:16 -->
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<title>TREXIO source code documentation</title>
@ -341,7 +341,7 @@ and bug reports should be submitted at
</div>
<div id="postamble" class="status">
<p class="author">Author: TREX-CoE</p>
<p class="date">Created: 2021-05-07 Fri 22:44</p>
<p class="date">Created: 2021-05-18 Tue 10:16</p>
<p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p>
</div>
</body>

View File

@ -3,7 +3,7 @@
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head>
<!-- 2021-05-07 Fri 22:44 -->
<!-- 2021-05-18 Tue 10:16 -->
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<title>Front end API</title>
@ -311,45 +311,45 @@ for the JavaScript code in this tag.
<h2>Table of Contents</h2>
<div id="text-table-of-contents">
<ul>
<li><a href="#orga9b3d12">1. Coding conventions</a>
<li><a href="#orgb621904">1. Coding conventions</a>
<ul>
<li><a href="#orgf51cf84">1.1. Memory allocation</a></li>
<li><a href="#orgf60579c">1.1. Memory allocation</a></li>
</ul>
</li>
<li><a href="#org2992887">2. Front end</a>
<li><a href="#org33261e1">2. Front end</a>
<ul>
<li><a href="#org2a57e83">2.1. Error handling</a></li>
<li><a href="#org4280d8b">2.2. Back ends</a></li>
<li><a href="#orgd3f3e42">2.3. Read/write behavior</a></li>
<li><a href="#org68cee1b">2.4. TREXIO file type</a></li>
<li><a href="#orge2d0e66">2.5. Polymorphism of the file handle</a></li>
<li><a href="#org84d0036">2.6. File opening</a></li>
<li><a href="#orgfbe194e">2.7. File closing</a></li>
<li><a href="#orgbd81908">2.1. Error handling</a></li>
<li><a href="#orgd8dd1bc">2.2. Back ends</a></li>
<li><a href="#orgef576de">2.3. Read/write behavior</a></li>
<li><a href="#org7388aca">2.4. TREXIO file type</a></li>
<li><a href="#org87ca0fd">2.5. Polymorphism of the file handle</a></li>
<li><a href="#org194ba10">2.6. File opening</a></li>
<li><a href="#org6fbeaff">2.7. File closing</a></li>
</ul>
</li>
<li><a href="#org6504270">3. Templates for front end</a>
<li><a href="#org850fa00">3. Templates for front end</a>
<ul>
<li><a href="#orgf572aa4">3.1. Templates for front end has/read/write a dimension</a>
<li><a href="#org5a2c5cf">3.1. Templates for front end has/read/write a dimension</a>
<ul>
<li><a href="#org438f96b">3.1.1. C templates for front end</a></li>
<li><a href="#org8276837">3.1.2. Fortran templates for front end</a></li>
<li><a href="#orgc021658">3.1.1. C templates for front end</a></li>
<li><a href="#orgff29680">3.1.2. Fortran templates for front end</a></li>
</ul>
</li>
<li><a href="#org3e2b9c7">3.2. Templates for front end has/read/write a dataset</a>
<li><a href="#orgbd13b06">3.2. Templates for front end has/read/write a dataset</a>
<ul>
<li><a href="#orgddb79e8">3.2.1. C templates for front end</a></li>
<li><a href="#orgb692f07">3.2.2. Fortran templates for front end</a></li>
<li><a href="#org09d4fd4">3.2.1. C templates for front end</a></li>
<li><a href="#org5b154e9">3.2.2. Fortran templates for front end</a></li>
</ul>
</li>
</ul>
</li>
<li><a href="#org9aed9ea">4. Fortran helper/wrapper functions</a></li>
<li><a href="#org55b49cd">4. Fortran helper/wrapper functions</a></li>
</ul>
</div>
</div>
<div id="outline-container-orga9b3d12" class="outline-2">
<h2 id="orga9b3d12"><span class="section-number-2">1</span> Coding conventions</h2>
<div id="outline-container-orgb621904" class="outline-2">
<h2 id="orgb621904"><span class="section-number-2">1</span> Coding conventions</h2>
<div class="outline-text-2" id="text-1">
<ul class="org-ul">
<li>integer types will be defined using types given in <code>stdint.h</code></li>
@ -364,8 +364,8 @@ for the JavaScript code in this tag.
</ul>
</div>
<div id="outline-container-orgf51cf84" class="outline-3">
<h3 id="orgf51cf84"><span class="section-number-3">1.1</span> Memory allocation</h3>
<div id="outline-container-orgf60579c" class="outline-3">
<h3 id="orgf60579c"><span class="section-number-3">1.1</span> Memory allocation</h3>
<div class="outline-text-3" id="text-1-1">
<p>
Memory allocation of structures can be facilitated by using the
@ -400,8 +400,8 @@ The maximum string size for the filenames is 4096 characters.
</div>
</div>
<div id="outline-container-org2992887" class="outline-2">
<h2 id="org2992887"><span class="section-number-2">2</span> Front end</h2>
<div id="outline-container-org33261e1" class="outline-2">
<h2 id="org33261e1"><span class="section-number-2">2</span> Front end</h2>
<div class="outline-text-2" id="text-2">
<p>
All calls to TREXIO are thread-safe.
@ -409,10 +409,10 @@ TREXIO front end is modular, which simplifies implementation of new back ends.
</p>
</div>
<div id="outline-container-org2a57e83" class="outline-3">
<h3 id="org2a57e83"><span class="section-number-3">2.1</span> Error handling</h3>
<div id="outline-container-orgbd81908" class="outline-3">
<h3 id="orgbd81908"><span class="section-number-3">2.1</span> Error handling</h3>
<div class="outline-text-3" id="text-2-1">
<table id="org0d36b30" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides">
<table id="org5c12de5" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides">
<colgroup>
@ -694,8 +694,8 @@ The text strings are extracted from the previous table.
</div>
</div>
<div id="outline-container-org4280d8b" class="outline-3">
<h3 id="org4280d8b"><span class="section-number-3">2.2</span> Back ends</h3>
<div id="outline-container-orgd8dd1bc" class="outline-3">
<h3 id="orgd8dd1bc"><span class="section-number-3">2.2</span> Back ends</h3>
<div class="outline-text-3" id="text-2-2">
<p>
TREXIO has several back ends:
@ -725,8 +725,8 @@ lines that correspond to the <code>TREXIO_JSON</code> back end (not implemented
</div>
</div>
</div>
<div id="outline-container-orgd3f3e42" class="outline-3">
<h3 id="orgd3f3e42"><span class="section-number-3">2.3</span> Read/write behavior</h3>
<div id="outline-container-orgef576de" class="outline-3">
<h3 id="orgef576de"><span class="section-number-3">2.3</span> Read/write behavior</h3>
<div class="outline-text-3" id="text-2-3">
<p>
Every time a reading function is called, the data is read from the
@ -754,8 +754,8 @@ concurrent programs, the behavior is not specified.
</p>
</div>
</div>
<div id="outline-container-org68cee1b" class="outline-3">
<h3 id="org68cee1b"><span class="section-number-3">2.4</span> TREXIO file type</h3>
<div id="outline-container-org7388aca" class="outline-3">
<h3 id="org7388aca"><span class="section-number-3">2.4</span> TREXIO file type</h3>
<div class="outline-text-3" id="text-2-4">
<p>
<code>trexio_s</code> is the the main type for TREXIO files, visible to the users
@ -787,8 +787,8 @@ TREXIO files will have as a first argument the TREXIO file handle.
</div>
</div>
</div>
<div id="outline-container-orge2d0e66" class="outline-3">
<h3 id="orge2d0e66"><span class="section-number-3">2.5</span> Polymorphism of the file handle</h3>
<div id="outline-container-org87ca0fd" class="outline-3">
<h3 id="org87ca0fd"><span class="section-number-3">2.5</span> Polymorphism of the file handle</h3>
<div class="outline-text-3" id="text-2-5">
<p>
Polymorphism of the <code>trexio_t</code> type is handled by ensuring that the
@ -807,8 +807,8 @@ corresponding types for all back ends can be safely casted to
</div>
</div>
<div id="outline-container-org84d0036" class="outline-3">
<h3 id="org84d0036"><span class="section-number-3">2.6</span> File opening</h3>
<div id="outline-container-org194ba10" class="outline-3">
<h3 id="org194ba10"><span class="section-number-3">2.6</span> File opening</h3>
<div class="outline-text-3" id="text-2-6">
<p>
<code>trexio_open</code> creates a new TREXIO file or opens existing one.
@ -970,8 +970,8 @@ should tend to avoid renaming the <code>.txt</code> data files.
</div>
</div>
<div id="outline-container-orgfbe194e" class="outline-3">
<h3 id="orgfbe194e"><span class="section-number-3">2.7</span> File closing</h3>
<div id="outline-container-org6fbeaff" class="outline-3">
<h3 id="org6fbeaff"><span class="section-number-3">2.7</span> File closing</h3>
<div class="outline-text-3" id="text-2-7">
<p>
<code>trexio_close</code> closes an existing <code>trexio_t</code> file.
@ -1070,8 +1070,8 @@ output:
</div>
</div>
<div id="outline-container-org6504270" class="outline-2">
<h2 id="org6504270"><span class="section-number-2">3</span> Templates for front end</h2>
<div id="outline-container-org850fa00" class="outline-2">
<h2 id="org850fa00"><span class="section-number-2">3</span> Templates for front end</h2>
<div class="outline-text-2" id="text-3">
<p>
Consider the following block of <code>trex.json</code>:
@ -1184,28 +1184,46 @@ each variable can be found below:
<td class="org-left"><code>%24.16e</code></td>
</tr>
<tr>
<td class="org-left"><code>$group_dset_dtype_default$</code></td>
<td class="org-left">Default datatype of the dataset [C]</td>
<td class="org-left"><code>double/int32_t</code></td>
</tr>
<tr>
<td class="org-left"><code>$group_dset_dtype_single$</code></td>
<td class="org-left">Single precision type of the dataset [C]</td>
<td class="org-left"><code>float</code></td>
<td class="org-left">Single precision datatype of the dataset [C]</td>
<td class="org-left"><code>float/int32_t</code></td>
</tr>
<tr>
<td class="org-left"><code>$group_dset_dtype_double$</code></td>
<td class="org-left">Double precision type of the dataset [C]</td>
<td class="org-left"><code>double</code></td>
<td class="org-left">Double precision datatype of the dataset [C]</td>
<td class="org-left"><code>double/int64_t</code></td>
</tr>
<tr>
<td class="org-left"><code>$default_prec$</code></td>
<td class="org-left">Default precision for read/write without suffix [C]</td>
<td class="org-left"><code>64/32</code></td>
</tr>
<tr>
<td class="org-left"><code>$group_dset_f_dtype_default$</code></td>
<td class="org-left">Default datatype of the dataset [Fortran]</td>
<td class="org-left"><code>real(8)/integer(4)</code></td>
</tr>
<tr>
<td class="org-left"><code>$group_dset_f_dtype_single$</code></td>
<td class="org-left">Single precision type of the dataset [Fortran]</td>
<td class="org-left"><code>real(4)</code></td>
<td class="org-left">Single precision datatype of the dataset [Fortran]</td>
<td class="org-left"><code>real(4)/integer(4)</code></td>
</tr>
<tr>
<td class="org-left"><code>$group_dset_f_dtype_double$</code></td>
<td class="org-left">Double precision type of the dataset [Fortran]</td>
<td class="org-left"><code>real(8)</code></td>
<td class="org-left">Double precision datatype of the dataset [Fortran]</td>
<td class="org-left"><code>real(8)/integer(8)</code></td>
</tr>
<tr>
@ -1243,8 +1261,8 @@ or double precision for integer and floating point numbers.
</p>
</div>
<div id="outline-container-orgf572aa4" class="outline-3">
<h3 id="orgf572aa4"><span class="section-number-3">3.1</span> Templates for front end has/read/write a dimension</h3>
<div id="outline-container-org5a2c5cf" class="outline-3">
<h3 id="org5a2c5cf"><span class="section-number-3">3.1</span> Templates for front end has/read/write a dimension</h3>
<div class="outline-text-3" id="text-3-1">
<p>
This section concerns API calls related to dimensioning variables.
@ -1313,8 +1331,8 @@ This section concerns API calls related to dimensioning variables.
</table>
</div>
<div id="outline-container-org438f96b" class="outline-4">
<h4 id="org438f96b"><span class="section-number-4">3.1.1</span> C templates for front end</h4>
<div id="outline-container-orgc021658" class="outline-4">
<h4 id="orgc021658"><span class="section-number-4">3.1.1</span> C templates for front end</h4>
<div class="outline-text-4" id="text-3-1-1">
<p>
The <code>C</code> templates that correspond to each of the abovementioned
@ -1506,8 +1524,8 @@ precision (see Table above).
</div>
</div>
<div id="outline-container-org8276837" class="outline-4">
<h4 id="org8276837"><span class="section-number-4">3.1.2</span> Fortran templates for front end</h4>
<div id="outline-container-orgff29680" class="outline-4">
<h4 id="orgff29680"><span class="section-number-4">3.1.2</span> Fortran templates for front end</h4>
<div class="outline-text-4" id="text-3-1-2">
<p>
The <code>Fortran</code> templates that provide an access to the <code>C</code> API calls from Fortran.
@ -1593,8 +1611,8 @@ These templates are based on the use of <code>iso_c_binding</code>. Pointers hav
</div>
</div>
<div id="outline-container-org3e2b9c7" class="outline-3">
<h3 id="org3e2b9c7"><span class="section-number-3">3.2</span> Templates for front end has/read/write a dataset</h3>
<div id="outline-container-orgbd13b06" class="outline-3">
<h3 id="orgbd13b06"><span class="section-number-3">3.2</span> Templates for front end has/read/write a dataset</h3>
<div class="outline-text-3" id="text-3-2">
<p>
This section concerns API calls related to datasets.
@ -1663,8 +1681,8 @@ This section concerns API calls related to datasets.
</table>
</div>
<div id="outline-container-orgddb79e8" class="outline-4">
<h4 id="orgddb79e8"><span class="section-number-4">3.2.1</span> C templates for front end</h4>
<div id="outline-container-org09d4fd4" class="outline-4">
<h4 id="org09d4fd4"><span class="section-number-4">3.2.1</span> C templates for front end</h4>
<div class="outline-text-4" id="text-3-2-1">
<p>
The C templates that correspond to each of the abovementioned functions can be found below.
@ -1876,18 +1894,18 @@ The basic (non-suffixed) API call on datasets deals with double precision (see T
<div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">trexio_exit_code</span>
<span style="color: #0000ff;">trexio_read_$group$_$group_dset$</span> (<span style="color: #228b22;">trexio_t</span>* <span style="color: #a020f0;">const</span> <span style="color: #a0522d;">file</span>, $group_dset_dtype_double$* <span style="color: #a020f0;">const</span> $group_dset$)
<span style="color: #0000ff;">trexio_read_$group$_$group_dset$</span> (<span style="color: #228b22;">trexio_t</span>* <span style="color: #a020f0;">const</span> <span style="color: #a0522d;">file</span>, $group_dset_dtype_default$* <span style="color: #a020f0;">const</span> $group_dset$)
{
<span style="color: #a020f0;">return</span> trexio_read_$group$_$group_dset$_64(file, $group_dset$);
<span style="color: #a020f0;">return</span> trexio_read_$group$_$group_dset$_$default_prec$(file, $group_dset$);
}
</pre>
</div>
<div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">trexio_exit_code</span>
<span style="color: #0000ff;">trexio_write_$group$_$group_dset$</span> (<span style="color: #228b22;">trexio_t</span>* <span style="color: #a020f0;">const</span> <span style="color: #a0522d;">file</span>, <span style="color: #a020f0;">const</span> $group_dset_dtype_double$* $group_dset$)
<span style="color: #0000ff;">trexio_write_$group$_$group_dset$</span> (<span style="color: #228b22;">trexio_t</span>* <span style="color: #a020f0;">const</span> <span style="color: #a0522d;">file</span>, <span style="color: #a020f0;">const</span> $group_dset_dtype_default$* $group_dset$)
{
<span style="color: #a020f0;">return</span> trexio_write_$group$_$group_dset$_64(file, $group_dset$);
<span style="color: #a020f0;">return</span> trexio_write_$group$_$group_dset$_$default_prec$(file, $group_dset$);
}
</pre>
</div>
@ -1922,8 +1940,8 @@ The basic (non-suffixed) API call on datasets deals with double precision (see T
</div>
</div>
<div id="outline-container-orgb692f07" class="outline-4">
<h4 id="orgb692f07"><span class="section-number-4">3.2.2</span> Fortran templates for front end</h4>
<div id="outline-container-org5b154e9" class="outline-4">
<h4 id="org5b154e9"><span class="section-number-4">3.2.2</span> Fortran templates for front end</h4>
<div class="outline-text-4" id="text-3-2-2">
<p>
The <code>Fortran</code> templates that provide an access to the <code>C</code> API calls from <code>Fortran</code>.
@ -1979,7 +1997,7 @@ These templates are based on the use of <code>iso_c_binding</code>. Pointers hav
<span style="color: #228b22;">integer </span><span style="color: #a020f0;">function</span><span style="color: #a0522d;"> </span><span style="color: #0000ff;">trexio_write_$group$_$group_dset$</span><span style="color: #a0522d;"> </span><span style="color: #000000; background-color: #ffffff;">(trex_file, dset) bind(C)</span>
<span style="color: #a020f0;">use</span>, <span style="color: #a020f0;">intrinsic</span> :: <span style="color: #0000ff;">iso_c_binding</span>
<span style="color: #228b22;">integer</span>(8), <span style="color: #a020f0;">intent</span>(in), <span style="color: #a020f0;">value</span> ::<span style="color: #a0522d;"> trex_file</span>
$group_dset_f_dtype_double$, <span style="color: #a020f0;">intent</span>(in) :: dset$group_dset_f_dims$
$group_dset_f_dtype_default$, <span style="color: #a020f0;">intent</span>(in) :: dset$group_dset_f_dims$
<span style="color: #a020f0;">end function</span> <span style="color: #0000ff;">trexio_write_$group$_$group_dset$</span>
<span style="color: #a020f0;">end interface</span>
</pre>
@ -1990,7 +2008,7 @@ These templates are based on the use of <code>iso_c_binding</code>. Pointers hav
<span style="color: #228b22;">integer </span><span style="color: #a020f0;">function</span><span style="color: #a0522d;"> </span><span style="color: #0000ff;">trexio_read_$group$_$group_dset$</span><span style="color: #a0522d;"> </span><span style="color: #000000; background-color: #ffffff;">(trex_file, dset) bind(C)</span>
<span style="color: #a020f0;">use</span>, <span style="color: #a020f0;">intrinsic</span> :: <span style="color: #0000ff;">iso_c_binding</span>
<span style="color: #228b22;">integer</span>(8), <span style="color: #a020f0;">intent</span>(in), <span style="color: #a020f0;">value</span> ::<span style="color: #a0522d;"> trex_file</span>
$group_dset_f_dtype_double$, <span style="color: #a020f0;">intent</span>(out) :: dset$group_dset_f_dims$
$group_dset_f_dtype_default$, <span style="color: #a020f0;">intent</span>(out) :: dset$group_dset_f_dims$
<span style="color: #a020f0;">end function</span> <span style="color: #0000ff;">trexio_read_$group$_$group_dset$</span>
<span style="color: #a020f0;">end interface</span>
</pre>
@ -2010,8 +2028,8 @@ These templates are based on the use of <code>iso_c_binding</code>. Pointers hav
</div>
</div>
<div id="outline-container-org9aed9ea" class="outline-2">
<h2 id="org9aed9ea"><span class="section-number-2">4</span> Fortran helper/wrapper functions</h2>
<div id="outline-container-org55b49cd" class="outline-2">
<h2 id="org55b49cd"><span class="section-number-2">4</span> Fortran helper/wrapper functions</h2>
<div class="outline-text-2" id="text-4">
<p>
The function below adapts the original C-based <code>trexio_open</code> for Fortran.
@ -2040,7 +2058,7 @@ Note, that Fortran interface calls the main <code>TREXIO</code> API, which is wr
</div>
<div id="postamble" class="status">
<p class="author">Author: TREX-CoE</p>
<p class="date">Created: 2021-05-07 Fri 22:44</p>
<p class="date">Created: 2021-05-18 Tue 10:16</p>
<p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p>
</div>
</body>

View File

@ -3,7 +3,7 @@
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head>
<!-- 2021-05-07 Fri 22:44 -->
<!-- 2021-05-18 Tue 10:16 -->
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<title>HDF5 back end</title>
@ -311,25 +311,25 @@ for the JavaScript code in this tag.
<h2>Table of Contents</h2>
<div id="text-table-of-contents">
<ul>
<li><a href="#org37aeb2f">1. HDF5 back end</a>
<li><a href="#org379a07d">1. HDF5 back end</a>
<ul>
<li><a href="#orgae6be5d">1.1. Template for HDF5 definitions</a></li>
<li><a href="#org02a6284">1.2. Template for HDF5 structures</a></li>
<li><a href="#org2ca5d1e">1.3. Template for HDF5 init/deinit</a></li>
<li><a href="#orgbcfefe6">1.4. Template for HDF5 has/read/write a number</a></li>
<li><a href="#org55daa80">1.5. Template for HDF5 has/read/write a dataset</a></li>
<li><a href="#orgc76be96">1.1. Template for HDF5 definitions</a></li>
<li><a href="#org718f8c4">1.2. Template for HDF5 structures</a></li>
<li><a href="#org0ec6e69">1.3. Template for HDF5 init/deinit</a></li>
<li><a href="#orgfc9bd3c">1.4. Template for HDF5 has/read/write a number</a></li>
<li><a href="#org7ea99e2">1.5. Template for HDF5 has/read/write a dataset</a></li>
</ul>
</li>
</ul>
</div>
</div>
<div id="outline-container-org37aeb2f" class="outline-2">
<h2 id="org37aeb2f"><span class="section-number-2">1</span> HDF5 back end</h2>
<div id="outline-container-org379a07d" class="outline-2">
<h2 id="org379a07d"><span class="section-number-2">1</span> HDF5 back end</h2>
<div class="outline-text-2" id="text-1">
</div>
<div id="outline-container-orgae6be5d" class="outline-3">
<h3 id="orgae6be5d"><span class="section-number-3">1.1</span> Template for HDF5 definitions</h3>
<div id="outline-container-orgc76be96" class="outline-3">
<h3 id="orgc76be96"><span class="section-number-3">1.1</span> Template for HDF5 definitions</h3>
<div class="outline-text-3" id="text-1-1">
<div class="org-src-container">
<pre class="src src-c"><span style="color: #483d8b;">#define</span> $GROUP$_GROUP_NAME <span style="color: #8b2252;">"$group$"</span>
@ -340,8 +340,8 @@ for the JavaScript code in this tag.
</div>
</div>
<div id="outline-container-org02a6284" class="outline-3">
<h3 id="org02a6284"><span class="section-number-3">1.2</span> Template for HDF5 structures</h3>
<div id="outline-container-org718f8c4" class="outline-3">
<h3 id="org718f8c4"><span class="section-number-3">1.2</span> Template for HDF5 structures</h3>
<div class="outline-text-3" id="text-1-2">
<div class="org-src-container">
<pre class="src src-c"><span style="color: #a020f0;">typedef</span> <span style="color: #a020f0;">struct</span> <span style="color: #228b22;">trexio_hdf5_s</span> {
@ -356,8 +356,8 @@ for the JavaScript code in this tag.
</div>
<div id="outline-container-org2ca5d1e" class="outline-3">
<h3 id="org2ca5d1e"><span class="section-number-3">1.3</span> Template for HDF5 init/deinit</h3>
<div id="outline-container-org0ec6e69" class="outline-3">
<h3 id="org0ec6e69"><span class="section-number-3">1.3</span> Template for HDF5 init/deinit</h3>
<div class="outline-text-3" id="text-1-3">
<div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">trexio_exit_code</span>
@ -440,8 +440,8 @@ for the JavaScript code in this tag.
</div>
</div>
<div id="outline-container-orgbcfefe6" class="outline-3">
<h3 id="orgbcfefe6"><span class="section-number-3">1.4</span> Template for HDF5 has/read/write a number</h3>
<div id="outline-container-orgfc9bd3c" class="outline-3">
<h3 id="orgfc9bd3c"><span class="section-number-3">1.4</span> Template for HDF5 has/read/write a number</h3>
<div class="outline-text-3" id="text-1-4">
<div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">trexio_exit_code</span>
@ -563,8 +563,8 @@ for the JavaScript code in this tag.
</div>
</div>
<div id="outline-container-org55daa80" class="outline-3">
<h3 id="org55daa80"><span class="section-number-3">1.5</span> Template for HDF5 has/read/write a dataset</h3>
<div id="outline-container-org7ea99e2" class="outline-3">
<h3 id="org7ea99e2"><span class="section-number-3">1.5</span> Template for HDF5 has/read/write a dataset</h3>
<div class="outline-text-3" id="text-1-5">
<div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">trexio_exit_code</span>
@ -698,7 +698,7 @@ for the JavaScript code in this tag.
</div>
<div id="postamble" class="status">
<p class="author">Author: TREX-CoE</p>
<p class="date">Created: 2021-05-07 Fri 22:44</p>
<p class="date">Created: 2021-05-18 Tue 10:16</p>
<p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p>
</div>
</body>

View File

@ -3,7 +3,7 @@
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head>
<!-- 2021-05-07 Fri 22:44 -->
<!-- 2021-05-18 Tue 10:16 -->
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<title>TEXT back end</title>
@ -311,24 +311,24 @@ for the JavaScript code in this tag.
<h2>Table of Contents</h2>
<div id="text-table-of-contents">
<ul>
<li><a href="#org325b286">1. TEXT back end</a>
<li><a href="#orgeb18814">1. TEXT back end</a>
<ul>
<li><a href="#org62ff6a5">1.1. Template for group-related structures in text back end</a></li>
<li><a href="#orgef9577b">1.2. Template for general structure in text back end</a></li>
<li><a href="#orge215c0e">1.3. Initialize function (constant part)</a></li>
<li><a href="#org76811c7">1.4. Deinitialize function (templated part)</a></li>
<li><a href="#org2faf0f6">1.5. Template for text read struct</a></li>
<li><a href="#org78ef45d">1.6. Template for text flush struct</a></li>
<li><a href="#org48132e9">1.7. Template for text free memory</a></li>
<li><a href="#org3b467a7">1.8. Template for has/read/write the <code>$group_num$</code> attribute</a></li>
<li><a href="#org175ffc7">1.9. Template for has/read/write the <code>$group_dset$</code> dataset</a></li>
<li><a href="#orgb73d27e">1.10. RDM struct (hard-coded)</a>
<li><a href="#org1ea13bf">1.1. Template for group-related structures in text back end</a></li>
<li><a href="#orgbd22980">1.2. Template for general structure in text back end</a></li>
<li><a href="#org679c225">1.3. Initialize function (constant part)</a></li>
<li><a href="#orgfb27c9e">1.4. Deinitialize function (templated part)</a></li>
<li><a href="#orgd4ddc34">1.5. Template for text read struct</a></li>
<li><a href="#org55a214f">1.6. Template for text flush struct</a></li>
<li><a href="#org12376a1">1.7. Template for text free memory</a></li>
<li><a href="#org6dcf9c3">1.8. Template for has/read/write the <code>$group_num$</code> attribute</a></li>
<li><a href="#org6533489">1.9. Template for has/read/write the <code>$group_dset$</code> dataset</a></li>
<li><a href="#org39093ae">1.10. RDM struct (hard-coded)</a>
<ul>
<li><a href="#orge9f9527">1.10.1. Read the complete struct</a></li>
<li><a href="#org119e83b">1.10.2. Flush the complete struct</a></li>
<li><a href="#org4effdb1">1.10.3. Free memory</a></li>
<li><a href="#orgb657d2d">1.10.4. Read/Write the one<sub>e</sub> attribute</a></li>
<li><a href="#orge070ec4">1.10.5. Read/Write the two<sub>e</sub> attribute</a></li>
<li><a href="#org9aa24e5">1.10.1. Read the complete struct</a></li>
<li><a href="#orgdd33185">1.10.2. Flush the complete struct</a></li>
<li><a href="#org781138b">1.10.3. Free memory</a></li>
<li><a href="#org42ceb8c">1.10.4. Read/Write the one<sub>e</sub> attribute</a></li>
<li><a href="#org2664fa8">1.10.5. Read/Write the two<sub>e</sub> attribute</a></li>
</ul>
</li>
</ul>
@ -337,8 +337,8 @@ for the JavaScript code in this tag.
</div>
</div>
<div id="outline-container-org325b286" class="outline-2">
<h2 id="org325b286"><span class="section-number-2">1</span> TEXT back end</h2>
<div id="outline-container-orgeb18814" class="outline-2">
<h2 id="orgeb18814"><span class="section-number-2">1</span> TEXT back end</h2>
<div class="outline-text-2" id="text-1">
<p>
The "file" produced by the text back end is a directory with one
@ -359,8 +359,8 @@ The file is written when closed, or when the flush function is called.
</p>
</div>
<div id="outline-container-org62ff6a5" class="outline-3">
<h3 id="org62ff6a5"><span class="section-number-3">1.1</span> Template for group-related structures in text back end</h3>
<div id="outline-container-org1ea13bf" class="outline-3">
<h3 id="org1ea13bf"><span class="section-number-3">1.1</span> Template for group-related structures in text back end</h3>
<div class="outline-text-3" id="text-1-1">
<div class="org-src-container">
<pre class="src src-c"><span style="color: #a020f0;">typedef</span> <span style="color: #a020f0;">struct</span> $group$_s {
@ -376,8 +376,8 @@ The file is written when closed, or when the flush function is called.
</div>
</div>
<div id="outline-container-orgef9577b" class="outline-3">
<h3 id="orgef9577b"><span class="section-number-3">1.2</span> Template for general structure in text back end</h3>
<div id="outline-container-orgbd22980" class="outline-3">
<h3 id="orgbd22980"><span class="section-number-3">1.2</span> Template for general structure in text back end</h3>
<div class="outline-text-3" id="text-1-2">
<div class="org-src-container">
<pre class="src src-c"><span style="color: #a020f0;">typedef</span> <span style="color: #a020f0;">struct</span> <span style="color: #228b22;">rdm_s</span> {
@ -403,8 +403,8 @@ The file is written when closed, or when the flush function is called.
</div>
</div>
<div id="outline-container-orge215c0e" class="outline-3">
<h3 id="orge215c0e"><span class="section-number-3">1.3</span> Initialize function (constant part)</h3>
<div id="outline-container-org679c225" class="outline-3">
<h3 id="org679c225"><span class="section-number-3">1.3</span> Initialize function (constant part)</h3>
<div class="outline-text-3" id="text-1-3">
<div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">trexio_exit_code</span>
@ -436,10 +436,6 @@ The file is written when closed, or when the flush function is called.
<span style="color: #228b22;">char</span> <span style="color: #a0522d;">file_name</span>[TREXIO_MAX_FILENAME_LENGTH];
<span style="color: #a020f0;">if</span> (file_name == <span style="color: #008b8b;">NULL</span>) {
<span style="color: #a020f0;">return</span> TREXIO_ALLOCATION_FAILED;
}
strncpy (file_name, file-&gt;file_name, TREXIO_MAX_FILENAME_LENGTH);
strncat (file_name, lock_file_name, TREXIO_MAX_FILENAME_LENGTH-strlen(lock_file_name));
@ -509,8 +505,8 @@ The file is written when closed, or when the flush function is called.
</div>
</div>
<div id="outline-container-org76811c7" class="outline-3">
<h3 id="org76811c7"><span class="section-number-3">1.4</span> Deinitialize function (templated part)</h3>
<div id="outline-container-orgfb27c9e" class="outline-3">
<h3 id="orgfb27c9e"><span class="section-number-3">1.4</span> Deinitialize function (templated part)</h3>
<div class="outline-text-3" id="text-1-4">
<div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">trexio_exit_code</span>
@ -534,8 +530,8 @@ The file is written when closed, or when the flush function is called.
</div>
</div>
<div id="outline-container-org2faf0f6" class="outline-3">
<h3 id="org2faf0f6"><span class="section-number-3">1.5</span> Template for text read struct</h3>
<div id="outline-container-orgd4ddc34" class="outline-3">
<h3 id="orgd4ddc34"><span class="section-number-3">1.5</span> Template for text read struct</h3>
<div class="outline-text-3" id="text-1-5">
<div class="org-src-container">
<pre class="src src-c">$group$_t*
@ -558,11 +554,6 @@ trexio_text_read_$group$ (<span style="color: #228b22;">trexio_text_t</span>* <s
/* <span style="color: #b22222;">Build the file name </span>*/
<span style="color: #a020f0;">const</span> <span style="color: #228b22;">char</span>* $group$_file_name = <span style="color: #8b2252;">"/$group$.txt"</span>;
<span style="color: #a020f0;">if</span> ($group$-&gt;file_name == <span style="color: #008b8b;">NULL</span>) {
FREE($group$);
<span style="color: #a020f0;">return</span> <span style="color: #008b8b;">NULL</span>;
}
strncpy ($group$-&gt;file_name, file-&gt;parent.file_name, TREXIO_MAX_FILENAME_LENGTH);
strncat ($group$-&gt;file_name, $group$_file_name,
TREXIO_MAX_FILENAME_LENGTH-strlen($group$_file_name));
@ -706,8 +697,8 @@ trexio_text_read_$group$ (<span style="color: #228b22;">trexio_text_t</span>* <s
</div>
</div>
<div id="outline-container-org78ef45d" class="outline-3">
<h3 id="org78ef45d"><span class="section-number-3">1.6</span> Template for text flush struct</h3>
<div id="outline-container-org55a214f" class="outline-3">
<h3 id="org55a214f"><span class="section-number-3">1.6</span> Template for text flush struct</h3>
<div class="outline-text-3" id="text-1-6">
<div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">trexio_exit_code</span>
@ -766,8 +757,8 @@ trexio_text_read_$group$ (<span style="color: #228b22;">trexio_text_t</span>* <s
</div>
</div>
<div id="outline-container-org48132e9" class="outline-3">
<h3 id="org48132e9"><span class="section-number-3">1.7</span> Template for text free memory</h3>
<div id="outline-container-org12376a1" class="outline-3">
<h3 id="org12376a1"><span class="section-number-3">1.7</span> Template for text free memory</h3>
<div class="outline-text-3" id="text-1-7">
<p>
Memory is allocated when reading. The following function frees memory.
@ -803,8 +794,8 @@ Memory is allocated when reading. The following function frees memory.
</div>
</div>
<div id="outline-container-org3b467a7" class="outline-3">
<h3 id="org3b467a7"><span class="section-number-3">1.8</span> Template for has/read/write the <code>$group_num$</code> attribute</h3>
<div id="outline-container-org6dcf9c3" class="outline-3">
<h3 id="org6dcf9c3"><span class="section-number-3">1.8</span> Template for has/read/write the <code>$group_num$</code> attribute</h3>
<div class="outline-text-3" id="text-1-8">
<div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">trexio_exit_code</span>
@ -866,8 +857,8 @@ Memory is allocated when reading. The following function frees memory.
</div>
</div>
<div id="outline-container-org175ffc7" class="outline-3">
<h3 id="org175ffc7"><span class="section-number-3">1.9</span> Template for has/read/write the <code>$group_dset$</code> dataset</h3>
<div id="outline-container-org6533489" class="outline-3">
<h3 id="org6533489"><span class="section-number-3">1.9</span> Template for has/read/write the <code>$group_dset$</code> dataset</h3>
<div class="outline-text-3" id="text-1-9">
<p>
The <code>group_dset</code> array is assumed allocated with the appropriate size.
@ -964,12 +955,12 @@ The <code>group_dset</code> array is assumed allocated with the appropriate size
</div>
</div>
<div id="outline-container-orgb73d27e" class="outline-3">
<h3 id="orgb73d27e"><span class="section-number-3">1.10</span> RDM struct (hard-coded)</h3>
<div id="outline-container-org39093ae" class="outline-3">
<h3 id="org39093ae"><span class="section-number-3">1.10</span> RDM struct (hard-coded)</h3>
<div class="outline-text-3" id="text-1-10">
</div>
<div id="outline-container-orge9f9527" class="outline-4">
<h4 id="orge9f9527"><span class="section-number-4">1.10.1</span> Read the complete struct</h4>
<div id="outline-container-org9aa24e5" class="outline-4">
<h4 id="org9aa24e5"><span class="section-number-4">1.10.1</span> Read the complete struct</h4>
<div class="outline-text-4" id="text-1-10-1">
<div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">rdm_t</span>* <span style="color: #0000ff;">trexio_text_read_rdm</span>(<span style="color: #228b22;">trexio_text_t</span>* <span style="color: #a020f0;">const</span> <span style="color: #a0522d;">file</span>);
@ -1064,8 +1055,8 @@ The <code>group_dset</code> array is assumed allocated with the appropriate size
</div>
</div>
<div id="outline-container-org119e83b" class="outline-4">
<h4 id="org119e83b"><span class="section-number-4">1.10.2</span> Flush the complete struct</h4>
<div id="outline-container-orgdd33185" class="outline-4">
<h4 id="orgdd33185"><span class="section-number-4">1.10.2</span> Flush the complete struct</h4>
<div class="outline-text-4" id="text-1-10-2">
<div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">trexio_exit_code</span> <span style="color: #0000ff;">trexio_text_flush_rdm</span>(<span style="color: #228b22;">trexio_text_t</span>* <span style="color: #a020f0;">const</span> <span style="color: #a0522d;">file</span>);
@ -1108,8 +1099,8 @@ The <code>group_dset</code> array is assumed allocated with the appropriate size
</div>
</div>
<div id="outline-container-org4effdb1" class="outline-4">
<h4 id="org4effdb1"><span class="section-number-4">1.10.3</span> Free memory</h4>
<div id="outline-container-org781138b" class="outline-4">
<h4 id="org781138b"><span class="section-number-4">1.10.3</span> Free memory</h4>
<div class="outline-text-4" id="text-1-10-3">
<p>
Memory is allocated when reading. The followig function frees memory.
@ -1145,8 +1136,8 @@ Memory is allocated when reading. The followig function frees memory.
</div>
</div>
<div id="outline-container-orgb657d2d" class="outline-4">
<h4 id="orgb657d2d"><span class="section-number-4">1.10.4</span> Read/Write the one<sub>e</sub> attribute</h4>
<div id="outline-container-org42ceb8c" class="outline-4">
<h4 id="org42ceb8c"><span class="section-number-4">1.10.4</span> Read/Write the one<sub>e</sub> attribute</h4>
<div class="outline-text-4" id="text-1-10-4">
<p>
The <code>one_e</code> array is assumed allocated with the appropriate size.
@ -1212,8 +1203,8 @@ The <code>one_e</code> array is assumed allocated with the appropriate size.
</div>
</div>
<div id="outline-container-orge070ec4" class="outline-4">
<h4 id="orge070ec4"><span class="section-number-4">1.10.5</span> Read/Write the two<sub>e</sub> attribute</h4>
<div id="outline-container-org2664fa8" class="outline-4">
<h4 id="org2664fa8"><span class="section-number-4">1.10.5</span> Read/Write the two<sub>e</sub> attribute</h4>
<div class="outline-text-4" id="text-1-10-5">
<p>
<code>two_e</code> is a sparse data structure, which can be too large to fit
@ -1321,7 +1312,7 @@ file for each sparse float structure.
</div>
<div id="postamble" class="status">
<p class="author">Author: TREX-CoE</p>
<p class="date">Created: 2021-05-07 Fri 22:44</p>
<p class="date">Created: 2021-05-18 Tue 10:16</p>
<p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p>
</div>
</body>