File: techrequirements.tex

package info (click to toggle)
hdf5-filter-plugin 0.0~git20221111.49e3b65-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 3,848 kB
  • sloc: ansic: 14,374; sh: 11,445; cpp: 1,463; makefile: 100; python: 19; xml: 6
file content (128 lines) | stat: -rw-r--r-- 4,191 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
\documentclass{scrartcl}
\usepackage{todonotes}
\usepackage{multirow}
\usepackage{hyperref}
\usepackage{url}

\hypersetup{ colorlinks=true,
             pdftitle={HDF5 external filters - technical issues},
             citecolor=blue,
             urlcolor=blue,
             pagebackref=true
}

\title{
       {\huge HDF5 external filters}\\
       technical issues}
       
       \author{Eugen Wintersberger}

\begin{document}
\maketitle
\begin{abstract}
    This document tries to address all the technical issues concerning 
    the development and maintenance of external filter modules for HDF5. 
\end{abstract}

%%%===========================================================================
\section{Supported platforms and architectures}

The current release of HDF5\footnote{At the time of writing this was 1.8.13} 
supports the following platforms and architectures
\begin{center}
\begin{tabular}{l|c|c|c|c|c}
    & i386 & x86\_64 & SPARC 32-bit & SPARC 64-bit & PPC64 \\
    \hline\hline
    Linux & X  &  X & -- & -- & X \\
    \hline
    Windows 7 & X  & X & -- & -- & -- \\
    \hline
    Windows 8.1 & X & X & -- & -- & -- \\
    \hline
    OS X Lion 10.7.3 & -- & X & -- & -- & -- \\
    \hline
    OS X Mt. Lion 10.8.5 & -- & X & -- & -- & -- \\
    \hline
    OS X Mavericks 10.9.2 & -- & X & -- & -- & -- \\
    \hline
    SunOS 5.11 & -- & -- & X & X & -- \\
    \hline
    FreeBSD 8.2 & X & X & -- & -- & -- \\
    \hline
\end{tabular}
\end{center}
All external filter modules (EFMs) have to support the same set of platforms and 
architectures as the actual HDF5 release. This should ensure that no user 
experiences problems whenever he or she uses HDF5 on an officially supported
platform-architecture setup.

%%%===========================================================================
\section{Source code management}

Reasonable maintenance of software is only possible by using a source code
management (SCM) tool. The HDF5 library is currently using SVN\cite{SVN}
( as SCM system. However, for EF module
development SVN, being a centralized SCM tool, might not be the best choice. 
Due to its central nature it has some natural drawbacks
\begin{itemize}
    \item working offline is rather difficult 
    \item branching is as hard 
    \item it is hard to move repositories between different servers. 
\end{itemize}
In order to make things easy I suggest git~\cite{GIT} as the preferred SCM for EFM 
development. One of the big advantages of git is that repositories can be 
moved easily. This makes changing the hosting platform for an EFM project
simple. Such a process may becomes necessary if the original platform ceases 
to exist or if an abandoned module is taken over by a new developer who 
wants to use a different platform. 


%%%===========================================================================
\section{Compilers and code}

The choice of the programming language is rather simple: as the HDF5 core
library is written in C, C should also be used for the EFM. 
The language standard used is C99.

\subsection{Supported compilers and language standards}

All modules must comply to the C99 standard and build the code with the
following compilers 
\begin{center}
\begin{tabular}{l|| c | c}
    \hline
    \multirow{3}{*}{Windows} & intel cc & ?? \\
                             & mingw gcc  & ?? \\
     & MS Studio & ?? \\
    \hline
    \multirow{3}{*}{Linux} & gcc & ?? \\
     & intel & ??  \\
     & clang & ?? \\
    \hline
    OSX     & clang & ?? \\
    \hline
\end{tabular}
\todo{Check compilers and required versions}
\todo{is there a good reason why HDF5
does not support the MinGW compiler suite?}
\end{center}

\subsection{Code organization and coding style}

The code should be organized according to the GNU standards
\cite{GNU_STYLE,GNU_MAINTENANCE}.

\subsection{Build systems}

Due to the large number of platforms every EF module has to support at least two
build systems
\begin{description}
    \item[cmake] \cite{CMAKE} for builds on Windows and OSX
    \item[autotools] \cite{AUTOTOOLS} for builds on Linux and Unix systems.
\end{description}

\bibliographystyle{IEEEtran}
\bibliography{references}


\end{document}