Age | Commit message (Collapse) | Author |
|
Change-Id: Ib9797fe97cd008cc6508ce8cec47dc5373416892
|
|
Change-Id: Id5f730fc447b11000b266954f9e7f5287bad02f4
|
|
Change-Id: I909a659e8ebfae35ca42680a54fa62dbd726adb5
|
|
More than two lines are removed for readability.
Change-Id: Ibff6cf68d7c512e240a54065b54a225bb23a782b
|
|
Change-Id: I92f1271ad36e4ae1221182a3a446f36cf770e003
|
|
Update code to use factory method URLTransformer::create
Change-Id: I3fd2e838497bcfd8fc949615c0e7d60a6ea47118
Signed-off-by: Stephan Bergmann <sbergman@redhat.com>, added some tweaks.
|
|
Update calls to factories to use new SimpleFileAccess::create method
Change-Id: Ie5b0696fe2228a9033b19969245a53c21a61aa14
Signed-off-by: Stephan Bergmann <sbergman@redhat.com>, added some tweaks.
|
|
Change-Id: Ia54eaa5cb1aa8bb4a052cea25396b07f048ff74c
|
|
... BOOST_STATIC_ASSERT_MSG was added in boost 1.46, while the internal
boost is still at version 1.44, so use BOOST_STATIC_ASSERT instead.
Change-Id: I14f8e48e31956b34a1a907cd2c4e454a5715889b
|
|
We do a "SELECT * FROM table" just to fetch the primary key columns;
so reuse the same XResultSet to fetch all columns.
Else, we immediately issue a "SELECT * FROM table WHERE
primary_key=current_value" to read the other columns, which is
wasteful and particularly silly.
Commit 1ae17f5b03cc14844fb600ca3573a96deb37ab3b already tried
to do that, but was essentially reverted piecewise because
it caused fdo#47520, fdo#48345, fdo#50372.
Commit c08067d6da94743d53217cbc26cffae00a22dc3a thought it did that,
but actually reverted commit 1ae17f5b03cc14844fb600ca3573a96deb37ab3b.
This implementation fetches the whole current row and caches it in memory;
only one row is cached: when the current row changes, the cache contains
the new current row.
This could be problematic (wrt to memory consumption) if the current
row is big (e.g. with BLOBs) and nobody is interested in the data
anyway (as would often be the case with BLOBs). Note that because of
our "SELECT *", the driver most probably has it in memory already
anyway, so we don't make the situation that much worse.
This could be incrementally improved with a heuristic of not
preemptively caching binary data (and also not LONGVARCHAR / TEXT /
MEMO / ...); a getFOO on these columns would issue a specific "SELECT
column FROM table WHERE primary_key=current_value" each time.
The *real* complete fix to all these issues would be to not do "SELECT
*" at all. Use "SELECT pkey_col1, pkey_col2, ..." when we are only
interested in the key columns. As to data, somehow figure out which
columns were ar interested in and "SELECT" only these (and maybe only
those with "small datatype"?). Interesting columns could be determined
by our caller (creator) as an argument to our constructor, or some
heuristic (no binary data, no "big" unbound data).
Also be extra smart and use *(m_aKeyIter) when getFOO is called
on a column included in it (and don't include it in any subsequent
SELECT).
However, there are several pitfalls.
One is buggy drivers that give use column names of columns that we
cannot fetch :-| Using "SELECT *" works around that because the driver
there *obviously* gives us only fetchable columns in the result.
Another one is the very restrictive nature of some database access
technologies. Take for example ODBC:
- Data can be fetched only *once* (with the SQLGetData interface;
bound columns offer a way around that, but that's viable only for
constant-length data, not variable-length data).
This could be addressed by an intelligent & lazy cache.
- Data must be fetched in increasing order of column number
(again, this is about SQLGetData).
This is a harder issue. The current solution has the nice advantage
of completely isolating the rest of LibO from these restrictions.
I don't currently see how to cleanly avoid (potentially
unnecessarily) caching column 4 if we are asked for column 3 then
column 5, just in case we are asked for column 4 later on, unless
we issue a specific "SELECT column4" later. But the latter would be
quite expensive in terms of app-to-database roudtripe times :-( and
thus creates another performance issue.
Change-Id: I999b3f8f0b8a215acb390ffefc839235346e8353
|
|
Change-Id: Ia8d12d02829087309e248506a7d3b0f94b5a425e
|
|
Change-Id: I3d7023fcb1857da1ef107a8af0d373b9ca464f03
|
|
Change-Id: I1dbb1990033602d7909ecdee72b8b699cce44cab
|
|
fixup of d4ae29a37873843c20fe7d5f5f071f8fb201fed9
after the call to m_pCacheSet->absolute_checked, the data *is* used,
so we cannot anymore exempt m_pCacheSet from giving correct data.
Change-Id: I7d3644ca08ce43cb030a80984605a1f8a8a64211
|
|
Change-Id: I90c9037b10a288d5d2e36f056c3632c796957fb4
|
|
Change-Id: I08114529cc6be6148a4f9ee3c89aafaafada77fe
|
|
Change-Id: I0f48c099eddc077b2a89e3b7fab66b5da55b57c8
|
|
Continuation of commits to fix fdo#48345
Change-Id: Ie28f6a55cd8715a7180f5d88fe23c5b310440744
|
|
Change-Id: I087d2893d853f431d27c592ba26bdc16e0a9cb84
|
|
This avoids asking the driver for the same data twice.
This is particularly important for ODBC data sources, because when asking for (VAR)CHAR data the second time, one gets no data (and status SQL_NO_DATA) because of the "retrieve in parts" semantics of these datatypes.
Change-Id: I96f2df9927fda72ccf19f78ec5c561f5626c003f
|
|
Instead, try to do the least unreasonable thing:
Fetch a new row
If that fails because no new row to fetch, at least we are properly positioned after last row. Calling code may not expect that and get confused, but that is the best we can do.
Change-Id: Ib7248e99ae3deee8344e9386cac2c9440e8bccd8
|
|
Change-Id: Ic00cdfce4172af0a2f0aa1aa33ef5e386d407976
|
|
Change-Id: I58636bc87bc17ff2b35621ad554bd05f5c1dab20
|
|
Change-Id: I181c5b5dd24836ff0398aa5ed03915c2c7c55183
|
|
Change-Id: I8848d0e687c3b19be1a8bc1f41c2a0c94e13bbbf
|
|
|
|
|
|
Change-Id: I39d54e3f635be6cb7a42fc9a0f7055619c885950
|
|
Change-Id: If89fd07ad78bca303a9bf8484f08cba08afffe8d
|
|
Change-Id: I51b86a10caa5da6e12583c2b22404b0d9282b13d
|
|
Change-Id: I2aeba0342e46c3a4bd50f49b8a43ebb125269dfa
|
|
Change-Id: I80a26483c4ecd099a1cfe76bdac1e97b947ef104
|
|
Change-Id: I7c3409ac39e690fcf2f7e4085bf6857e6bd182fb
|
|
a) merge them together and move it into comphelper
b) turn it into a POD rather than having vast amounts
of destructors registered into the cxa_atexit chain
Change-Id: I04d3b9d7804f8e233013c916df9d617a0f84f96a
|
|
Change-Id: I173275e0f8faa852500d108f65636080f79636c6
|
|
Change-Id: I5a254459a491b9547530d8e312260dceed21f25c
|
|
|
|
|
|
Change-Id: I563ab83a24ca4f839892548b350486e83dd071d3
|
|
|
|
Change-Id: I756c0a19bea7b1cc0e290d9f382a04d655819bfb
|
|
Change-Id: I827e539c65a7463709af6425d39ccaaedaa73a8d
|
|
this removes dmake completely out of the build for migrated modules
build.pl now assumes modules to be gbuild, unless there is a
prj/dmake file
Change-Id: I674a036b182ee13c5ec093e83cb3d38133112d3b
|
|
Change-Id: I1efec5017927d06c519f65312ab29e2b19a6cff6
|
|
|
|
|
|
|
|
|
|
|
|
The error message is:
"'*((void*)& aValue +1)' may be used uninitialized in this function"
using gcc 4.7.0 in gnu++11 mode and boost 1.48.0 .
|