2009-04-16 13:08:19 +0200 oj r270882 : #i14538# set property at control 2009-04-16 13:04:28 +0200 oj r270881 : #i98557# remove binary string for SRB 2009-04-15 13:19:10 +0200 oj r270838 : #i96782# use type set at view 2009-04-14 14:53:20 +0200 oj r270778 : #i96782# set initialize size for custom shape 2009-04-06 14:19:14 +0200 oj r270546 : #i88432# correct pos when < 0 while resizing 2009-04-06 13:36:13 +0200 oj r270541 : #i96782# handle toolbar and menubar differently 2009-04-06 13:33:54 +0200 oj r270540 : #i96782# handle toolbar and menubar differently 2009-04-06 12:28:23 +0200 oj r270534 : #i96782# handle toolbar and menubar differently 2009-04-06 12:27:44 +0200 oj r270533 : #i96782# handle toolbar and menubar differently 2009-04-06 12:24:32 +0200 oj r270532 : #i96782# handle toolbar and menubar differently 2009-04-06 12:15:15 +0200 oj r270531 : do not initialze when field is empty 2009-04-06 10:06:08 +0200 oj r270528 : #i96782# clean up of menubar and remove duplicates 2009-04-06 09:47:49 +0200 oj r270527 : #i96519# adjust help text dynamic 2009-04-03 13:43:20 +0200 oj r270482 : do not need to remove section from observer they are already disposed 2009-04-03 13:27:28 +0200 fs r270479 : #i97356# 2009-04-02 11:30:39 +0200 fs r270386 : UNX line ends 2009-04-02 10:54:51 +0200 fs r270379 : UNX line ends 2009-04-02 10:39:57 +0200 fs r270378 : UNX line ends 2009-04-02 10:37:24 +0200 fs r270377 : why did this survive the rebase? was removed on trunk ... 2009-03-31 13:31:12 +0200 fs r270277 : component_foo should be public 2009-03-28 00:21:01 +0100 fs r270176 : manuallly merged the changes which happened in CWS before resync to m45, where the directory had been moved from reportdesign/registry to reportbuilder/registry 2009-03-27 23:01:20 +0100 fs r270174 : CWS-TOOLING: rebase CWS dba32a to trunk@270033 (milestone: DEV300:m45) 2009-03-11 12:23:35 +0100 fs r269310 : #i99958# ensure the ControlModelLock doesn't release twice 2009-03-06 09:07:32 +0100 fs r268970 : ignore output paths in SVN's status 2009-03-06 09:07:08 +0100 fs r268969 : ignore output paths in SVN's status 2009-03-04 11:28:02 +0100 oj r268800 : copy and paste error, check correct end now 2009-03-03 15:49:11 +0100 fs r268736 : #i10000# those merges were lost during the rebase (m38->m42) 2009-03-03 13:25:27 +0100 lla r268720 : #i99652# fix wrong refactoring 2009-02-27 11:12:56 +0100 fs r268566 : beautified 2009-02-27 10:53:47 +0100 fs r268561 : doFormListening(false) only when actually isFormListening() (found during complex test case XMLFormSettings with assertions) 2009-02-26 20:55:31 +0100 fs r268546 : #i96530# set the Label property of the bound control, if we didn't create a dedicated label control 2009-02-26 11:53:09 +0100 fs r268494 : #i10000# 2009-02-26 11:27:50 +0100 fs r268493 : #i10000# 2009-02-26 11:17:08 +0100 fs r268490 : reportdesign depends on REPORTBUILDER, not REPORTDESIGN 2009-02-25 11:39:48 +0100 fs r268422 : #i10000# post-resync: INFO_ESCAPE_DATETIME got lost during rebase 2009-02-24 23:24:10 +0100 fs r268411 : CWS-TOOLING: rebase CWS dba32a to trunk@268395 (milestone: DEV300:m42) 2009-02-20 15:09:48 +0100 fs r268324 : respect ImplicitCatalog/SchemaRestriction in all necessary places 2009-02-20 13:48:10 +0100 oj r268318 : order of initialize corrected 2009-02-14 15:07:52 +0100 fs r267759 : #i98975# when an image does not have a bitmap, but a text, draw this (as placeholder) 2009-02-14 15:02:40 +0100 fs r267758 : consolidated and removed some duplicate code 2009-02-14 13:52:23 +0100 fs r267756 : #i10000# 2009-02-13 22:08:34 +0100 fs r267750 : #i100000# 2009-02-13 22:07:25 +0100 fs r267749 : #i10000# 2009-02-13 21:55:36 +0100 fs r267747 : #i10000# 2009-02-13 21:54:27 +0100 fs r267746 : use const_cast 2009-02-13 21:29:10 +0100 fs r267745 : #i10000# 2009-02-13 21:27:39 +0100 fs r267744 : #i10000# 2009-02-13 20:59:13 +0100 fs r267742 : #i10000# 2009-02-13 13:21:30 +0100 fs r267717 : better diagnostics 2009-02-13 13:17:24 +0100 fs r267715 : #i58313# support Catalog/SchemaRestriction settings, which are applied in getTables when 'all catalogs/schemas' are to be retrieved 2009-02-13 13:16:14 +0100 fs r267714 : filter out some more known global settings 2009-02-13 12:39:43 +0100 fs r267713 : #i58313# ImplicitCatalog/SchemaRestriction 2009-02-13 12:36:50 +0100 fs r267712 : when exporting data source settings, allow for properties which have a VOID default value, but are currently not VOID 2009-02-13 12:35:57 +0100 fs r267711 : implement XSet, to allow inserting properties which have a default value of VOID 2009-02-13 12:35:03 +0100 fs r267710 : +addVoidProperty 2009-02-13 10:20:08 +0100 fs r267697 : removed unused variable 2009-02-13 09:46:46 +0100 fs r267695 : refactored the table filtering code, to have a better base for introducing additional low level filters 2009-02-10 09:23:07 +0100 lla r267537 : #i10000# wrong line feed, double named variable 2009-02-09 12:13:08 +0100 oj r267508 : #i98605# notify hanlder 2009-02-09 11:50:34 +0100 oj r267507 : #i98926# solve refcount problem 2009-02-09 11:50:05 +0100 oj r267506 : #i98971# fix for simple html 2009-02-09 11:49:24 +0100 oj r267505 : #i98971# fix for simple html 2009-02-09 11:47:27 +0100 oj r267504 : invoke on copy 2009-02-09 09:51:00 +0100 fs r267500 : #i98316# 2009-02-09 09:46:10 +0100 fs r267499 : setCurrentSelection: don't reset the current form when we de-select everything 2009-02-09 09:43:45 +0100 fs r267498 : #i98316# 2009-02-08 21:25:18 +0100 fs r267496 : #i98272# introduce late ctor for cloning 2009-02-07 21:08:39 +0100 fs r267485 : #i98272# when copy-constructing a FmFormPageImpl, use the XCloneable of the forms collection, instead of XPersistObject (which is incompletely implemented) 2009-02-07 21:07:26 +0100 fs r267484 : removed obsolete include guards 2009-02-07 21:05:22 +0100 fs r267483 : #i98272# implement XCloneable 2009-02-06 15:02:48 +0100 lla r267467 : #i96523# add XImageControl 2009-02-06 14:41:38 +0100 oj r267463 : #i98926# late init when connection disposed but only when asked for 2009-02-06 13:49:57 +0100 lla r267457 : #i92860# bigint in forms doesn't allow input of values > 1, fixed 2009-02-06 13:03:55 +0100 oj r267455 : ImageScaleMode 2009-02-05 14:48:19 +0100 lla r267424 : #i89335# dropdown listboxes are 14 instead of 7 lines high 2009-02-05 13:40:00 +0100 oj r267423 : #i96945# insert new prop Opaque 2009-02-05 13:39:19 +0100 oj r267422 : #i96945# insert layer handling for hell and heaven 2009-02-05 13:29:32 +0100 lla r267420 : #i89335# add is null, is not null, is not like filter condition 2009-02-04 12:23:02 +0100 oj r267364 : #i98821# load table font settings 2009-02-04 10:05:27 +0100 oj r267351 : #i98821# load table font settings 2009-02-04 09:23:22 +0100 fs r267350 : checking persistency of UI settings in database documents - for the moment, capture table formattings (which is issue 98821) 2009-02-04 09:22:15 +0100 fs r267349 : moved some methods which are of wider interest from DatabaseDocument to FileHelper resp. TestCase 2009-02-04 08:56:27 +0100 oj r267347 : #i97586# UcbStreamHelper::CreateStream doesn't check all streamModes use different method 2009-02-04 08:23:26 +0100 oj r267346 : #i98701# check key size is >= 3 and some redesign 2009-02-03 23:29:24 +0100 fs r267345 : return the component (controller), not the frame 2009-02-03 23:28:53 +0100 fs r267344 : openExisting returns a controller now, not the frame (this was a bug) 2009-02-03 23:28:25 +0100 fs r267343 : openElement: properly return the component in the table/query case 2009-02-02 12:48:17 +0100 oj r267261 : #i96013# fix for relative path 2009-02-02 10:33:28 +0100 lla r267253 : #i98557# cleanups and consolidation 2009-02-02 09:37:23 +0100 lla r267250 : #i88432# resize will no longer move components to other sections 2009-02-02 09:08:24 +0100 oj r267245 : #i97475# write 0x1A at the end of the file 2009-01-30 19:39:20 +0100 lla r267230 : #i10000# unused parameters 2009-01-30 09:51:09 +0100 fs r267181 : onsolete 2009-01-30 09:49:27 +0100 fs r267180 : onsolete 2009-01-29 14:28:22 +0100 oj r267139 : #i96825# import cell style 2009-01-29 14:23:12 +0100 oj r267137 : #i98601# export imagescalehandler 2009-01-29 14:19:57 +0100 lla r267135 : #i98601# add ImageScaleMode 2009-01-29 13:21:08 +0100 oj r267124 : #i98601# impl ScaleMode 2009-01-29 13:20:56 +0100 oj r267123 : #i98601# impl ScaleMode 2009-01-29 08:46:40 +0100 oj r267095 : new property: ScaleMode 2009-01-29 08:45:23 +0100 oj r267094 : new ScaleMode from UnControlImageModel 2009-01-29 08:28:12 +0100 oj r267093 : #i87930# close all sub forms/reports when the desktop is going to be terminated and no db frame exists 2009-01-28 19:54:34 +0100 lla r267082 : #i98557# pictures in report wizard 2009-01-28 15:06:25 +0100 oj r267060 : #i87930# close all sub forms/reports when the desktop is going to be terminated and no db frame exists 2009-01-28 11:38:41 +0100 lla r267046 : #i76783# handle binary fields in forms 2009-01-28 09:24:43 +0100 lla r267025 : #i10000# 2009-01-28 08:40:04 +0100 fs r267024 : #i10000# 2009-01-28 08:04:43 +0100 oj r267023 : #i93456# use resource strings for function names 2009-01-27 13:26:05 +0100 oj r266988 : check data field is type field or expression 2009-01-27 13:07:17 +0100 oj r266985 : check data field length 2009-01-27 11:48:19 +0100 oj r266974 : #i96823# return dll string as column name when no alias exists 2009-01-27 09:53:11 +0100 fs r266958 : display the message of a caught exception 2009-01-27 09:44:13 +0100 fs r266957 : #i58313# when retrieving all tables, just set an empty table type filter - the connection will care for translating this, by respecting the TableTypeFilterMode setting 2009-01-27 09:36:09 +0100 fs r266956 : #i58313# getTables: per JDBC spec, is not a valid table type filter. Translate it to 'null'. 2009-01-26 11:24:49 +0100 lla r266912 : #i97865# cleanups (AddField viewable in remote mode) 2009-01-26 07:49:27 +0100 lla r266897 : #i97865# AddField opens in remote case 2009-01-26 07:48:58 +0100 lla r266896 : #i97865# AddField opens in remote case 2009-01-26 07:48:42 +0100 lla r266895 : #i97865# AddField opens in remote case 2009-01-23 15:04:40 +0100 fs r266825 : consolidate the usage of OSQLMessageBox with MessageType==Warning into OSQLWarningBox 2009-01-23 10:47:33 +0100 fs r266787 : +supportsUserAdministration 2009-01-23 10:47:11 +0100 fs r266784 : use DatabaseMetaData.supportsUserAdministration 2009-01-23 07:55:59 +0100 lla r266767 : #i10000# fix gcc compiler failures 2009-01-21 15:08:55 +0100 lla r266673 : #i97265# Labels in HC (IsDark) with other color (viewable) 2009-01-19 14:58:54 +0100 lla r266504 : #i96523# last problems with FormatKey and '0' values fixed 2009-01-19 14:58:00 +0100 lla r266503 : #i96519# AddField help text 2009-01-19 11:59:02 +0100 fs r266485 : #i96523# for formatted field models, init them with TreatAsNumber = false 2009-01-16 10:31:49 +0100 lla r266405 : #i96793# add shrink to popup menu 2009-01-16 09:21:44 +0100 lla r266401 : #i96519# AddField contains a help text 2009-01-15 11:21:49 +0100 lla r266357 : #i96523# problem with XVclWindowPeer not fixed now 2009-01-15 09:19:20 +0100 lla r266335 : #i96523# more crashes fixed. 2009-01-14 13:08:34 +0100 lla r266291 : #i96523# problems with crashes fixed 2009-01-13 10:54:24 +0100 lla r266199 : #i96523# show datasource in formattedfields new files 2009-01-13 10:52:39 +0100 lla r266198 : #i96523# show datasource in formattedfields 2009-01-13 09:41:50 +0100 lla r266197 : #i96526# handling none existance default.otr 2009-01-12 12:55:49 +0100 fs r266151 : don't expect the control model to be a BoundComponent before adding as modify listener 2009-01-12 12:51:33 +0100 fs r266149 : #i88458# let the ImageControl be an XModifyBroadcaster, so the forms runtime can notice when the user changes the control content while it does not have the focus 2009-01-09 13:41:22 +0100 fs r266080 : doc 2009-01-09 13:14:14 +0100 fs r266077 : #i97377# SetModified when order is changed via DnD 2009-01-07 09:55:40 +0100 oj r265951 : merge from master 2009-01-07 09:55:24 +0100 oj r265950 : removed observer 2009-01-07 09:55:06 +0100 oj r265949 : merge from master 2009-01-07 07:29:11 +0100 oj r265945 : shadow var changed 2009-01-06 07:25:57 +0100 oj r265893 : CWS-TOOLING: rebase CWS dba32a to trunk@265758 (milestone: DEV300:m38) 2009-01-05 13:18:22 +0100 oj r265865 : convert to unix le 2009-01-05 09:13:52 +0100 lla r265857 : #i79423# lc_ sc_ permutation fix 2009-01-02 19:40:59 +0100 lla r265847 : #i79423# section shrink icons 2008-12-22 11:37:57 +0100 lla r265749 : #i97484# move component to negative Y-position 2008-12-22 11:37:05 +0100 lla r265748 : #i97484# move component to negative Y-position 2008-12-22 11:35:33 +0100 lla r265747 : #i97484# move component to negative Y-position 2008-12-22 11:25:07 +0100 lla r265745 : #i96757# changes via property browser was not undoable 2008-12-18 15:10:38 +0100 fs r265694 : corrected an condition in doFormListening, which otherwise leads to uncommitable grid columns in documents which are loaded from disc (not in documents which are newly created) 2008-12-18 14:54:39 +0100 fs r265692 : Hide Columns text slightly changed 2008-12-18 13:44:15 +0100 fs r265683 : #i94068# properly display erros happening during a form operation - at least once, and at most once 2008-12-18 11:28:29 +0100 fs r265677 : document the new InputRequired property 2008-12-18 11:04:15 +0100 fs r265676 : #i96530# createControlLabelPair: don't actually create a label for a checkbox 2008-12-18 10:35:53 +0100 fs r265674 : #i95226# when a column is replaced, and it's the selected column, update the selection 2008-12-18 10:34:42 +0100 fs r265673 : #i95226# refactoring of the implReplaced method 2008-12-18 10:34:28 +0100 fs r265672 : #i95226# when replacing a grid column, update the property browser 2008-12-18 10:33:17 +0100 fs r265671 : when an element is removed, remove it from m_aCurrentSelection, too (if necessary) 2008-12-18 10:31:57 +0100 fs r265670 : Hide Columns text slightly changed 2008-12-18 10:15:56 +0100 lla r265669 : #i14538# do not allow to press finish button twice 2008-12-18 08:56:33 +0100 lla r265665 : #i10000# build depend=t problem hacked. 2008-12-17 20:59:10 +0100 fs r265656 : #i89821# don't let a MultiLineEdit select all text when it receives the focus 2008-12-17 12:10:54 +0100 fs r265594 : #i97356# 2008-12-17 12:06:29 +0100 fs r265593 : #i97355# Print -> Printable 2008-12-17 11:59:31 +0100 fs r265591 : #i97350# combo boxes comment on list selection (as list boxes already do) 2008-12-16 09:53:57 +0100 lla r265527 : #i96526# handling none existance default.otr 2008-12-15 14:48:39 +0100 lla r265500 : #i79423# reparing, was wrong implemented 2008-12-12 15:08:33 +0100 lla r265424 : #i10000# remove wrong carridge returns 2008-12-12 15:07:55 +0100 lla r265423 : #i10000# remove wrong carridge returns 2008-12-12 15:06:41 +0100 lla r265422 : #i10000# remove wrong carridge returns 2008-12-12 10:23:13 +0100 lla r265395 : #i95234# reset DragDelta 2008-12-12 10:11:02 +0100 lla r265393 : #i79423# pre versions of shrink buttons 2008-12-11 15:32:13 +0100 fs r265318 : prevent a deadlock during complex.dbaccess.DatabaseDocument test 2008-12-11 15:30:06 +0100 fs r265316 : prevent a deadlock during complex.dbaccess.DatabaseDocument test 2008-12-11 15:07:05 +0100 fs r265307 : removed superfluous text 2008-12-11 12:29:54 +0100 lla r265282 : #i96757# cleanup second try 2008-12-11 12:09:15 +0100 lla r265278 : #i96757# cleanup 2008-12-11 12:07:56 +0100 lla r265277 : #i95234# 2008-12-10 14:04:39 +0100 lla r265183 : #i93472# D&D fixes 2008-12-10 12:29:33 +0100 lla r265168 : #i94067# add (APP|SYS)FONT to XUnitConversion 2008-12-10 12:15:02 +0100 lla r265166 : #i94067# add APPFONT, SYSFONT to MeasureUnit 2008-12-10 11:52:10 +0100 lla r265163 : #i94067# add comments 2008-12-06 20:33:05 +0100 fs r264935 : #i10000# precompiled header 2008-12-05 09:29:26 +0100 fs r264889 : #i10000# 2008-12-05 09:07:31 +0100 fs r264888 : #i10000# 2008-12-04 13:25:46 +0100 fs r264838 : CWS-TOOLING: rebase CWS dba32a to trunk@264807 (milestone: DEV300:m37) 2008-12-03 23:49:13 +0100 fs r264808 : merge changes from trunk, to be able to do a rebase 2008-12-03 17:13:09 +0100 lla r264801 : #i91041# update documentation 2008-12-03 16:57:04 +0100 lla r264799 : #i94067# allow convert(Point|Size)ToLogic as pixel also 2008-12-02 12:36:32 +0100 lla r264687 : #i96782# bring toolbar objects to menu structure 2008-12-02 10:32:44 +0100 lla r264667 : #i86255# make property work 2008-12-02 09:22:47 +0100 lla r264659 : #i79423# add section shrink toolbar 2008-12-02 07:41:22 +0100 lla r264657 : #i86255# add check box for Escape DateTime property 2008-12-02 07:37:17 +0100 lla r264656 : #i79423# new shrink buttons 2008-11-26 11:55:28 +0100 fs r264362 : #i96541# FillPropertySet: do not only catch UnknownPropertyException when setting the Char/ParaAutoStyleName, but also care for the other exceptions which can be thrown by XPropertySet::setPropertyValue. This is actually not the real fix for #i96541#, but only a follow-up. The root cause of the issue was fixed in CWS dba301b, but this here was another (potential) bug which popped up during investigations. 2008-11-25 09:04:40 +0100 lla r264273 : #i82083# new toolbox in GroupsSorting dialog 2008-11-25 08:56:08 +0100 lla r264272 : #i94729# change token strings into string list, move class out of function 2008-11-24 15:52:22 +0100 fs r264251 : #i96532# do not set AppendTableAlias, NameLengthLimit, etc., if the OXMLDataSourceInstance is used for elements at which those attributes never appear 2008-11-24 15:51:45 +0100 fs r264249 : #i96532# do not set AppendTableAlias, NameLengthLimit, etc., if the OXMLDataSourceInstance is used for elements at which those attributes never appear 2008-11-24 15:45:21 +0100 fs r264244 : #i96532# the API default for ParamNameSubst is false 2008-11-24 15:45:04 +0100 fs r264243 : #i96532# do not set AppendTableAlias, NameLengthLimit, etc., if the OXMLDataSourceInstance is used for elements at which those attributes never appear 2008-11-24 15:44:14 +0100 fs r264241 : #i96532# slight refactoring of exporting properties which have a XML default different from the API default 2008-11-24 10:50:01 +0100 lla r264216 : #i82083# icons for new toolbox 2008-11-24 09:38:45 +0100 lla r264205 : #i82083# new toolbox in GroupsSorting dialog 2008-11-24 09:32:20 +0100 lla r264201 : #i96501# cleanup assertions 2008-11-24 09:12:55 +0100 lla r264198 : #i83082# enhancement for toolboxes, better HC comfort 2008-11-24 08:46:43 +0100 lla r264197 : #i96501# fix problem with negative positions 2008-11-21 11:44:47 +0100 fs r264118 : #i57042# introduce a counter for suspending change notifications of a given property, so recursive calls are possible 2008-11-21 11:02:17 +0100 fs r264116 : #i96388# don't call ExecuteContextMenuAction when no action was chosen by the user 2008-11-21 10:36:53 +0100 fs r264114 : #i47384# assertion was wrong 2008-11-14 12:33:15 +0100 fs r263673 : #i47318# XRowSetChangeBroadcaster/Listener, to be able to listen for changes in an XRowSetSupplier's RowSet 2008-11-14 12:30:29 +0100 fs r263672 : #i47318# more refactoring - BoundControlModels now listen at the XRowSetSupplier for changes in the supplied RowSet, to properly revoke/register old/new listeners at the RowSet - replaced ::osl::Mutex in various places with a ControlModelLock 2008-11-14 12:20:55 +0100 fs r263671 : when BUILD_TYPE includes QADEVOOO, the BUILD_QADEVOOO needs to bet set, too 2008-11-14 12:19:21 +0100 fs r263670 : oops, this was not intended to be committed 2008-11-12 11:08:10 +0100 fs r263579 : #i96096# new ctors taking UNO_QUERY_THROW 2008-11-12 09:15:54 +0100 fs r263576 : no need to load the complete dialog just to get a string which the dialog itself loads from resource 2008-11-10 17:55:45 +0100 fs r263535 : spelling in comment 2008-11-10 15:51:14 +0100 fs r263523 : #i47318# various refactorings 1. don't forward syntetic XLoadListener events from the grid control to the grid columns. Instead, forward GridColumn::XChild::setParent to the base class, which then can add itself as load listener 2. removed various occurances of XMultiServiceFactory, instead use the ::comphelper::ComponentContext 3. in O(Bound)ControlModel, have a mechanism to lock the instance (using ControlModelLock) and fire property changes when the last lock dies. 2008-11-10 12:49:24 +0100 oj r263513 : #i94729# change token strings into string list 2008-11-10 12:13:15 +0100 oj r263512 : #i95222# export chart:title style as well 2008-11-10 08:55:25 +0100 oj r263507 : #i93471# show the correct tabpage when selecting a different object 2008-11-07 23:38:29 +0100 fs r263490 : #i95977# for the event input controls, add a component extending their functionality so they're reset when the users presses DEL 2008-11-07 23:35:39 +0100 fs r263489 : during #i95977#: When a VCL Window is deleted from within VCL code, the respective WindowPeer was never disposed. Corrected this. 2008-11-07 14:57:07 +0100 fs r263420 : #i95963# human-readable display names for event bindings 2008-11-06 10:34:52 +0100 fs r263366 : #i95865# don't use library names containing InvalidZipEntryFileNames - workaround until i95409 is fixed 2008-11-06 10:33:28 +0100 fs r263365 : #i95865# copied the following change from CWS odfmetadata2 (not yet integrated) into CWS dba31d - comphelper/inc/comphelper/storagehelper.hxx, comphelper/source/misc/storagehelper.cxx: + add function IsValidZipEntryFileName (moved from module package)
1696 lines
65 KiB
C++
1696 lines
65 KiB
C++
/*************************************************************************
|
|
*
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
*
|
|
* Copyright 2008 by Sun Microsystems, Inc.
|
|
*
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
|
*
|
|
* $RCSfile: TableController.cxx,v $
|
|
* $Revision: 1.122.24.3 $
|
|
*
|
|
* This file is part of OpenOffice.org.
|
|
*
|
|
* OpenOffice.org is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser General Public License version 3
|
|
* only, as published by the Free Software Foundation.
|
|
*
|
|
* OpenOffice.org is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Lesser General Public License version 3 for more details
|
|
* (a copy is included in the LICENSE file that accompanied this code).
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* version 3 along with OpenOffice.org. If not, see
|
|
* <http://www.openoffice.org/license.html>
|
|
* for a copy of the LGPLv3 License.
|
|
*
|
|
************************************************************************/
|
|
|
|
// MARKER(update_precomp.py): autogen include statement, do not remove
|
|
#include "precompiled_dbaccess.hxx"
|
|
#ifndef DBUI_TABLECONTROLLER_HXX
|
|
#include "TableController.hxx"
|
|
#endif
|
|
|
|
#ifndef _DBAU_REGHELPER_HXX_
|
|
#include "dbu_reghelper.hxx"
|
|
#endif
|
|
#ifndef _STRING_HXX
|
|
#include <tools/string.hxx>
|
|
#endif
|
|
#include <tools/diagnose_ex.h>
|
|
#ifndef _SFXSIDS_HRC
|
|
#include <sfx2/sfxsids.hrc>
|
|
#endif
|
|
#ifndef _DBU_TBL_HRC_
|
|
#include "dbu_tbl.hrc"
|
|
#endif
|
|
#ifndef DBACCESS_UI_BROWSER_ID_HXX
|
|
#include "browserids.hxx"
|
|
#endif
|
|
#ifndef _COMPHELPER_TYPES_HXX_
|
|
#include <comphelper/types.hxx>
|
|
#endif
|
|
#ifndef DBACCESS_SHARED_DBUSTRINGS_HRC
|
|
#include "dbustrings.hrc"
|
|
#endif
|
|
#ifndef DBACCESS_SOURCE_UI_INC_DEFAULTOBJECTNAMECHECK_HXX
|
|
#include "defaultobjectnamecheck.hxx"
|
|
#endif
|
|
#ifndef _CONNECTIVITY_DBTOOLS_HXX_
|
|
#include <connectivity/dbtools.hxx>
|
|
#endif
|
|
#ifndef _COM_SUN_STAR_FRAME_FRAMESEARCHFLAG_HPP_
|
|
#include <com/sun/star/frame/FrameSearchFlag.hpp>
|
|
#endif
|
|
#ifndef _COMPHELPER_EXTRACT_HXX_
|
|
#include <comphelper/extract.hxx>
|
|
#endif
|
|
#ifndef DBAUI_DLGSAVE_HXX
|
|
#include "dlgsave.hxx"
|
|
#endif
|
|
#ifndef _COM_SUN_STAR_CONTAINER_XCHILD_HPP_
|
|
#include <com/sun/star/container/XChild.hpp>
|
|
#endif
|
|
#ifndef _COM_SUN_STAR_CONTAINER_XNAMECONTAINER_HPP_
|
|
#include <com/sun/star/container/XNameContainer.hpp>
|
|
#endif
|
|
#ifndef _COM_SUN_STAR_SDBCX_XDATADESCRIPTORFACTORY_HPP_
|
|
#include <com/sun/star/sdbcx/XDataDescriptorFactory.hpp>
|
|
#endif
|
|
#ifndef _COM_SUN_STAR_SDBCX_XTABLESSUPPLIER_HPP_
|
|
#include <com/sun/star/sdbcx/XTablesSupplier.hpp>
|
|
#endif
|
|
#ifndef _COM_SUN_STAR_SDBCX_KEYTYPE_HPP_
|
|
#include <com/sun/star/sdbcx/KeyType.hpp>
|
|
#endif
|
|
#ifndef _COM_SUN_STAR_SDBCX_XDROP_HPP_
|
|
#include <com/sun/star/sdbcx/XDrop.hpp>
|
|
#endif
|
|
#ifndef _COM_SUN_STAR_SDBCX_XALTERTABLE_HPP_
|
|
#include <com/sun/star/sdbcx/XAlterTable.hpp>
|
|
#endif
|
|
#ifndef _COM_SUN_STAR_SDBCX_XAPPEND_HPP_
|
|
#include <com/sun/star/sdbcx/XAppend.hpp>
|
|
#endif
|
|
#ifndef _COM_SUN_STAR_SDB_SQLCONTEXT_HPP_
|
|
#include <com/sun/star/sdb/SQLContext.hpp>
|
|
#endif
|
|
#ifndef _COM_SUN_STAR_SDBC_SQLWARNING_HPP_
|
|
#include <com/sun/star/sdbc/SQLWarning.hpp>
|
|
#endif
|
|
#ifndef _COM_SUN_STAR_SDBC_COLUMNVALUE_HPP_
|
|
#include <com/sun/star/sdbc/ColumnValue.hpp>
|
|
#endif
|
|
#ifndef _COM_SUN_STAR_SDBC_XROW_HPP_
|
|
#include <com/sun/star/sdbc/XRow.hpp>
|
|
#endif
|
|
#ifndef _COM_SUN_STAR_SDBCX_XINDEXESSUPPLIER_HPP_
|
|
#include <com/sun/star/sdbcx/XIndexesSupplier.hpp>
|
|
#endif
|
|
#include <com/sun/star/frame/XTitleChangeListener.hpp>
|
|
#ifndef _DBHELPER_DBEXCEPTION_HXX_
|
|
#include <connectivity/dbexception.hxx>
|
|
#endif
|
|
#ifndef _COM_SUN_STAR_UI_XEXECUTABLEDIALOG_HPP_
|
|
#include <com/sun/star/ui/dialogs/XExecutableDialog.hpp>
|
|
#endif
|
|
#include <com/sun/star/frame/XUntitledNumbers.hpp>
|
|
#ifndef _COMPHELPER_STREAMSECTION_HXX_
|
|
#include <comphelper/streamsection.hxx>
|
|
#endif
|
|
#ifndef _COM_SUN_STAR_IO_XACTIVEDATASOURCE_HPP_
|
|
#include <com/sun/star/io/XActiveDataSource.hpp>
|
|
#endif
|
|
#ifndef _COM_SUN_STAR_IO_XACTIVEDATASINK_HPP_
|
|
#include <com/sun/star/io/XActiveDataSink.hpp>
|
|
#endif
|
|
#ifndef DBAUI_TABLEDESIGNVIEW_HXX
|
|
#include "TableDesignView.hxx"
|
|
#endif
|
|
#ifndef _COM_SUN_STAR_SDB_COMMANDTYPE_HPP_
|
|
#include <com/sun/star/sdb/CommandType.hpp>
|
|
#endif
|
|
#ifndef DBAUI_FIELDDESCRIPTIONS_HXX
|
|
#include "FieldDescriptions.hxx"
|
|
#endif
|
|
#ifndef DBAUI_TABLEROW_HXX
|
|
#include "TableRow.hxx"
|
|
#endif
|
|
#ifndef DBAUI_TYPEINFO_HXX
|
|
#include "TypeInfo.hxx"
|
|
#endif
|
|
#ifndef DBAUI_TABLEEDITORCONTROL_HXX
|
|
#include "TEditControl.hxx"
|
|
#endif
|
|
#ifndef _DBAUI_SQLMESSAGE_HXX_
|
|
#include "sqlmessage.hxx"
|
|
#endif
|
|
#ifndef _SV_MSGBOX_HXX
|
|
#include <vcl/msgbox.hxx>
|
|
#endif
|
|
#ifndef _DBAUI_INDEXDIALOG_HXX_
|
|
#include "indexdialog.hxx"
|
|
#endif
|
|
#ifndef DBAUI_TOOLS_HXX
|
|
#include "UITools.hxx"
|
|
#endif
|
|
#ifndef DBAUI_TOOLS_HXX
|
|
#include "UITools.hxx"
|
|
#endif
|
|
#include <boost/mem_fn.hpp>
|
|
|
|
#ifndef _CPPUHELPER_EXC_HLP_HXX_
|
|
#include <cppuhelper/exc_hlp.hxx>
|
|
#endif
|
|
#include "dsmeta.hxx"
|
|
|
|
extern "C" void SAL_CALL createRegistryInfo_OTableControl()
|
|
{
|
|
static ::dbaui::OMultiInstanceAutoRegistration< ::dbaui::OTableController > aAutoRegistration;
|
|
}
|
|
|
|
using namespace ::com::sun::star;
|
|
using namespace ::com::sun::star::uno;
|
|
using namespace ::com::sun::star::io;
|
|
using namespace ::com::sun::star::beans;
|
|
using namespace ::com::sun::star::frame;
|
|
using namespace ::com::sun::star::util;
|
|
using namespace ::com::sun::star::lang;
|
|
using namespace ::com::sun::star::container;
|
|
using namespace ::com::sun::star::sdbcx;
|
|
using namespace ::com::sun::star::sdbc;
|
|
using namespace ::com::sun::star::sdb;
|
|
using namespace ::com::sun::star::ui;
|
|
using namespace ::com::sun::star::util;
|
|
using namespace ::dbtools;
|
|
using namespace ::dbaui;
|
|
using namespace ::comphelper;
|
|
|
|
namespace
|
|
{
|
|
void dropTable(const Reference<XNameAccess>& _rxTable,const ::rtl::OUString& _sTableName)
|
|
{
|
|
if ( _rxTable->hasByName(_sTableName) )
|
|
{
|
|
Reference<XDrop> xNameCont(_rxTable,UNO_QUERY);
|
|
OSL_ENSURE(xNameCont.is(),"No drop interface for tables!");
|
|
if ( xNameCont.is() )
|
|
xNameCont->dropByName(_sTableName);
|
|
}
|
|
}
|
|
//------------------------------------------------------------------------------
|
|
struct OTableRowCompare : public ::std::binary_function< ::boost::shared_ptr<OTableRow> , ::rtl::OUString, bool>
|
|
{
|
|
bool operator() (const ::boost::shared_ptr<OTableRow> lhs, const ::rtl::OUString& rhs) const
|
|
{
|
|
OFieldDescription* pField = lhs->GetActFieldDescr();
|
|
return pField && pField->GetName() == rhs;
|
|
}
|
|
};
|
|
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
::rtl::OUString SAL_CALL OTableController::getImplementationName() throw( RuntimeException )
|
|
{
|
|
return getImplementationName_Static();
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
::rtl::OUString OTableController::getImplementationName_Static() throw( RuntimeException )
|
|
{
|
|
return ::rtl::OUString::createFromAscii("org.openoffice.comp.dbu.OTableDesign");
|
|
}
|
|
//------------------------------------------------------------------------------
|
|
Sequence< ::rtl::OUString> OTableController::getSupportedServiceNames_Static(void) throw( RuntimeException )
|
|
{
|
|
Sequence< ::rtl::OUString> aSupported(1);
|
|
aSupported.getArray()[0] = ::rtl::OUString::createFromAscii("com.sun.star.sdb.TableDesign");
|
|
return aSupported;
|
|
}
|
|
//-------------------------------------------------------------------------
|
|
Sequence< ::rtl::OUString> SAL_CALL OTableController::getSupportedServiceNames() throw(RuntimeException)
|
|
{
|
|
return getSupportedServiceNames_Static();
|
|
}
|
|
// -------------------------------------------------------------------------
|
|
Reference< XInterface > SAL_CALL OTableController::Create(const Reference<XMultiServiceFactory >& _rxFactory)
|
|
{
|
|
return *(new OTableController(_rxFactory));
|
|
}
|
|
|
|
DBG_NAME(OTableController)
|
|
// -----------------------------------------------------------------------------
|
|
OTableController::OTableController(const Reference< XMultiServiceFactory >& _rM) : OTableController_BASE(_rM)
|
|
,m_sTypeNames(ModuleRes(STR_TABLEDESIGN_DBFIELDTYPES))
|
|
,m_pTypeInfo()
|
|
,m_bAllowAutoIncrementValue(sal_False)
|
|
,m_bNew(sal_True)
|
|
{
|
|
DBG_CTOR(OTableController,NULL);
|
|
|
|
InvalidateAll();
|
|
m_pTypeInfo = TOTypeInfoSP(new OTypeInfo());
|
|
m_pTypeInfo->aUIName = m_sTypeNames.GetToken(TYPE_OTHER);
|
|
m_aTypeCollection.initUserDriverTypes(_rM);
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
OTableController::~OTableController()
|
|
{
|
|
m_aTypeInfoIndex.clear();
|
|
m_aTypeInfo.clear();
|
|
|
|
DBG_DTOR(OTableController,NULL);
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
|
void OTableController::startTableListening()
|
|
{
|
|
Reference< XComponent > xComponent(m_xTable, UNO_QUERY);
|
|
if (xComponent.is())
|
|
xComponent->addEventListener(static_cast<XModifyListener*>(this));
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
|
void OTableController::stopTableListening()
|
|
{
|
|
Reference< XComponent > xComponent(m_xTable, UNO_QUERY);
|
|
if (xComponent.is())
|
|
xComponent->removeEventListener(static_cast<XModifyListener*>(this));
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
|
void OTableController::disposing()
|
|
{
|
|
OTableController_BASE::disposing();
|
|
m_pView = NULL;
|
|
|
|
m_vRowList.clear();
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
FeatureState OTableController::GetState(sal_uInt16 _nId) const
|
|
{
|
|
FeatureState aReturn;
|
|
// (disabled automatically)
|
|
|
|
switch (_nId)
|
|
{
|
|
case ID_BROWSER_CLOSE:
|
|
aReturn.bEnabled = sal_True;
|
|
break;
|
|
case ID_BROWSER_EDITDOC:
|
|
aReturn.bChecked = isEditable();
|
|
aReturn.bEnabled = m_bNew || isEditable();// the editable flag is set through this one -> || isAddAllowed() || isDropAllowed() || isAlterAllowed();
|
|
break;
|
|
case ID_BROWSER_SAVEDOC:
|
|
aReturn.bEnabled = isModified();
|
|
if ( aReturn.bEnabled )
|
|
{
|
|
::std::vector< ::boost::shared_ptr<OTableRow> >::const_iterator aIter = ::std::find_if(m_vRowList.begin(),m_vRowList.end(),
|
|
::boost::mem_fn(&OTableRow::isValid));
|
|
aReturn.bEnabled = aIter != m_vRowList.end();
|
|
}
|
|
break;
|
|
case ID_BROWSER_SAVEASDOC:
|
|
aReturn.bEnabled = isConnected() && isEditable();
|
|
if ( aReturn.bEnabled )
|
|
{
|
|
::std::vector< ::boost::shared_ptr<OTableRow> >::const_iterator aIter = ::std::find_if(m_vRowList.begin(),m_vRowList.end(),
|
|
::boost::mem_fn(&OTableRow::isValid));
|
|
aReturn.bEnabled = aIter != m_vRowList.end();
|
|
}
|
|
break;
|
|
|
|
case ID_BROWSER_CUT:
|
|
aReturn.bEnabled = isEditable() && m_aCurrentFrame.isActive() && getView() && static_cast<OTableDesignView*>(getView())->isCutAllowed();
|
|
break;
|
|
case ID_BROWSER_COPY:
|
|
aReturn.bEnabled = m_aCurrentFrame.isActive() && getView() && static_cast<OTableDesignView*>(getView())->isCopyAllowed();
|
|
break;
|
|
case ID_BROWSER_PASTE:
|
|
aReturn.bEnabled = isEditable() && m_aCurrentFrame.isActive() && getView() && static_cast<OTableDesignView*>(getView())->isPasteAllowed();
|
|
break;
|
|
case SID_INDEXDESIGN:
|
|
aReturn.bEnabled =
|
|
( ( ((!m_bNew && isModified()) || isModified())
|
|
|| Reference< XIndexesSupplier >(m_xTable, UNO_QUERY).is()
|
|
)
|
|
&& isConnected()
|
|
);
|
|
if ( aReturn.bEnabled )
|
|
{
|
|
::std::vector< ::boost::shared_ptr<OTableRow> >::const_iterator aIter = ::std::find_if(m_vRowList.begin(),m_vRowList.end(),
|
|
::boost::mem_fn(&OTableRow::isValid));
|
|
aReturn.bEnabled = aIter != m_vRowList.end();
|
|
}
|
|
break;
|
|
default:
|
|
aReturn = OTableController_BASE::GetState(_nId);
|
|
}
|
|
return aReturn;
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
void OTableController::Execute(sal_uInt16 _nId, const Sequence< PropertyValue >& aArgs)
|
|
{
|
|
switch(_nId)
|
|
{
|
|
case ID_BROWSER_EDITDOC:
|
|
setEditable(!isEditable());
|
|
static_cast<OTableDesignView*>(getView())->setReadOnly(!isEditable());
|
|
InvalidateFeature(ID_BROWSER_PASTE);
|
|
InvalidateFeature(SID_BROWSER_CLEAR_QUERY);
|
|
break;
|
|
case ID_BROWSER_SAVEASDOC:
|
|
doSaveDoc(sal_True);
|
|
break;
|
|
case ID_BROWSER_SAVEDOC:
|
|
static_cast<OTableDesignView*>(getView())->GetEditorCtrl()->SaveCurRow();
|
|
doSaveDoc(sal_False);
|
|
break;
|
|
case ID_BROWSER_CUT:
|
|
static_cast<OTableDesignView*>(getView())->cut();
|
|
break;
|
|
case ID_BROWSER_COPY:
|
|
static_cast<OTableDesignView*>(getView())->copy();
|
|
break;
|
|
case ID_BROWSER_PASTE:
|
|
static_cast<OTableDesignView*>(getView())->paste();
|
|
break;
|
|
case SID_INDEXDESIGN:
|
|
doEditIndexes();
|
|
break;
|
|
default:
|
|
OTableController_BASE::Execute(_nId,aArgs);
|
|
}
|
|
InvalidateFeature(_nId);
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
|
sal_Bool OTableController::doSaveDoc(sal_Bool _bSaveAs)
|
|
{
|
|
if (!isConnected())
|
|
reconnect(sal_True); // ask the user for a new connection
|
|
Reference<XTablesSupplier> xTablesSup(getConnection(),UNO_QUERY);
|
|
|
|
if (!xTablesSup.is())
|
|
{
|
|
String aMessage(ModuleRes(STR_TABLEDESIGN_CONNECTION_MISSING));
|
|
OSQLWarningBox( getView(), aMessage ).Execute();
|
|
return sal_False;
|
|
}
|
|
|
|
// check if a column exists
|
|
// TODO
|
|
|
|
Reference<XNameAccess> xTables;
|
|
::rtl::OUString sCatalog, sSchema;
|
|
|
|
sal_Bool bNew = (0 == m_sName.getLength());
|
|
bNew = bNew || m_bNew || _bSaveAs;
|
|
|
|
try
|
|
{
|
|
xTables = xTablesSup->getTables();
|
|
OSL_ENSURE(xTables.is(),"The tables can't be null!");
|
|
bNew = bNew || (xTables.is() && !xTables->hasByName(m_sName));
|
|
|
|
// first we need a name for our query so ask the user
|
|
if(bNew)
|
|
{
|
|
String aDefaultName;
|
|
if (_bSaveAs && !bNew)
|
|
aDefaultName = String(m_sName);
|
|
else
|
|
{
|
|
String aName = String(ModuleRes(STR_TBL_TITLE));
|
|
aDefaultName = aName.GetToken(0,' ');
|
|
//aDefaultName = getPrivateTitle();
|
|
aDefaultName = ::dbtools::createUniqueName(xTables,aDefaultName);
|
|
}
|
|
|
|
DynamicTableOrQueryNameCheck aNameChecker( getConnection(), CommandType::TABLE );
|
|
OSaveAsDlg aDlg( getView(), CommandType::TABLE, getORB(), getConnection(), aDefaultName, aNameChecker );
|
|
if ( aDlg.Execute() != RET_OK )
|
|
return sal_False;
|
|
|
|
m_sName = aDlg.getName();
|
|
sCatalog = aDlg.getCatalog();
|
|
sSchema = aDlg.getSchema();
|
|
}
|
|
|
|
// did we get a name
|
|
if(!m_sName.getLength())
|
|
return sal_False;
|
|
}
|
|
catch(Exception&)
|
|
{
|
|
OSL_ENSURE(sal_False, "OTableController::doSaveDoc: nothing is expected to happen here!");
|
|
}
|
|
|
|
sal_Bool bAlter = sal_False;
|
|
sal_Bool bError = sal_False;
|
|
SQLExceptionInfo aInfo;
|
|
try
|
|
{
|
|
// check the columns for double names
|
|
if(!checkColumns(bNew || !xTables->hasByName(m_sName)))
|
|
{
|
|
// #105323# OJ
|
|
return sal_False;
|
|
}
|
|
|
|
Reference<XPropertySet> xTable;
|
|
if(bNew || !xTables->hasByName(m_sName)) // just to make sure the table already exists
|
|
{
|
|
dropTable(xTables,m_sName);
|
|
|
|
Reference<XDataDescriptorFactory> xFact(xTables,UNO_QUERY);
|
|
OSL_ENSURE(xFact.is(),"OTableController::doSaveDoc: No XDataDescriptorFactory available!");
|
|
xTable = xFact->createDataDescriptor();
|
|
OSL_ENSURE(xTable.is(),"OTableController::doSaveDoc: Create query failed!");
|
|
// to set the name is only allowed when the wuery is new
|
|
xTable->setPropertyValue(PROPERTY_CATALOGNAME,makeAny(sCatalog));
|
|
xTable->setPropertyValue(PROPERTY_SCHEMANAME,makeAny(sSchema));
|
|
xTable->setPropertyValue(PROPERTY_NAME,makeAny(m_sName));
|
|
|
|
// now append the columns
|
|
Reference<XColumnsSupplier> xColSup(xTable,UNO_QUERY);
|
|
appendColumns(xColSup,bNew);
|
|
// now append the primary key
|
|
Reference<XKeysSupplier> xKeySup(xTable,UNO_QUERY);
|
|
appendPrimaryKey(xKeySup,bNew);
|
|
}
|
|
// now set the properties
|
|
if(bNew)
|
|
{
|
|
Reference<XAppend> xAppend(xTables,UNO_QUERY);
|
|
OSL_ENSURE(xAppend.is(),"OTableController::doSaveDoc: No XAppend Interface!");
|
|
xAppend->appendByDescriptor(xTable);
|
|
|
|
assignTable();
|
|
if(!m_xTable.is()) // correct name and try again
|
|
{
|
|
// it can be that someone inserted new data for us
|
|
m_sName = ::dbtools::composeTableName( getConnection()->getMetaData(), xTable, ::dbtools::eInDataManipulation, false, false, false );
|
|
assignTable();
|
|
}
|
|
// now check if our datasource has set a tablefilter and if append the new table name to it
|
|
::dbaui::appendToFilter(getConnection(),m_sName,getORB(),getView()); // we are not interessted in the return value
|
|
Reference< frame::XTitleChangeListener> xEventListener(impl_getTitleHelper_throw(),UNO_QUERY);
|
|
if ( xEventListener.is() )
|
|
{
|
|
frame::TitleChangedEvent aEvent;
|
|
xEventListener->titleChanged(aEvent);
|
|
}
|
|
releaseNumberForComponent();
|
|
}
|
|
else if(m_xTable.is())
|
|
{
|
|
bAlter = sal_True;
|
|
alterColumns();
|
|
}
|
|
reSyncRows();
|
|
}
|
|
catch(const SQLContext& e)
|
|
{
|
|
aInfo = SQLExceptionInfo(e);
|
|
}
|
|
catch(const SQLWarning& e)
|
|
{
|
|
aInfo = SQLExceptionInfo(e);
|
|
}
|
|
catch(const SQLException& e)
|
|
{
|
|
aInfo = SQLExceptionInfo(e);
|
|
}
|
|
catch(const ElementExistException& )
|
|
{
|
|
String sText( ModuleRes( STR_NAME_ALREADY_EXISTS ) );
|
|
sText.SearchAndReplaceAscii( "#" , m_sName);
|
|
OSQLMessageBox aDlg( getView(), String( ModuleRes( STR_ERROR_DURING_CREATION ) ), sText, WB_OK, OSQLMessageBox::Error );
|
|
|
|
aDlg.Execute();
|
|
bError = sal_True;
|
|
}
|
|
catch( const Exception& )
|
|
{
|
|
bError = sal_True;
|
|
DBG_UNHANDLED_EXCEPTION();
|
|
}
|
|
|
|
if ( aInfo.isValid() )
|
|
aInfo.prepend( String( ModuleRes( STR_TABLEDESIGN_SAVE_ERROR ) ) );
|
|
showError(aInfo);
|
|
|
|
if (aInfo.isValid() || bError)
|
|
{
|
|
if(!bAlter || bNew)
|
|
{
|
|
m_sName = ::rtl::OUString();
|
|
stopTableListening();
|
|
m_xTable = NULL;
|
|
}
|
|
// reload(); // a error occured so we have to reload
|
|
}
|
|
return ! (aInfo.isValid() || bError);
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
|
void OTableController::doEditIndexes()
|
|
{
|
|
// table needs to be saved before editing indexes
|
|
if (m_bNew || isModified())
|
|
{
|
|
QueryBox aAsk(getView(), ModuleRes(QUERY_SAVE_TABLE_EDIT_INDEXES));
|
|
if (RET_YES != aAsk.Execute())
|
|
return;
|
|
|
|
if (!doSaveDoc(sal_False))
|
|
return;
|
|
|
|
OSL_ENSURE(!m_bNew && !isModified(), "OTableController::doEditIndexes: what the hell did doSaveDoc do?");
|
|
}
|
|
|
|
Reference< XNameAccess > xIndexes; // will be the keys of the table
|
|
Sequence< ::rtl::OUString > aFieldNames; // will be the column names of the table
|
|
try
|
|
{
|
|
// get the keys
|
|
Reference< XIndexesSupplier > xIndexesSupp(m_xTable, UNO_QUERY);
|
|
if (xIndexesSupp.is())
|
|
{
|
|
xIndexes = xIndexesSupp->getIndexes();
|
|
OSL_ENSURE(xIndexes.is(), "OTableController::doEditIndexes: no keys got from the indexes supplier!");
|
|
}
|
|
else
|
|
OSL_ENSURE(sal_False, "OTableController::doEditIndexes: should never have reached this (no indexes supplier)!");
|
|
|
|
// get the field names
|
|
Reference< XColumnsSupplier > xColSupp(m_xTable, UNO_QUERY);
|
|
OSL_ENSURE(xColSupp.is(), "OTableController::doEditIndexes: no columns supplier!");
|
|
if (xColSupp.is())
|
|
{
|
|
Reference< XNameAccess > xCols = xColSupp->getColumns();
|
|
OSL_ENSURE(xCols.is(), "OTableController::doEditIndexes: no columns!");
|
|
if (xCols.is())
|
|
aFieldNames = xCols->getElementNames();
|
|
}
|
|
}
|
|
catch( const Exception& )
|
|
{
|
|
DBG_UNHANDLED_EXCEPTION();
|
|
}
|
|
|
|
if (!xIndexes.is())
|
|
return;
|
|
|
|
DbaIndexDialog aDialog(getView(), aFieldNames, xIndexes, getConnection(),getORB(),isConnected() ? getConnection()->getMetaData().is() && getConnection()->getMetaData()->getMaxColumnsInIndex() : sal_Int32(0));
|
|
if (RET_OK != aDialog.Execute())
|
|
return;
|
|
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
|
void OTableController::impl_initialize()
|
|
{
|
|
try
|
|
{
|
|
OTableController_BASE::impl_initialize();
|
|
|
|
const NamedValueCollection& rArguments( getInitParams() );
|
|
|
|
rArguments.get_ensureType( (::rtl::OUString)PROPERTY_CURRENTTABLE, m_sName );
|
|
|
|
// read autoincrement value set in the datasource
|
|
::dbaui::fillAutoIncrementValue(getDataSource(),m_bAllowAutoIncrementValue,m_sAutoIncrementValue);
|
|
|
|
assignTable();
|
|
}
|
|
catch( const Exception& )
|
|
{
|
|
DBG_UNHANDLED_EXCEPTION();
|
|
}
|
|
|
|
try
|
|
{
|
|
::dbaui::fillTypeInfo(getConnection(),m_sTypeNames,m_aTypeInfo,m_aTypeInfoIndex); // fill the needed type information
|
|
}
|
|
catch(const SQLException&)
|
|
{
|
|
OSQLWarningBox( getView(), ModuleRes( STR_NO_TYPE_INFO_AVAILABLE ) ).Execute();
|
|
throw;
|
|
}
|
|
try
|
|
{
|
|
loadData(); // fill the column information form the table
|
|
getView()->initialize(); // show the windows and fill with our informations
|
|
getUndoMgr()->Clear(); // clear all undo redo things
|
|
setModified(sal_False); // and we are not modified yet
|
|
}
|
|
catch( const Exception& )
|
|
{
|
|
DBG_UNHANDLED_EXCEPTION();
|
|
}
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
sal_Bool OTableController::Construct(Window* pParent)
|
|
{
|
|
m_pView = new OTableDesignView( pParent, getORB(), *this );
|
|
OTableController_BASE::Construct(pParent);
|
|
// m_pView->Construct();
|
|
// m_pView->Show();
|
|
return sal_True;
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
sal_Bool SAL_CALL OTableController::suspend(sal_Bool /*_bSuspend*/) throw( RuntimeException )
|
|
{
|
|
if ( getBroadcastHelper().bInDispose || getBroadcastHelper().bDisposed )
|
|
return sal_True;
|
|
|
|
vos::OGuard aSolarGuard( Application::GetSolarMutex() );
|
|
::osl::MutexGuard aGuard( getMutex() );
|
|
if ( getView() && getView()->IsInModalMode() )
|
|
return sal_False;
|
|
if ( getView() )
|
|
static_cast<OTableDesignView*>(getView())->GrabFocus();
|
|
sal_Bool bCheck = sal_True;
|
|
if ( isModified() )
|
|
{
|
|
::std::vector< ::boost::shared_ptr<OTableRow> >::iterator aIter = ::std::find_if(m_vRowList.begin(),m_vRowList.end(),
|
|
::boost::mem_fn(&OTableRow::isValid));
|
|
if ( aIter != m_vRowList.end() )
|
|
{
|
|
QueryBox aQry(getView(), ModuleRes(TABLE_DESIGN_SAVEMODIFIED));
|
|
switch (aQry.Execute())
|
|
{
|
|
case RET_YES:
|
|
Execute(ID_BROWSER_SAVEDOC,Sequence<PropertyValue>());
|
|
if ( isModified() )
|
|
bCheck = sal_False; // when we save the table this must be false else some press cancel
|
|
break;
|
|
case RET_CANCEL:
|
|
bCheck = sal_False;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
else if ( !m_bNew )
|
|
{
|
|
QueryBox aQry(getView(), ModuleRes(TABLE_DESIGN_ALL_ROWS_DELETED));
|
|
switch (aQry.Execute())
|
|
{
|
|
case RET_YES:
|
|
{
|
|
try
|
|
{
|
|
Reference<XTablesSupplier> xTablesSup(getConnection(),UNO_QUERY);
|
|
Reference<XNameAccess> xTables = xTablesSup->getTables();
|
|
dropTable(xTables,m_sName);
|
|
}
|
|
catch(const Exception&)
|
|
{
|
|
OSL_ENSURE(sal_False, "OTableController::suspend: nothing is expected to happen here!");
|
|
}
|
|
|
|
}
|
|
break;
|
|
case RET_CANCEL:
|
|
bCheck = sal_False;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
/*
|
|
if ( bCheck )
|
|
OSingleDocumentController::suspend(_bSuspend);
|
|
*/
|
|
return bCheck;
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
void OTableController::describeSupportedFeatures()
|
|
{
|
|
OSingleDocumentController::describeSupportedFeatures();
|
|
|
|
implDescribeSupportedFeature( ".uno:Redo", ID_BROWSER_REDO, CommandGroup::EDIT );
|
|
implDescribeSupportedFeature( ".uno:Save", ID_BROWSER_SAVEDOC, CommandGroup::EDIT );
|
|
implDescribeSupportedFeature( ".uno:Undo", ID_BROWSER_UNDO, CommandGroup::EDIT );
|
|
implDescribeSupportedFeature( ".uno:HelpMenu", SID_HELPMENU, CommandGroup::APPLICATION );
|
|
implDescribeSupportedFeature( ".uno:NewDoc", SID_NEWDOC, CommandGroup::DOCUMENT );
|
|
implDescribeSupportedFeature( ".uno:SaveAs", ID_BROWSER_SAVEASDOC, CommandGroup::DOCUMENT );
|
|
implDescribeSupportedFeature( ".uno:DBIndexDesign", SID_INDEXDESIGN, CommandGroup::APPLICATION );
|
|
implDescribeSupportedFeature( ".uno:EditDoc", ID_BROWSER_EDITDOC, CommandGroup::EDIT );
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
SfxUndoManager* OTableController::getUndoMgr()
|
|
{
|
|
return &m_aUndoManager;
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
void OTableController::setModified(sal_Bool _bModified)
|
|
{
|
|
OSingleDocumentController::setModified(_bModified);
|
|
InvalidateFeature(SID_INDEXDESIGN);
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
void SAL_CALL OTableController::disposing( const EventObject& _rSource ) throw(RuntimeException)
|
|
{
|
|
if ( _rSource.Source == m_xTable )
|
|
{ // some deleted our table so we have a new one
|
|
stopTableListening();
|
|
m_xTable = NULL;
|
|
m_bNew = sal_True;
|
|
setModified(sal_True);
|
|
}
|
|
else
|
|
OTableController_BASE::disposing( _rSource );
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
void OTableController::Save(const Reference< XObjectOutputStream>& _rxOut)
|
|
{
|
|
OStreamSection aSection(_rxOut.get());
|
|
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
void OTableController::Load(const Reference< XObjectInputStream>& _rxIn)
|
|
{
|
|
OStreamSection aSection(_rxIn.get());
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
|
void OTableController::losingConnection( )
|
|
{
|
|
// let the base class do it's reconnect
|
|
OTableController_BASE::losingConnection( );
|
|
|
|
// remove from the table
|
|
Reference< XComponent > xComponent(m_xTable, UNO_QUERY);
|
|
if (xComponent.is())
|
|
{
|
|
Reference<XEventListener> xEvtL( static_cast< ::cppu::OWeakObject*>(this), UNO_QUERY);
|
|
xComponent->removeEventListener(xEvtL);
|
|
}
|
|
stopTableListening();
|
|
m_xTable = NULL;
|
|
assignTable();
|
|
if(!m_xTable.is())
|
|
{
|
|
m_bNew = sal_True;
|
|
setModified(sal_True);
|
|
}
|
|
InvalidateAll();
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
TOTypeInfoSP OTableController::getTypeInfoByType(sal_Int32 _nDataType) const
|
|
{
|
|
return queryTypeInfoByType(_nDataType,m_aTypeInfo);
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
void OTableController::appendColumns(Reference<XColumnsSupplier>& _rxColSup,sal_Bool _bNew,sal_Bool _bKeyColumns)
|
|
{
|
|
try
|
|
{
|
|
// now append the columns
|
|
OSL_ENSURE(_rxColSup.is(),"No columns supplier");
|
|
if(!_rxColSup.is())
|
|
return;
|
|
Reference<XNameAccess> xColumns = _rxColSup->getColumns();
|
|
OSL_ENSURE(xColumns.is(),"No columns");
|
|
Reference<XDataDescriptorFactory> xColumnFactory(xColumns,UNO_QUERY);
|
|
|
|
Reference<XAppend> xAppend(xColumns,UNO_QUERY);
|
|
OSL_ENSURE(xAppend.is(),"No XAppend Interface!");
|
|
|
|
::std::vector< ::boost::shared_ptr<OTableRow> >::iterator aIter = m_vRowList.begin();
|
|
::std::vector< ::boost::shared_ptr<OTableRow> >::iterator aEnd = m_vRowList.end();
|
|
for(;aIter != aEnd;++aIter)
|
|
{
|
|
OSL_ENSURE(*aIter,"OTableRow is null!");
|
|
OFieldDescription* pField = (*aIter)->GetActFieldDescr();
|
|
if ( !pField || (!_bNew && (*aIter)->IsReadOnly() && !_bKeyColumns) )
|
|
continue;
|
|
|
|
Reference<XPropertySet> xColumn;
|
|
if(pField->IsPrimaryKey() || !_bKeyColumns)
|
|
xColumn = xColumnFactory->createDataDescriptor();
|
|
if(xColumn.is())
|
|
{
|
|
if(!_bKeyColumns)
|
|
::dbaui::setColumnProperties(xColumn,pField);
|
|
else
|
|
xColumn->setPropertyValue(PROPERTY_NAME,makeAny(pField->GetName()));
|
|
|
|
xAppend->appendByDescriptor(xColumn);
|
|
xColumn = NULL;
|
|
// now only the settings are missing
|
|
if(xColumns->hasByName(pField->GetName()))
|
|
{
|
|
xColumns->getByName(pField->GetName()) >>= xColumn;
|
|
if(xColumn.is())
|
|
pField->copyColumnSettingsTo(xColumn);
|
|
}
|
|
else
|
|
{
|
|
OSL_ENSURE(sal_False, "OTableController::appendColumns: invalid field name!");
|
|
}
|
|
|
|
}
|
|
}
|
|
}
|
|
catch(const SQLException& )
|
|
{
|
|
showError( SQLExceptionInfo( ::cppu::getCaughtException() ) );
|
|
}
|
|
catch( const Exception& )
|
|
{
|
|
DBG_UNHANDLED_EXCEPTION();
|
|
}
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
void OTableController::appendPrimaryKey(Reference<XKeysSupplier>& _rxSup,sal_Bool _bNew)
|
|
{
|
|
if(!_rxSup.is())
|
|
return; // the database doesn't support keys
|
|
|
|
OSL_ENSURE(_rxSup.is(),"No XKeysSupplier!");
|
|
Reference<XIndexAccess> xKeys(_rxSup->getKeys(),UNO_QUERY);
|
|
Reference<XPropertySet> xProp;
|
|
const sal_Int32 nCount = xKeys->getCount();
|
|
for(sal_Int32 i=0;i< nCount ;++i)
|
|
{
|
|
xKeys->getByIndex(i) >>= xProp;
|
|
sal_Int32 nKeyType = 0;
|
|
xProp->getPropertyValue(PROPERTY_TYPE) >>= nKeyType;
|
|
if(KeyType::PRIMARY == nKeyType)
|
|
{
|
|
return; // primary key already exists after appending a column
|
|
}
|
|
}
|
|
Reference<XDataDescriptorFactory> xKeyFactory(xKeys,UNO_QUERY);
|
|
OSL_ENSURE(xKeyFactory.is(),"No XDataDescriptorFactory Interface!");
|
|
if ( !xKeyFactory.is() )
|
|
return;
|
|
Reference<XAppend> xAppend(xKeyFactory,UNO_QUERY);
|
|
OSL_ENSURE(xAppend.is(),"No XAppend Interface!");
|
|
|
|
Reference<XPropertySet> xKey = xKeyFactory->createDataDescriptor();
|
|
OSL_ENSURE(xKey.is(),"Key is null!");
|
|
xKey->setPropertyValue(PROPERTY_TYPE,makeAny(KeyType::PRIMARY));
|
|
|
|
Reference<XColumnsSupplier> xColSup(xKey,UNO_QUERY);
|
|
if(xColSup.is())
|
|
{
|
|
appendColumns(xColSup,_bNew,sal_True);
|
|
Reference<XNameAccess> xColumns = xColSup->getColumns();
|
|
if(xColumns->hasElements())
|
|
xAppend->appendByDescriptor(xKey);
|
|
}
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
void OTableController::loadData()
|
|
{
|
|
//////////////////////////////////////////////////////////////////////
|
|
// Wenn Datenstruktur bereits vorhanden, Struktur leeren
|
|
m_vRowList.clear();
|
|
|
|
::boost::shared_ptr<OTableRow> pTabEdRow;
|
|
Reference< XDatabaseMetaData> xMetaData = getMetaData( );
|
|
//////////////////////////////////////////////////////////////////////
|
|
// Datenstruktur mit Daten aus DatenDefinitionsObjekt fuellen
|
|
if(m_xTable.is() && xMetaData.is())
|
|
{
|
|
Reference<XColumnsSupplier> xColSup(m_xTable,UNO_QUERY);
|
|
OSL_ENSURE(xColSup.is(),"No XColumnsSupplier!");
|
|
Reference<XNameAccess> xColumns = xColSup->getColumns();
|
|
OFieldDescription* pActFieldDescr = NULL;
|
|
String aType;
|
|
//////////////////////////////////////////////////////////////////////
|
|
// ReadOnly-Flag
|
|
// Bei Drop darf keine Zeile editierbar sein.
|
|
// Bei Add duerfen nur die leeren Zeilen editierbar sein.
|
|
// Bei Add und Drop koennen alle Zeilen editiert werden.
|
|
// sal_Bool bReadOldRow = xMetaData->supportsAlterTableWithAddColumn() && xMetaData->supportsAlterTableWithDropColumn();
|
|
sal_Bool bIsAlterAllowed = isAlterAllowed();
|
|
Sequence< ::rtl::OUString> aColumns = xColumns->getElementNames();
|
|
const ::rtl::OUString* pIter = aColumns.getConstArray();
|
|
const ::rtl::OUString* pEnd = pIter + aColumns.getLength();
|
|
|
|
for(;pIter != pEnd;++pIter)
|
|
{
|
|
Reference<XPropertySet> xColumn;
|
|
xColumns->getByName(*pIter) >>= xColumn;
|
|
sal_Int32 nType = 0;
|
|
sal_Int32 nScale = 0;
|
|
sal_Int32 nPrecision = 0;
|
|
sal_Int32 nNullable = 0;
|
|
sal_Int32 nFormatKey = 0;
|
|
sal_Int32 nAlign = 0;
|
|
|
|
sal_Bool bIsAutoIncrement = false, bIsCurrency = false;
|
|
::rtl::OUString sName,sDescription,sTypeName;
|
|
Any aControlDefault;
|
|
|
|
// get the properties from the column
|
|
xColumn->getPropertyValue(PROPERTY_NAME) >>= sName;
|
|
xColumn->getPropertyValue(PROPERTY_TYPENAME) >>= sTypeName;
|
|
xColumn->getPropertyValue(PROPERTY_ISNULLABLE) >>= nNullable;
|
|
xColumn->getPropertyValue(PROPERTY_ISAUTOINCREMENT) >>= bIsAutoIncrement;
|
|
xColumn->getPropertyValue(PROPERTY_ISCURRENCY) >>= bIsCurrency;
|
|
xColumn->getPropertyValue(PROPERTY_TYPE) >>= nType;
|
|
xColumn->getPropertyValue(PROPERTY_SCALE) >>= nScale;
|
|
xColumn->getPropertyValue(PROPERTY_PRECISION) >>= nPrecision;
|
|
|
|
|
|
if(xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_HELPTEXT))
|
|
xColumn->getPropertyValue(PROPERTY_HELPTEXT) >>= sDescription;
|
|
if(xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_CONTROLDEFAULT))
|
|
aControlDefault = xColumn->getPropertyValue(PROPERTY_CONTROLDEFAULT);
|
|
if(xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_FORMATKEY))
|
|
xColumn->getPropertyValue(PROPERTY_FORMATKEY) >>= nFormatKey;
|
|
if(xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_ALIGN))
|
|
xColumn->getPropertyValue(PROPERTY_ALIGN) >>= nAlign;
|
|
|
|
pTabEdRow.reset(new OTableRow());
|
|
pTabEdRow->SetReadOnly(!bIsAlterAllowed);
|
|
// search for type
|
|
sal_Bool bForce;
|
|
::rtl::OUString sCreate(RTL_CONSTASCII_USTRINGPARAM("x"));
|
|
TOTypeInfoSP pTypeInfo = ::dbaui::getTypeInfoFromType(m_aTypeInfo,nType,sTypeName,sCreate,nPrecision,nScale,bIsAutoIncrement,bForce);
|
|
if ( !pTypeInfo.get() )
|
|
pTypeInfo = m_pTypeInfo;
|
|
pTabEdRow->SetFieldType( pTypeInfo, bForce );
|
|
|
|
pActFieldDescr = pTabEdRow->GetActFieldDescr();
|
|
OSL_ENSURE(pActFieldDescr, "OTableController::loadData: invalid field description generated by the table row!");
|
|
if ( pActFieldDescr )
|
|
{
|
|
pActFieldDescr->SetName(sName);
|
|
pActFieldDescr->SetFormatKey(nFormatKey);
|
|
// pActFieldDescr->SetPrimaryKey(pPrimary->GetValue());
|
|
pActFieldDescr->SetDescription(sDescription);
|
|
pActFieldDescr->SetAutoIncrement(bIsAutoIncrement);
|
|
pActFieldDescr->SetHorJustify(dbaui::mapTextJustify(nAlign));
|
|
pActFieldDescr->SetCurrency(bIsCurrency);
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
// Spezielle Daten
|
|
pActFieldDescr->SetIsNullable(nNullable);
|
|
pActFieldDescr->SetControlDefault(aControlDefault);
|
|
pActFieldDescr->SetPrecision(nPrecision);
|
|
pActFieldDescr->SetScale(nScale);
|
|
}
|
|
m_vRowList.push_back( pTabEdRow);
|
|
}
|
|
// fill the primary key information
|
|
Reference<XNameAccess> xKeyColumns = getKeyColumns();
|
|
if(xKeyColumns.is())
|
|
{
|
|
Sequence< ::rtl::OUString> aKeyColumns = xKeyColumns->getElementNames();
|
|
const ::rtl::OUString* pKeyBegin = aKeyColumns.getConstArray();
|
|
const ::rtl::OUString* pKeyEnd = pKeyBegin + aKeyColumns.getLength();
|
|
|
|
for(;pKeyBegin != pKeyEnd;++pKeyBegin)
|
|
{
|
|
::std::vector< ::boost::shared_ptr<OTableRow> >::iterator rowIter = m_vRowList.begin();
|
|
for(;rowIter != m_vRowList.end();++rowIter)
|
|
{
|
|
if((*rowIter)->GetActFieldDescr()->GetName() == *pKeyBegin)
|
|
{
|
|
(*rowIter)->SetPrimaryKey(sal_True);
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
// Leere Zeilen fuellen
|
|
|
|
OTypeInfoMap::iterator aTypeIter = m_aTypeInfo.find(DataType::VARCHAR);
|
|
if(aTypeIter == m_aTypeInfo.end())
|
|
aTypeIter = m_aTypeInfo.begin();
|
|
|
|
OSL_ENSURE(aTypeIter != m_aTypeInfo.end(),"We have no type infomation!");
|
|
|
|
bool bReadRow = !isAddAllowed();
|
|
for(sal_Int32 i=m_vRowList.size(); i<128; i++ )
|
|
{
|
|
pTabEdRow.reset(new OTableRow());
|
|
pTabEdRow->SetReadOnly(bReadRow);
|
|
m_vRowList.push_back( pTabEdRow);
|
|
}
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
Reference<XNameAccess> OTableController::getKeyColumns() const
|
|
{
|
|
// use keys and indexes for excat postioning
|
|
// first the keys
|
|
Reference<XKeysSupplier> xKeySup(m_xTable,UNO_QUERY);
|
|
Reference<XIndexAccess> xKeys;
|
|
if(xKeySup.is())
|
|
xKeys = xKeySup->getKeys();
|
|
|
|
Reference<XColumnsSupplier> xKeyColsSup;
|
|
Reference<XNameAccess> xKeyColumns;
|
|
if(xKeys.is())
|
|
{
|
|
Reference<XPropertySet> xProp;
|
|
sal_Int32 nCount = xKeys->getCount();
|
|
for(sal_Int32 i=0;i< nCount;++i)
|
|
{
|
|
xKeys->getByIndex(i) >>= xProp;
|
|
OSL_ENSURE(xProp.is(),"Key is invalid: NULL!");
|
|
if ( xProp.is() )
|
|
{
|
|
sal_Int32 nKeyType = 0;
|
|
xProp->getPropertyValue(PROPERTY_TYPE) >>= nKeyType;
|
|
if(KeyType::PRIMARY == nKeyType)
|
|
{
|
|
xKeyColsSup.set(xProp,UNO_QUERY);
|
|
OSL_ENSURE(xKeyColsSup.is(),"Columnsupplier is null!");
|
|
xKeyColumns = xKeyColsSup->getColumns();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return xKeyColumns;
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
sal_Bool OTableController::checkColumns(sal_Bool _bNew) throw(::com::sun::star::sdbc::SQLException)
|
|
{
|
|
sal_Bool bOk = sal_True;
|
|
sal_Bool bFoundPKey = sal_False;
|
|
Reference< XDatabaseMetaData> xMetaData = getMetaData( );
|
|
|
|
::comphelper::UStringMixEqual bCase(xMetaData.is() ? xMetaData->supportsMixedCaseQuotedIdentifiers() : sal_True);
|
|
::std::vector< ::boost::shared_ptr<OTableRow> >::const_iterator aIter = m_vRowList.begin();
|
|
::std::vector< ::boost::shared_ptr<OTableRow> >::const_iterator aEnd = m_vRowList.end();
|
|
for(;aIter != aEnd;++aIter)
|
|
{
|
|
OFieldDescription* pFieldDesc = (*aIter)->GetActFieldDescr();
|
|
if (pFieldDesc && pFieldDesc->GetName().getLength())
|
|
{
|
|
bFoundPKey |= (*aIter)->IsPrimaryKey();
|
|
// first check for duplicate names
|
|
::std::vector< ::boost::shared_ptr<OTableRow> >::const_iterator aIter2 = aIter+1;
|
|
for(;aIter2 != aEnd;++aIter2)
|
|
{
|
|
OFieldDescription* pCompareDesc = (*aIter2)->GetActFieldDescr();
|
|
if (pCompareDesc && bCase(pCompareDesc->GetName(),pFieldDesc->GetName()))
|
|
{
|
|
String strMessage = String(ModuleRes(STR_TABLEDESIGN_DUPLICATE_NAME));
|
|
strMessage.SearchAndReplaceAscii("$column$", pFieldDesc->GetName());
|
|
OSQLWarningBox( getView(), strMessage ).Execute();
|
|
return sal_False;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
if(!bFoundPKey)
|
|
{
|
|
if(_bNew && xMetaData.is() && xMetaData->supportsCoreSQLGrammar())
|
|
{
|
|
String sTitle(ModuleRes(STR_TABLEDESIGN_NO_PRIM_KEY_HEAD));
|
|
String sMsg(ModuleRes(STR_TABLEDESIGN_NO_PRIM_KEY));
|
|
OSQLMessageBox aBox(getView(), sTitle,sMsg, WB_YES_NO_CANCEL | WB_DEF_YES);
|
|
|
|
INT16 nReturn = aBox.Execute();
|
|
|
|
if (nReturn == RET_YES)
|
|
{
|
|
::boost::shared_ptr<OTableRow> pNewRow(new OTableRow());
|
|
TOTypeInfoSP pTypeInfo = ::dbaui::queryPrimaryKeyType(m_aTypeInfo);
|
|
|
|
if ( pTypeInfo.get() )
|
|
{
|
|
pNewRow->SetFieldType( pTypeInfo );
|
|
OFieldDescription* pActFieldDescr = pNewRow->GetActFieldDescr();
|
|
|
|
pActFieldDescr->SetAutoIncrement(sal_False); // #95927# pTypeInfo->bAutoIncrement
|
|
pActFieldDescr->SetIsNullable(ColumnValue::NO_NULLS);
|
|
|
|
pActFieldDescr->SetName( createUniqueName(::rtl::OUString::createFromAscii("ID") ));
|
|
pActFieldDescr->SetPrimaryKey( sal_True );
|
|
m_vRowList.insert(m_vRowList.begin(),pNewRow);
|
|
|
|
static_cast<OTableDesignView*>(getView())->GetEditorCtrl()->Invalidate();
|
|
static_cast<OTableDesignView*>(getView())->GetEditorCtrl()->RowInserted(0);
|
|
} // if ( pTypeInfo.get() )
|
|
}
|
|
else if (nReturn == RET_CANCEL)
|
|
bOk = sal_False;
|
|
}
|
|
}
|
|
return bOk;
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
void OTableController::alterColumns()
|
|
{
|
|
Reference<XColumnsSupplier> xColSup(m_xTable,UNO_QUERY_THROW);
|
|
OSL_ENSURE(xColSup.is(),"What happen here?!");
|
|
|
|
Reference<XNameAccess> xColumns = xColSup->getColumns();
|
|
Reference<XIndexAccess> xIdxColumns(xColumns,UNO_QUERY_THROW);
|
|
OSL_ENSURE(xColumns.is(),"No columns");
|
|
if ( !xColumns.is() )
|
|
return;
|
|
Reference<XAlterTable> xAlter(m_xTable,UNO_QUERY); // can be null
|
|
|
|
sal_Int32 nColumnCount = xIdxColumns->getCount();
|
|
Reference<XDrop> xDrop(xColumns,UNO_QUERY); // can be null
|
|
Reference<XAppend> xAppend(xColumns,UNO_QUERY); // can be null
|
|
Reference<XDataDescriptorFactory> xColumnFactory(xColumns,UNO_QUERY); // can be null
|
|
|
|
sal_Bool bReload = sal_False; // refresh the data
|
|
|
|
// contains all columns names which are already handled those which are not in the list will be deleted
|
|
Reference< XDatabaseMetaData> xMetaData = getMetaData( );
|
|
|
|
::std::map< ::rtl::OUString,sal_Bool,::comphelper::UStringMixLess> aColumns(xMetaData.is() ? (xMetaData->supportsMixedCaseQuotedIdentifiers() ? true : false): sal_True);
|
|
::std::vector< ::boost::shared_ptr<OTableRow> >::iterator aIter = m_vRowList.begin();
|
|
::std::vector< ::boost::shared_ptr<OTableRow> >::iterator aEnd = m_vRowList.end();
|
|
// first look for columns where something other than the name changed
|
|
for(sal_Int32 nPos = 0;aIter != aEnd;++aIter,++nPos)
|
|
{
|
|
OSL_ENSURE(*aIter,"OTableRow is null!");
|
|
OFieldDescription* pField = (*aIter)->GetActFieldDescr();
|
|
if ( !pField )
|
|
continue;
|
|
if ( (*aIter)->IsReadOnly() )
|
|
{
|
|
aColumns[pField->GetName()] = sal_True;
|
|
continue;
|
|
}
|
|
|
|
Reference<XPropertySet> xColumn;
|
|
if ( xColumns->hasByName(pField->GetName()) )
|
|
{
|
|
aColumns[pField->GetName()] = sal_True;
|
|
xColumns->getByName(pField->GetName()) >>= xColumn;
|
|
OSL_ENSURE(xColumn.is(),"Column is null!");
|
|
|
|
sal_Int32 nType=0,nPrecision=0,nScale=0,nNullable=0,nFormatKey=0,nAlignment=0;
|
|
sal_Bool bAutoIncrement = false;
|
|
::rtl::OUString sDescription, sTypeName;
|
|
Any aControlDefault;
|
|
|
|
xColumn->getPropertyValue(PROPERTY_TYPE) >>= nType;
|
|
xColumn->getPropertyValue(PROPERTY_PRECISION) >>= nPrecision;
|
|
xColumn->getPropertyValue(PROPERTY_SCALE) >>= nScale;
|
|
xColumn->getPropertyValue(PROPERTY_ISNULLABLE) >>= nNullable;
|
|
xColumn->getPropertyValue(PROPERTY_ISAUTOINCREMENT) >>= bAutoIncrement;
|
|
|
|
try { xColumn->getPropertyValue(PROPERTY_TYPENAME) >>= sTypeName; }
|
|
catch( const Exception& )
|
|
{
|
|
OSL_ENSURE( sal_False, "no TypeName property?!" );
|
|
// since this is a last minute fix for #i41785#, I want to be on the safe side,
|
|
// and catch errors here as early as possible (instead of the whole process of altering
|
|
// the columns failing)
|
|
// Normally, sdbcx::Column objects are expected to have a TypeName property
|
|
}
|
|
|
|
// xColumn->getPropertyValue(PROPERTY_ISCURRENCY,::cppu::bool2any(pField->IsCurrency()));
|
|
if(xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_HELPTEXT))
|
|
xColumn->getPropertyValue(PROPERTY_HELPTEXT) >>= sDescription;
|
|
if(xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_CONTROLDEFAULT))
|
|
aControlDefault = xColumn->getPropertyValue(PROPERTY_CONTROLDEFAULT);
|
|
if(xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_FORMATKEY))
|
|
xColumn->getPropertyValue(PROPERTY_FORMATKEY) >>= nFormatKey;
|
|
if(xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_ALIGN))
|
|
xColumn->getPropertyValue(PROPERTY_ALIGN) >>= nAlignment;
|
|
|
|
// check if something changed
|
|
if((nType != pField->GetType() ||
|
|
sTypeName != pField->GetTypeName() ||
|
|
nPrecision != pField->GetPrecision() ||
|
|
nScale != pField->GetScale() ||
|
|
nNullable != pField->GetIsNullable() ||
|
|
bAutoIncrement != pField->IsAutoIncrement())&&
|
|
xColumnFactory.is())
|
|
{
|
|
Reference<XPropertySet> xNewColumn;
|
|
xNewColumn = xColumnFactory->createDataDescriptor();
|
|
::dbaui::setColumnProperties(xNewColumn,pField);
|
|
// first try to alter the column
|
|
sal_Bool bNotOk = sal_False;
|
|
try
|
|
{
|
|
// first try if we can alter the column
|
|
if(xAlter.is())
|
|
xAlter->alterColumnByName(pField->GetName(),xNewColumn);
|
|
}
|
|
catch(const SQLException&)
|
|
{
|
|
if(xDrop.is() && xAppend.is())
|
|
{
|
|
String aMessage( ModuleRes( STR_TABLEDESIGN_ALTER_ERROR ) );
|
|
aMessage.SearchAndReplaceAscii( "$column$", pField->GetName() );
|
|
|
|
SQLExceptionInfo aError( ::cppu::getCaughtException() );
|
|
OSQLWarningBox aMsg( getView(), aMessage, WB_YES_NO | WB_DEF_YES , &aError );
|
|
bNotOk = aMsg.Execute() == RET_YES;
|
|
}
|
|
else
|
|
throw;
|
|
}
|
|
// if something went wrong or we can't alter columns
|
|
// drop and append a new one
|
|
if((!xAlter.is() || bNotOk) && xDrop.is() && xAppend.is())
|
|
{
|
|
xDrop->dropByName(pField->GetName());
|
|
try
|
|
{
|
|
xAppend->appendByDescriptor(xNewColumn);
|
|
}
|
|
catch(const SQLException&)
|
|
{ // an error occured so we try to reactivate the old one
|
|
xAppend->appendByDescriptor(xColumn);
|
|
throw;
|
|
}
|
|
}
|
|
// exceptions are caught outside
|
|
xNewColumn = NULL;
|
|
if(xColumns->hasByName(pField->GetName()))
|
|
xColumns->getByName(pField->GetName()) >>= xColumn;
|
|
bReload = sal_True;
|
|
}
|
|
|
|
if(nFormatKey != pField->GetFormatKey())
|
|
{
|
|
if(xColumn.is() && xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_FORMATKEY))
|
|
xColumn->setPropertyValue(PROPERTY_FORMATKEY,makeAny(pField->GetFormatKey()));
|
|
}
|
|
if(nAlignment != dbaui::mapTextAllign(pField->GetHorJustify()))
|
|
{
|
|
if(xColumn.is() && xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_ALIGN))
|
|
xColumn->setPropertyValue(PROPERTY_ALIGN,makeAny(dbaui::mapTextAllign(pField->GetHorJustify())));
|
|
}
|
|
if(sDescription != pField->GetDescription())
|
|
{
|
|
if(xColumn.is() && xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_HELPTEXT))
|
|
xColumn->setPropertyValue(PROPERTY_HELPTEXT,makeAny(pField->GetDescription()));
|
|
}
|
|
if ( aControlDefault != pField->GetControlDefault())
|
|
{
|
|
if(xColumn.is() && xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_CONTROLDEFAULT))
|
|
xColumn->setPropertyValue(PROPERTY_CONTROLDEFAULT,pField->GetControlDefault());
|
|
}
|
|
}
|
|
else if(xColumnFactory.is() && xAlter.is() && nPos < nColumnCount)
|
|
{ // we can't find the column so we could try it with the index before we drop and append a new column
|
|
try
|
|
{
|
|
Reference<XPropertySet> xNewColumn;
|
|
xNewColumn = xColumnFactory->createDataDescriptor();
|
|
::dbaui::setColumnProperties(xNewColumn,pField);
|
|
xAlter->alterColumnByIndex(nPos,xNewColumn);
|
|
if(xColumns->hasByName(pField->GetName()))
|
|
{ // ask for the append by name
|
|
aColumns[pField->GetName()] = sal_True;
|
|
xColumns->getByName(pField->GetName()) >>= xColumn;
|
|
if(xColumn.is())
|
|
pField->copyColumnSettingsTo(xColumn);
|
|
}
|
|
else
|
|
{
|
|
OSL_ENSURE(sal_False, "OTableController::alterColumns: invalid column (2)!");
|
|
}
|
|
}
|
|
catch(const SQLException&)
|
|
{ // we couldn't alter the column so we have to add new columns
|
|
bReload = sal_True;
|
|
if(xDrop.is() && xAppend.is())
|
|
{
|
|
String aMessage(ModuleRes(STR_TABLEDESIGN_ALTER_ERROR));
|
|
aMessage.SearchAndReplaceAscii("$column$",pField->GetName());
|
|
OSQLWarningBox aMsg( getView(), aMessage, WB_YES_NO | WB_DEF_YES );
|
|
if ( aMsg.Execute() != RET_YES )
|
|
{
|
|
Reference<XPropertySet> xNewColumn(xIdxColumns->getByIndex(nPos),UNO_QUERY_THROW);
|
|
::rtl::OUString sName;
|
|
xNewColumn->getPropertyValue(PROPERTY_NAME) >>= sName;
|
|
aColumns[sName] = sal_True;
|
|
aColumns[pField->GetName()] = sal_True;
|
|
continue;
|
|
}
|
|
}
|
|
else
|
|
throw;
|
|
}
|
|
}
|
|
else
|
|
bReload = sal_True;
|
|
}
|
|
// second drop all columns which could be found by name
|
|
Reference<XNameAccess> xKeyColumns = getKeyColumns();
|
|
// now we have to look for the columns who could be deleted
|
|
if ( xDrop.is() )
|
|
{
|
|
Sequence< ::rtl::OUString> aColumnNames = xColumns->getElementNames();
|
|
const ::rtl::OUString* pIter = aColumnNames.getConstArray();
|
|
const ::rtl::OUString* pEnd = pIter + aColumnNames.getLength();
|
|
for(;pIter != pEnd;++pIter)
|
|
{
|
|
if(aColumns.find(*pIter) == aColumns.end()) // found a column to delete
|
|
{
|
|
if(xKeyColumns.is() && xKeyColumns->hasByName(*pIter)) // check if this column is a member of the primary key
|
|
{
|
|
String aMsgT(ModuleRes(STR_TBL_COLUMN_IS_KEYCOLUMN));
|
|
aMsgT.SearchAndReplaceAscii("$column$",*pIter);
|
|
String aTitle(ModuleRes(STR_TBL_COLUMN_IS_KEYCOLUMN_TITLE));
|
|
OSQLMessageBox aMsg(getView(),aTitle,aMsgT,WB_YES_NO| WB_DEF_YES);
|
|
if(aMsg.Execute() == RET_YES)
|
|
{
|
|
xKeyColumns = NULL;
|
|
dropPrimaryKey();
|
|
}
|
|
else
|
|
{
|
|
bReload = sal_True;
|
|
continue;
|
|
}
|
|
}
|
|
try
|
|
{
|
|
xDrop->dropByName(*pIter);
|
|
}
|
|
catch (const SQLException&)
|
|
{
|
|
String sError( ModuleRes( STR_TABLEDESIGN_COULD_NOT_DROP_COL ) );
|
|
sError.SearchAndReplaceAscii( "$column$", *pIter );
|
|
|
|
SQLException aNewException;
|
|
aNewException.Message = sError;
|
|
aNewException.SQLState = ::rtl::OUString::createFromAscii( "S1000" );
|
|
aNewException.NextException = ::cppu::getCaughtException();
|
|
|
|
throw aNewException;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
// third append the new columns
|
|
aIter = m_vRowList.begin();
|
|
for(;aIter != m_vRowList.end();++aIter)
|
|
{
|
|
OSL_ENSURE(*aIter,"OTableRow is null!");
|
|
OFieldDescription* pField = (*aIter)->GetActFieldDescr();
|
|
if ( !pField || (*aIter)->IsReadOnly() || aColumns.find(pField->GetName()) != aColumns.end() )
|
|
continue;
|
|
|
|
Reference<XPropertySet> xColumn;
|
|
if(!xColumns->hasByName(pField->GetName()))
|
|
{
|
|
if(xColumnFactory.is() && xAppend.is())
|
|
{// column not found by its name so we assume it is new
|
|
// Column is new
|
|
xColumn = xColumnFactory->createDataDescriptor();
|
|
::dbaui::setColumnProperties(xColumn,pField);
|
|
xAppend->appendByDescriptor(xColumn);
|
|
if(xColumns->hasByName(pField->GetName()))
|
|
{ // ask for the append by name
|
|
aColumns[pField->GetName()] = sal_True;
|
|
xColumns->getByName(pField->GetName()) >>= xColumn;
|
|
if(xColumn.is())
|
|
pField->copyColumnSettingsTo(xColumn);
|
|
}
|
|
else
|
|
{
|
|
OSL_ENSURE(sal_False, "OTableController::alterColumns: invalid column!");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
// check if we have to do something with the primary key
|
|
sal_Bool bNeedDropKey = sal_False;
|
|
sal_Bool bNeedAppendKey = sal_False;
|
|
if ( xKeyColumns.is() )
|
|
{
|
|
aIter = m_vRowList.begin();
|
|
for(;aIter != m_vRowList.end();++aIter)
|
|
{
|
|
OSL_ENSURE(*aIter,"OTableRow is null!");
|
|
OFieldDescription* pField = (*aIter)->GetActFieldDescr();
|
|
if ( !pField )
|
|
continue;
|
|
|
|
if ( pField->IsPrimaryKey()
|
|
&& !xKeyColumns->hasByName( pField->GetName() )
|
|
)
|
|
{ // new primary key column inserted which isn't already in the columns selection
|
|
bNeedDropKey = bNeedAppendKey = sal_True;
|
|
break;
|
|
}
|
|
else if ( !pField->IsPrimaryKey()
|
|
&& xKeyColumns->hasByName( pField->GetName() )
|
|
)
|
|
{ // found a column which currently is in the primary key, but is marked not to be anymore
|
|
bNeedDropKey = bNeedAppendKey = sal_True;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{ // no primary key available so we check if we should create one
|
|
bNeedAppendKey = sal_True;
|
|
}
|
|
|
|
if ( bNeedDropKey )
|
|
dropPrimaryKey();
|
|
|
|
if ( bNeedAppendKey )
|
|
{
|
|
Reference< XKeysSupplier > xKeySup( m_xTable, UNO_QUERY );
|
|
appendPrimaryKey( xKeySup ,sal_False);
|
|
}
|
|
|
|
reSyncRows();
|
|
|
|
if ( bReload )
|
|
reload();
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
void OTableController::dropPrimaryKey()
|
|
{
|
|
try
|
|
{
|
|
Reference<XKeysSupplier> xKeySup(m_xTable,UNO_QUERY);
|
|
Reference<XIndexAccess> xKeys;
|
|
if(xKeySup.is())
|
|
xKeys = xKeySup->getKeys();
|
|
|
|
if(xKeys.is())
|
|
{
|
|
Reference<XPropertySet> xProp;
|
|
for(sal_Int32 i=0;i< xKeys->getCount();++i)
|
|
{
|
|
xProp.set(xKeys->getByIndex(i),UNO_QUERY);
|
|
sal_Int32 nKeyType = 0;
|
|
xProp->getPropertyValue(PROPERTY_TYPE) >>= nKeyType;
|
|
if(KeyType::PRIMARY == nKeyType)
|
|
{
|
|
Reference<XDrop> xDrop(xKeys,UNO_QUERY);
|
|
xDrop->dropByIndex(i); // delete the key
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
catch( const Exception& )
|
|
{
|
|
DBG_UNHANDLED_EXCEPTION();
|
|
}
|
|
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
void OTableController::assignTable()
|
|
{
|
|
::rtl::OUString sComposedName;
|
|
// get the table
|
|
if(m_sName.getLength())
|
|
{
|
|
Reference<XNameAccess> xNameAccess;
|
|
Reference<XTablesSupplier> xSup(getConnection(),UNO_QUERY);
|
|
if(xSup.is())
|
|
{
|
|
xNameAccess = xSup->getTables();
|
|
OSL_ENSURE(xNameAccess.is(),"no nameaccess for the queries!");
|
|
|
|
Reference<XPropertySet> xProp;
|
|
if(xNameAccess->hasByName(m_sName) && ::cppu::extractInterface(xProp,xNameAccess->getByName(m_sName)) && xProp.is())
|
|
{
|
|
m_xTable = xProp;
|
|
startTableListening();
|
|
|
|
// check if we set the table editable
|
|
Reference<XDatabaseMetaData> xMeta = getConnection()->getMetaData();
|
|
setEditable( xMeta.is() && !xMeta->isReadOnly() && (isAlterAllowed() || isDropAllowed() || isAddAllowed()) );
|
|
if(!isEditable())
|
|
{
|
|
::std::vector< ::boost::shared_ptr<OTableRow> >::iterator aIter = m_vRowList.begin();
|
|
for(; aIter != m_vRowList.end(); ++aIter)
|
|
(*aIter)->SetReadOnly(sal_True);
|
|
}
|
|
m_bNew = sal_False;
|
|
// be notified when the table is in disposing
|
|
InvalidateAll();
|
|
}
|
|
}
|
|
}
|
|
//updateTitle();
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
sal_Bool OTableController::isAddAllowed() const
|
|
{
|
|
Reference<XColumnsSupplier> xColsSup(m_xTable,UNO_QUERY);
|
|
sal_Bool bAddAllowed = !m_xTable.is();
|
|
if(xColsSup.is())
|
|
bAddAllowed = Reference<XAppend>(xColsSup->getColumns(),UNO_QUERY).is();
|
|
|
|
try
|
|
{
|
|
Reference< XDatabaseMetaData > xMetaData = getMetaData( );
|
|
bAddAllowed = bAddAllowed || ( xMetaData.is() && xMetaData->supportsAlterTableWithAddColumn());
|
|
}
|
|
catch(Exception&)
|
|
{
|
|
DBG_UNHANDLED_EXCEPTION();
|
|
bAddAllowed = sal_False;
|
|
}
|
|
|
|
return bAddAllowed;
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
sal_Bool OTableController::isDropAllowed() const
|
|
{
|
|
Reference<XColumnsSupplier> xColsSup(m_xTable,UNO_QUERY);
|
|
sal_Bool bDropAllowed = !m_xTable.is();
|
|
if(xColsSup.is())
|
|
{
|
|
Reference<XNameAccess> xNameAccess = xColsSup->getColumns();
|
|
bDropAllowed = Reference<XDrop>(xNameAccess,UNO_QUERY).is() && xNameAccess->hasElements();
|
|
}
|
|
|
|
Reference< XDatabaseMetaData> xMetaData = getMetaData( );
|
|
bDropAllowed = bDropAllowed || ( xMetaData.is() && xMetaData->supportsAlterTableWithDropColumn());
|
|
|
|
return bDropAllowed;
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
sal_Bool OTableController::isAlterAllowed() const
|
|
{
|
|
sal_Bool bAllowed(!m_xTable.is() || Reference<XAlterTable>(m_xTable,UNO_QUERY).is());
|
|
return bAllowed;
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
void OTableController::reSyncRows()
|
|
{
|
|
sal_Bool bAlterAllowed = isAlterAllowed();
|
|
sal_Bool bAddAllowed = isAddAllowed();
|
|
::std::vector< ::boost::shared_ptr<OTableRow> >::iterator aIter = m_vRowList.begin();
|
|
for(;aIter != m_vRowList.end();++aIter)
|
|
{
|
|
OSL_ENSURE(*aIter,"OTableRow is null!");
|
|
OFieldDescription* pField = (*aIter)->GetActFieldDescr();
|
|
if ( pField )
|
|
(*aIter)->SetReadOnly(!bAlterAllowed);
|
|
else
|
|
(*aIter)->SetReadOnly(!bAddAllowed);
|
|
|
|
}
|
|
static_cast<OTableDesignView*>(getView())->reSync(); // show the windows and fill with our informations
|
|
|
|
getUndoMgr()->Clear(); // clear all undo redo things
|
|
setModified(sal_False); // and we are not modified yet
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
::rtl::OUString OTableController::createUniqueName(const ::rtl::OUString& _rName)
|
|
{
|
|
::rtl::OUString sName = _rName;
|
|
Reference< XDatabaseMetaData> xMetaData = getMetaData( );
|
|
|
|
::comphelper::UStringMixEqual bCase(xMetaData.is() ? xMetaData->supportsMixedCaseQuotedIdentifiers() : sal_True);
|
|
|
|
::std::vector< ::boost::shared_ptr<OTableRow> >::const_iterator aIter = m_vRowList.begin();
|
|
for(sal_Int32 i=0;aIter != m_vRowList.end();++aIter)
|
|
{
|
|
OFieldDescription* pFieldDesc = (*aIter)->GetActFieldDescr();
|
|
if (pFieldDesc && pFieldDesc->GetName().getLength() && bCase(sName,pFieldDesc->GetName()))
|
|
{ // found a second name of _rName so we need another
|
|
sName = _rName + ::rtl::OUString::valueOf(++i);
|
|
aIter = m_vRowList.begin(); // and retry
|
|
}
|
|
}
|
|
return sName;
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
::rtl::OUString OTableController::getPrivateTitle() const
|
|
{
|
|
::rtl::OUString sTitle;
|
|
try
|
|
{
|
|
// get the table
|
|
if ( m_sName.getLength() && getConnection().is() )
|
|
{
|
|
if ( m_xTable.is() )
|
|
sTitle = ::dbtools::composeTableName( getConnection()->getMetaData(), m_xTable, ::dbtools::eInDataManipulation, false, false, false );
|
|
else
|
|
sTitle = m_sName;
|
|
}
|
|
if ( !sTitle.getLength() )
|
|
{
|
|
String aName = String(ModuleRes(STR_TBL_TITLE));
|
|
sTitle = aName.GetToken(0,' ');
|
|
sTitle += ::rtl::OUString::valueOf(getCurrentStartNumber());
|
|
}
|
|
}
|
|
catch( const Exception& )
|
|
{
|
|
DBG_UNHANDLED_EXCEPTION();
|
|
}
|
|
return sTitle;
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
void OTableController::reload()
|
|
{
|
|
loadData(); // fill the column information form the table
|
|
static_cast<OTableDesignView*>(getView())->reSync(); // show the windows and fill with our informations
|
|
getUndoMgr()->Clear(); // clear all undo redo things
|
|
setModified(sal_False); // and we are not modified yet
|
|
static_cast<OTableDesignView*>(getView())->Invalidate();
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
sal_Int32 OTableController::getFirstEmptyRowPosition() const
|
|
{
|
|
sal_Int32 nRet = -1;
|
|
::std::vector< ::boost::shared_ptr<OTableRow> >::const_iterator aIter = m_vRowList.begin();
|
|
::std::vector< ::boost::shared_ptr<OTableRow> >::const_iterator aEnd = m_vRowList.end();
|
|
for(;aIter != aEnd;++aIter)
|
|
{
|
|
if ( !*aIter || !(*aIter)->GetActFieldDescr() || !(*aIter)->GetActFieldDescr()->GetName().getLength() )
|
|
{
|
|
nRet = aIter - m_vRowList.begin();
|
|
break;
|
|
}
|
|
}
|
|
return nRet;
|
|
}
|
|
// -----------------------------------------------------------------------------
|
|
bool OTableController::isAutoIncrementPrimaryKey() const
|
|
{
|
|
::dbaccess::DATASOURCE_TYPE eType = m_aTypeCollection.getType(::comphelper::getString(getDataSource()->getPropertyValue(PROPERTY_URL)));
|
|
DataSourceMetaData aMeta(eType);
|
|
return aMeta.getAdvancedSettingsSupport().bAutoIncrementIsPrimaryKey;
|
|
}
|
|
// -----------------------------------------------------------------------------
|