[ooo-build-commit] .: 3 commits - patches/dev300
René Engelhard
rene at kemper.freedesktop.org
Tue Apr 6 09:57:32 PDT 2010
patches/dev300/apply | 5
patches/dev300/cws-linuxaxp01.diff | 18
patches/dev300/layout-post-cws-layoutdialogs2-mysteriously-missing.diff | 12
patches/dev300/novell-win32-odma-m12.diff | 2501 ++++++++++
patches/dev300/novell-win32-odma.diff | 2
5 files changed, 2528 insertions(+), 10 deletions(-)
New commits:
commit 68a69e97766d9f19fca2e83917f3a8031be6b313
Author: Rene Engelhard <rene at debian.org>
Date: Tue Apr 6 18:56:02 2010 +0200
fix patch.apply on m12 again
* patches/dev300/apply: add missing [ VBAObjects ]
diff --git a/patches/dev300/apply b/patches/dev300/apply
index ad5f9b6..099e9a2 100644
--- a/patches/dev300/apply
+++ b/patches/dev300/apply
@@ -1805,6 +1805,7 @@ cws-vbasupportdev300-m13.diff
[ VBAObjects >= ooo320-m14 ]
cws-vbasupportdev300.diff
+[ VBAObjects ]
eventhelper-closecrash-fix.diff, n#438606, i#106270
# make sure no vba libraries are loaded ( if not filtering )
vba-dont-load-for-odf.diff
commit b80c39da5d62be3e480350a28284c2681f357991
Author: Rene Engelhard <rene at debian.org>
Date: Tue Apr 6 18:30:30 2010 +0200
more ooo320-m14 updates
* patches/dev300/novell-win32-odma-m12.diff: rotate
* patches/dev300/novell-win32-odma.diff: update
* patches/dev300/apply: adapt
* patches/dev300/layout-post-cws-layoutdialogs2-mysteriously-missing.diff: update to apply
diff --git a/patches/dev300/apply b/patches/dev300/apply
index f8299f1..ad5f9b6 100644
--- a/patches/dev300/apply
+++ b/patches/dev300/apply
@@ -2773,7 +2773,9 @@ SectionOwner => jholesov
# disable automatic spellchecking by default
reduced-disable-auto-spellcheck.diff
-[ Features ]
+[ Features < ooo320-m13 ]
+novell-win32-odma-m12.diff, i#6885, i#32741, tml
+[ Features >= ooo320-m13 ]
novell-win32-odma.diff, i#6885, i#32741, tml
[ VOSremoval ]
diff --git a/patches/dev300/layout-post-cws-layoutdialogs2-mysteriously-missing.diff b/patches/dev300/layout-post-cws-layoutdialogs2-mysteriously-missing.diff
index 69cb323..6a49d75 100644
--- a/patches/dev300/layout-post-cws-layoutdialogs2-mysteriously-missing.diff
+++ b/patches/dev300/layout-post-cws-layoutdialogs2-mysteriously-missing.diff
@@ -18,13 +18,13 @@ index 9e34ed4..0b919fe 100644
--- sc/prj/build.lst
+++ sc/prj/build.lst
@@ -1,6 +1,7 @@
- sc sc : l10n oovbaapi svx stoc uui BOOST:boost formula oox NULL
- sc sc usr1 - all sc_mkout NULL
- sc sc\inc nmake - all sc_inc NULL
+ sc sc : l10n vbahelper oovbaapi svx stoc uui BOOST:boost formula oox NULL
+ sc sc usr1 - all sc_mkout NULL
+ sc sc\inc nmake - all sc_inc NULL
+sc sc\uiconfig\layout nmake - all sc_layout NULL
- sc sc\prj get - all sc_prj NULL
- sc sc\res get - all sc_res NULL
- sc sc\res\imglst\inputwin get - all sc_resiw NULL
+ sc sc\prj get - all sc_prj NULL
+ sc sc\res get - all sc_res NULL
+ sc sc\res\imglst\inputwin get - all sc_resiw NULL
diff --git svx/uiconfig/layout/find-and-replace.xml svx/uiconfig/layout/find-and-replace.xml
new file mode 100644
index 0000000..771ffb9
diff --git a/patches/dev300/novell-win32-odma-m12.diff b/patches/dev300/novell-win32-odma-m12.diff
new file mode 100644
index 0000000..a3d5299
--- /dev/null
+++ b/patches/dev300/novell-win32-odma-m12.diff
@@ -0,0 +1,2501 @@
+--- ucb/prj/build.lst.old 2010-03-03 16:59:55.000000000 +0100
++++ ucb/prj/build.lst 2010-03-03 16:59:55.000000000 +0100
+@@ -14,3 +14,4 @@ uc ucb\source\ucp\webdav nmake - all uc
+ uc ucb\source\ucp\package nmake - all uc_package uc_inc NULL
+ uc ucb\source\ucp\tdoc nmake - all uc_tdoc uc_inc NULL
+ uc ucb\source\ucp\expand nmake - all uc_expand uc_inc NULL
++uc ucb\source\ucp\odma nmake - w uc_odma uc_inc NULL
+--- ucb/prj/d.lst.old 2009-10-07 15:07:04.000000000 +0200
++++ ucb/prj/d.lst 2010-03-03 16:59:55.000000000 +0100
+@@ -23,6 +23,11 @@
+ ..\%__SRC%\lib\ucp*.uno.dylib %_DEST%\lib%_EXT%\ucp*.uno.dylib
+ ..\%__SRC%\misc\ucp*.map %_DEST%\bin%_EXT%\ucp*.map
+ ..\%__SRC%\misc\ucp*.sym %_DEST%\bin%_EXT%\ucp*.sym
++
++..\%__SRC%\slb\odma_lib.lib %_DEST%\lib%_EXT%\odma_lib.lib
++..\source\ucp\odma\odma.h %_DEST%\inc%_EXT%\odma.h
++..\source\ucp\odma\odma_lib.hxx %_DEST%\inc%_EXT%\odma_lib.hxx
++
+ ..\source\ucp\file\ucpfile.xml %_DEST%\xml%_EXT%\ucpfile.xml
+ ..\source\ucp\ftp\ucpftp.xml %_DEST%\xml%_EXT%\ucpftp.xml
+ ..\source\ucp\hierarchy\ucphier.xml %_DEST%\xml%_EXT%\ucphier.xml
+--- ucb/source/ucp/odma/makefile.mk.old 2009-10-07 15:07:04.000000000 +0200
++++ ucb/source/ucp/odma/makefile.mk 2010-03-03 16:59:55.000000000 +0100
+@@ -51,7 +51,7 @@ LIBTARGET=NO
+
+ # --- General -----------------------------------------------------
+
+-SLOFILES=\
++SLO1FILES=\
+ $(SLO)$/odma_lib.obj \
+ $(SLO)$/odma_services.obj \
+ $(SLO)$/odma_provider.obj \
+@@ -62,7 +62,7 @@ SLOFILES=\
+ $(SLO)$/odma_contentcaps.obj
+
+ LIB1TARGET=$(SLB)$/_$(TARGET).lib
+-LIB1OBJFILES=$(SLOFILES)
++LIB1OBJFILES=$(SLO1FILES)
+
+ # --- Shared-Library ---------------------------------------------------
+
+@@ -95,6 +95,13 @@ APP2STDLIBS=$(SALLIB) \
+
+ DEF2DES=UCB ODMA URL converter
+
++# --- odma_lib library -----------------------------------------------
++
++SLO3FILES=$(SLO)$/odma_lib.obj
++
++LIB3TARGET=$(SLB)$/odma_lib.lib
++LIB3OBJFILES=$(SLO3FILES)
++
+ # --- Targets ----------------------------------------------------------
+
+ .INCLUDE: target.mk
+--- ucb/source/ucp/odma/odma_content.cxx.old 2009-10-07 15:07:04.000000000 +0200
++++ ucb/source/ucp/odma/odma_content.cxx 2010-03-03 16:59:55.000000000 +0100
+@@ -474,6 +474,12 @@ uno::Any SAL_CALL Content::execute(
+ }
+ else if( ! aCommand.Name.compareToAscii( "transfer" ) )
+ {
++ // So far I have determined that this command is called when
++ // doing "Save As" to copy an already written backup copy of
++ // the document in the file system into the DMS.
++
++ // Maybe also in other situations.
++
+ ucb::TransferInfo aTransferInfo;
+ if( ! ( aCommand.Argument >>= aTransferInfo ) )
+ {
+@@ -489,84 +495,21 @@ uno::Any SAL_CALL Content::execute(
+ ::rtl::Reference<ContentProperties> aProp = m_aProps;
+ if(aProp->m_bIsFolder)
+ {
+- aProp = getContentProvider()->getContentPropertyWithTitle(aTransferInfo.NewTitle);
++ aProp = getContentProvider()->getContentPropertyWithDocumentId(aTransferInfo.NewTitle);
+ if(!aProp.is())
+ aProp = getContentProvider()->getContentPropertyWithSavedAsName(aTransferInfo.NewTitle);
+ sal_Bool bError = !aProp.is();
+- if(bError)
+- {
+- sal_Char* pExtension = NULL;
+- ::rtl::OString sExt;
+- sal_Int32 nPos = aTransferInfo.NewTitle.lastIndexOf('.');
+- if(nPos != -1)
+- {
+- sExt = ::rtl::OUStringToOString(aTransferInfo.NewTitle.copy(nPos+1),RTL_TEXTENCODING_ASCII_US);
+- if(sExt.equalsIgnoreAsciiCase("txt"))
+- pExtension = ODM_FORMAT_TEXT;
+- else if(sExt.equalsIgnoreAsciiCase("rtf"))
+- pExtension = ODM_FORMAT_RTF;
+- else if(sExt.equalsIgnoreAsciiCase("ps"))
+- pExtension = ODM_FORMAT_PS;
+- else
+- pExtension = const_cast<sal_Char*>(sExt.getStr());
+- }
+- else
+- pExtension = ODM_FORMAT_TEXT;
+-
+- sal_Char* lpszNewDocId = new sal_Char[ODM_DOCID_MAX];
+- void *pData = NULL;
+- DWORD dwFlags = ODM_SILENT;
+- ODMSTATUS odm = NODMSaveAsEx(ContentProvider::getHandle(),
+- NULL, // means it is saved the first time
+- lpszNewDocId,
+- pExtension,
+- NULL, // no callback function here
+- pData,
+- &dwFlags);
+
+- // check if we have to call the DMS dialog
+- if(odm == ODM_E_USERINT)
+- {
+- dwFlags = 0;
+- odm = NODMSaveAsEx(ContentProvider::getHandle(),
+- NULL, // means it is saved the first time
+- lpszNewDocId,
+- pExtension,
+- NULL, // no callback function here
+- pData,
+- &dwFlags);
+- }
+- bError = odm != ODM_SUCCESS;
+- if(!bError)
+- {
+- aProp = new ContentProperties();
+- aProp->m_sDocumentId = ::rtl::OString(lpszNewDocId);
+- aProp->m_sContentType = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM(ODMA_CONTENT_TYPE));
+- aProp->m_sSavedAsName = aTransferInfo.NewTitle;
+- getContentProvider()->append(aProp);
++ // There used to be code below that called ODMSaveAsEx,
++ // but that was very broken. We have already called
++ // ODMSaveAsEx in the ODMA file picker when selecting the
++ // name for a new document, or the document already exists
++ // in the DMS and we don't need any ODMSaveAsEx. The ODMA
++ // file picker tells odma::ContentProvider about the new
++ // document's DOCID, so the
++ // getContentPropertyWithDocumentId() call above should
++ // succeed.
+
+- // now set the title
+- WORD nDocInfo = ODM_NAME;
+- ::rtl::OUString sFileName = aTransferInfo.NewTitle;
+- sal_Int32 nIndex = aTransferInfo.NewTitle.lastIndexOf( sal_Unicode('.') );
+- if(nIndex != -1)
+- sFileName = aTransferInfo.NewTitle.copy(0,nIndex);
+-
+- ::rtl::OString sDocInfoValue = ::rtl::OUStringToOString(sFileName,RTL_TEXTENCODING_ASCII_US);
+- odm = NODMSetDocInfo( ContentProvider::getHandle(),
+- lpszNewDocId,
+- nDocInfo,
+- const_cast<sal_Char*>(sDocInfoValue.getStr())
+- );
+-
+- }
+- else if ( odm == ODM_E_CANCEL)
+- NODMActivate(ContentProvider::getHandle(),
+- ODM_DELETE,
+- lpszNewDocId);
+-
+- delete lpszNewDocId;
+- }
+ if(bError)
+ ucbhelper::cancelCommandExecution(
+ uno::makeAny( lang::IllegalArgumentException(
+@@ -578,12 +521,23 @@ uno::Any SAL_CALL Content::execute(
+ rtl::OUString sFileURL = ContentProvider::openDoc(aProp);
+
+ sal_Int32 nLastIndex = sFileURL.lastIndexOf( sal_Unicode('/') );
++ // Create a new Content object for the "shadow" file
++ // corresponding to the opened document from the DMS.
+ ::ucbhelper::Content aContent(sFileURL.copy(0,nLastIndex),NULL);
+ // aTransferInfo.NameClash = ucb::NameClash::OVERWRITE;
+ aTransferInfo.NewTitle = sFileURL.copy( 1 + nLastIndex );
++ // Copy our saved backup copy to the "shadow" file.
+ aContent.executeCommand(::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("transfer")),uno::makeAny(aTransferInfo));
++ // Tell the DMS that the "shadow" file is done and can be
++ // imported.
+ getContentProvider()->saveDocument(aProp->m_sDocumentId);
+ }
++ else if ( aCommand.Name.equalsAsciiL(
++ RTL_CONSTASCII_STRINGPARAM( "getCasePreservingURL" ) ) )
++ {
++ rtl::OUString CasePreservingURL = openDoc();
++ aRet <<= CasePreservingURL;
++ }
+ else
+ {
+ //////////////////////////////////////////////////////////////////
+--- ucb/source/ucp/odma/odma_content.hxx.old 2009-10-07 15:07:04.000000000 +0200
++++ ucb/source/ucp/odma/odma_content.hxx 2010-03-03 16:59:55.000000000 +0100
+@@ -62,7 +62,7 @@ namespace odma
+
+ // UNO service name for the content.
+ #define ODMA_CONTENT_SERVICE_NAME \
+- "com.sun.star.ucb.OdmaContent"
++ "com.sun.star.ucb.ODMAContent"
+
+ //=========================================================================
+ class ContentProvider;
+--- ucb/source/ucp/odma/odma_contentprops.hxx.old 2009-10-07 15:07:04.000000000 +0200
++++ ucb/source/ucp/odma/odma_contentprops.hxx 2010-03-03 16:59:55.000000000 +0100
+@@ -67,6 +67,7 @@ namespace odma
+ {}
+
+ inline ::rtl::OUString getTitle() const { return m_sTitle; }
++ inline ::rtl::OUString getDocumentId() const { return ::rtl::OStringToOUString( m_sDocumentId, RTL_TEXTENCODING_ASCII_US ); }
+ inline ::rtl::OUString getSavedAsName() const { return m_sSavedAsName; }
+ };
+ typedef ::std::binary_function< ::rtl::Reference<ContentProperties>, ::rtl::OUString,bool> TContentPropertiesFunctorBase;
+--- ucb/source/ucp/odma/odma_datasupplier.cxx.old 2009-10-07 15:07:04.000000000 +0200
++++ ucb/source/ucp/odma/odma_datasupplier.cxx 2010-03-03 16:59:55.000000000 +0100
+@@ -44,7 +44,6 @@
+ #include "odma_content.hxx"
+ #include "odma_contentprops.hxx"
+ #include "odma_provider.hxx"
+-#include "odma_lib.hxx"
+
+ using namespace com::sun::star::beans;
+ using namespace com::sun::star::lang;
+@@ -287,7 +286,7 @@ sal_Bool DataSupplier::getResult( sal_uI
+ ODMSTATUS odm = NODMGetDMS(ODMA_ODMA_REGNAME, lpszDMSList);
+ lpszDMSList[strlen(lpszDMSList)+1] = '\0';
+
+- ::rtl::OString sQuery("SELECT ODM_DOCID, ODM_NAME");
++ ::rtl::OString sQuery("SELECT ODM_DOCID_LATEST, ODM_NAME");
+
+ DWORD dwFlags = ODM_SPECIFIC;
+ odm = NODMQueryExecute(ContentProvider::getHandle(), sQuery,dwFlags, lpszDMSList, pQueryId );
+--- ucb/source/ucp/odma/odma_lib.cxx.old 2009-10-07 15:07:04.000000000 +0200
++++ ucb/source/ucp/odma/odma_lib.cxx 2010-03-03 16:59:55.000000000 +0100
+@@ -35,6 +35,8 @@
+ //#endif
+ #include <osl/module.h>
+ #include <rtl/ustring.hxx>
++#include <tools/prewin.h>
++#include <tools/postwin.h>
+ #include "odma_lib.hxx"
+
+
+@@ -73,17 +75,18 @@ namespace odma
+
+ sal_Bool LoadFunctions(oslModule _pODMA);
+
+- sal_Bool LoadLibrary()
++ sal_Bool DMSsAvailable()
+ {
+ static sal_Bool bLoaded = sal_False;
+- static oslModule pODMA = NULL;
++ static sal_Bool bBeenHere = sal_False;
++ oslModule pODMA = NULL;
+
+- if (bLoaded)
+- return sal_True;
++ if (bBeenHere)
++ return bLoaded;
++
+ ::rtl::OUString sPath;
+ #ifdef WIN
+ sPath = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("ODMA.DLL"));
+-
+ #endif
+ #ifdef WNT
+ sPath = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("ODMA32.DLL"));
+@@ -92,11 +95,21 @@ namespace odma
+ sPath = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("libodma.so"));
+ #endif
+
++ bBeenHere = sal_True;
++
+ pODMA = osl_loadModule( sPath.pData,SAL_LOADMODULE_NOW );
+ if( !pODMA)
+ return sal_False;
+
+- return bLoaded = LoadFunctions(pODMA);
++ if (!LoadFunctions(pODMA))
++ return sal_False;
++
++ bLoaded = (NODMGetDMSCount() > 0);
++
++ if (getenv ("NO_ODMA"))
++ bLoaded = sal_False;
++
++ return bLoaded;
+ }
+ // -------------------------------------------------------------------------
+
+--- ucb/source/ucp/odma/odma_lib.hxx.old 2009-10-07 15:07:04.000000000 +0200
++++ ucb/source/ucp/odma/odma_lib.hxx 2010-03-03 16:59:55.000000000 +0100
+@@ -30,19 +30,7 @@
+ #ifndef ODMA_LIB_HXX
+ #define ODMA_LIB_HXX
+
+-typedef void *LPVOID;
+-typedef char *LPSTR,
+- *PSTR;
+-typedef const char *LPCSTR;
+-typedef unsigned long DWORD;
+-typedef unsigned short WORD;
+-typedef unsigned short *LPWORD;
+-typedef DWORD *LPDWORD;
+-
+-#define WINAPI __stdcall
+-#define FAR
+-
+-#include "odma.h"
++#include <odma.h>
+
+ namespace odma
+ {
+@@ -208,37 +196,37 @@ namespace odma
+
+ // now we define some macros
+
+- #define NODMRegisterApp(a,b,c,d,e) (*(pODMRegisterApp))(a,b,c,d,e)
+- #define NODMUnRegisterApp(a) (*(pODMUnRegisterApp))(a)
+- #define NODMSelectDoc(a,b,c) (*(pODMSelectDoc))(a,b,c)
+- #define NODMOpenDoc(a,b,c,d) (*(pODMOpenDoc))(a,b,c,d)
+- #define NODMSaveDoc(a,b,c) (*(pODMSaveDoc))(a,b,c)
+- #define NODMCloseDoc(a,b,c,d,e,f) (*(pODMCloseDoc))(a,b,c,d,e,f)
+- #define NODMNewDoc(a,b,c,d,e) (*(pODMNewDoc))(a,b,c,d,e)
+- #define NODMSaveAs(a,b,c,d,e,f) (*(pODMSaveAs))(a,b,c,d,e,f)
+- #define NODMActivate(a,b,c) (*(pODMActivate))(a,b,c)
+- #define NODMGetDocInfo(a,b,c,d,e) (*(pODMGetDocInfo))(a,b,c,d,e)
+- #define NODMSetDocInfo(a,b,c,d) (*(pODMSetDocInfo))(a,b,c,d)
+- #define NODMGetDMSInfo(a,b,c,d) (*(pODMGetDMSInfo))(a,b,c,d)
+- #define NODMGetDMSCount() (*(pODMGetDMSCount))()
+- #define NODMGetDMSList(a,b) (*(pODMGetDMSList))(a,b)
+- #define NODMGetDMS(a,b) (*(pODMGetDMS))(a,b)
+- #define NODMSetDMS(a,b) (*(pODMSetDMS))(a,b)
+- #define NODMQueryExecute(a,b,c,d,e) (*(pODMQueryExecute))(a,b,c,d,e)
+- #define NODMQueryGetResults(a,b,c,d,e,f) (*(pODMQueryGetResults))(a,b,c,d,e,f)
+- #define NODMQueryClose(a,b) (*(pODMQueryClose))(a,b)
+- #define NODMCloseDocEx(a,b,c,d,e,f,g) (*(pODMCloseDocEx))(a,b,c,d,e,f,g)
+- #define NODMSaveAsEx(a,b,c,d,e,f,g) (*(pODMSaveAsEx))(a,b,c,d,e,f,g)
+- #define NODMSaveDocEx(a,b,c,d) (*(pODMSaveDocEx))(a,b,c,d)
+- #define NODMSelectDocEx(a,b,c,d,e,f) (*(pODMSelectDocEx))(a,b,c,d,e,f)
+- #define NODMQueryCapability(a,b,c,d,e) (*(pODMQueryCapability))(a,b,c,d,e)
+- #define NODMSetDocEvent(a,b,c,d,e,f,g) (*(pODMSetDocEvent))(a,b,c,d,e,f,g)
+- #define NODMGetAlternateContent(a,b,c,d,e) (*(pODMGetAlternateContent))(a,b,c,d,e)
+- #define NODMSetAlternateContent(a,b,c,d,e) (*(pODMSetAlternateContent))(a,b,c,d,e)
+- #define NODMGetDocRelation(a,b,c,d,e,f) (*(pODMGetDocRelation))(a,b,c,d,e,f)
+- #define NODMSetDocRelation(a,b,c,d,e,f) (*(pODMSetDocRelation))(a,b,c,d,e,f)
++ #define NODMRegisterApp(a,b,c,d,e) (*(::odma::pODMRegisterApp))(a,b,c,d,e)
++ #define NODMUnRegisterApp(a) (*(::odma::pODMUnRegisterApp))(a)
++ #define NODMSelectDoc(a,b,c) (*(::odma::pODMSelectDoc))(a,b,c)
++ #define NODMOpenDoc(a,b,c,d) (*(::odma::pODMOpenDoc))(a,b,c,d)
++ #define NODMSaveDoc(a,b,c) (*(::odma::pODMSaveDoc))(a,b,c)
++ #define NODMCloseDoc(a,b,c,d,e,f) (*(::odma::pODMCloseDoc))(a,b,c,d,e,f)
++ #define NODMNewDoc(a,b,c,d,e) (*(::odma::pODMNewDoc))(a,b,c,d,e)
++ #define NODMSaveAs(a,b,c,d,e,f) (*(::odma::pODMSaveAs))(a,b,c,d,e,f)
++ #define NODMActivate(a,b,c) (*(::odma::pODMActivate))(a,b,c)
++ #define NODMGetDocInfo(a,b,c,d,e) (*(::odma::pODMGetDocInfo))(a,b,c,d,e)
++ #define NODMSetDocInfo(a,b,c,d) (*(::odma::pODMSetDocInfo))(a,b,c,d)
++ #define NODMGetDMSInfo(a,b,c,d) (*(::odma::pODMGetDMSInfo))(a,b,c,d)
++ #define NODMGetDMSCount() (*(::odma::pODMGetDMSCount))()
++ #define NODMGetDMSList(a,b) (*(::odma::pODMGetDMSList))(a,b)
++ #define NODMGetDMS(a,b) (*(::odma::pODMGetDMS))(a,b)
++ #define NODMSetDMS(a,b) (*(::odma::pODMSetDMS))(a,b)
++ #define NODMQueryExecute(a,b,c,d,e) (*(::odma::pODMQueryExecute))(a,b,c,d,e)
++ #define NODMQueryGetResults(a,b,c,d,e,f) (*(::odma::pODMQueryGetResults))(a,b,c,d,e,f)
++ #define NODMQueryClose(a,b) (*(::odma::pODMQueryClose))(a,b)
++ #define NODMCloseDocEx(a,b,c,d,e,f,g) (*(::odma::pODMCloseDocEx))(a,b,c,d,e,f,g)
++ #define NODMSaveAsEx(a,b,c,d,e,f,g) (*(::odma::pODMSaveAsEx))(a,b,c,d,e,f,g)
++ #define NODMSaveDocEx(a,b,c,d) (*(::odma::pODMSaveDocEx))(a,b,c,d)
++ #define NODMSelectDocEx(a,b,c,d,e,f) (*(::odma::pODMSelectDocEx))(a,b,c,d,e,f)
++ #define NODMQueryCapability(a,b,c,d,e) (*(::odma::pODMQueryCapability))(a,b,c,d,e)
++ #define NODMSetDocEvent(a,b,c,d,e,f,g) (*(::odma::pODMSetDocEvent))(a,b,c,d,e,f,g)
++ #define NODMGetAlternateContent(a,b,c,d,e) (*(::odma::pODMGetAlternateContent))(a,b,c,d,e)
++ #define NODMSetAlternateContent(a,b,c,d,e) (*(::odma::pODMSetAlternateContent))(a,b,c,d,e)
++ #define NODMGetDocRelation(a,b,c,d,e,f) (*(::odma::pODMGetDocRelation))(a,b,c,d,e,f)
++ #define NODMSetDocRelation(a,b,c,d,e,f) (*(::odma::pODMSetDocRelation))(a,b,c,d,e,f)
+
+- sal_Bool LoadLibrary();
++ sal_Bool DMSsAvailable();
+
+ extern TODMRegisterApp pODMRegisterApp;
+ extern TODMUnRegisterApp pODMUnRegisterApp;
+--- ucb/source/ucp/odma/odma_provider.cxx.old 2009-10-07 15:07:04.000000000 +0200
++++ ucb/source/ucp/odma/odma_provider.cxx 2010-03-03 16:59:55.000000000 +0100
+@@ -437,7 +437,7 @@ void ContentProvider::append(const ::rtl
+ lpszDMSList[strlen(lpszDMSList)+1] = '\0';
+
+ ::rtl::OString sTitleText(::rtl::OUStringToOString(_sDocumentName,RTL_TEXTENCODING_ASCII_US));
+- ::rtl::OString sQuery("SELECT ODM_DOCID, ODM_NAME WHERE ODM_TITLETEXT = '");
++ ::rtl::OString sQuery("SELECT ODM_DOCID_LATEST, ODM_NAME WHERE ODM_TITLETEXT = '");
+ sQuery += sTitleText;
+ sQuery += "'";
+
+@@ -525,6 +525,12 @@ void ContentProvider::append(const ::rtl
+ return getContentProperty(_sTitle,aFunc);
+ }
+ // -----------------------------------------------------------------------------
++::rtl::Reference<ContentProperties> ContentProvider::getContentPropertyWithDocumentId(const ::rtl::OUString& _sDocumentId) const
++{
++ ContentPropertiesMemberFunctor aFunc(::std::mem_fun(&ContentProperties::getDocumentId));
++ return getContentProperty(_sDocumentId,aFunc);
++}
++// -----------------------------------------------------------------------------
+ ::rtl::OUString ContentProvider::openDoc(const ::rtl::Reference<ContentProperties>& _rProp) throw (uno::Exception)
+ {
+ OSL_ENSURE(_rProp.is(),"No valid content properties!");
+--- ucb/source/ucp/odma/odma_provider.hxx.old 2009-10-07 15:07:04.000000000 +0200
++++ ucb/source/ucp/odma/odma_provider.hxx 2010-03-03 16:59:55.000000000 +0100
+@@ -32,6 +32,8 @@
+ #define ODMA_PROVIDER_HXX
+
+ #include <ucbhelper/providerhelper.hxx>
++#include <tools/prewin.h>
++#include <tools/postwin.h>
+ #include "odma_lib.hxx"
+
+ #include "rtl/ref.hxx"
+@@ -46,7 +48,7 @@ namespace odma {
+ // UNO service name for the provider. This name will be used by the UCB to
+ // create instances of the provider.
+ #define ODMA_CONTENT_PROVIDER_SERVICE_NAME \
+- "com.sun.star.ucb.OdmaContentProvider"
++ "com.sun.star.ucb.ODMAContentProvider"
+ // #define ODMA_CONTENT_PROVIDER_SERVICE_NAME_LENGTH 34
+
+ // URL scheme. This is the scheme the provider will be able to create
+@@ -136,14 +138,21 @@ public:
+ */
+ ::rtl::Reference<ContentProperties> queryContentProperty(const ::rtl::OUString& _sDocumentName);
+
+- /** getContentProperty returns the ContentProperties for the first content with that title
++ /** getContentPropertyWithTitle returns the ContentProperties for the first content with that title
+ @param _sTitle the title of the document
+
+ @return the content properties
+ */
+ ::rtl::Reference<ContentProperties> getContentPropertyWithTitle(const ::rtl::OUString& _sTitle) const;
+
+- /** getContentProperty returns the ContentProperties for the first content with that SavedAsName
++ /** getContentPropertyWithDocumentId returns the ContentProperties for the first content with that title
++ @param _sTitle the title of the document
++
++ @return the content properties
++ */
++ ::rtl::Reference<ContentProperties> getContentPropertyWithDocumentId(const ::rtl::OUString& _sDocumentId) const;
++
++ /** getContentPropertyWithSavedAsName returns the ContentProperties for the first content with that SavedAsName
+ @param _sSaveAsName the SavedAsName of the document
+
+ @return the content properties
+--- ucb/source/ucp/odma/odma_services.cxx.old 2009-10-07 15:07:04.000000000 +0200
++++ ucb/source/ucp/odma/odma_services.cxx 2010-03-03 16:59:55.000000000 +0100
+@@ -35,21 +35,19 @@
+ #include <com/sun/star/registry/XRegistryKey.hpp>
+ #include "odma_contentprops.hxx"
+ #include "odma_provider.hxx"
+-#include "odma_lib.hxx"
+
+-using namespace rtl;
+ using namespace com::sun::star::uno;
+ using namespace com::sun::star::lang;
+ using namespace com::sun::star::registry;
+
+ //=========================================================================
+ static sal_Bool writeInfo( void * pRegistryKey,
+- const OUString & rImplementationName,
+- Sequence< OUString > const & rServiceNames )
++ const rtl::OUString & rImplementationName,
++ Sequence< rtl::OUString > const & rServiceNames )
+ {
+- OUString aKeyName( OUString::createFromAscii( "/" ) );
++ rtl::OUString aKeyName( rtl::OUString::createFromAscii( "/" ) );
+ aKeyName += rImplementationName;
+- aKeyName += OUString::createFromAscii( "/UNO/SERVICES" );
++ aKeyName += rtl::OUString::createFromAscii( "/UNO/SERVICES" );
+
+ Reference< XRegistryKey > xKey;
+ try
+@@ -122,10 +120,8 @@ extern "C" void * SAL_CALL component_get
+ if ( ::odma::ContentProvider::getImplementationName_Static().
+ compareToAscii( pImplName ) == 0 )
+ {
+- if(::odma::LoadLibrary())
++ if(::odma::DMSsAvailable())
+ xFactory = ::odma::ContentProvider::createServiceFactory( xSMgr );
+- else
+- OSL_ASSERT(!"Could not load library!");
+ }
+
+ //////////////////////////////////////////////////////////////////////
+--- ucb/source/ucp/odma/ucpodma.xml.old 2009-10-07 15:07:04.000000000 +0200
++++ ucb/source/ucp/odma/ucpodma.xml 2010-03-03 16:59:55.000000000 +0100
+@@ -11,7 +11,7 @@
+ Ocke Janssen
+ </author>
+ <name>
+- com.sun.star.comp.ucb.OdmaContentProvider
++ com.sun.star.comp.ucb.ODMAContentProvider
+ </name>
+ <description>
+ This component implements a Content Provider for the Universal
+--- officecfg/registry/data/org/openoffice/ucb/Configuration.xcu.old 2010-03-03 16:59:07.000000000 +0100
++++ officecfg/registry/data/org/openoffice/ucb/Configuration.xcu 2010-03-03 16:59:55.000000000 +0100
+@@ -200,6 +200,17 @@
+ <value/>
+ </prop>
+ </node>
++ <node oor:name="Provider42" oor:op="replace">
++ <prop oor:name="ServiceName">
++ <value>com.sun.star.ucb.ODMAContentProvider</value>
++ </prop>
++ <prop oor:name="URLTemplate">
++ <value>vnd.sun.star.odma</value>
++ </prop>
++ <prop oor:name="Arguments">
++ <value/>
++ </prop>
++ </node>
+ <!-- We want the Provider to be the final fallback provider -->
+ <node oor:name="Provider999" oor:op="replace" install:module="gio">
+ <prop oor:name="ServiceName">
+--- scp2/source/ooo/file_library_ooo.scp.old 2010-03-03 16:59:46.000000000 +0100
++++ scp2/source/ooo/file_library_ooo.scp 2010-03-03 16:59:55.000000000 +0100
+@@ -708,6 +708,10 @@ End
+ #endif
+ #endif
+
++#ifdef WNT
++SPECIAL_UNO_COMPONENT_LIB_FILE( gid_File_Lib_Fps_ODMA, fps_odma.uno )
++#endif
++
+ SPECIAL_UNO_COMPONENT_LIB_FILE( gid_File_Lib_Fps_Office, fps_office.uno )
+ SPECIAL_UNO_COMPONENT_LIB_FILE( gid_File_Lib_Fpicker, fpicker.uno )
+
+@@ -1647,6 +1651,10 @@ SPECIAL_UNO_COMPONENT_LIB_FILE(gid_File_
+
+ SPECIAL_UNO_COMPONENT_LIB_FILE(gid_File_Ucpexpand1, ucpexpand1.uno)
+
++#ifdef WNT
++SPECIAL_UNO_COMPONENT_LIB_FILE(gid_File_Ucpodma1, ucpodma1)
++#endif
++
+ File gid_File_Lib_Lnth
+ TXT_FILE_BODY;
+ Styles = (PACKED,UNO_COMPONENT,PATCH);
+--- desktop/source/app/cmdlineargs.cxx.old 2010-03-03 16:59:08.000000000 +0100
++++ desktop/source/app/cmdlineargs.cxx 2010-03-03 16:59:55.000000000 +0100
+@@ -297,6 +297,15 @@ void CommandLineArgs::ParseCommandLine_I
+ }
+ else
+ {
++ if( bOpenEvent || bViewEvent || bForceNewEvent || bForceOpenEvent )
++ {
++ if( ::rtl::OUString(aArgStr).matchIgnoreAsciiCaseAsciiL(RTL_CONSTASCII_STRINGPARAM("::ODMA")) )
++ {
++ ::rtl::OUString sArg = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("vnd.sun.star.odma:/"));
++ sArg += aArgStr;
++ aArgStr = sArg;
++ }
++ }
+ // handle this argument as a filename
+ if ( bOpenEvent )
+ AddStringListParam_Impl( CMD_STRINGPARAM_OPENLIST, aArgStr );
+--- fpicker/prj/build.lst.old 2010-03-03 16:59:29.000000000 +0100
++++ fpicker/prj/build.lst 2010-03-03 16:59:55.000000000 +0100
+@@ -2,6 +2,7 @@ fp fpicker : l10n rdbmaker svtools NU
+ fp fpicker\inc nmake - all fp_inc NULL
+ fp fpicker\source\generic nmake - all fp_generic fp_inc NULL
+ fp fpicker\source\office nmake - all fp_office fp_inc NULL
++fp fpicker\source\odma nmake - w fp_odma NULL
+ fp fpicker\source\unx\gnome nmake - u fp_gnome_filepicker fp_inc NULL
+ fp fpicker\source\unx\kde4 nmake - u fp_kde4_filepicker fp_inc NULL
+ fp fpicker\source\unx\kde_unx nmake - u fp_unx_common fp_inc NULL
+--- fpicker/source/generic/makefile.mk.old 2009-10-07 15:06:59.000000000 +0200
++++ fpicker/source/generic/makefile.mk 2010-03-03 16:59:55.000000000 +0100
+@@ -50,6 +50,7 @@ SHL1TARGET= $(TARGET)
+ SHL1IMPLIB= i$(TARGET)
+ SHL1OBJS= $(SLOFILES)
+ SHL1STDLIBS=\
++ $(ODMA_LIB_LIB) \
+ $(VCLLIB) \
+ $(SVLLIB) \
+ $(SVTOOLLIB) \
+--- fpicker/source/generic/fpicker.cxx.old 2009-10-08 16:17:54.000000000 +0200
++++ fpicker/source/generic/fpicker.cxx 2010-03-03 16:59:55.000000000 +0100
+@@ -37,6 +37,13 @@
+ #include "cppuhelper/implementationentry.hxx"
+ #endif
+ #include "com/sun/star/lang/XMultiComponentFactory.hpp"
++
++#ifdef WNT
++#include <tools/prewin.h>
++#include <tools/postwin.h>
++#include <odma_lib.hxx>
++#endif
++
+ #include "svtools/miscopt.hxx"
+ #include "svtools/pickerhistoryaccess.hxx"
+
+@@ -55,6 +62,7 @@ using rtl::OUString;
+ */
+ static OUString FilePicker_getSystemPickerServiceName()
+ {
++#ifdef UNX
+ OUString aDesktopEnvironment (Application::GetDesktopEnvironment());
+ if (aDesktopEnvironment.equalsIgnoreAsciiCaseAscii ("gnome"))
+ return OUString (RTL_CONSTASCII_USTRINGPARAM ("com.sun.star.ui.dialogs.GtkFilePicker"));
+@@ -64,8 +72,14 @@ static OUString FilePicker_getSystemPick
+ return OUString (RTL_CONSTASCII_USTRINGPARAM ("com.sun.star.ui.dialogs.KDE4FilePicker"));
+ else if (aDesktopEnvironment.equalsIgnoreAsciiCaseAscii ("macosx"))
+ return OUString (RTL_CONSTASCII_USTRINGPARAM ("com.sun.star.ui.dialogs.AquaFilePicker"));
+- else
+- return OUString (RTL_CONSTASCII_USTRINGPARAM ("com.sun.star.ui.dialogs.SystemFilePicker"));
++#endif
++#ifdef WNT
++ if (SvtMiscOptions().TryODMADialog() && ::odma::DMSsAvailable()) {
++ return OUString (RTL_CONSTASCII_USTRINGPARAM ("com.sun.star.ui.dialogs.ODMAFilePicker"));
++ }
++ return OUString (RTL_CONSTASCII_USTRINGPARAM ("com.sun.star.ui.dialogs.Win32FilePicker"));
++#endif
++ return OUString (RTL_CONSTASCII_USTRINGPARAM ("com.sun.star.ui.dialogs.SystemFilePicker"));
+ }
+
+ static Reference< css::uno::XInterface > FilePicker_createInstance (
+@@ -126,14 +140,20 @@ static Sequence< OUString > FilePicker_g
+ static OUString FolderPicker_getSystemPickerServiceName()
+ {
+ OUString aDesktopEnvironment (Application::GetDesktopEnvironment());
++#ifdef UNX
+ if (aDesktopEnvironment.equalsIgnoreAsciiCaseAscii ("gnome"))
+ return OUString (RTL_CONSTASCII_USTRINGPARAM ("com.sun.star.ui.dialogs.GtkFolderPicker"));
+ else if (aDesktopEnvironment.equalsIgnoreAsciiCaseAscii ("kde"))
+ return OUString (RTL_CONSTASCII_USTRINGPARAM ("com.sun.star.ui.dialogs.KDEFolderPicker"));
+ else if (aDesktopEnvironment.equalsIgnoreAsciiCaseAscii ("macosx"))
+ return OUString (RTL_CONSTASCII_USTRINGPARAM ("com.sun.star.ui.dialogs.AquaFolderPicker"));
+- else
+- return OUString (RTL_CONSTASCII_USTRINGPARAM ("com.sun.star.ui.dialogs.SystemFolderPicker"));
++#endif
++#ifdef WNT
++ if (SvtMiscOptions().TryODMADialog() && ::odma::DMSsAvailable()) {
++ return OUString (RTL_CONSTASCII_USTRINGPARAM ("com.sun.star.ui.dialogs.ODMAFolderPicker"));
++ }
++#endif
++ return OUString (RTL_CONSTASCII_USTRINGPARAM ("com.sun.star.ui.dialogs.SystemFolderPicker"));
+ }
+
+ static Reference< css::uno::XInterface > FolderPicker_createInstance (
+--- fpicker/source/odma/ODMAFilePicker.cxx.old 2010-03-03 16:59:55.000000000 +0100
++++ fpicker/source/odma/ODMAFilePicker.cxx 2010-03-03 16:59:55.000000000 +0100
+@@ -0,0 +1,565 @@
++/*************************************************************************
++ *
++ * OpenOffice.org - a multi-platform office productivity suite
++ *
++ * $RCSfile$
++ *
++ * $Revision: 12010 $
++ *
++ * last change: $Author: tml $ $Date: 2008-03-26 02:30:23 +0200 (on, 26 mar 2008) $
++ *
++ * The Contents of this file are made available subject to
++ * the terms of GNU Lesser General Public License Version 2.1.
++ *
++ *
++ * GNU Lesser General Public License Version 2.1
++ * =============================================
++ * Copyright 2005 by Sun Microsystems, Inc.
++ * 901 San Antonio Road, Palo Alto, CA 94303, USA
++ *
++ * This library is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License version 2.1, as published by the Free Software Foundation.
++ *
++ * This library 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 for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with this library; if not, write to the Free Software
++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
++ * MA 02111-1307 USA
++ *
++ ************************************************************************/
++
++// MARKER(update_precomp.py): autogen include statement, do not remove
++#include "precompiled_fpicker.hxx"
++
++#include "ODMAFilePicker.hxx"
++
++#ifndef _TOOLS_DEBUG_HXX
++#include <tools/debug.hxx>
++#endif
++
++#ifndef _COM_SUN_STAR_BEANS_PROPERTYVALUE_HPP_
++#include <com/sun/star/beans/PropertyValue.hpp>
++#endif
++#ifndef _COM_SUN_STAR_BEANS_STRINGPAIR_HPP_
++#include <com/sun/star/beans/StringPair.hpp>
++#endif
++#ifndef _COM_SUN_STAR_UI_DIALOGS_FILEPREVIEWIMAGEFORMATS_HPP_
++#include <com/sun/star/ui/dialogs/FilePreviewImageFormats.hpp>
++#endif
++#ifndef _COM_SUN_STAR_UI_DIALOGS_EXECUTABLEDIALOGRESULTS_HPP_
++#include <com/sun/star/ui/dialogs/ExecutableDialogResults.hpp>
++#endif
++#ifndef _COM_SUN_STAR_UI_DIALOGS_TEMPLATEDESCRIPTION_HPP_
++#include <com/sun/star/ui/dialogs/TemplateDescription.hpp>
++#endif
++#ifndef _COM_SUN_STAR_UCB_XCOMMANDENVIRONMENT_HPP_
++#include <com/sun/star/ucb/XCommandEnvironment.hpp>
++#endif
++#ifndef _COM_SUN_STAR_UNO_ANY_HXX_
++#include <com/sun/star/uno/Any.hxx>
++#endif
++#ifndef _COM_SUN_STAR_UNO_SEQUENCE_HXX_
++#include <com/sun/star/uno/Sequence.hxx>
++#endif
++
++#ifndef _COMPHELPER_SEQUENCE_HXX_
++#include <comphelper/sequence.hxx>
++#endif
++#ifndef _CPPUHELPER_TYPEPROVIDER_HXX_
++#include <cppuhelper/typeprovider.hxx>
++#endif
++#ifndef _UCBHELPER_CONTENT_HXX
++#include <ucbhelper/content.hxx>
++#endif
++#ifndef _UNOTOOLS_UCBHELPER_HXX
++#include <unotools/ucbhelper.hxx>
++#endif
++
++#ifndef ODMA_LIB_HXX
++#include <tools/prewin.h>
++#include <tools/postwin.h>
++#include <odma_lib.hxx>
++#endif
++
++// using ----------------------------------------------------------------
++
++using namespace ::com::sun::star::beans;
++using namespace ::com::sun::star::lang;
++using namespace ::com::sun::star::ui::dialogs;
++using namespace ::com::sun::star::ucb;
++using namespace ::com::sun::star::uno;
++using namespace ::com::sun::star::util;
++using namespace ::utl;
++
++//------------------------------------------------------------------------------------
++// class ODMAFilePicker
++//------------------------------------------------------------------------------------
++ODMAFilePicker::ODMAFilePicker( const Reference < XMultiServiceFactory >& xFactory ) :
++ cppu::WeakComponentImplHelper9<
++ XFilterManager,
++ XFilterGroupManager,
++ XFilePickerControlAccess,
++ XFilePickerNotifier,
++ XFilePreview,
++ XInitialization,
++ XCancellable,
++ XEventListener,
++ XServiceInfo>( m_rbHelperMtx ),
++ m_bMultiSelectionMode( sal_False ),
++ m_aDefaultName( ),
++ m_aFiles( ),
++ m_nDialogKind( OPEN )
++{
++ m_bUseDMS = ::odma::DMSsAvailable();
++ m_xSystemFilePicker = xFactory->createInstance(
++ ::rtl::OUString::createFromAscii( "com.sun.star.ui.dialogs.Win32FilePicker" ) );
++}
++
++// XExecutableDialog functions
++
++void SAL_CALL ODMAFilePicker::setTitle( const ::rtl::OUString& aTitle )
++ throw (RuntimeException)
++{
++ Reference< XExecutableDialog > xExecutableDialog( m_xSystemFilePicker, UNO_QUERY );
++ xExecutableDialog->setTitle( aTitle);
++}
++
++sal_Int16 SAL_CALL ODMAFilePicker::execute( )
++ throw (RuntimeException)
++{
++ ODMSTATUS status;
++ ODMHANDLE handle;
++ WORD count = 0;
++ DWORD flags;
++
++ status = NODMRegisterApp( &handle, ODM_API_VERSION, "sodma", (DWORD) GetActiveWindow( ), NULL );
++ if (status == ODM_SUCCESS)
++ {
++ if (m_nDialogKind == OPEN)
++ {
++ const int MAXDOCS = 10;
++ char docids[ODM_DOCID_MAX*MAXDOCS+1];
++ WORD docidslen = sizeof( docids );
++
++ flags = 0;
++ if (m_bMultiSelectionMode)
++ count = MAXDOCS;
++ else
++ count = 1;
++ status = NODMSelectDocEx( handle, docids, &docidslen, &count, &flags, NULL );
++ if (status == ODM_SUCCESS)
++ {
++ // GroupWise doesn't set docidslen or count, so
++ // calculate number of document IDs manually
++ char *p = docids;
++ count = 0;
++ while (*p) {
++ count++;
++ p += strlen( p ) + 1;
++ }
++ }
++ else if (status == ODM_E_NOSUPPORT)
++ {
++ status = NODMSelectDoc( handle, docids, &flags );
++ if (status == ODM_SUCCESS)
++ count = 1;
++ }
++ NODMUnRegisterApp( handle );
++ if (status == ODM_SUCCESS)
++ {
++ rtl::OUString *strings = new rtl::OUString[count];
++ int i;
++ char *p = docids;
++
++ for (i = 0; i < count; i++) {
++ // Insane API... the first element is a full URI, the rest
++ // are just the "basenames" in the same "directory".
++ if (i == 0)
++ strings[0] = rtl::OUString::createFromAscii( "vnd.sun.star.odma:/" ) + rtl::OUString::createFromAscii( p );
++ else
++ strings[i] = rtl::OUString::createFromAscii( p );
++ p += strlen( p );
++ }
++
++ m_aFiles = Sequence< rtl::OUString >( strings, count );
++ delete[] strings;
++ return ExecutableDialogResults::OK;
++ }
++ }
++ else /* m_nDialogKind == SAVE */
++ {
++ char newdocid[ODM_DOCID_MAX+1];
++
++ if (m_aDefaultName.getLength() == 0 ||
++ !m_aDefaultName.matchIgnoreAsciiCaseAsciiL( "::ODMA\\", 7, 0 ))
++ {
++ char tempdocid[ODM_DOCID_MAX+1];
++
++ status = NODMNewDoc( handle, tempdocid, ODM_SILENT, NULL, NULL );
++ if (status == ODM_SUCCESS)
++ status = NODMSaveAs( handle, tempdocid, newdocid, NULL, NULL, NULL );
++ }
++ else
++ {
++ rtl::OString sDefaultName = rtl::OUStringToOString( m_aDefaultName, RTL_TEXTENCODING_ASCII_US );
++ status = NODMSaveAs( handle,
++ const_cast<sal_Char*>( sDefaultName.getStr() ),
++ newdocid, NULL, NULL, NULL );
++ }
++
++ NODMUnRegisterApp( handle );
++ if (status == ODM_SUCCESS)
++ {
++ rtl::OUString s( rtl::OUString::createFromAscii( "vnd.sun.star.odma:/" ) +
++ rtl::OUString::createFromAscii( newdocid ) );
++ // Create a Content for the odma URL so that
++ // odma::ContentProvider will learn about the DOCID we
++ // just created.
++ ucbhelper::Content content( s, Reference< XCommandEnvironment >() );
++ m_aFiles = Sequence< rtl::OUString >( &s, 1 );
++ return ExecutableDialogResults::OK;
++ }
++ }
++ }
++ if (status == ODM_E_APPSELECT)
++ {
++ m_bUseDMS = sal_False;
++
++ Reference< XExecutableDialog > xExecutableDialog( m_xSystemFilePicker, UNO_QUERY );
++ return xExecutableDialog->execute();
++ }
++
++ // Fallback
++ return ExecutableDialogResults::CANCEL;
++}
++
++// XFilePicker functions
++
++void SAL_CALL ODMAFilePicker::setMultiSelectionMode( sal_Bool bMode )
++ throw( RuntimeException )
++{
++ m_bMultiSelectionMode = bMode;
++
++ Reference< XFilePicker > xFilePicker( m_xSystemFilePicker, UNO_QUERY );
++ xFilePicker->setMultiSelectionMode( bMode );
++}
++
++void SAL_CALL ODMAFilePicker::setDefaultName( const rtl::OUString& aName )
++ throw( RuntimeException )
++{
++ // When editing a document from DMS, and doing Save As, this is
++ // called twice, first with the complete DOCID, the second time
++ // with the "extension" removed. Of course, this is bogus, as
++ // DOCIDs should be treated as opaque strings, they don't have
++ // "extensions".
++
++ // In the GroupWise case a DOCID is like
++ // ::ODMA\GRPWISE\FOO1.BAR.FOO-Bla_bla:12345.12 where the final
++ // dot separates the version number, not an "extension".
++ //
++ // So ignore the second call.
++ //
++ // The second call without "extension" is done if the
++ // XFilePickerControlAccess is set to have auto-extension turned
++ // on. (See sfx2/source/dialog/filedlghelper.cxx:
++ // FileDialogHelper_Impl::implInitializeFileName().) Thus we could
++ // alternatively make sure that a getValue call to get
++ // ExtendedFilePickerElementIds::CHECKBOX_AUTOEXTENSION returns
++ // false. But that might be hard as we don't know in advance
++ // whether the user will click the "use application dialog"
++ // button. If so, we indeed do use auto-extensions.
++ //
++ // Yes, this is ugly, relying on knowing details on how this
++ // function will be called.
++
++ if ( m_aDefaultName.getLength() == 0 )
++ m_aDefaultName = aName;
++
++ Reference< XFilePicker > xFilePicker( m_xSystemFilePicker, UNO_QUERY );
++ xFilePicker->setDefaultName( aName );
++}
++
++void SAL_CALL ODMAFilePicker::setDisplayDirectory( const rtl::OUString& aDirectory )
++ throw( IllegalArgumentException, RuntimeException )
++{
++ m_aDisplayDirectory = aDirectory;
++
++ Reference< XFilePicker > xFilePicker( m_xSystemFilePicker, UNO_QUERY );
++ xFilePicker->setDisplayDirectory( aDirectory );
++}
++
++rtl::OUString SAL_CALL ODMAFilePicker::getDisplayDirectory( )
++ throw( RuntimeException )
++{
++ if (m_bUseDMS)
++ return m_aDisplayDirectory;
++
++ Reference< XFilePicker > xFilePicker( m_xSystemFilePicker, UNO_QUERY );
++ return xFilePicker->getDisplayDirectory();
++}
++
++Sequence< rtl::OUString > SAL_CALL ODMAFilePicker::getFiles( )
++ throw( RuntimeException )
++{
++ if (m_bUseDMS)
++ return m_aFiles;
++
++ Reference< XFilePicker > xFilePicker( m_xSystemFilePicker, UNO_QUERY );
++ return xFilePicker->getFiles();
++}
++
++// XFilePickerControlAccess functions
++
++void SAL_CALL ODMAFilePicker::setValue( sal_Int16 nElementID,
++ sal_Int16 nControlAction,
++ const Any& rValue )
++ throw( RuntimeException )
++{
++ Reference< XFilePickerControlAccess > xFilePickerControlAccess( m_xSystemFilePicker, UNO_QUERY );
++ xFilePickerControlAccess->setValue( nElementID, nControlAction, rValue );
++}
++
++Any SAL_CALL ODMAFilePicker::getValue( sal_Int16 nElementID, sal_Int16 nControlAction )
++ throw( RuntimeException )
++{
++ Reference< XFilePickerControlAccess > xFilePickerControlAccess( m_xSystemFilePicker, UNO_QUERY );
++ return xFilePickerControlAccess->getValue( nElementID, nControlAction );
++}
++
++void SAL_CALL ODMAFilePicker::setLabel( sal_Int16 nLabelID, const rtl::OUString& rValue )
++ throw ( RuntimeException )
++{
++ Reference< XFilePickerControlAccess > xFilePickerControlAccess( m_xSystemFilePicker, UNO_QUERY );
++ xFilePickerControlAccess->setLabel( nLabelID, rValue );
++}
++
++rtl::OUString SAL_CALL ODMAFilePicker::getLabel( sal_Int16 nLabelID )
++ throw ( RuntimeException )
++{
++ Reference< XFilePickerControlAccess > xFilePickerControlAccess( m_xSystemFilePicker, UNO_QUERY );
++ return xFilePickerControlAccess->getLabel( nLabelID );
++}
++
++void SAL_CALL ODMAFilePicker::enableControl( sal_Int16 nElementID, sal_Bool bEnable )
++ throw( RuntimeException )
++{
++ Reference< XFilePickerControlAccess > xFilePickerControlAccess( m_xSystemFilePicker, UNO_QUERY );
++ xFilePickerControlAccess->enableControl( nElementID, bEnable );
++}
++
++// XFilePickerNotifier functions
++
++void SAL_CALL ODMAFilePicker::addFilePickerListener( const Reference< XFilePickerListener >& xListener )
++ throw ( RuntimeException )
++{
++ Reference< XFilePickerNotifier > xFilePickerNotifier( m_xSystemFilePicker, UNO_QUERY );
++ xFilePickerNotifier->addFilePickerListener( xListener );
++}
++
++void SAL_CALL ODMAFilePicker::removeFilePickerListener( const Reference< XFilePickerListener >& xListener )
++ throw ( RuntimeException )
++{
++ Reference< XFilePickerNotifier > xFilePickerNotifier( m_xSystemFilePicker, UNO_QUERY );
++ xFilePickerNotifier->removeFilePickerListener( xListener );
++}
++
++// XFilePreview functions
++
++Sequence< sal_Int16 > SAL_CALL ODMAFilePicker::getSupportedImageFormats( )
++ throw ( RuntimeException )
++{
++ Reference< XFilePreview > xFilePreview( m_xSystemFilePicker, UNO_QUERY );
++ return xFilePreview->getSupportedImageFormats();
++}
++
++sal_Int32 SAL_CALL ODMAFilePicker::getTargetColorDepth( )
++ throw ( RuntimeException )
++{
++ Reference< XFilePreview > xFilePreview( m_xSystemFilePicker, UNO_QUERY );
++ return xFilePreview->getTargetColorDepth();
++}
++
++sal_Int32 SAL_CALL ODMAFilePicker::getAvailableWidth( )
++ throw ( RuntimeException )
++{
++ Reference< XFilePreview > xFilePreview( m_xSystemFilePicker, UNO_QUERY );
++ return xFilePreview->getAvailableWidth();
++}
++
++sal_Int32 SAL_CALL ODMAFilePicker::getAvailableHeight( )
++ throw ( RuntimeException )
++{
++ Reference< XFilePreview > xFilePreview( m_xSystemFilePicker, UNO_QUERY );
++ return xFilePreview->getAvailableHeight();
++}
++
++void SAL_CALL ODMAFilePicker::setImage( sal_Int16 aImageFormat, const Any& rImage )
++ throw ( IllegalArgumentException, RuntimeException )
++{
++ Reference< XFilePreview > xFilePreview( m_xSystemFilePicker, UNO_QUERY );
++ xFilePreview->setImage( aImageFormat, rImage);
++}
++
++sal_Bool SAL_CALL ODMAFilePicker::setShowState( sal_Bool bShowState )
++ throw ( RuntimeException )
++{
++ Reference< XFilePreview > xFilePreview( m_xSystemFilePicker, UNO_QUERY );
++ return xFilePreview->setShowState( bShowState);
++}
++
++sal_Bool SAL_CALL ODMAFilePicker::getShowState( )
++ throw ( RuntimeException )
++{
++ Reference< XFilePreview > xFilePreview( m_xSystemFilePicker, UNO_QUERY );
++ return xFilePreview->getShowState();
++}
++
++// XFilterGroupManager functions
++
++void SAL_CALL ODMAFilePicker::appendFilterGroup( const ::rtl::OUString& sGroupTitle,
++ const Sequence< StringPair >& aFilters )
++ throw ( IllegalArgumentException, RuntimeException )
++{
++ Reference< XFilterGroupManager > xFilterGroupManager( m_xSystemFilePicker, UNO_QUERY );
++ xFilterGroupManager->appendFilterGroup( sGroupTitle, aFilters );
++}
++
++// XFilterManager functions
++
++void SAL_CALL ODMAFilePicker::appendFilter( const rtl::OUString& aTitle,
++ const rtl::OUString& aFilter )
++ throw( IllegalArgumentException, RuntimeException )
++{
++ Reference< XFilterManager > xFilterManager( m_xSystemFilePicker, UNO_QUERY );
++ xFilterManager->appendFilter( aTitle, aFilter );
++}
++
++void SAL_CALL ODMAFilePicker::setCurrentFilter( const rtl::OUString& aTitle )
++ throw( IllegalArgumentException, RuntimeException )
++{
++ Reference< XFilterManager > xFilterManager( m_xSystemFilePicker, UNO_QUERY );
++ xFilterManager->setCurrentFilter( aTitle );
++}
++
++rtl::OUString SAL_CALL ODMAFilePicker::getCurrentFilter( )
++ throw( RuntimeException )
++{
++ Reference< XFilterManager > xFilterManager( m_xSystemFilePicker, UNO_QUERY );
++ return xFilterManager->getCurrentFilter();
++}
++
++// XInitialization functions
++
++void SAL_CALL ODMAFilePicker::initialize( const Sequence< Any >& aArguments )
++ throw ( Exception, RuntimeException )
++{
++ if (aArguments.getLength( ) > 0)
++ {
++ Any aAny = aArguments[0];
++
++ if ( (aAny.getValueType() == ::getCppuType((sal_Int16*)0)) ||
++ (aAny.getValueType() == ::getCppuType((sal_Int8*)0)) )
++ {
++ sal_Int16 nTemplateId = -1;
++ aAny >>= nTemplateId;
++
++ switch (nTemplateId) {
++ case TemplateDescription::FILEOPEN_SIMPLE:
++ case TemplateDescription::FILEOPEN_LINK_PREVIEW_IMAGE_TEMPLATE:
++ case TemplateDescription::FILEOPEN_PLAY:
++ case TemplateDescription::FILEOPEN_READONLY_VERSION:
++ case TemplateDescription::FILEOPEN_LINK_PREVIEW:
++ m_nDialogKind = OPEN;
++ break;
++ default:
++ m_nDialogKind = SAVE;
++ }
++ }
++ }
++
++ Reference< XInitialization > xInitialization( m_xSystemFilePicker, UNO_QUERY );
++ xInitialization->initialize( aArguments );
++}
++
++// XCancellable functions
++
++void SAL_CALL ODMAFilePicker::cancel( )
++ throw( ::com::sun::star::uno::RuntimeException )
++{
++ Reference< XCancellable > xCancellable( m_xSystemFilePicker, UNO_QUERY );
++ xCancellable->cancel();
++}
++
++// XEventListener functions
++
++void SAL_CALL ODMAFilePicker::disposing( const ::com::sun::star::lang::EventObject& aEvent )
++ throw( RuntimeException )
++{
++ Reference< XEventListener > xEventListener( m_xSystemFilePicker, UNO_QUERY );
++ xEventListener->disposing( aEvent );
++}
++
++// XServiceInfo functions
++
++rtl::OUString SAL_CALL ODMAFilePicker::getImplementationName( )
++ throw( RuntimeException )
++{
++ return impl_getStaticImplementationName();
++}
++
++sal_Bool SAL_CALL ODMAFilePicker::supportsService( const rtl::OUString& sServiceName )
++ throw( RuntimeException )
++{
++ Sequence< rtl::OUString > seqServiceNames = getSupportedServiceNames();
++ const rtl::OUString* pArray = seqServiceNames.getConstArray();
++ for ( sal_Int32 i = 0; i < seqServiceNames.getLength(); i++ )
++ {
++ if ( sServiceName == pArray[i] )
++ {
++ return sal_True ;
++ }
++ }
++ return sal_False ;
++}
++
++Sequence< rtl::OUString > SAL_CALL ODMAFilePicker::getSupportedServiceNames( )
++ throw( RuntimeException )
++{
++ return impl_getStaticSupportedServiceNames();
++}
++
++Sequence< rtl::OUString > ODMAFilePicker::impl_getStaticSupportedServiceNames( )
++{
++ Sequence< rtl::OUString > seqServiceNames( 2 );
++ rtl::OUString* pArray = seqServiceNames.getArray();
++ pArray[0] = rtl::OUString::createFromAscii( "com.sun.star.ui.dialogs.ODMAFilePicker" );
++
++ // Super-ugly, but check the function sal_Bool
++ // lcl_isSystemFilePicker( const Reference< XFilePicker >& ) in
++ // sfx2/source/dialog/filedlghelper.cxx
++
++ // Lovely undocumented coupling right across abstraction layers,
++ // isn't it? If we don't claim to implement this "service" (which
++ // is not defined in any IDL file, btw), we get hangs.
++
++ pArray[1] = rtl::OUString::createFromAscii( "com.sun.star.ui.dialogs.SystemFilePicker" );
++ return seqServiceNames ;
++}
++
++rtl::OUString ODMAFilePicker::impl_getStaticImplementationName( )
++{
++ return rtl::OUString::createFromAscii( "com.sun.star.svtools.ODMAFilePicker" );
++}
++
++Reference< XInterface > SAL_CALL ODMAFilePicker::impl_createInstance(
++ const Reference< XComponentContext >& rxContext)
++ throw( Exception )
++{
++ Reference< XMultiServiceFactory > xServiceManager (rxContext->getServiceManager(), UNO_QUERY_THROW);
++ return Reference< XInterface >( *new ODMAFilePicker( xServiceManager ) );
++}
+--- fpicker/source/odma/ODMAFilePicker.hxx.old 2010-03-03 16:59:55.000000000 +0100
++++ fpicker/source/odma/ODMAFilePicker.hxx 2010-03-03 16:59:55.000000000 +0100
+@@ -0,0 +1,242 @@
++/*************************************************************************
++ *
++ * OpenOffice.org - a multi-platform office productivity suite
++ *
++ * $RCSfile$
++ *
++ * $Revision: 12010 $
++ *
++ * last change: $Author: tml $ $Date: 2008-03-26 02:30:23 +0200 (on, 26 mar 2008) $
++ *
++ * The Contents of this file are made available subject to
++ * the terms of GNU Lesser General Public License Version 2.1.
++ *
++ *
++ * GNU Lesser General Public License Version 2.1
++ * =============================================
++ * Copyright 2005 by Sun Microsystems, Inc.
++ * 901 San Antonio Road, Palo Alto, CA 94303, USA
++ *
++ * This library is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License version 2.1, as published by the Free Software Foundation.
++ *
++ * This library 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 for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with this library; if not, write to the Free Software
++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
++ * MA 02111-1307 USA
++ *
++ ************************************************************************/
++#ifndef INCLUDED_ODMA_FILEPICKER_HXX
++#define INCLUDED_ODMA_FILEPICKER_HXX
++
++#ifndef _CPPUHELPER_COMPBASE9_HXX_
++#include <cppuhelper/compbase9.hxx>
++#endif
++
++#ifndef _COM_SUN_STAR_UI_DIALOGS_XFILEPICKERCONTROLACCESS_HPP_
++#include <com/sun/star/ui/dialogs/XFilePickerControlAccess.hpp>
++#endif
++#ifndef _COM_SUN_STAR_UI_DIALOGS_XFILEPICKERNOTIFIER_HPP_
++#include <com/sun/star/ui/dialogs/XFilePickerNotifier.hpp>
++#endif
++#ifndef _COM_SUN_STAR_UI_DIALOGS_XFILEPREVIEW_HPP_
++#include <com/sun/star/ui/dialogs/XFilePreview.hpp>
++#endif
++#ifndef _COM_SUN_STAR_UI_DIALOGS_XFILTERMANAGER_HPP_
++#include <com/sun/star/ui/dialogs/XFilterManager.hpp>
++#endif
++#ifndef _COM_SUN_STAR_UI_DIALOGS_XFILTERGROUPMANAGER_HPP_
++#include <com/sun/star/ui/dialogs/XFilterGroupManager.hpp>
++#endif
++#ifndef _COM_SUN_STAR_UI_DIALOGS_XFILEPICKERLISTENER_HPP_
++#include <com/sun/star/ui/dialogs/XFilePickerListener.hpp>
++#endif
++#ifndef _COM_SUN_STAR_UTIL_XCANCELLABLE_HPP_
++#include <com/sun/star/util/XCancellable.hpp>
++#endif
++#ifndef _COM_SUN_STAR_LANG_XSERVICEINFO_HPP_
++#include <com/sun/star/lang/XServiceInfo.hpp>
++#endif
++#ifndef _COM_SUN_STAR_UNO_XCOMPONENT_CONTEXT_HPP_
++#include <com/sun/star/uno/XComponentContext.hpp>
++#endif
++
++#ifndef _COM_SUN_STAR_LANG_XINITIALIZATION_HPP_
++#include <com/sun/star/lang/XInitialization.hpp>
++#endif
++
++// class ODMAFilePicker ---------------------------------------------------
++
++class ODMAFilePicker :
++ public cppu::WeakComponentImplHelper9<
++ ::com::sun::star::ui::dialogs::XFilterManager,
++ ::com::sun::star::ui::dialogs::XFilterGroupManager,
++ ::com::sun::star::ui::dialogs::XFilePickerControlAccess,
++ ::com::sun::star::ui::dialogs::XFilePickerNotifier,
++ ::com::sun::star::ui::dialogs::XFilePreview,
++ ::com::sun::star::lang::XInitialization,
++ ::com::sun::star::util::XCancellable,
++ ::com::sun::star::lang::XEventListener,
++ ::com::sun::star::lang::XServiceInfo >
++{
++private:
++ sal_Bool m_bUseDMS;
++ sal_Bool m_bMultiSelectionMode;
++ rtl::OUString m_aDefaultName;
++ rtl::OUString m_aDisplayDirectory;
++ ::com::sun::star::uno::Sequence< rtl::OUString > m_aFiles;
++ enum { OPEN, SAVE } m_nDialogKind;
++
++ ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface > m_xSystemFilePicker;
++
++protected:
++ ::osl::Mutex m_rbHelperMtx;
++
++public:
++
++ ODMAFilePicker( const ::com::sun::star::uno::Reference < ::com::sun::star::lang::XMultiServiceFactory >& xFactory );
++
++ // XFilterManager functions
++
++ virtual void SAL_CALL appendFilter( const ::rtl::OUString& aTitle,
++ const ::rtl::OUString& aFilter )
++ throw( ::com::sun::star::lang::IllegalArgumentException, ::com::sun::star::uno::RuntimeException );
++
++ virtual void SAL_CALL setCurrentFilter( const ::rtl::OUString& aTitle )
++ throw( ::com::sun::star::lang::IllegalArgumentException,
++ ::com::sun::star::uno::RuntimeException );
++
++ virtual ::rtl::OUString SAL_CALL getCurrentFilter( )
++ throw( ::com::sun::star::uno::RuntimeException );
++
++ // XFilterGroupManager functions
++
++ virtual void SAL_CALL appendFilterGroup( const ::rtl::OUString& sGroupTitle,
++ const ::com::sun::star::uno::Sequence< ::com::sun::star::beans::StringPair >& aFilters )
++ throw (::com::sun::star::lang::IllegalArgumentException,
++ ::com::sun::star::uno::RuntimeException );
++
++ // XFilePickerControlAccess functions
++
++ virtual void SAL_CALL setValue( sal_Int16 nControlID,
++ sal_Int16 nControlAction,
++ const ::com::sun::star::uno::Any& aValue )
++ throw( ::com::sun::star::uno::RuntimeException );
++
++ virtual ::com::sun::star::uno::Any SAL_CALL getValue( sal_Int16 nControlID,
++ sal_Int16 nControlAction )
++ throw( ::com::sun::star::uno::RuntimeException );
++
++ virtual void SAL_CALL setLabel( sal_Int16 nControlID,
++ const ::rtl::OUString& aValue )
++ throw ( ::com::sun::star::uno::RuntimeException );
++
++ virtual ::rtl::OUString SAL_CALL getLabel( sal_Int16 nControlID )
++ throw ( ::com::sun::star::uno::RuntimeException );
++
++ virtual void SAL_CALL enableControl( sal_Int16 nControlID,
++ sal_Bool bEnable )
++ throw( ::com::sun::star::uno::RuntimeException );
++
++ // XFilePicker functions
++
++ virtual void SAL_CALL setMultiSelectionMode( sal_Bool bMode )
++ throw( ::com::sun::star::uno::RuntimeException );
++
++ virtual void SAL_CALL setDefaultName( const ::rtl::OUString& aName )
++ throw( ::com::sun::star::uno::RuntimeException );
++
++ virtual void SAL_CALL setDisplayDirectory( const ::rtl::OUString& aDirectory )
++ throw( ::com::sun::star::lang::IllegalArgumentException,
++ ::com::sun::star::uno::RuntimeException );
++
++ virtual ::rtl::OUString SAL_CALL getDisplayDirectory( )
++ throw( ::com::sun::star::uno::RuntimeException );
++
++ virtual ::com::sun::star::uno::Sequence< ::rtl::OUString > SAL_CALL getFiles( )
++ throw( ::com::sun::star::uno::RuntimeException );
++
++ // XExecutableDialog functions
++
++ virtual void SAL_CALL setTitle( const ::rtl::OUString& aTitle )
++ throw (::com::sun::star::uno::RuntimeException);
++
++ virtual sal_Int16 SAL_CALL execute( )
++ throw (::com::sun::star::uno::RuntimeException);
++
++ // XFilePickerNotifier functions
++
++ virtual void SAL_CALL addFilePickerListener( const ::com::sun::star::uno::Reference< ::com::sun::star::ui::dialogs::XFilePickerListener >& xListener )
++ throw ( ::com::sun::star::uno::RuntimeException );
++
++ virtual void SAL_CALL removeFilePickerListener( const ::com::sun::star::uno::Reference< ::com::sun::star::ui::dialogs::XFilePickerListener >& xListener )
++ throw ( ::com::sun::star::uno::RuntimeException );
++
++ // XFilePreview functions
++
++ virtual ::com::sun::star::uno::Sequence< sal_Int16 > SAL_CALL getSupportedImageFormats( )
++ throw ( ::com::sun::star::uno::RuntimeException );
++
++ virtual sal_Int32 SAL_CALL getTargetColorDepth( )
++ throw ( ::com::sun::star::uno::RuntimeException );
++
++ virtual sal_Int32 SAL_CALL getAvailableWidth( )
++ throw ( ::com::sun::star::uno::RuntimeException );
++
++ virtual sal_Int32 SAL_CALL getAvailableHeight( )
++ throw ( ::com::sun::star::uno::RuntimeException );
++
++ virtual void SAL_CALL setImage( sal_Int16 aImageFormat,
++ const ::com::sun::star::uno::Any& aImage )
++ throw ( ::com::sun::star::lang::IllegalArgumentException,
++ ::com::sun::star::uno::RuntimeException );
++
++ virtual sal_Bool SAL_CALL setShowState( sal_Bool bShowState )
++ throw ( ::com::sun::star::uno::RuntimeException );
++
++ virtual sal_Bool SAL_CALL getShowState( )
++ throw ( ::com::sun::star::uno::RuntimeException );
++
++ // XInitialization functions
++
++ virtual void SAL_CALL initialize( const ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Any >& aArguments )
++ throw ( ::com::sun::star::uno::Exception, ::com::sun::star::uno::RuntimeException );
++
++ // XCancellable functions
++
++ virtual void SAL_CALL cancel( )
++ throw( ::com::sun::star::uno::RuntimeException );
++
++ // XEventListener functions
++
++ using cppu::WeakComponentImplHelperBase::disposing;
++ virtual void SAL_CALL disposing( const ::com::sun::star::lang::EventObject& aEvent )
++ throw( ::com::sun::star::uno::RuntimeException );
++
++ // XServiceInfo functions
++
++ virtual ::rtl::OUString SAL_CALL getImplementationName( )
++ throw( ::com::sun::star::uno::RuntimeException );
++
++ virtual sal_Bool SAL_CALL supportsService( const ::rtl::OUString& sServiceName )
++ throw( ::com::sun::star::uno::RuntimeException );
++
++ virtual ::com::sun::star::uno::Sequence< ::rtl::OUString > SAL_CALL getSupportedServiceNames( )
++ throw( ::com::sun::star::uno::RuntimeException );
++
++ /* Helper for XServiceInfo */
++ static ::com::sun::star::uno::Sequence< ::rtl::OUString > impl_getStaticSupportedServiceNames( );
++ static ::rtl::OUString impl_getStaticImplementationName( );
++
++ /* Helper for registry */
++ static ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface > SAL_CALL impl_createInstance ( const ::com::sun::star::uno::Reference< ::com::sun::star::uno::XComponentContext >& rxContext )
++ throw( ::com::sun::star::uno::Exception );
++};
++
++#endif // INCLUDED_ODMA_FILEPICKER_HXX
+--- fpicker/source/odma/ODMAFolderPicker.cxx.old 2010-03-03 16:59:55.000000000 +0100
++++ fpicker/source/odma/ODMAFolderPicker.cxx 2010-03-03 16:59:55.000000000 +0100
+@@ -0,0 +1,202 @@
++/*************************************************************************
++ *
++ * OpenOffice.org - a multi-platform office productivity suite
++ *
++ * $RCSfile$
++ *
++ * $Revision: 12010 $
++ *
++ * last change: $Author: tml $ $Date: 2008-03-26 02:30:23 +0200 (on, 26 mar 2008) $
++ *
++ * The Contents of this file are made available subject to
++ * the terms of GNU Lesser General Public License Version 2.1.
++ *
++ *
++ * GNU Lesser General Public License Version 2.1
++ * =============================================
++ * Copyright 2005 by Sun Microsystems, Inc.
++ * 901 San Antonio Road, Palo Alto, CA 94303, USA
++ *
++ * This library is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License version 2.1, as published by the Free Software Foundation.
++ *
++ * This library 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 for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with this library; if not, write to the Free Software
++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
++ * MA 02111-1307 USA
++ *
++ ************************************************************************/
++
++// MARKER(update_precomp.py): autogen include statement, do not remove
++#include "precompiled_fpicker.hxx"
++
++#include "ODMAFolderPicker.hxx"
++
++#define _SVSTDARR_STRINGSDTOR
++#include "svtools/svstdarr.hxx"
++
++#ifndef _COM_SUN_STAR_CONTAINER_XCONTENTENUMERATIONACCESS_HPP_
++#include <com/sun/star/container/XContentEnumerationAccess.hpp>
++#endif
++#ifndef _COM_SUN_STAR_CONTAINER_XSET_HPP_
++#include <com/sun/star/container/XSet.hpp>
++#endif
++#ifndef _COM_SUN_STAR_UNO_ANY_HXX_
++#include <com/sun/star/uno/Any.hxx>
++#endif
++#ifndef _CPPUHELPER_FACTORY_HXX_
++#include <cppuhelper/factory.hxx>
++#endif
++#ifndef _COM_SUN_STAR_BEANS_XPROPERTYSET_HPP_
++#include <com/sun/star/beans/XPropertySet.hpp>
++#endif
++
++#ifndef INCLUDED_SVTOOLS_PATHOPTIONS_HXX
++#include <svtools/pathoptions.hxx>
++#endif
++
++#ifndef ODMA_LIB_HXX
++#include <tools/prewin.h>
++#include <odma_lib.hxx>
++#include <tools/postwin.h>
++#endif
++
++// using ----------------------------------------------------------------
++
++using namespace ::com::sun::star::beans;
++using namespace ::com::sun::star::container;
++using namespace ::com::sun::star::lang;
++using namespace ::com::sun::star::uno;
++
++//------------------------------------------------------------------------------------
++// class ODMAFolderPicker
++//------------------------------------------------------------------------------------
++
++//------------------------------------------------------------------------------------
++ODMAFolderPicker::ODMAFolderPicker( const Reference < XMultiServiceFactory >& xFactory ) :
++ cppu::WeakComponentImplHelper2<
++ XFolderPicker,
++ XServiceInfo>( m_rbHelperMtx ),
++ m_bUseDMS( sal_False )
++{
++ m_xInterface = xFactory->createInstance(
++ ::rtl::OUString::createFromAscii( "com.sun.star.ui.dialogs.SystemFolderPicker" ) );
++}
++
++// XExecutableDialog functions
++
++void SAL_CALL ODMAFolderPicker::setTitle( const ::rtl::OUString& _rTitle ) throw (RuntimeException)
++{
++ if (m_bUseDMS)
++ return;
++
++ Reference< XExecutableDialog > xExecutableDialog( m_xInterface, UNO_QUERY );
++ xExecutableDialog->setTitle( _rTitle);
++}
++
++sal_Int16 SAL_CALL ODMAFolderPicker::execute( )
++ throw (RuntimeException)
++{
++ if (m_bUseDMS)
++ throw new RuntimeException( );
++
++ Reference< XExecutableDialog > xExecutableDialog( m_xInterface, UNO_QUERY );
++ return xExecutableDialog->execute();
++}
++
++// XFolderPicker functions
++
++void SAL_CALL ODMAFolderPicker::setDisplayDirectory( const ::rtl::OUString& aDirectory )
++ throw( IllegalArgumentException, RuntimeException )
++{
++ if (m_bUseDMS)
++ return;
++
++ Reference< XFolderPicker > xFolderPicker( m_xInterface, UNO_QUERY );
++ xFolderPicker->setDisplayDirectory( aDirectory );
++}
++
++::rtl::OUString SAL_CALL ODMAFolderPicker::getDisplayDirectory( )
++ throw( RuntimeException )
++{
++ if (m_bUseDMS)
++ return rtl::OUString();
++
++ Reference< XFolderPicker > xFolderPicker( m_xInterface, UNO_QUERY );
++ return xFolderPicker->getDisplayDirectory();
++}
++
++::rtl::OUString SAL_CALL ODMAFolderPicker::getDirectory( )
++ throw( RuntimeException )
++{
++ if (m_bUseDMS)
++ return rtl::OUString();
++
++ Reference< XFolderPicker > xFolderPicker( m_xInterface, UNO_QUERY );
++ return xFolderPicker->getDirectory();
++}
++
++void SAL_CALL ODMAFolderPicker::setDescription( const ::rtl::OUString& aDescription )
++ throw( RuntimeException )
++{
++ if (m_bUseDMS)
++ return;
++
++ Reference< XFolderPicker > xFolderPicker( m_xInterface, UNO_QUERY );
++ xFolderPicker->setDescription( aDescription );
++}
++
++// XServiceInfo
++
++::rtl::OUString SAL_CALL ODMAFolderPicker::getImplementationName( )
++ throw( RuntimeException )
++{
++ return impl_getStaticImplementationName();
++}
++
++sal_Bool SAL_CALL ODMAFolderPicker::supportsService( const ::rtl::OUString& sServiceName )
++ throw( RuntimeException )
++{
++ Sequence< ::rtl::OUString > seqServiceNames = getSupportedServiceNames();
++ const ::rtl::OUString* pArray = seqServiceNames.getConstArray();
++ for ( sal_Int32 i = 0; i < seqServiceNames.getLength(); i++ )
++ {
++ if ( sServiceName == pArray[i] )
++ {
++ return sal_True ;
++ }
++ }
++ return sal_False ;
++}
++
++Sequence< ::rtl::OUString > SAL_CALL ODMAFolderPicker::getSupportedServiceNames()
++ throw( RuntimeException )
++{
++ return impl_getStaticSupportedServiceNames();
++}
++
++Sequence< ::rtl::OUString > ODMAFolderPicker::impl_getStaticSupportedServiceNames( )
++{
++ Sequence< ::rtl::OUString > seqServiceNames( 1 );
++ ::rtl::OUString* pArray = seqServiceNames.getArray();
++ pArray[0] = ::rtl::OUString::createFromAscii( "com.sun.star.ui.dialogs.ODMAFolderPicker" );
++ return seqServiceNames ;
++}
++
++::rtl::OUString ODMAFolderPicker::impl_getStaticImplementationName( )
++{
++ return ::rtl::OUString::createFromAscii( "com.sun.star.svtools.ODMAFolderPicker" );
++}
++
++Reference< XInterface > SAL_CALL ODMAFolderPicker::impl_createInstance( const Reference< XComponentContext >& rxContext )
++ throw( Exception )
++{
++ Reference< XMultiServiceFactory > xServiceManager (rxContext->getServiceManager(), UNO_QUERY_THROW);
++ return Reference< XInterface >( *new ODMAFolderPicker( xServiceManager ) );
++}
+--- fpicker/source/odma/ODMAFolderPicker.hxx.old 2010-03-03 16:59:55.000000000 +0100
++++ fpicker/source/odma/ODMAFolderPicker.hxx 2010-03-03 16:59:55.000000000 +0100
+@@ -0,0 +1,118 @@
++/*************************************************************************
++ *
++ * OpenOffice.org - a multi-platform office productivity suite
++ *
++ * $RCSfile$
++ *
++ * $Revision: 12010 $
++ *
++ * last change: $Author: tml $ $Date: 2008-03-26 02:30:23 +0200 (on, 26 mar 2008) $
++ *
++ * The Contents of this file are made available subject to
++ * the terms of GNU Lesser General Public License Version 2.1.
++ *
++ *
++ * GNU Lesser General Public License Version 2.1
++ * =============================================
++ * Copyright 2005 by Sun Microsystems, Inc.
++ * 901 San Antonio Road, Palo Alto, CA 94303, USA
++ *
++ * This library is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License version 2.1, as published by the Free Software Foundation.
++ *
++ * This library 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 for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with this library; if not, write to the Free Software
++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
++ * MA 02111-1307 USA
++ *
++ ************************************************************************/
++#ifndef INCLUDED_ODMA_FOLDERPICKER_HXX
++#define INCLUDED_ODMA_FOLDERPICKER_HXX
++
++#ifndef _CPPUHELPER_COMPBASE2_HXX_
++#include <cppuhelper/compbase2.hxx>
++#endif
++
++#ifndef _COM_SUN_STAR_UI_DIALOGS_XFOLDERPICKER_HPP_
++#include <com/sun/star/ui/dialogs/XFolderPicker.hpp>
++#endif
++#ifndef _COM_SUN_STAR_LANG_XSERVICEINFO_HPP_
++#include <com/sun/star/lang/XServiceInfo.hpp>
++#endif
++#ifndef _COM_SUN_STAR_LANG_XSINGLESERVICEFACTORY_HPP_
++#include <com/sun/star/lang/XSingleServiceFactory.hpp>
++#endif
++#ifndef _COM_SUN_STAR_LANG_DISPOSEDEXCEPTION_HPP_
++#include <com/sun/star/lang/DisposedException.hpp>
++#endif
++#ifndef _COM_SUN_STAR_UNO_XCOMPONENTCONTEXT_HPP_
++#include <com/sun/star/uno/XComponentContext.hpp>
++#endif
++
++// class ODMAFolderPicker ---------------------------------------------------
++
++class ODMAFolderPicker :
++ public cppu::WeakComponentImplHelper2<
++ ::com::sun::star::ui::dialogs::XFolderPicker,
++ ::com::sun::star::lang::XServiceInfo >
++{
++private:
++ sal_Bool m_bUseDMS;
++
++protected:
++ ::osl::Mutex m_rbHelperMtx;
++
++ ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface > m_xInterface;
++
++public:
++ ODMAFolderPicker( const ::com::sun::star::uno::Reference < ::com::sun::star::lang::XMultiServiceFactory >& xFactory );
++
++ // XFolderPicker functions
++
++ virtual void SAL_CALL setDisplayDirectory( const ::rtl::OUString& aDirectory )
++ throw( ::com::sun::star::lang::IllegalArgumentException, ::com::sun::star::uno::RuntimeException );
++
++ virtual ::rtl::OUString SAL_CALL getDisplayDirectory( )
++ throw( ::com::sun::star::uno::RuntimeException );
++
++ virtual ::rtl::OUString SAL_CALL getDirectory( )
++ throw( ::com::sun::star::uno::RuntimeException );
++
++ virtual void SAL_CALL setDescription( const ::rtl::OUString& aDescription )
++ throw ( ::com::sun::star::uno::RuntimeException );
++
++ // XExecutableDialog functions
++
++ virtual void SAL_CALL setTitle( const ::rtl::OUString& _rTitle )
++ throw (::com::sun::star::uno::RuntimeException);
++
++ virtual sal_Int16 SAL_CALL execute( )
++ throw (::com::sun::star::uno::RuntimeException);
++
++ // XServiceInfo functions
++
++ virtual ::rtl::OUString SAL_CALL getImplementationName( )
++ throw( ::com::sun::star::uno::RuntimeException );
++
++ virtual sal_Bool SAL_CALL supportsService( const ::rtl::OUString& sServiceName )
++ throw( ::com::sun::star::uno::RuntimeException );
++
++ virtual com::sun::star::uno::Sequence< ::rtl::OUString > SAL_CALL getSupportedServiceNames( )
++ throw( ::com::sun::star::uno::RuntimeException );
++
++ /* Helper for XServiceInfo */
++ static com::sun::star::uno::Sequence< ::rtl::OUString > impl_getStaticSupportedServiceNames( );
++ static ::rtl::OUString impl_getStaticImplementationName( );
++
++ /* Helper for registry */
++ static ::com::sun::star::uno::Reference< com::sun::star::uno::XInterface > SAL_CALL impl_createInstance ( const ::com::sun::star::uno::Reference< com::sun::star::uno::XComponentContext >& rxContext )
++ throw( com::sun::star::uno::Exception );
++};
++
++#endif // INCLUDED_ODMA_FOLDERPICKER_HXX
+--- fpicker/source/odma/exports.map.old 2010-03-03 16:59:55.000000000 +0100
++++ fpicker/source/odma/exports.map 2010-03-03 16:59:55.000000000 +0100
+@@ -0,0 +1,8 @@
++UDK_3_0_0 {
++ global:
++ component_getImplementationEnvironment;
++ component_writeInfo;
++ component_getFactory;
++ local:
++ *;
++};
+--- fpicker/source/odma/fps_odma.cxx.old 2010-03-03 16:59:55.000000000 +0100
++++ fpicker/source/odma/fps_odma.cxx 2010-03-03 16:59:55.000000000 +0100
+@@ -0,0 +1,90 @@
++/*************************************************************************
++ *
++ * OpenOffice.org - a multi-platform office productivity suite
++ *
++ * $RCSfile$
++ *
++ * $Revision: 12010 $
++ *
++ * last change: $Author: tml $ $Date: 2008-03-26 02:30:23 +0200 (on, 26 mar 2008) $
++ *
++ * The Contents of this file are made available subject to
++ * the terms of GNU Lesser General Public License Version 2.1.
++ *
++ *
++ * GNU Lesser General Public License Version 2.1
++ * =============================================
++ * Copyright 2005 by Sun Microsystems, Inc.
++ * 901 San Antonio Road, Palo Alto, CA 94303, USA
++ *
++ * This library is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License version 2.1, as published by the Free Software Foundation.
++ *
++ * This library 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 for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with this library; if not, write to the Free Software
++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
++ * MA 02111-1307 USA
++ *
++ ************************************************************************/
++
++
++// MARKER(update_precomp.py): autogen include statement, do not remove
++#include "precompiled_fpicker.hxx"
++
++#ifndef _SAL_TYPES_H_
++#include "sal/types.h"
++#endif
++
++#ifndef _CPPUHELPER_IMPLEMENTATIONENTRY_HXX_
++#include "cppuhelper/implementationentry.hxx"
++#endif
++
++#include "ODMAFilePicker.hxx"
++#include "ODMAFolderPicker.hxx"
++
++static cppu::ImplementationEntry g_entries[] =
++{
++ {
++ ODMAFilePicker::impl_createInstance,
++ ODMAFilePicker::impl_getStaticImplementationName,
++ ODMAFilePicker::impl_getStaticSupportedServiceNames,
++ cppu::createSingleComponentFactory, 0, 0
++ },
++ {
++ ODMAFolderPicker::impl_createInstance,
++ ODMAFolderPicker::impl_getStaticImplementationName,
++ ODMAFolderPicker::impl_getStaticSupportedServiceNames,
++ cppu::createSingleComponentFactory, 0, 0
++ },
++ { 0, 0, 0, 0, 0, 0 }
++};
++
++extern "C"
++{
++SAL_DLLPUBLIC_EXPORT void SAL_CALL component_getImplementationEnvironment (
++ const sal_Char ** ppEnvTypeName, uno_Environment ** /* ppEnv */)
++{
++ *ppEnvTypeName = CPPU_CURRENT_LANGUAGE_BINDING_NAME;
++}
++
++SAL_DLLPUBLIC_EXPORT sal_Bool SAL_CALL component_writeInfo (
++ void * pServiceManager, void * pRegistryKey)
++{
++ return cppu::component_writeInfoHelper (
++ pServiceManager, pRegistryKey, g_entries);
++}
++
++SAL_DLLPUBLIC_EXPORT void * SAL_CALL component_getFactory (
++ const sal_Char * pImplementationName, void * pServiceManager, void * pRegistryKey)
++{
++ return cppu::component_getFactoryHelper (
++ pImplementationName, pServiceManager, pRegistryKey, g_entries);
++}
++
++} // extern "C"
+--- fpicker/source/odma/makefile.mk.old 2010-03-03 16:59:55.000000000 +0100
++++ fpicker/source/odma/makefile.mk 2010-03-03 16:59:55.000000000 +0100
+@@ -0,0 +1,79 @@
++#*************************************************************************
++#
++# OpenOffice.org - a multi-platform office productivity suite
++#
++# $RCSfile$
++#
++# $Revision: 12010 $
++#
++# last change: $Author: tml $ $Date: 2008-03-26 02:30:23 +0200 (on, 26 mar 2008) $
++#
++# The Contents of this file are made available subject to
++# the terms of GNU Lesser General Public License Version 2.1.
++#
++#
++# GNU Lesser General Public License Version 2.1
++# =============================================
++# Copyright 2005 by Sun Microsystems, Inc.
++# 901 San Antonio Road, Palo Alto, CA 94303, USA
++#
++# This library is free software; you can redistribute it and/or
++# modify it under the terms of the GNU Lesser General Public
++# License version 2.1, as published by the Free Software Foundation.
++#
++# This library 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 for more details.
++#
++# You should have received a copy of the GNU Lesser General Public
++# License along with this library; if not, write to the Free Software
++# Foundation, Inc., 59 Temple Place, Suite 330, Boston,
++# MA 02111-1307 USA
++#
++#*************************************************************************
++
++PRJ=..$/..
++
++PRJNAME=fpicker
++TARGET=fps_odma
++LIBTARGET=NO
++ENABLE_EXCEPTIONS=TRUE
++GEN_HID=TRUE
++
++# --- Settings -----------------------------------------------------
++
++.INCLUDE : settings.mk
++DLLPRE=
++
++# --- Files --------------------------------------------------------
++
++SLOFILES=\
++ $(SLO)$/ODMAFilePicker.obj \
++ $(SLO)$/ODMAFolderPicker.obj \
++ $(SLO)$/fps_odma.obj
++
++SHL1TARGET= $(TARGET).uno
++SHL1IMPLIB= i$(TARGET)
++SHL1OBJS= $(SLOFILES)
++SHL1STDLIBS=\
++ $(ODMA_LIB_LIB) \
++ $(SVTOOLLIB) \
++ $(TKLIB) \
++ $(VCLLIB) \
++ $(SVLLIB) \
++ $(UNOTOOLSLIB) \
++ $(TOOLSLIB) \
++ $(UCBHELPERLIB) \
++ $(COMPHELPERLIB) \
++ $(CPPUHELPERLIB) \
++ $(CPPULIB) \
++ $(SALLIB)
++
++SHL1VERSIONMAP=exports.map
++SHL1DEF= $(MISC)$/$(SHL1TARGET).def
++DEF1NAME= $(SHL1TARGET)
++
++# --- Targets ------------------------------------------------------
++
++.INCLUDE : target.mk
+--- solenv/inc/libs.mk.old 2010-03-03 16:59:33.000000000 +0100
++++ solenv/inc/libs.mk 2010-03-03 16:59:55.000000000 +0100
+@@ -32,6 +32,9 @@ LIBSMKREV!:="$$Revision: 1.134.2.3 $$"
+
+ .IF ("$(GUI)"=="UNX" || "$(COM)"=="GCC") && "$(GUI)"!="OS2"
+
++# No ODMA on UNX
++ODMA_LIB_LIB=
++
+ #
+ #externe libs in plattform.mk
+ #
+@@ -346,6 +349,7 @@ UNOPKGAPPLIB=-lunopkgapp
+
+ .ELSE # ("$(GUI)"=="UNX" || "$(COM)"=="GCC") && "$(GUI)"!="OS2"
+
++ODMA_LIB_LIB=odma_lib.lib
+ AWTLIB*=jawt.lib
+ AVMEDIALIB=iavmedia.lib
+ ICUINLIB=icuin.lib
+--- svtools/inc/svtools/miscopt.hxx.old 2009-10-07 15:06:52.000000000 +0200
++++ svtools/inc/svtools/miscopt.hxx 2010-03-03 16:59:55.000000000 +0100
+@@ -113,6 +113,10 @@ class SVT_DLLPUBLIC SvtMiscOptions: publ
+ void SetUseSystemFileDialog( sal_Bool bSet );
+ sal_Bool IsUseSystemFileDialogReadOnly() const;
+
++ sal_Bool TryODMADialog() const;
++ void SetTryODMADialog( sal_Bool bSet );
++ sal_Bool IsTryUseODMADialogReadOnly() const;
++
+ sal_Bool IsPluginsEnabled() const;
+ void SetPluginsEnabled( sal_Bool bEnable );
+ sal_Bool IsPluginsEnabledReadOnly() const;
+--- svtools/source/config/miscopt.cxx.old 2010-03-03 16:59:44.000000000 +0100
++++ svtools/source/config/miscopt.cxx 2010-03-03 16:59:55.000000000 +0100
+@@ -85,8 +85,10 @@ using namespace ::com::sun::star;
+ #define PROPERTYHANDLE_SYMBOLSTYLE 4
+ #define PROPERTYNAME_USESYSTEMPRINTDIALOG ASCII_STR("UseSystemPrintDialog")
+ #define PROPERTYHANDLE_USESYSTEMPRINTDIALOG 5
++#define PROPERTYNAME_TRYODMADIALOG ASCII_STR("TryODMADialog")
++#define PROPERTYHANDLE_TRYODMADIALOG 6
+
+-#define PROPERTYCOUNT 6
++#define PROPERTYCOUNT 7
+
+ #define VCL_TOOLBOX_STYLE_FLAT ((USHORT)0x0004) // from <vcl/toolbox.hxx>
+
+@@ -106,6 +108,8 @@ class SvtMiscOptions_Impl : public Confi
+ LinkList aList;
+ sal_Bool m_bUseSystemFileDialog;
+ sal_Bool m_bIsUseSystemFileDialogRO;
++ sal_Bool m_bTryODMADialog;
++ sal_Bool m_bIsTryODMADialogRO;
+ sal_Bool m_bPluginsEnabled;
+ sal_Bool m_bIsPluginsEnabledRO;
+ sal_Int16 m_nSymbolsSize;
+@@ -183,6 +187,15 @@ class SvtMiscOptions_Impl : public Confi
+ inline sal_Bool IsUseSystemFileDialogReadOnly() const
+ { return m_bIsUseSystemFileDialogRO; }
+
++ inline sal_Bool TryODMADialog() const
++ { return m_bTryODMADialog; }
++
++ inline void SetTryODMADialog( sal_Bool bSet )
++ { m_bTryODMADialog = bSet; SetModified(); }
++
++ inline sal_Bool IsTryUseODMADialogReadOnly() const
++ { return m_bIsTryODMADialogRO; }
++
+ inline sal_Bool IsPluginsEnabled() const
+ { return m_bPluginsEnabled; }
+
+@@ -307,6 +320,8 @@ SvtMiscOptions_Impl::SvtMiscOptions_Impl
+
+ , m_bUseSystemFileDialog( sal_False )
+ , m_bIsUseSystemFileDialogRO( sal_False )
++ , m_bTryODMADialog( sal_False )
++ , m_bIsTryODMADialogRO( sal_False )
+ , m_bPluginsEnabled( sal_False )
+ , m_bIsPluginsEnabledRO( sal_False )
+ , m_nSymbolsSize( 0 )
+@@ -388,6 +403,16 @@ SvtMiscOptions_Impl::SvtMiscOptions_Impl
+ break;
+ }
+
++ case PROPERTYHANDLE_TRYODMADIALOG :
++ {
++ if( !(seqValues[nProperty] >>= m_bTryODMADialog) )
++ {
++ DBG_ERROR("Wrong type of \"Misc\\TryODMADialog\"!" );
++ }
++ m_bIsTryODMADialogRO = seqRO[nProperty];
++ break;
++ }
++
+ case PROPERTYHANDLE_SYMBOLSTYLE :
+ {
+ ::rtl::OUString aSymbolsStyle;
+@@ -491,6 +516,13 @@ void SvtMiscOptions_Impl::Load( const Se
+ }
+ }
+ break;
++ case PROPERTYHANDLE_TRYODMADIALOG : {
++ if( !(seqValues[nProperty] >>= m_bTryODMADialog) )
++ {
++ DBG_ERROR("Wrong type of \"Misc\\TryODMADialog\"!" );
++ }
++ }
++ break;
+ case PROPERTYHANDLE_SYMBOLSTYLE : {
+ ::rtl::OUString aSymbolsStyle;
+ if( seqValues[nProperty] >>= aSymbolsStyle )
+@@ -637,6 +669,13 @@ void SvtMiscOptions_Impl::Commit()
+ break;
+ }
+
++ case PROPERTYHANDLE_TRYODMADIALOG :
++ {
++ if ( !m_bIsTryODMADialogRO )
++ seqValues[nProperty] <<= m_bTryODMADialog;
++ break;
++ }
++
+ case PROPERTYHANDLE_SYMBOLSTYLE :
+ {
+ if ( !m_bIsSymbolsStyleRO )
+@@ -669,7 +708,8 @@ Sequence< OUString > SvtMiscOptions_Impl
+ PROPERTYNAME_TOOLBOXSTYLE,
+ PROPERTYNAME_USESYSTEMFILEDIALOG,
+ PROPERTYNAME_SYMBOLSTYLE,
+- PROPERTYNAME_USESYSTEMPRINTDIALOG
++ PROPERTYNAME_USESYSTEMPRINTDIALOG,
++ PROPERTYNAME_TRYODMADIALOG
+ };
+
+ // Initialize return sequence with these list ...
+@@ -737,6 +777,21 @@ sal_Bool SvtMiscOptions::IsUseSystemFile
+ return m_pDataContainer->IsUseSystemFileDialogReadOnly();
+ }
+
++sal_Bool SvtMiscOptions::TryODMADialog() const
++{
++ return m_pDataContainer->TryODMADialog();
++}
++
++void SvtMiscOptions::SetTryODMADialog( sal_Bool bEnable )
++{
++ m_pDataContainer->SetTryODMADialog( bEnable );
++}
++
++sal_Bool SvtMiscOptions::IsTryUseODMADialogReadOnly() const
++{
++ return m_pDataContainer->IsTryUseODMADialogReadOnly();
++}
++
+ sal_Bool SvtMiscOptions::IsPluginsEnabled() const
+ {
+ return m_pDataContainer->IsPluginsEnabled();
+--- officecfg/registry/schema/org/openoffice/Office/Common.xcs.old 2010-03-03 16:59:50.000000000 +0100
++++ officecfg/registry/schema/org/openoffice/Office/Common.xcs 2010-03-03 16:59:55.000000000 +0100
+@@ -5731,6 +5731,13 @@ Dymamic border coloring means that when
+ </info>
+ <value>false</value>
+ </prop>
++ <prop oor:name="TryODMADialog" oor:type="xs:boolean">
++ <info>
++ <author>tml</author>
++ <desc>Determines whether to show the document creation and selection of the machine's default ODMA (Open Document Management Architecture) DMS (Document Management System). If true, and the machine has a DMS available, the DMS's dialog will be displayed. That dialog then gives the opportunity to use the application's dialog instead, which means the normal system file and folder pickers will be displayed. Relevant only on Windows.</desc>
++ </info>
++ <value>false</value>
++ </prop>
+ <prop oor:name="SymbolSet" oor:type="xs:short">
+ <!-- UIHints: Tools Options General View -->
+ <info>
+--- svx/source/cui/optgdlg.src.old 2010-03-03 16:59:44.000000000 +0100
++++ svx/source/cui/optgdlg.src 2010-03-03 16:59:55.000000000 +0100
+@@ -115,34 +115,41 @@ TabPage OFA_TP_MISC
+ Size = MAP_APPFONT( WHOLE_WIDTH - COL1, RSC_CD_CHECKBOX_HEIGHT );
+ Text [ en-US ] = "~Use %PRODUCTNAME dialogs";
+ };
++ CheckBox CB_ODMADLG
++ {
++ Pos = MAP_APPFONT( COL1, ROW8 );
++ Size = MAP_APPFONT( WHOLE_WIDTH - COL4, RSC_CD_CHECKBOX_HEIGHT );
++ Text [ en-US ] = "Show ODMA DMS dialogs first";
++ Text [ en-GB ] = "Show ODMA DMS dialogues first";
++ };
+ FixedLine FL_DOCSTATUS
+ {
+- Pos = MAP_APPFONT( COL0, ROW8 );
++ Pos = MAP_APPFONT( COL0, ROW9 );
+ Size = MAP_APPFONT( WHOLE_WIDTH, RSC_CD_FIXEDLINE_HEIGHT );
+ Text [ en-US ] = "Document status";
+ };
+ CheckBox CB_DOCSTATUS
+ {
+- Pos = MAP_APPFONT( COL1, ROW9 );
++ Pos = MAP_APPFONT( COL1, ROW10 );
+ Size = MAP_APPFONT( WHOLE_WIDTH - COL1, RSC_CD_CHECKBOX_HEIGHT );
+ Text [ en-US ] = "~Printing sets \"document modified\" status";
+ };
+ FixedLine FL_TWOFIGURE
+ {
+- Pos = MAP_APPFONT( COL0, ROW10 );
++ Pos = MAP_APPFONT( COL0, ROW11 );
+ Size = MAP_APPFONT( WHOLE_WIDTH, RSC_CD_FIXEDLINE_HEIGHT );
+ Text [ en-US ] = "Year (two digits)" ;
+ };
+ FixedText FT_INTERPRET
+ {
+- Pos = MAP_APPFONT( COL1, OFFS_TEXTBOX_FIXEDTEXT(ROW11) );
++ Pos = MAP_APPFONT( COL1, OFFS_TEXTBOX_FIXEDTEXT(ROW12) );
+ Size = MAP_APPFONT( DIFF( COL1, COL3), RSC_CD_FIXEDTEXT_HEIGHT );
+ Text [ en-US ] = "Interpret as years between";
+ };
+ NumericField NF_YEARVALUE
+ {
+ Border = TRUE ;
+- Pos = MAP_APPFONT( COL4, ROW11 );
++ Pos = MAP_APPFONT( COL4, ROW12 );
+ Size = MAP_APPFONT( EDIT_WIDTH, RSC_CD_TEXTBOX_HEIGHT );
+ Minimum = 1583 ;
+ Maximum = 9857 ;
+@@ -151,7 +158,7 @@ TabPage OFA_TP_MISC
+ };
+ FixedText FT_TOYEAR
+ {
+- Pos = MAP_APPFONT( COL6, OFFS_TEXTBOX_FIXEDTEXT(ROW11) );
++ Pos = MAP_APPFONT( COL6, OFFS_TEXTBOX_FIXEDTEXT(ROW12) );
+ Size = MAP_APPFONT( WHOLE_WIDTH - COL6, RSC_CD_FIXEDTEXT_HEIGHT );
+ Text [ en-US ] = "and " ;
+ };
+--- svx/source/cui/optgdlg.hrc.old 2009-10-08 16:17:55.000000000 +0200
++++ svx/source/cui/optgdlg.hrc 2010-03-03 16:59:55.000000000 +0100
+@@ -56,9 +56,10 @@
+ #define ROW6 (ROW5+RSC_CD_DROPDOWN_HEIGHT+ROWSPACE)
+ #define ROW7 (ROW6+RSC_CD_FIXEDLINE_HEIGHT+ROWSPACE)
+ #define ROW8 (ROW7+RSC_CD_CHECKBOX_HEIGHT+ROWSPACE)
+-#define ROW9 (ROW8+RSC_CD_FIXEDLINE_HEIGHT+ROWSPACE)
+-#define ROW10 (ROW9+RSC_CD_CHECKBOX_HEIGHT+ROWSPACE)
+-#define ROW11 (ROW10+RSC_CD_FIXEDLINE_HEIGHT+ROWSPACE)
++#define ROW9 (ROW8+RSC_CD_CHECKBOX_HEIGHT+ROWSPACE)
++#define ROW10 (ROW9+RSC_CD_FIXEDLINE_HEIGHT+ROWSPACE)
++#define ROW11 (ROW10+RSC_CD_CHECKBOX_HEIGHT+ROWSPACE)
++#define ROW12 (ROW11+RSC_CD_FIXEDLINE_HEIGHT+ROWSPACE)
+
+ #define DIFF(v1,v2) (v2-v1)
+ #define OFFS_TEXTBOX_FIXEDTEXT(base) (base+(RSC_CD_TEXTBOX_HEIGHT-RSC_CD_FIXEDTEXT_HEIGHT)/2)
+@@ -202,6 +203,7 @@
+ #define FT_HELPAGENT_TIME_UNIT 59
+ #define FL_DOCSTATUS 60
+ #define CB_DOCSTATUS 61
++#define CB_ODMADLG 62
+ #endif // #ifndef _SVX_OPTGDLG_HRC
+
+ // ******************************************************************* EOF
+--- svx/source/cui/optgdlg.hxx.old 2010-03-03 16:59:45.000000000 +0100
++++ svx/source/cui/optgdlg.hxx 2010-03-03 16:59:55.000000000 +0100
+@@ -59,6 +59,7 @@ private:
+ FixedLine aFileDlgFL;
+ ReadOnlyImage aFileDlgROImage;
+ CheckBox aFileDlgCB;
++ CheckBox aODMADlgCB;
+
+ FixedLine aPrintDlgFL;
+ CheckBox aPrintDlgCB;
+@@ -77,6 +78,9 @@ private:
+ DECL_LINK( TwoFigureConfigHdl, NumericField* );
+ DECL_LINK( HelpCheckHdl_Impl, CheckBox* );
+ DECL_LINK( HelpAgentResetHdl_Impl, PushButton* );
++#ifdef WNT
++ DECL_LINK( OnFileDlgToggled, CheckBox* );
++#endif
+ protected:
+ virtual int DeactivatePage( SfxItemSet* pSet = NULL );
+
+--- svx/source/cui/optgdlg.cxx.old 2010-03-03 16:59:45.000000000 +0100
++++ svx/source/cui/optgdlg.cxx 2010-03-03 16:59:55.000000000 +0100
+@@ -218,6 +218,7 @@ OfaMiscTabPage::OfaMiscTabPage(Window* p
+ aFileDlgFL ( this, SVX_RES( FL_FILEDLG ) ),
+ aFileDlgROImage ( this, SVX_RES( FI_FILEDLG_RO ) ),
+ aFileDlgCB ( this, SVX_RES( CB_FILEDLG ) ),
++ aODMADlgCB ( this, SVX_RES( CB_ODMADLG ) ),
+ aPrintDlgFL ( this, SVX_RES( FL_PRINTDLG ) ),
+ aPrintDlgCB ( this, SVX_RES( CB_PRINTDLG ) ),
+ aDocStatusFL ( this, SVX_RES( FL_DOCSTATUS ) ),
+@@ -241,6 +242,31 @@ OfaMiscTabPage::OfaMiscTabPage(Window* p
+ aPrintDlgCB.Hide();
+ #endif
+
++#ifdef WNT
++ aFileDlgCB.SetToggleHdl( LINK( this, OfaMiscTabPage, OnFileDlgToggled ) );
++#else
++ {
++ aODMADlgCB.Hide();
++ // rearrange the following controls
++ Point aNewPos = aDocStatusFL.GetPosPixel();
++ long nDelta = aNewPos.Y() - aODMADlgCB.GetPosPixel().Y();
++
++ Window* pWins[] =
++ {
++ &aDocStatusFL, &aDocStatusCB, &aTwoFigureFL,
++ &aInterpretFT, &aYearValueField, &aToYearFT
++ };
++ Window** pCurrent = pWins;
++ const sal_Int32 nCount = sizeof( pWins ) / sizeof( pWins[ 0 ] );
++ for ( sal_Int32 i = 0; i < nCount; ++i, ++pCurrent )
++ {
++ aNewPos = (*pCurrent)->GetPosPixel();
++ aNewPos.Y() -= nDelta;
++ (*pCurrent)->SetPosPixel( aNewPos );
++ }
++ }
++#endif
++
+ if ( !aFileDlgCB.IsVisible() )
+ {
+ // rearrange the following controls
+@@ -330,6 +356,14 @@ OfaMiscTabPage::OfaMiscTabPage(Window* p
+ }
+ }
+
++#ifdef WNT
++IMPL_LINK( OfaMiscTabPage, OnFileDlgToggled, CheckBox*, EMPTYARG )
++{
++ aODMADlgCB.Enable( !aFileDlgCB.IsChecked() );
++ return 0;
++}
++#endif
++
+ // -----------------------------------------------------------------------
+
+ OfaMiscTabPage::~OfaMiscTabPage()
+@@ -384,6 +418,13 @@ BOOL OfaMiscTabPage::FillItemSet( SfxIte
+ bModified = TRUE;
+ }
+
++ if ( aODMADlgCB.IsChecked() != aODMADlgCB.GetSavedValue() )
++ {
++ SvtMiscOptions aMiscOpt;
++ aMiscOpt.SetTryODMADialog( aODMADlgCB.IsChecked() );
++ bModified = TRUE;
++ }
++
+ if ( aDocStatusCB.IsChecked() != aDocStatusCB.GetSavedValue() )
+ {
+ SvtPrintWarningOptions aPrintOptions;
+@@ -433,6 +474,9 @@ void OfaMiscTabPage::Reset( const SfxIte
+ aPrintDlgCB.Check( !aMiscOpt.UseSystemPrintDialog() );
+ aPrintDlgCB.SaveValue();
+
++ aODMADlgCB.Check( aMiscOpt.TryODMADialog() );
++ aODMADlgCB.SaveValue();
++
+ SvtPrintWarningOptions aPrintOptions;
+ aDocStatusCB.Check(aPrintOptions.IsModifyDocumentOnPrintingAllowed());
+ aDocStatusCB.SaveValue();
+--- solenv/bin/modules/installer/windows/component.pm.old 2009-10-07 15:06:49.000000000 +0200
++++ solenv/bin/modules/installer/windows/component.pm 2010-03-03 16:59:55.000000000 +0100
+@@ -132,6 +132,11 @@ sub get_file_component_directory
+ return $installer::globals::templatefolder;
+ }
+
++ if ( $destdir =~ /\bPREDEFINED_OSWINSHELLNEWDIR\b/ )
++ {
++ return "WindowsShellNewFolder";
++ }
++
+ my $destination = $onefile->{'destination'};
+
+ installer::pathanalyzer::get_path_from_fullqualifiedname(\$destination);
+--- solenv/bin/modules/installer/windows/directory.pm.old 2009-10-07 15:06:49.000000000 +0200
++++ solenv/bin/modules/installer/windows/directory.pm 2010-03-03 16:59:55.000000000 +0100
+@@ -273,6 +273,12 @@ sub add_root_directories
+ my $oneline = "TARGETDIR\t\tSourceDir\n";
+ push(@{$directorytableref}, $oneline);
+
++ $oneline = "WindowsFolder\tTARGETDIR\tWindows\n";
++ push(@{$directorytableref}, $oneline);
++
++ $oneline = "WindowsShellNewFolder\tWindowsFolder\tShellNew\n";
++ push(@{$directorytableref}, $oneline);
++
+ my $sourcediraddon = "";
+ if (($installer::globals::addchildprojects) ||
+ ($installer::globals::patch) ||
+--- scp2/source/ooo/directory_ooo.scp.old 2010-03-03 16:59:25.000000000 +0100
++++ scp2/source/ooo/directory_ooo.scp 2010-03-03 16:59:55.000000000 +0100
+@@ -166,6 +166,11 @@ Directory gid_Dir_Shellnew
+ DosName = "shellnew";
+ End
+
++Directory gid_Dir_ShellnewToo
++ ParentID = gid_Dir_Program;
++ DosName = "shellnew2";
++End
++
+ #endif
+
+ Directory gid_Dir_User
+--- scp2/source/ooo/file_ooo.scp.old 2010-03-03 16:59:44.000000000 +0100
++++ scp2/source/ooo/file_ooo.scp 2010-03-03 16:59:55.000000000 +0100
+@@ -2319,24 +2319,56 @@ End
+
+ STD_SHELLNEW_FILE(gid_File_Shellnew_Ods_Soffice, soffice.ods)
+
++File gid_File_Shellnew2_Ods_Soffice
++ TXT_FILE_BODY;
++ Styles = (PACKED,WORKSTATION, OVERWRITE);
++ Dir = PREDEFINED_OSWINSHELLNEWDIR;
++ NetDir = gid_Dir_ShellnewToo;
++ Name = "soffice.ods";
++End
++
+ #endif
+
+ #ifdef WNT
+
+ STD_SHELLNEW_FILE(gid_File_Shellnew_Odg_Soffice, soffice.odg)
+
++File gid_File_Shellnew2_Odg_Soffice
++ TXT_FILE_BODY;
++ Styles = (PACKED,WORKSTATION, OVERWRITE);
++ Dir = PREDEFINED_OSWINSHELLNEWDIR;
++ NetDir = gid_Dir_ShellnewToo;
++ Name = "soffice.odg";
++End
++
+ #endif
+
+ #ifdef WNT
+
+ STD_SHELLNEW_FILE(gid_File_Shellnew_Odp_Soffice, soffice.odp)
+
++File gid_File_Shellnew2_Odp_Soffice
++ TXT_FILE_BODY;
++ Styles = (PACKED,WORKSTATION, OVERWRITE);
++ Dir = PREDEFINED_OSWINSHELLNEWDIR;
++ NetDir = gid_Dir_ShellnewToo;
++ Name = "soffice.odp";
++End
++
+ #endif
+
+ #ifdef WNT
+
+ STD_SHELLNEW_FILE(gid_File_Shellnew_Odt_Soffice, soffice.odt)
+
++File gid_File_Shellnew2_Odt_Soffice
++ TXT_FILE_BODY;
++ Styles = (PACKED,WORKSTATION, OVERWRITE);
++ Dir = PREDEFINED_OSWINSHELLNEWDIR;
++ NetDir = gid_Dir_ShellnewToo;
++ Name = "soffice.odt";
++End
++
+ #endif
+
+ #ifdef UNX
+--- framework/prj/build.lst.old 2009-10-08 16:17:54.000000000 +0200
++++ framework/prj/build.lst 2010-03-03 16:59:55.000000000 +0100
+@@ -1,4 +1,4 @@
+-fr framework : l10n svtools NULL
++fr framework : l10n svtools ucb NULL
+ fr framework usr1 - all fr_mkout NULL
+ fr framework\inc nmake - all fr_inc NULL
+ fr framework\source\constant nmake - all fr_constant fr_inc NULL
+--- framework/source/uielement/recentfilesmenucontroller.cxx.old 2009-10-08 16:17:54.000000000 +0200
++++ framework/source/uielement/recentfilesmenucontroller.cxx 2010-03-03 16:59:55.000000000 +0100
+@@ -65,6 +65,11 @@
+ #include <svtools/historyoptions.hxx>
+ #include <cppuhelper/implbase1.hxx>
+ #include <osl/file.hxx>
++#ifdef WNT
++#include <tools/prewin.h>
++#include <tools/postwin.h>
++#include <odma_lib.hxx>
++#endif
+ //#include <tools/solar.hrc>
+ #include <dispatch/uieventloghelper.hxx>
+
+@@ -213,6 +218,41 @@ void RecentFilesMenuController::fillPopu
+ else
+ aMenuTitle = aSystemPath;
+ }
++#ifdef WNT
++ else if ( aURL.GetProtocol() == INET_PROT_VND_SUN_STAR_ODMA && ::odma::DMSsAvailable ())
++ {
++ String aShortTitle = m_aRecentFilesItems.at( i ).aTitle;
++
++ // This is against all rules for using
++ // proper abstraction layers and whatnot.
++ // But figuring out how to do it "right"
++ // would have taken the whole week.
++ // So just call the odma_lib functions...
++ // (odma_lib is a thin layer on
++ // top of the ODMA32 DLL)
++
++ static ODMHANDLE handle = NULL;
++ static sal_Bool beenhere = sal_False;
++ ODMSTATUS status;
++
++ if ( ! beenhere )
++ {
++ status = NODMRegisterApp( &handle, ODM_API_VERSION, "sodma", NULL, NULL );
++ beenhere = sal_True;
++ }
++
++ if ( handle != NULL )
++ {
++ rtl::OUString s = aURL.GetMainURL( INetURLObject::DECODE_WITH_CHARSET, RTL_TEXTENCODING_MS_1252 );
++ s = s.copy( strlen ( "vnd.sun.star.odma:/" ) );
++ char title[47];
++ status = NODMGetDocInfo( handle, rtl::OUStringToOString( s, RTL_TEXTENCODING_MS_1252 ).pData->buffer, ODM_NAME, title, sizeof ( title ) );
++ aShortTitle = String::CreateFromAscii( title );
++ }
++ aMenuTitle += aShortTitle;
++ aTipHelpText = aURLString;
++ }
++#endif
+ else
+ {
+ // Use INetURLObject to abbreviate all other URLs
... etc. - the rest is truncated
More information about the ooo-build-commit
mailing list