xref: /AOO41X/main/connectivity/source/drivers/file/FNoException.cxx (revision 9b5730f6ddef7eb82608ca4d31dc0d7678e652cf)
1 /**************************************************************
2  *
3  * Licensed to the Apache Software Foundation (ASF) under one
4  * or more contributor license agreements.  See the NOTICE file
5  * distributed with this work for additional information
6  * regarding copyright ownership.  The ASF licenses this file
7  * to you under the Apache License, Version 2.0 (the
8  * "License"); you may not use this file except in compliance
9  * with the License.  You may obtain a copy of the License at
10  *
11  *   http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing,
14  * software distributed under the License is distributed on an
15  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16  * KIND, either express or implied.  See the License for the
17  * specific language governing permissions and limitations
18  * under the License.
19  *
20  *************************************************************/
21 
22 
23 
24 // MARKER(update_precomp.py): autogen include statement, do not remove
25 #include "precompiled_connectivity.hxx"
26 #include "file/FCatalog.hxx"
27 #include "file/fcomp.hxx"
28 #include "file/fanalyzer.hxx"
29 #include "file/FResultSet.hxx"
30 #include "file/FPreparedStatement.hxx"
31 #include <connectivity/FValue.hxx>
32 #include <tools/debug.hxx>
33 #include "TKeyValue.hxx"
34 #include <rtl/logfile.hxx>
35 
36 using namespace connectivity;
37 using namespace connectivity::file;
38 // -----------------------------------------------------------------------------
refreshViews()39 void OFileCatalog::refreshViews()
40 {}
refreshGroups()41 void OFileCatalog::refreshGroups()
42 {}
refreshUsers()43 void OFileCatalog::refreshUsers()
44 {
45 }
46 // -----------------------------------------------------------------------------
~OPredicateInterpreter()47 OPredicateInterpreter::~OPredicateInterpreter()
48 {
49     while(!m_aStack.empty())
50     {
51         delete m_aStack.top();
52         m_aStack.pop();
53     }
54     //  m_aStack.clear();
55 }
56 // -----------------------------------------------------------------------------
Clean()57 void OPredicateCompiler::Clean()
58 {
59     for(OCodeList::reverse_iterator aIter = m_aCodeList.rbegin(); aIter != m_aCodeList.rend();++aIter)
60     {
61         delete *aIter;
62     }
63     m_aCodeList.clear();
64 }
65 // -----------------------------------------------------------------------------
clean()66 void OSQLAnalyzer::clean()
67 {
68     m_aCompiler->Clean();
69 }
70 // -----------------------------------------------------------------------------
bindParameterRow(OValueRefRow & _pRow)71 void OSQLAnalyzer::bindParameterRow(OValueRefRow& _pRow)
72 {
73     OCodeList& rCodeList    = m_aCompiler->m_aCodeList;
74     for(OCodeList::iterator aIter = rCodeList.begin(); aIter != rCodeList.end();++aIter)
75     {
76         OOperandParam* pParam = PTR_CAST(OOperandParam,(*aIter));
77         if ( pParam )
78             pParam->bindValue(_pRow);
79     }
80 }
81 // -----------------------------------------------------------------------------
scanParameter(OSQLParseNode * pParseNode,::std::vector<OSQLParseNode * > & _rParaNodes)82 void OPreparedStatement::scanParameter(OSQLParseNode* pParseNode,::std::vector< OSQLParseNode*>& _rParaNodes)
83 {
84     RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OPreparedStatement::scanParameter" );
85     DBG_ASSERT(pParseNode != NULL,"OResultSet: interner Fehler: ungueltiger ParseNode");
86 
87     // Parameter Name-Regel gefunden?
88     if (SQL_ISRULE(pParseNode,parameter))
89     {
90         DBG_ASSERT(pParseNode->count() >= 1,"OResultSet: Parse Tree fehlerhaft");
91         DBG_ASSERT(pParseNode->getChild(0)->getNodeType() == SQL_NODE_PUNCTUATION,"OResultSet: Parse Tree fehlerhaft");
92 
93         _rParaNodes.push_back(pParseNode);
94         // Weiterer Abstieg nicht erforderlich
95         return;
96     }
97 
98     // Weiter absteigen im Parse Tree
99     for (sal_uInt32 i = 0; i < pParseNode->count(); i++)
100         scanParameter(pParseNode->getChild(i),_rParaNodes);
101 }
102 // -----------------------------------------------------------------------------
GetOrderbyKeyValue(OValueRefRow & _rRow)103 OKeyValue* OResultSet::GetOrderbyKeyValue(OValueRefRow& _rRow)
104 {
105     RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSet::GetOrderbyKeyValue" );
106     sal_uInt32 nBookmarkValue = Abs((sal_Int32)(_rRow->get())[0]->getValue());
107 
108     OKeyValue* pKeyValue = OKeyValue::createKeyValue((sal_uInt32)nBookmarkValue);
109 
110     ::std::vector<sal_Int32>::iterator aIter = m_aOrderbyColumnNumber.begin();
111     for (;aIter != m_aOrderbyColumnNumber.end(); ++aIter)
112     {
113         OSL_ENSURE(*aIter < static_cast<sal_Int32>(_rRow->get().size()),"Invalid index for orderkey values!");
114         pKeyValue->pushKey(new ORowSetValueDecorator((_rRow->get())[*aIter]->getValue()));
115     }
116 
117     return pKeyValue;
118 }
119 // -----------------------------------------------------------------------------
120 
121 
122 
123 
124 
125 
126 
127 
128