[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