| 1 | /** @mainpage | 
|---|
| 2 |  | 
|---|
| 3 | @brief FACT++ - The FACT slow control software | 
|---|
| 4 |  | 
|---|
| 5 | @author thomas.bretz@phys.ethz.ch et al. | 
|---|
| 6 | <!--@version 1.0--> | 
|---|
| 7 |  | 
|---|
| 8 | <hr width="100%"> | 
|---|
| 9 |  | 
|---|
| 10 | @section toc Table of contents | 
|---|
| 11 | <table border='1' bgcolor=#FAFAFA width='100%'> | 
|---|
| 12 | <tr> | 
|---|
| 13 | <td> | 
|---|
| 14 | <ul> | 
|---|
| 15 | <li> @ref install_sec | 
|---|
| 16 | <ul> | 
|---|
| 17 | <li> @ref rootwarning | 
|---|
| 18 | <li> @ref packages | 
|---|
| 19 | <li> @ref installroot | 
|---|
| 20 | </ul> | 
|---|
| 21 | <li> @ref demos | 
|---|
| 22 | <li> @ref dimremarks | 
|---|
| 23 | <li> @ref addtab | 
|---|
| 24 | <li> @ref Documentation | 
|---|
| 25 | <li> @ref References | 
|---|
| 26 | <ul> | 
|---|
| 27 | <li> @ref generalref | 
|---|
| 28 | <li> @ref boostref | 
|---|
| 29 | <li> @ref fitsref | 
|---|
| 30 | <li> @ref qtroot | 
|---|
| 31 | </ul> | 
|---|
| 32 | <li> @ref availableprograms | 
|---|
| 33 | <li> @ref Examples | 
|---|
| 34 | </ul> | 
|---|
| 35 | </tr> | 
|---|
| 36 | </td> | 
|---|
| 37 | </table> | 
|---|
| 38 |  | 
|---|
| 39 | @section install_sec Installation | 
|---|
| 40 |  | 
|---|
| 41 | FACT++ can be downloaded from the svn by | 
|---|
| 42 |  | 
|---|
| 43 | \verbatim | 
|---|
| 44 | svn checkout https://www.fact-project.org/svn/trunk/FACT++ [localdir] | 
|---|
| 45 | \endverbatim | 
|---|
| 46 |  | 
|---|
| 47 | it includes a dim version which is automatically compiled. | 
|---|
| 48 |  | 
|---|
| 49 | For compilation use | 
|---|
| 50 |  | 
|---|
| 51 | \verbatim | 
|---|
| 52 | ./configure | 
|---|
| 53 | make | 
|---|
| 54 | \endverbatim | 
|---|
| 55 |  | 
|---|
| 56 | Check the \b ./configure options with \b --help. It might look | 
|---|
| 57 | confusing, but some features like FITS or QT4 can be switched off, | 
|---|
| 58 | if the necessary library is not at hand and the feature is not needed. | 
|---|
| 59 | For example, if the GUI is not needed its compilation can be switched | 
|---|
| 60 | off by disabling QT4 support with \b --without-qt4. | 
|---|
| 61 |  | 
|---|
| 62 | If you use a custom built root version on your system without QT | 
|---|
| 63 | support, but have a distribution packe (e.g. debian package) with | 
|---|
| 64 | QT support available, you can give the path to root executables, | 
|---|
| 65 | for example, with <B>--with-rootsys=/usr/bin</B>. All other paths | 
|---|
| 66 | are extracted from subsequent calls to \b root-config. | 
|---|
| 67 |  | 
|---|
| 68 | Running \b ./configure will take some time. It tries to really check | 
|---|
| 69 | carefully that everything needed is available on your system, so that you | 
|---|
| 70 | get errors before you start compilation. | 
|---|
| 71 |  | 
|---|
| 72 | If \b ./configure fails and you send a bug report please attach | 
|---|
| 73 | the file config.log. | 
|---|
| 74 |  | 
|---|
| 75 | If \b make fails and you send a bug report please attach | 
|---|
| 76 | the complete output of <B>make V=1</B>. | 
|---|
| 77 |  | 
|---|
| 78 | \b Reminder: These programs use shared libraries, i.e. whenever you re-compile | 
|---|
| 79 | part of the project some of them might be re-compiled as well. As a result | 
|---|
| 80 | already running programs might crash unexpectedly! This is \b not a bug. | 
|---|
| 81 |  | 
|---|
| 82 | In principle configure also supports | 
|---|
| 83 |  | 
|---|
| 84 | \verbatim | 
|---|
| 85 | make install | 
|---|
| 86 | \endverbatim | 
|---|
| 87 |  | 
|---|
| 88 | which would install the package and the libraries in your system, | 
|---|
| 89 | although at the moment this is not recommended | 
|---|
| 90 |  | 
|---|
| 91 | @subsection rootwarning ROOT warnings during compilation | 
|---|
| 92 |  | 
|---|
| 93 | During compilation of the GUI you get some warning from root's | 
|---|
| 94 | TQtWidget.h. These warnings are completely harmless and can be ignored. | 
|---|
| 95 | However, it is sometimes advicable to get rid of them to get a clean | 
|---|
| 96 | compiler run which makes development easier. | 
|---|
| 97 |  | 
|---|
| 98 | Therefore replace | 
|---|
| 99 | \verbatim | 
|---|
| 100 | inline void resize(const QSize &size) { QPixmap newSize(size); *(QPixmap *)this = newSize; } | 
|---|
| 101 | \endverbatim | 
|---|
| 102 | by | 
|---|
| 103 | \verbatim | 
|---|
| 104 | inline void resize(const QSize &sz) { QPixmap newSize(sz); *(QPixmap *)this = newSize; } | 
|---|
| 105 | \endverbatim | 
|---|
| 106 | in TQtWidget.h | 
|---|
| 107 |  | 
|---|
| 108 |  | 
|---|
| 109 | @subsection packages Required packages | 
|---|
| 110 |  | 
|---|
| 111 | The following section gives a list of packages which were necessary after | 
|---|
| 112 | a fresh Ubuntu 11.04 installation. In addition to all the development | 
|---|
| 113 | packages the corresponding package with the library is needed. | 
|---|
| 114 |  | 
|---|
| 115 | Note that a recent C++ compiler is needed supporting the latest C++0x | 
|---|
| 116 | standard. | 
|---|
| 117 |  | 
|---|
| 118 | <i>Required (configure will fail without them)</i> | 
|---|
| 119 | - subversion | 
|---|
| 120 | - gcc | 
|---|
| 121 | - g++ | 
|---|
| 122 | - make | 
|---|
| 123 | - libreadline6-dev | 
|---|
| 124 | - libboost-all-dev | 
|---|
| 125 | - libx11-dev (needed for lesstif, qt4, root) | 
|---|
| 126 |  | 
|---|
| 127 | <i>FITS file support (datalogger, event builder)</i> | 
|---|
| 128 | - libccfits-dev | 
|---|
| 129 |  | 
|---|
| 130 | <i>MySQL support (command line options, scheduler)</i> | 
|---|
| 131 | - libmysqlclient-dev (optional for MySQL support) | 
|---|
| 132 | - libmysql++-dev (option for MySQL support) | 
|---|
| 133 |  | 
|---|
| 134 | <i>If you want 'did'</i> | 
|---|
| 135 | - lesstif2-dev | 
|---|
| 136 |  | 
|---|
| 137 | <i>For JavaScrip support</i> | 
|---|
| 138 | - libv8-dev | 
|---|
| 139 |  | 
|---|
| 140 | <i>To compile the GUIs</i> | 
|---|
| 141 | - libqt4-dev | 
|---|
| 142 | - root (see section about root, currently recommended versions 5.18/00b-5.26/00e) | 
|---|
| 143 |  | 
|---|
| 144 | <i>To compile the raw data viewer</i> | 
|---|
| 145 | - libglu1-mesa-dev | 
|---|
| 146 |  | 
|---|
| 147 | <i>To compile smartfact with astronomy support and moon</i> | 
|---|
| 148 | - libnova-dev | 
|---|
| 149 |  | 
|---|
| 150 | <i>To compile tngweather</i> | 
|---|
| 151 | - libsoprano-dev | 
|---|
| 152 |  | 
|---|
| 153 | <i>To compile skypeclient</i> | 
|---|
| 154 | - libdbus-1-dev | 
|---|
| 155 | - libdbus-glib-1-dev | 
|---|
| 156 |  | 
|---|
| 157 | <i>To create your own documentation</i> | 
|---|
| 158 | - graphviz | 
|---|
| 159 | - doxygen | 
|---|
| 160 | - help2man | 
|---|
| 161 | - groff | 
|---|
| 162 | - ps2pdf | 
|---|
| 163 |  | 
|---|
| 164 | <i>To create JavaScript documentation</i> | 
|---|
| 165 | - jsdoc-toolkit | 
|---|
| 166 |  | 
|---|
| 167 | <i>For developers</i> | 
|---|
| 168 | - autoconf | 
|---|
| 169 | - autoconf-archive | 
|---|
| 170 | - libtool | 
|---|
| 171 | - qt4-designer | 
|---|
| 172 |  | 
|---|
| 173 | If you intend to change only Makefile.am but not configure.ac the \b automake | 
|---|
| 174 | package instead of the \b autoconf package should be enough. | 
|---|
| 175 |  | 
|---|
| 176 | <i>Some nice to have (FACT++)</i> | 
|---|
| 177 | - colorgcc | 
|---|
| 178 | - colordiff | 
|---|
| 179 |  | 
|---|
| 180 | <i>Some nice to have (system)</i> | 
|---|
| 181 | - fte | 
|---|
| 182 | - efte | 
|---|
| 183 | - htop | 
|---|
| 184 |  | 
|---|
| 185 | <i>Documentation (usually accessible through http://localhost/ for the tools above:</I> | 
|---|
| 186 | - autoconf-doc | 
|---|
| 187 | - gcc-doc | 
|---|
| 188 | - graphviz-doc | 
|---|
| 189 | - libboost-doc | 
|---|
| 190 | - libmysql++-doc | 
|---|
| 191 | - libtool-doc | 
|---|
| 192 | - make-doc | 
|---|
| 193 | - qt4-dev-tools [qt4-assistant] | 
|---|
| 194 | - qt4-doc-html | 
|---|
| 195 |  | 
|---|
| 196 |  | 
|---|
| 197 | <!-- | 
|---|
| 198 | VIEWER | 
|---|
| 199 | libqwt5-qt4-dev | 
|---|
| 200 | libqwt5-doc | 
|---|
| 201 | --> | 
|---|
| 202 |  | 
|---|
| 203 | @subsection installroot How to install root 5.26/00 on Ubuntu 11.04 (natty) | 
|---|
| 204 |  | 
|---|
| 205 | - install gpp4.4, gcc4.4, g++4.4 (root does not compile with gcc4.5) | 
|---|
| 206 | - make links to hidden X11 libraries: | 
|---|
| 207 | <B><pre> | 
|---|
| 208 | cd /usr/local | 
|---|
| 209 | sudo ln -s x86_64-linux-gnu/libX* . | 
|---|
| 210 | </pre></B> | 
|---|
| 211 | - in the root source directory | 
|---|
| 212 | <B><pre> | 
|---|
| 213 | ./configure --enable-qt --with-cc=gcc-4.4 --with-cxx=g++-4.4 --with-xrootd-opts=--syslibs=/usr/lib/x86_64-linux-gnu --prefix=/usr/local | 
|---|
| 214 | </pre></B> | 
|---|
| 215 | - \b make | 
|---|
| 216 | - <b>sudo make install</b> | 
|---|
| 217 | - pray | 
|---|
| 218 | - don't forget to set LD_LIBRARY_PATH correctly before you try to start the fact gui | 
|---|
| 219 |  | 
|---|
| 220 |  | 
|---|
| 221 | @section demos Current demonstration programs | 
|---|
| 222 |  | 
|---|
| 223 | - \b dserver2: A virtual board (A TCP/IP server). It is sending a | 
|---|
| 224 | "hello" message after accepting a communication and then in 3s | 
|---|
| 225 | intervals the current UTC time. The board can be set to state 1 or back | 
|---|
| 226 | to state 0 (just as a demonstration) | 
|---|
| 227 | - \b dclient5: A control program. It accesses two viratual boards (start them | 
|---|
| 228 | with 'dserver2 5000' and 'dserver2 4001') If both boards are connected the START | 
|---|
| 229 | command can be issued to get them to state 'Running'. In this state | 
|---|
| 230 | an asynchronous time stamp can be requested sending the TIME command. | 
|---|
| 231 | to get back from Running to Connected use STOP. | 
|---|
| 232 | - \b test3: a dim console which allows to control all dim servers | 
|---|
| 233 | by sending commands via the dim network. | 
|---|
| 234 | - Both, \b dclient5 and \b test3 accept the command line options -c0, -c1, -c2 | 
|---|
| 235 | to switch between different console types (or no console in the case of | 
|---|
| 236 | \b dclient5). In the console you get help with 'h' and the available | 
|---|
| 237 | command with 'c' You get the avilable command-line options with --help | 
|---|
| 238 |  | 
|---|
| 239 | First start the two dserver2s. Then start a dclient5 (if you want it | 
|---|
| 240 | with console use one of the -c options) and a test3 console (with one | 
|---|
| 241 | of the console options if you like) you can now control the hardware | 
|---|
| 242 | boards with the START, STOP and TIME commands or stop (Ctrl-C) and | 
|---|
| 243 | start one of the programs to see what's happening. In the test3 case | 
|---|
| 244 | you first have to \e cd to the server to which you want to talk by \b | 
|---|
| 245 | DATA_LOGGER. Don't forget to start \b dns if you want to control dclient5 | 
|---|
| 246 | from test3 via Dim. | 
|---|
| 247 |  | 
|---|
| 248 | @section dimremarks Remarks about Dim usage | 
|---|
| 249 |  | 
|---|
| 250 | To be able to write all received data directly to the FITS files, | 
|---|
| 251 | padding has been disabled calling dic_diable_padding() and | 
|---|
| 252 | dis_disable_padding(). This is done in our own error handler | 
|---|
| 253 | DimErrorRedirecter. Since this should be one of the first | 
|---|
| 254 | objects created in any environment it is quite save. However, every | 
|---|
| 255 | Dim client or server in our network which does not use the | 
|---|
| 256 | DimErrorRedirecter \b must call these two functions as early as | 
|---|
| 257 | possible. | 
|---|
| 258 |  | 
|---|
| 259 | <!-- | 
|---|
| 260 | @section exitcodes Exit Code | 
|---|
| 261 | @section newcommand How to add a new command? | 
|---|
| 262 | @section description How to add help textes to services and commands? | 
|---|
| 263 | --> | 
|---|
| 264 |  | 
|---|
| 265 | @section blocking Blocking programs at startup | 
|---|
| 266 |  | 
|---|
| 267 | At startup most programs try to resolve the name of the dim-dns | 
|---|
| 268 | as well as their local IP address. After this Dim is initialized | 
|---|
| 269 | and tries to contact the dns. These are so far the only blocking operations. | 
|---|
| 270 | Be patient at program startup. They will usually timeout after a while and | 
|---|
| 271 | give you proper informations. | 
|---|
| 272 |  | 
|---|
| 273 |  | 
|---|
| 274 | @section addtab How to add a new tab in the gui? | 
|---|
| 275 |  | 
|---|
| 276 | Do the following steps in exactly this order: | 
|---|
| 277 | - Insert the new page from the context menu of the QTabWidget | 
|---|
| 278 | - Copy the QDockWidget from one of the other tabs to the clipboard | 
|---|
| 279 | - Paste the copied QDockWidget and add it to the new tab (only the tab should be highlited) | 
|---|
| 280 | - Now click on the context menu of the region in the tab (QWidget) and change the layout to grid layout | 
|---|
| 281 |  | 
|---|
| 282 |  | 
|---|
| 283 | @section Documentation | 
|---|
| 284 |  | 
|---|
| 285 | Each program has an extensive help text (except the examples). This | 
|---|
| 286 | help text can be displayed with the \b --help option. For each program | 
|---|
| 287 | a man-page is automatically created (from the help-output), which (at | 
|---|
| 288 | the moment) can be accessed with <B>man ./program.man</B> (Don't forget | 
|---|
| 289 | the ./ before the filename). With <B>make program.html</B> and | 
|---|
| 290 | <B>make program.pdf</B> a HTML page and a pdf document can be created | 
|---|
| 291 | from the man-page. | 
|---|
| 292 |  | 
|---|
| 293 | With <B>make doxygen-doc</B> the HTML documentation as well as a pdf | 
|---|
| 294 | with the whole code documentation can be created. | 
|---|
| 295 |  | 
|---|
| 296 | @subsection FACT++ programs | 
|---|
| 297 |  | 
|---|
| 298 | Each documentation is also available with <B>program --help</B> or | 
|---|
| 299 | <B>man ./program.man</B>. | 
|---|
| 300 |  | 
|---|
| 301 | In alphabetic order: | 
|---|
| 302 |  | 
|---|
| 303 | - <A HREF="man/biasctrl.html">biasctrl</A> [<A HREF="pdf/biasctrl.pdf">pdf</A>] | 
|---|
| 304 | - <A HREF="man/datalogger.html">datalogger</A> [<A HREF="pdf/datalogger.pdf">pdf</A>] | 
|---|
| 305 | - <A HREF="man/dimctrl.html">dimctrl</A> [<A HREF="pdf/dimctrl.pdf">pdf</A>] | 
|---|
| 306 | - <A HREF="man/drivectrl.html">drivectrl</A> [<A HREF="pdf/drivrctrl.pdf">pdf</A>] | 
|---|
| 307 | - <A HREF="man/evtserver.html">evtserver</A> [<A HREF="pdf/evtserver.pdf">pdf</A>] | 
|---|
| 308 | - <A HREF="man/fadctrl.html">fadctrl</A> [<A HREF="pdf/fadctrl.pdf">pdf</A>] | 
|---|
| 309 | - <A HREF="man/feedback.html">feedback</A> [<A HREF="pdf/feedback.pdf">pdf</A>] | 
|---|
| 310 | - <A HREF="man/fitsdump.html">fitsdump</A> [<A HREF="pdf/fitsdump.pdf">pdf</A>] | 
|---|
| 311 | - <A HREF="man/fitscheck.html">fitscheck</A> [<A HREF="pdf/fitscheck.pdf">pdf</A>] | 
|---|
| 312 | - <A HREF="man/fitsselect.html">fitsselect</A> [<A HREF="pdf/fitsselect.pdf">pdf</A>] | 
|---|
| 313 | - <A HREF="man/fscctrl.html">fscctrl</A> [<A HREF="pdf/fscctrl.pdf">pdf</A>] | 
|---|
| 314 | - <A HREF="man/ftmctrl.html">ftmctrl</A> [<A HREF="pdf/ftmctrl.pdf">pdf</A>] | 
|---|
| 315 | - <A HREF="man/getevent.html">getevent</A> [<A HREF="pdf/getevent.pdf">pdf</A>] | 
|---|
| 316 | - <A HREF="man/gpsctrl.html">gpsctrl</A> [<A HREF="pdf/gpsctrl.pdf">pdf</A>] | 
|---|
| 317 | - <A HREF="man/lidctrl.html">lidctrl</A> [<A HREF="pdf/lidctrl.pdf">pdf</A>] | 
|---|
| 318 | - <A HREF="man/magiclidar.html">magiclidar</A> [<A HREF="pdf/magiclidar.pdf">pdf</A>] | 
|---|
| 319 | - <A HREF="man/magicweather.html">magicweather</A> [<A HREF="pdf/magicweather.pdf">pdf</A>] | 
|---|
| 320 | - <A HREF="man/mcp.html">mcp</A> [<A HREF="pdf/mcp.pdf">pdf</A>] | 
|---|
| 321 | - <A HREF="man/pfminictrl.html">pfminictrl</A> [<A HREF="pdf/pfminictrl.pdf">pdf</A>] | 
|---|
| 322 | - <A HREF="man/pwrctrl.html">pwrctrl</A> [<A HREF="pdf/pwrctrl.pdf">pdf</A>] | 
|---|
| 323 | - <A HREF="man/ratecontrol.html">ratecontrol</A> [<A HREF="pdf/ratecontrol.pdf">pdf</A>] | 
|---|
| 324 | - <A HREF="man/ratescan.html">ratescan</A> [<A HREF="pdf/ratescan.pdf">pdf</A>] | 
|---|
| 325 | - <A HREF="man/showlog.html">showlog</A> [<A HREF="pdf/showlog.pdf">pdf</A>] | 
|---|
| 326 | - <A HREF="man/smartfact.html">smartfact</A> [<A HREF="pdf/smartfact.pdf">pdf</A>] | 
|---|
| 327 | - <A HREF="man/sqmctrl.html">sqmctrl</A> [<A HREF="pdf/sqmctrl.pdf">pdf</A>] | 
|---|
| 328 | - <A HREF="man/temperature.html">temperature</A> [<A HREF="pdf/temperature.pdf">pdf</A>] | 
|---|
| 329 | - <A HREF="man/timecheck.html">timecheck</A> [<A HREF="pdf/timecheck.pdf">pdf</A>] | 
|---|
| 330 | - <A HREF="man/tngweather.html">tngweather</A> [<A HREF="pdf/tngweather.pdf">pdf</A>] | 
|---|
| 331 | - <A HREF="man/zfits.html">zfits</A> [<A HREF="pdf/zfits.pdf">pdf</A>] | 
|---|
| 332 |  | 
|---|
| 333 | @section References | 
|---|
| 334 |  | 
|---|
| 335 | @subsection generalref General references | 
|---|
| 336 | - <A HREF="http://www.cplusplus.com/reference">The C++ reference</A> | 
|---|
| 337 | - <A HREF="http://www.boost.org">boost.org: The boost C++ libraries</A> | 
|---|
| 338 | - <A HREF="http://www.highscore.de/cpp/boost/titelseite.html">Boris Schäling: Die Boost C++ Bibliotheken</A> | 
|---|
| 339 | - <A HREF="http://cnswww.cns.cwru.edu/php/chet/readline/rltop.html">GNU Readline</A> | 
|---|
| 340 | - <A HREF="http://www.gnu.org/software/ncurses">GNU Ncurses</A> | 
|---|
| 341 | - <A HREF="http://dim.web.cern.ch/">Distributed Information Management (DIM)</A> | 
|---|
| 342 | - <A HREF="http://dim.web.cern.ch/dim/cpp_doc/DimCpp.html">Distributed Information Management (DIM) - C++ reference</A> | 
|---|
| 343 | - <A HREF="http://qt.nokia.com/">Qt homepage</A> | 
|---|
| 344 | - <A HREF="http://qt.nokia.com/downloads/">Qt downloads</A> | 
|---|
| 345 |  | 
|---|
| 346 | @subsection boostref Boost references | 
|---|
| 347 | - <A HREF="http://www.boost.org/doc/libs/1_45_0/libs/bind/bind.html">boost::bind (V1.45.0)</A> | 
|---|
| 348 | - <A HREF="http://www.boost.org/doc/libs/1_45_0/doc/html/boost_asio.html">boost asio (V1.45.0)</A> | 
|---|
| 349 | - <A HREF="http://www.boost.org/doc/libs/1_45_0/doc/html/date_time.html">boost date_time (V1.45.0)</A> | 
|---|
| 350 | - <A HREF="http://www.boost.org/doc/libs/1_45_0/doc/html/program_options.html">boost program_options (V1.45.0)</A> | 
|---|
| 351 | - <A HREF="http://www.boost.org/doc/libs/1_45_0/libs/filesystem/v3/doc/index.htm">boost filesystem (V1.45.0)</A> | 
|---|
| 352 | - <A HREF="http://www.boost.org/doc/libs/1_45_0/libs/regex/doc/html/index.html">boost regex (V1.45.0)</A> | 
|---|
| 353 | - <A HREF="http://www.boost.org/doc/libs/1_45_0/libs/system/doc/index.html">boost system (error codes) (V1.45.0)</A> | 
|---|
| 354 | - <A HREF="http://www.boost.org/doc/libs/1_45_0/doc/html/thread.html">boost thread (V1.45.0)</A> | 
|---|
| 355 | - <A HREF="http://www.boost.org/doc/libs/1_45_0/libs/conversion/lexical_cast.htm">boost lexical_cast (V1.45.0)</A> | 
|---|
| 356 |  | 
|---|
| 357 | @subsection fitsref FITS references | 
|---|
| 358 | - <A HREF="http://heasarc.gsfc.nasa.gov/docs/heasarc/fits.html">The FITS data format</A> | 
|---|
| 359 | - <A HREF="http://heasarc.gsfc.nasa.gov/fitsio/">FITS homepage</A> | 
|---|
| 360 | - <A HREF="http://heasarc.gsfc.nasa.gov/fitsio/CCfits/">CCfits - A C++ wrapper to cfitsio</A> | 
|---|
| 361 | - <A HREF="http://heasarc.gsfc.nasa.gov/docs/software/ftools/fv/">fv - A very simple viewer to FITS file contents</A> | 
|---|
| 362 | - <A HREF="http://www.star.bris.ac.uk/~mbt/topcat/">topcat - <B>T</B>ool for <B>OP</B>erations on <B>C</B>atalogues <B>A</B>nd <B>T</B>ables | 
|---|
| 363 |  | 
|---|
| 364 | @subsection qtroot How to integrate root in QT? | 
|---|
| 365 |  | 
|---|
| 366 | - <A HREF="http://doc.trolltech.com/4.3/designer-creating-custom-widgets.html">QT4: Creating custom widgets</A> | 
|---|
| 367 | - <A HREF="http://root.cern.ch/download/doc/26ROOTandQt.pdf">root: QT integration (pdf)</A> | 
|---|
| 368 |  | 
|---|
| 369 |  | 
|---|
| 370 | @section availableprograms Available programs | 
|---|
| 371 |  | 
|---|
| 372 | - dns: Dim's domain-name-server (needed for any communication between Dim servers and clients) | 
|---|
| 373 | - did: A simple graphical interface to analyse everything in a Dim network | 
|---|
| 374 |  | 
|---|
| 375 | @section Examples | 
|---|
| 376 |  | 
|---|
| 377 | There are a few example programs | 
|---|
| 378 | - \b ./argv: Example for usage of the class Configure (command line options, configuration file) | 
|---|
| 379 | - \b ./time: Example for the usage of the class Time (time input/output, conversion) | 
|---|
| 380 | - \b ./log, \b ./logtime: A simple Dim-Service/-Client combination using MessageDimRX/MessageDimTX | 
|---|
| 381 |  | 
|---|
| 382 | **/ | 
|---|