xref: /trunk/main/odk/examples/DevelopersGuide/Database/DriverSkeleton/propertyids.cxx (revision cdf0e10c4e3984b49a9502b011690b615761d4a3)
1*cdf0e10cSrcweir /*************************************************************************
2*cdf0e10cSrcweir  *
3*cdf0e10cSrcweir  *  The Contents of this file are made available subject to the terms of
4*cdf0e10cSrcweir  *  the BSD license.
5*cdf0e10cSrcweir  *
6*cdf0e10cSrcweir  *  Copyright 2000, 2010 Oracle and/or its affiliates.
7*cdf0e10cSrcweir  *  All rights reserved.
8*cdf0e10cSrcweir  *
9*cdf0e10cSrcweir  *  Redistribution and use in source and binary forms, with or without
10*cdf0e10cSrcweir  *  modification, are permitted provided that the following conditions
11*cdf0e10cSrcweir  *  are met:
12*cdf0e10cSrcweir  *  1. Redistributions of source code must retain the above copyright
13*cdf0e10cSrcweir  *     notice, this list of conditions and the following disclaimer.
14*cdf0e10cSrcweir  *  2. Redistributions in binary form must reproduce the above copyright
15*cdf0e10cSrcweir  *     notice, this list of conditions and the following disclaimer in the
16*cdf0e10cSrcweir  *     documentation and/or other materials provided with the distribution.
17*cdf0e10cSrcweir  *  3. Neither the name of Sun Microsystems, Inc. nor the names of its
18*cdf0e10cSrcweir  *     contributors may be used to endorse or promote products derived
19*cdf0e10cSrcweir  *     from this software without specific prior written permission.
20*cdf0e10cSrcweir  *
21*cdf0e10cSrcweir  *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22*cdf0e10cSrcweir  *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23*cdf0e10cSrcweir  *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24*cdf0e10cSrcweir  *  FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25*cdf0e10cSrcweir  *  COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26*cdf0e10cSrcweir  *  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27*cdf0e10cSrcweir  *  BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
28*cdf0e10cSrcweir  *  OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
29*cdf0e10cSrcweir  *  ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
30*cdf0e10cSrcweir  *  TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
31*cdf0e10cSrcweir  *  USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32*cdf0e10cSrcweir  *
33*cdf0e10cSrcweir  *************************************************************************/
34*cdf0e10cSrcweir 
35*cdf0e10cSrcweir #include <osl/diagnose.h>
36*cdf0e10cSrcweir #include "propertyids.hxx"
37*cdf0e10cSrcweir namespace connectivity
38*cdf0e10cSrcweir {
39*cdf0e10cSrcweir namespace skeleton
40*cdf0e10cSrcweir {
41*cdf0e10cSrcweir         const sal_Char* getPROPERTY_QUERYTIMEOUT()          { return    "QueryTimeOut"; }
42*cdf0e10cSrcweir         const sal_Char* getPROPERTY_MAXFIELDSIZE()          { return    "MaxFieldSize"; }
43*cdf0e10cSrcweir         const sal_Char* getPROPERTY_MAXROWS()               { return    "MaxRows"; }
44*cdf0e10cSrcweir         const sal_Char* getPROPERTY_CURSORNAME()            { return    "CursorName"; }
45*cdf0e10cSrcweir         const sal_Char* getPROPERTY_RESULTSETCONCURRENCY()  { return    "ResultSetConcurrency"; }
46*cdf0e10cSrcweir         const sal_Char* getPROPERTY_RESULTSETTYPE()         { return    "ResultSetType"; }
47*cdf0e10cSrcweir         const sal_Char* getPROPERTY_FETCHDIRECTION()        { return    "FetchDirection"; }
48*cdf0e10cSrcweir         const sal_Char* getPROPERTY_FETCHSIZE()             { return    "FetchSize"; }
49*cdf0e10cSrcweir         const sal_Char* getPROPERTY_ESCAPEPROCESSING()      { return    "EscapeProcessing"; }
50*cdf0e10cSrcweir         const sal_Char* getPROPERTY_USEBOOKMARKS()          { return    "UseBookmarks"; }
51*cdf0e10cSrcweir 
52*cdf0e10cSrcweir         const sal_Char* getPROPERTY_NAME()                  { return    "Name"; }
53*cdf0e10cSrcweir         const sal_Char* getPROPERTY_TYPE()                  { return    "Type"; }
54*cdf0e10cSrcweir         const sal_Char* getPROPERTY_TYPENAME()              { return    "TypeName"; }
55*cdf0e10cSrcweir         const sal_Char* getPROPERTY_PRECISION()             { return    "Precision"; }
56*cdf0e10cSrcweir         const sal_Char* getPROPERTY_SCALE()                 { return    "Scale"; }
57*cdf0e10cSrcweir         const sal_Char* getPROPERTY_ISNULLABLE()            { return    "IsNullable"; }
58*cdf0e10cSrcweir         const sal_Char* getPROPERTY_ISAUTOINCREMENT()       { return    "IsAutoIncrement"; }
59*cdf0e10cSrcweir         const sal_Char* getPROPERTY_ISROWVERSION()          { return    "IsRowVersion"; }
60*cdf0e10cSrcweir         const sal_Char* getPROPERTY_DESCRIPTION()           { return    "Description"; }
61*cdf0e10cSrcweir         const sal_Char* getPROPERTY_DEFAULTVALUE()          { return    "DefaultValue"; }
62*cdf0e10cSrcweir 
63*cdf0e10cSrcweir         const sal_Char* getPROPERTY_REFERENCEDTABLE()       { return    "ReferencedTable"; }
64*cdf0e10cSrcweir         const sal_Char* getPROPERTY_UPDATERULE()            { return    "UpdateRule"; }
65*cdf0e10cSrcweir         const sal_Char* getPROPERTY_DELETERULE()            { return    "DeleteRule"; }
66*cdf0e10cSrcweir         const sal_Char* getPROPERTY_CATALOG()               { return    "Catalog"; }
67*cdf0e10cSrcweir         const sal_Char* getPROPERTY_ISUNIQUE()              { return    "IsUnique"; }
68*cdf0e10cSrcweir         const sal_Char* getPROPERTY_ISPRIMARYKEYINDEX()     { return    "IsPrimaryKeyIndex"; }
69*cdf0e10cSrcweir         const sal_Char* getPROPERTY_ISCLUSTERED()           { return    "IsClustered"; }
70*cdf0e10cSrcweir         const sal_Char* getPROPERTY_ISASCENDING()           { return    "IsAscending"; }
71*cdf0e10cSrcweir         const sal_Char* getPROPERTY_SCHEMANAME()            { return    "SchemaName"; }
72*cdf0e10cSrcweir         const sal_Char* getPROPERTY_CATALOGNAME()           { return    "CatalogName"; }
73*cdf0e10cSrcweir         const sal_Char* getPROPERTY_COMMAND()               { return    "Command"; }
74*cdf0e10cSrcweir         const sal_Char* getPROPERTY_CHECKOPTION()           { return    "CheckOption"; }
75*cdf0e10cSrcweir         const sal_Char* getPROPERTY_PASSWORD()              { return    "Password"; }
76*cdf0e10cSrcweir         const sal_Char* getPROPERTY_RELATEDCOLUMN()         { return    "RelatedColumn"; }
77*cdf0e10cSrcweir 
78*cdf0e10cSrcweir         const sal_Char* getSTAT_INVALID_INDEX()             { return    "Invalid descriptor index"; }
79*cdf0e10cSrcweir 
80*cdf0e10cSrcweir         const sal_Char* getPROPERTY_FUNCTION()              { return    "Function"; }
81*cdf0e10cSrcweir         const sal_Char* getPROPERTY_TABLENAME()             { return    "TableName"; }
82*cdf0e10cSrcweir         const sal_Char* getPROPERTY_REALNAME()              { return    "RealName"; }
83*cdf0e10cSrcweir         const sal_Char* getPROPERTY_DBASEPRECISIONCHANGED() { return    "DbasePrecisionChanged"; }
84*cdf0e10cSrcweir         const sal_Char* getPROPERTY_ISCURRENCY()            { return    "IsCurrency"; }
85*cdf0e10cSrcweir         const sal_Char* getPROPERTY_ISBOOKMARKABLE()        { return    "IsBookmarkable"; }
86*cdf0e10cSrcweir 
87*cdf0e10cSrcweir         const sal_Char* getPROPERTY_FORMATKEY()             { return    "FormatKey"; }
88*cdf0e10cSrcweir         const sal_Char* getPROPERTY_LOCALE()                { return    "Locale"; }
89*cdf0e10cSrcweir 
90*cdf0e10cSrcweir         const sal_Char* getPROPERTY_AUTOINCREMENTCREATION() { return    "AutoIncrementCreation"; }
91*cdf0e10cSrcweir         const sal_Char* getPROPERTY_PRIVILEGES()            { return    "Privileges"; }
92*cdf0e10cSrcweir     //============================================================
93*cdf0e10cSrcweir     //= error messages
94*cdf0e10cSrcweir     //============================================================
95*cdf0e10cSrcweir         const sal_Char* getERRORMSG_SEQUENCE()              { return    "Function sequence error"; }
96*cdf0e10cSrcweir         const sal_Char* getSQLSTATE_SEQUENCE()              { return    "HY010"; }
97*cdf0e10cSrcweir         const sal_Char* getSQLSTATE_GENERAL()               { return    "HY0000"; }
98*cdf0e10cSrcweir         const sal_Char* getSTR_DELIMITER()                  { return    "/"; }
99*cdf0e10cSrcweir 
100*cdf0e10cSrcweir         OPropertyMap::~OPropertyMap()
101*cdf0e10cSrcweir         {
102*cdf0e10cSrcweir             ::std::map<sal_Int32 , rtl_uString*>::iterator aIter = m_aPropertyMap.begin();
103*cdf0e10cSrcweir             for(;aIter != m_aPropertyMap.end();++aIter)
104*cdf0e10cSrcweir                 if(aIter->second)
105*cdf0e10cSrcweir                     rtl_uString_release(aIter->second);
106*cdf0e10cSrcweir         }
107*cdf0e10cSrcweir         // ------------------------------------------------------------------------------
108*cdf0e10cSrcweir         ::rtl::OUString OPropertyMap::getNameByIndex(sal_Int32 _nIndex) const
109*cdf0e10cSrcweir         {
110*cdf0e10cSrcweir             ::rtl::OUString sRet;
111*cdf0e10cSrcweir             ::std::map<sal_Int32 , rtl_uString*>::const_iterator aIter = m_aPropertyMap.find(_nIndex);
112*cdf0e10cSrcweir             if(aIter == m_aPropertyMap.end())
113*cdf0e10cSrcweir                 sRet = const_cast<OPropertyMap*>(this)->fillValue(_nIndex);
114*cdf0e10cSrcweir             else
115*cdf0e10cSrcweir                 sRet = aIter->second;
116*cdf0e10cSrcweir             return sRet;
117*cdf0e10cSrcweir         }
118*cdf0e10cSrcweir         // ------------------------------------------------------------------------------
119*cdf0e10cSrcweir         ::rtl::OUString OPropertyMap::fillValue(sal_Int32 _nIndex)
120*cdf0e10cSrcweir         {
121*cdf0e10cSrcweir             rtl_uString* pStr = NULL;
122*cdf0e10cSrcweir             switch(_nIndex)
123*cdf0e10cSrcweir             {
124*cdf0e10cSrcweir                 case PROPERTY_ID_QUERYTIMEOUT:              { rtl_uString_newFromAscii(&pStr,getPROPERTY_QUERYTIMEOUT()         ); break; }
125*cdf0e10cSrcweir                 case PROPERTY_ID_MAXFIELDSIZE:              { rtl_uString_newFromAscii(&pStr,getPROPERTY_MAXFIELDSIZE()         ); break; }
126*cdf0e10cSrcweir                 case PROPERTY_ID_MAXROWS:                   { rtl_uString_newFromAscii(&pStr,getPROPERTY_MAXROWS()              ); break;       }
127*cdf0e10cSrcweir                 case PROPERTY_ID_CURSORNAME:                { rtl_uString_newFromAscii(&pStr,getPROPERTY_CURSORNAME()           ); break;   }
128*cdf0e10cSrcweir                 case PROPERTY_ID_RESULTSETCONCURRENCY:      { rtl_uString_newFromAscii(&pStr,getPROPERTY_RESULTSETCONCURRENCY() ); break; }
129*cdf0e10cSrcweir                 case PROPERTY_ID_RESULTSETTYPE:             { rtl_uString_newFromAscii(&pStr,getPROPERTY_RESULTSETTYPE()            ); break; }
130*cdf0e10cSrcweir                 case PROPERTY_ID_FETCHDIRECTION:            { rtl_uString_newFromAscii(&pStr,getPROPERTY_FETCHDIRECTION()       ); break; }
131*cdf0e10cSrcweir                 case PROPERTY_ID_FETCHSIZE:                 { rtl_uString_newFromAscii(&pStr,getPROPERTY_FETCHSIZE()                ); break;   }
132*cdf0e10cSrcweir                 case PROPERTY_ID_ESCAPEPROCESSING:          { rtl_uString_newFromAscii(&pStr,getPROPERTY_ESCAPEPROCESSING()     ); break; }
133*cdf0e10cSrcweir                 case PROPERTY_ID_USEBOOKMARKS:              { rtl_uString_newFromAscii(&pStr,getPROPERTY_USEBOOKMARKS()         ); break; }
134*cdf0e10cSrcweir                 // Column
135*cdf0e10cSrcweir                 case PROPERTY_ID_NAME:                      { rtl_uString_newFromAscii(&pStr,getPROPERTY_NAME()             ); break; }
136*cdf0e10cSrcweir                 case PROPERTY_ID_TYPE:                      { rtl_uString_newFromAscii(&pStr,getPROPERTY_TYPE()             ); break; }
137*cdf0e10cSrcweir                 case PROPERTY_ID_TYPENAME:                  { rtl_uString_newFromAscii(&pStr,getPROPERTY_TYPENAME()         ); break; }
138*cdf0e10cSrcweir                 case PROPERTY_ID_PRECISION:                 { rtl_uString_newFromAscii(&pStr,getPROPERTY_PRECISION()            ); break; }
139*cdf0e10cSrcweir                 case PROPERTY_ID_SCALE:                     { rtl_uString_newFromAscii(&pStr,getPROPERTY_SCALE()                ); break; }
140*cdf0e10cSrcweir                 case PROPERTY_ID_ISNULLABLE:                { rtl_uString_newFromAscii(&pStr,getPROPERTY_ISNULLABLE()       ); break; }
141*cdf0e10cSrcweir                 case PROPERTY_ID_ISAUTOINCREMENT:           { rtl_uString_newFromAscii(&pStr,getPROPERTY_ISAUTOINCREMENT()  ); break; }
142*cdf0e10cSrcweir                 case PROPERTY_ID_ISROWVERSION:              { rtl_uString_newFromAscii(&pStr,getPROPERTY_ISROWVERSION()     ); break; }
143*cdf0e10cSrcweir                 case PROPERTY_ID_DESCRIPTION:               { rtl_uString_newFromAscii(&pStr,getPROPERTY_DESCRIPTION()      ); break; }
144*cdf0e10cSrcweir                 case PROPERTY_ID_DEFAULTVALUE:              { rtl_uString_newFromAscii(&pStr,getPROPERTY_DEFAULTVALUE()     ); break; }
145*cdf0e10cSrcweir 
146*cdf0e10cSrcweir                 case PROPERTY_ID_REFERENCEDTABLE:           { rtl_uString_newFromAscii(&pStr,getPROPERTY_REFERENCEDTABLE()  ); break; }
147*cdf0e10cSrcweir                 case PROPERTY_ID_UPDATERULE:                { rtl_uString_newFromAscii(&pStr,getPROPERTY_UPDATERULE()       ); break; }
148*cdf0e10cSrcweir                 case PROPERTY_ID_DELETERULE:                { rtl_uString_newFromAscii(&pStr,getPROPERTY_DELETERULE()       ); break; }
149*cdf0e10cSrcweir                 case PROPERTY_ID_CATALOG:                   { rtl_uString_newFromAscii(&pStr,getPROPERTY_CATALOG()          ); break; }
150*cdf0e10cSrcweir                 case PROPERTY_ID_ISUNIQUE:                  { rtl_uString_newFromAscii(&pStr,getPROPERTY_ISUNIQUE()         ); break; }
151*cdf0e10cSrcweir                 case PROPERTY_ID_ISPRIMARYKEYINDEX:         { rtl_uString_newFromAscii(&pStr,getPROPERTY_ISPRIMARYKEYINDEX()    ); break; }
152*cdf0e10cSrcweir                 case PROPERTY_ID_ISCLUSTERED:               { rtl_uString_newFromAscii(&pStr,getPROPERTY_ISCLUSTERED()          ); break; }
153*cdf0e10cSrcweir                 case PROPERTY_ID_ISASCENDING:               { rtl_uString_newFromAscii(&pStr,getPROPERTY_ISASCENDING()          ); break; }
154*cdf0e10cSrcweir                 case PROPERTY_ID_SCHEMANAME:                { rtl_uString_newFromAscii(&pStr,getPROPERTY_SCHEMANAME()           ); break; }
155*cdf0e10cSrcweir                 case PROPERTY_ID_CATALOGNAME:               { rtl_uString_newFromAscii(&pStr,getPROPERTY_CATALOGNAME()          ); break; }
156*cdf0e10cSrcweir 
157*cdf0e10cSrcweir                 case PROPERTY_ID_COMMAND:                   { rtl_uString_newFromAscii(&pStr,getPROPERTY_COMMAND()              ); break; }
158*cdf0e10cSrcweir                 case PROPERTY_ID_CHECKOPTION:               { rtl_uString_newFromAscii(&pStr,getPROPERTY_CHECKOPTION()          ); break; }
159*cdf0e10cSrcweir                 case PROPERTY_ID_PASSWORD:                  { rtl_uString_newFromAscii(&pStr,getPROPERTY_PASSWORD()             ); break; }
160*cdf0e10cSrcweir                 case PROPERTY_ID_RELATEDCOLUMN:             { rtl_uString_newFromAscii(&pStr,getPROPERTY_RELATEDCOLUMN()        ); break;  }
161*cdf0e10cSrcweir 
162*cdf0e10cSrcweir                 case PROPERTY_ID_FUNCTION:                  { rtl_uString_newFromAscii(&pStr,getPROPERTY_FUNCTION()             ); break; }
163*cdf0e10cSrcweir                 case PROPERTY_ID_TABLENAME:                 { rtl_uString_newFromAscii(&pStr,getPROPERTY_TABLENAME()                ); break; }
164*cdf0e10cSrcweir                 case PROPERTY_ID_REALNAME:                  { rtl_uString_newFromAscii(&pStr,getPROPERTY_REALNAME()             ); break; }
165*cdf0e10cSrcweir                 case PROPERTY_ID_DBASEPRECISIONCHANGED:     { rtl_uString_newFromAscii(&pStr,getPROPERTY_DBASEPRECISIONCHANGED() ); break; }
166*cdf0e10cSrcweir                 case PROPERTY_ID_ISCURRENCY:                { rtl_uString_newFromAscii(&pStr,getPROPERTY_ISCURRENCY()           ); break; }
167*cdf0e10cSrcweir                 case PROPERTY_ID_ISBOOKMARKABLE:            { rtl_uString_newFromAscii(&pStr,getPROPERTY_ISBOOKMARKABLE()       ); break; }
168*cdf0e10cSrcweir                 case PROPERTY_ID_INVALID_INDEX:             { rtl_uString_newFromAscii(&pStr,getSTAT_INVALID_INDEX()            ); break; }
169*cdf0e10cSrcweir                 case PROPERTY_ID_ERRORMSG_SEQUENCE:         { rtl_uString_newFromAscii(&pStr,getERRORMSG_SEQUENCE()             ); break; }
170*cdf0e10cSrcweir                 case PROPERTY_ID_HY010:                     { rtl_uString_newFromAscii(&pStr,getSQLSTATE_SEQUENCE()             ); break; }
171*cdf0e10cSrcweir                 case PROPERTY_ID_HY0000:                    { rtl_uString_newFromAscii(&pStr,getSQLSTATE_GENERAL()              ); break; }
172*cdf0e10cSrcweir                 case PROPERTY_ID_DELIMITER:                 { rtl_uString_newFromAscii(&pStr,getSTR_DELIMITER()                 ); break; }
173*cdf0e10cSrcweir                 case PROPERTY_ID_FORMATKEY:                 { rtl_uString_newFromAscii(&pStr,getPROPERTY_FORMATKEY()            ); break; }
174*cdf0e10cSrcweir                 case PROPERTY_ID_LOCALE:                    { rtl_uString_newFromAscii(&pStr,getPROPERTY_LOCALE()               ); break; }
175*cdf0e10cSrcweir                 case PROPERTY_ID_AUTOINCREMENTCREATION:     { rtl_uString_newFromAscii(&pStr,getPROPERTY_AUTOINCREMENTCREATION()        ); break; }
176*cdf0e10cSrcweir                 case PROPERTY_ID_PRIVILEGES:                { rtl_uString_newFromAscii(&pStr,getPROPERTY_PRIVILEGES()           ); break; }
177*cdf0e10cSrcweir             }
178*cdf0e10cSrcweir             m_aPropertyMap[_nIndex] = pStr;
179*cdf0e10cSrcweir             return pStr;
180*cdf0e10cSrcweir         }
181*cdf0e10cSrcweir     }
182*cdf0e10cSrcweir }
183