[Libreoffice-commits] core.git: dbaccess/source
Tamas Bunth
tamas.bunth at collabora.co.uk
Sat Apr 7 16:31:57 UTC 2018
dbaccess/source/filter/hsqldb/createparser.hxx | 23 ++++++++++++++++++
dbaccess/source/filter/hsqldb/fbcreateparser.hxx | 8 ++++++
dbaccess/source/filter/hsqldb/hsqlbinarynode.hxx | 28 ++++++++++++++++++++++-
dbaccess/source/filter/hsqldb/hsqlimport.hxx | 11 +++++++++
dbaccess/source/filter/hsqldb/parseschema.hxx | 20 ++++++++++++++++
dbaccess/source/filter/hsqldb/rowinputbinary.hxx | 11 ++++++++-
6 files changed, 99 insertions(+), 2 deletions(-)
New commits:
commit b29f801e4106b0c729e90ff7c1b1718b671fd32d
Author: Tamas Bunth <tamas.bunth at collabora.co.uk>
Date: Sat Apr 7 16:05:26 2018 +0200
dbahsql: Add doxygen comments
Change-Id: Ie666d4d8660d29c36479c2e8a1289bd789d1433b
Reviewed-on: https://gerrit.libreoffice.org/52549
Tested-by: Jenkins <ci at libreoffice.org>
Reviewed-by: Tamás Bunth <btomi96 at gmail.com>
diff --git a/dbaccess/source/filter/hsqldb/createparser.hxx b/dbaccess/source/filter/hsqldb/createparser.hxx
index 5aa6bc0e9b16..d23eef83b91b 100644
--- a/dbaccess/source/filter/hsqldb/createparser.hxx
+++ b/dbaccess/source/filter/hsqldb/createparser.hxx
@@ -28,10 +28,33 @@ protected:
public:
CreateStmtParser();
virtual ~CreateStmtParser() {}
+
+ /**
+ * @return name of the table which is to be created.
+ */
OUString getTableName() const { return m_sTableName; }
+
+ /**
+ * @return a vector of column descriptors, representing the columns of the
+ * parsed statement.
+ */
const std::vector<ColumnDefinition>& getColumnDef() const { return m_aColumns; }
+
+ /**
+ * @return a vector of words.
+ */
const std::vector<OUString>& getForeignParts() const { return m_aForeignParts; }
+
+ /**
+ * Parses a create statement.
+ *
+ * @param SQL "CREATE" statement
+ */
void parse(const OUString& sSql);
+
+ /**
+ * Recreate the sql statement.
+ */
virtual OUString compose() const = 0;
};
}
diff --git a/dbaccess/source/filter/hsqldb/fbcreateparser.hxx b/dbaccess/source/filter/hsqldb/fbcreateparser.hxx
index 98b90158051a..fab6752b8b0d 100644
--- a/dbaccess/source/filter/hsqldb/fbcreateparser.hxx
+++ b/dbaccess/source/filter/hsqldb/fbcreateparser.hxx
@@ -17,7 +17,15 @@ namespace dbahsql
class SAL_DLLPUBLIC_EXPORT FbCreateStmtParser : public CreateStmtParser
{
public:
+ /**
+ * Create statement parser, which can compose the result to statements of
+ * Firebird dialect.
+ */
FbCreateStmtParser() {}
+
+ /**
+ * Compose the result of the parser to statements of Firebird dialect
+ */
virtual OUString compose() const override;
};
diff --git a/dbaccess/source/filter/hsqldb/hsqlbinarynode.hxx b/dbaccess/source/filter/hsqldb/hsqlbinarynode.hxx
index 71e0fd799171..5abc294bec2f 100644
--- a/dbaccess/source/filter/hsqldb/hsqlbinarynode.hxx
+++ b/dbaccess/source/filter/hsqldb/hsqlbinarynode.hxx
@@ -26,10 +26,36 @@ private:
sal_Int32 m_nPos = -1;
public:
+ /**
+ * Represents one element of an AVL tree in the binary file which contains
+ * the data.
+ */
HsqlBinaryNode(sal_Int32 nPos);
- void readChildren(HsqlRowInputStream& input);
+
+ /**
+ * Read position of children from data file.
+ *
+ * @param rInput input stream where the positions should be read from.
+ */
+ void readChildren(HsqlRowInputStream& rInput);
+
+ /**
+ * Get Position of left children. It should be called only after position of
+ * children is read.
+ */
sal_Int32 getLeft() const;
+
+ /**
+ * Get Position of right children. It should be called only after position of
+ * children is read.
+ */
sal_Int32 getRight() const;
+
+ /**
+ * Read the row represented by this node.
+ *
+ * @param rInput input stream where the row should be read from.
+ */
std::vector<css::uno::Any> readRow(HsqlRowInputStream& rInput,
const std::vector<ColumnDefinition>& aColTypes);
};
diff --git a/dbaccess/source/filter/hsqldb/hsqlimport.hxx b/dbaccess/source/filter/hsqldb/hsqlimport.hxx
index d6975ce80c8b..1df9ddbc3a10 100644
--- a/dbaccess/source/filter/hsqldb/hsqlimport.hxx
+++ b/dbaccess/source/filter/hsqldb/hsqlimport.hxx
@@ -34,9 +34,20 @@ protected:
const std::vector<ColumnDefinition>& rColTypes, const OUString& sTableName);
public:
+ /**
+ * @param rConnection reference to an sdbc connection. The migration will
+ * perform to this connection.
+ *
+ * @param rStorage Storage where the HSQL database can be found. The schema
+ * definition should be in file "script" in form of DDL SQL statements. The
+ * data should be found in file "data". These are HSQLDB's own format.
+ */
HsqlImporter(css::uno::Reference<css::sdbc::XConnection>& rConnection,
const css::uno::Reference<css::embed::XStorage>& rStorage);
+ /**
+ * Migrate a HSQL database to another.
+ */
void importHsqlDatabase();
};
}
diff --git a/dbaccess/source/filter/hsqldb/parseschema.hxx b/dbaccess/source/filter/hsqldb/parseschema.hxx
index b22f5e12fe90..6f73d2a4e584 100644
--- a/dbaccess/source/filter/hsqldb/parseschema.hxx
+++ b/dbaccess/source/filter/hsqldb/parseschema.hxx
@@ -35,10 +35,30 @@ private:
public:
explicit SchemaParser(css::uno::Reference<css::embed::XStorage>& rStorage);
+ /**
+ * Parses table definitions contained by a file called "script" in storage.
+ *
+ * @return A vector of schema definition SQL strings in Firebird dialect.
+ */
SqlStatementVector parseSchema();
+ /**
+ * Returns the colmn types of a table. It should not be called before
+ * calling parseSchema().
+ *
+ * @param sTableName name of the table.
+ *
+ * @return A vector of column descriptors.
+ */
std::vector<ColumnDefinition> getTableColumnTypes(const OUString& sTableName) const;
+ /**
+ * Returns a vector of indexes for each table. These indexes are used for
+ * locating the data related to the actual table in the binary file.
+ *
+ * The indexes point to root elements of AVL trees. Each node of the tree
+ * contains one row.
+ */
const std::map<OUString, std::vector<sal_Int32>>& getTableIndexes() const;
};
}
diff --git a/dbaccess/source/filter/hsqldb/rowinputbinary.hxx b/dbaccess/source/filter/hsqldb/rowinputbinary.hxx
index 8fcdf1ec0cd5..1fa5a6066476 100644
--- a/dbaccess/source/filter/hsqldb/rowinputbinary.hxx
+++ b/dbaccess/source/filter/hsqldb/rowinputbinary.hxx
@@ -29,13 +29,22 @@ protected:
OUString readString();
bool checkNull();
- // reimplement reading of an UTF string with a given length
OUString readUTF(sal_Int32 nLen);
public:
HsqlRowInputStream();
+
+ /**
+ * Reads one row from the actual position.
+ * @param colTypes Field types of the row, in a strict order.
+ */
std::vector<css::uno::Any> readOneRow(const std::vector<ColumnDefinition>& colTypes);
+
+ /**
+ * Sets the file-pointer offset, measured from the beginning of the file
+ */
void seek(sal_Int32 nPos);
+
void setInputStream(css::uno::Reference<css::io::XInputStream>& rStream);
SvStream* getInputStream() const;
};
More information about the Libreoffice-commits
mailing list