dime  0.9.1
Portable DXF file library
Loading...
Searching...
No Matches
Record.h
1/**************************************************************************\
2 * Copyright (c) Kongsberg Oil & Gas Technologies AS
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions are
7 * met:
8 *
9 * Redistributions of source code must retain the above copyright notice,
10 * this list of conditions and the following disclaimer.
11 *
12 * Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 *
16 * Neither the name of the copyright holder nor the names of its
17 * contributors may be used to endorse or promote products derived from
18 * this software without specific prior written permission.
19 *
20 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24 * HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31\**************************************************************************/
32
33#ifndef DIME_RECORD_H
34#define DIME_RECORD_H
35
36#include <dime/Basic.h>
37#include <dime/Base.h>
38#include <stdio.h>
39
40class dimeInput;
41class dimeOutput;
42
43class DIME_DLL_API dimeRecord : public dimeBase
44{
45public:
46 dimeRecord(const int group_code);
47 virtual ~dimeRecord();
48
49 virtual void setValue(const dimeParam &param, dimeMemHandler * const memhandler = NULL) = 0;
50 virtual void getValue(dimeParam &param) const = 0;
51 virtual dimeRecord *copy(dimeMemHandler * const memhandler) const = 0;
52
53 void setGroupCode(const int group_code);
54 int getGroupCode() const;
55
56
57public:
58 virtual bool isEndOfSectionRecord() const;
59 virtual bool isEndOfFileRecord() const;
60 virtual int typeId() const = 0;
61 virtual bool read(dimeInput * const in) = 0;
62 virtual bool write(dimeOutput * const out);
63 virtual void print() const {fprintf(stderr, "rec: %d\n", groupCode);}
64
65public:
66 static bool readRecordData(dimeInput * const in, const int group_code,
67 dimeParam &param);
68 static dimeRecord *readRecord(dimeInput * const in);
69 static dimeRecord *createRecord(const int group_code,
70 dimeMemHandler * const memhandler);
71 static dimeRecord *createRecord(const int group_code,
72 const dimeParam &param,
73 dimeMemHandler * const memhandler);
74 static int getRecordType(const int group_code);
75
76protected:
77 int groupCode;
78
79}; // class dimeRecord
80
81#endif // ! DIME_RECORD_H
82
The dimeBase class is the superclass for most classes in Dime.
Definition Base.h:42
The dimeInput class offers transparent file I/O for DXF and DXB.
Definition Input.h:42
The dimeMemHandler class is a special-purpose memory manager.
Definition MemHandler.h:39
The dimeOutput class handles writing of DXF and DXB files.
Definition Output.h:42
The dimeRecord class is the superclass of all record classes.
Definition Record.h:44
virtual void print() const
Definition Record.h:63
virtual int typeId() const =0
virtual bool read(dimeInput *const in)=0
virtual dimeRecord * copy(dimeMemHandler *const memhandler) const =0
virtual void setValue(const dimeParam &param, dimeMemHandler *const memhandler=NULL)=0
virtual void getValue(dimeParam &param) const =0
The dimeParam class is a union of the different parameter types.
Definition Basic.h:102