1 /***************************************************************************
2 * Copyright (C) 2007 by www.databasecache.com *
3 * Contact: praba_tuty@databasecache.com *
5 * This program is free software; you can redistribute it and/or modify *
6 * it under the terms of the GNU General Public License as published by *
7 * the Free Software Foundation; either version 2 of the License, or *
8 * (at your option) any later version. *
10 * This program is distributed in the hope that it will be useful, *
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
13 * GNU General Public License for more details. *
15 ***************************************************************************/
18 #include<CatalogTables.h>
26 void TableDef::reset()
32 int TableDef::addField(const char *name
, DataType type
, size_t length
,
33 const void *defaultValue
, bool notNull
, bool autoIn
)
35 if (name
== NULL
) return (int)ErrBadArg
;
36 if(strlen(name
)>IDENTIFIER_LENGTH
)
38 printError(ErrBadRange
,"Field name should not exceed 64 character");
39 return (int)ErrBadRange
;
41 // The following code checks for duplicates
42 FieldIterator iter
= getFieldIterator();
43 while (iter
.hasElement())
45 FieldDef
*def
= iter
.nextElement();
46 if (! strcmp(def
->fldName_
, name
)) {
47 printError(ErrAlready
, "Field %s already Exists", name
);
48 return (int) ErrAlready
;
52 if (!Util::isIdentifier((char*)name
)) {
53 printError(ErrBadArg
, "fieldname contains invalid characters");
54 return (int) ErrBadArg
;
57 strcpy(fldDef
.fldName_
, name
);
58 fldDef
.fldName_
[IDENTIFIER_LENGTH
] = '\0';
60 fldDef
.length_
= AllDataType::size(type
, length
);
62 if (defaultValue
!= NULL
&& *(char *)defaultValue
!= '\0')
64 fldDef
.isDefault_
= true;
65 if (typeBinary
== type
) {
66 const char *p
= (const char *) defaultValue
;
68 if (! isxdigit((int)(*p
++)) ) {
69 printError(ErrBadArg
, "Invalid hexadecimal value");
70 return (int) ErrBadArg
;
74 os::memcpy(fldDef
.defaultValueBuf_
, defaultValue
, DEFAULT_VALUE_BUF_LENGTH
);
78 fldDef
.isDefault_
= false;
79 os::memset(fldDef
.defaultValueBuf_
,0, DEFAULT_VALUE_BUF_LENGTH
);
81 fldDef
.isNull_
= notNull
;
82 fldDef
.isAutoIncrement_
= autoIn
;
83 //os::memset(fldDef.autoVal_,0, DEFAULT_VALUE_BUF_LENGTH);
89 fldDef
.length_
= os::align(length
);
92 fldDef
.length_
= os::align(AllDataType::size(type
));
95 fldDef
.offset_
= fldList
.getTupleSize();
96 int ret
= fldList
.append(fldDef
);
97 if (0 == ret
) fldCount
++;
101 int TableDef::dropField(const char *name
)
103 int ret
= fldList
.remove(name
);
104 if (0 == ret
) fldCount
--;
108 int TableDef::getFieldCount()
113 size_t TableDef::getTupleSize()
116 FieldIterator iter
= getFieldIterator();
117 while (iter
.hasElement())
119 FieldDef
*def
= iter
.nextElement();
120 if (def
->type_
== typeVarchar
) length
+= sizeof (void *);
121 else length
= length
+ def
->length_
;
126 bool TableDef::isVarcharPresentInSchema(FieldIterator
&iter
)
128 while (iter
.hasElement())
130 FieldDef
*fDef
= iter
.nextElement();
131 if (fDef
->type_
== typeVarchar
) return true;