'************************************************************************* ' ' DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ' ' Copyright 2000, 2010 Oracle and/or its affiliates. ' ' OpenOffice.org - a multi-platform office productivity suite ' ' This file is part of OpenOffice.org. ' ' OpenOffice.org is free software: you can redistribute it and/or modify ' it under the terms of the GNU Lesser General Public License version 3 ' only, as published by the Free Software Foundation. ' ' OpenOffice.org is distributed in the hope that it will be useful, ' but WITHOUT ANY WARRANTY; without even the implied warranty of ' MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ' GNU Lesser General Public License version 3 for more details ' (a copy is included in the LICENSE file that accompanied this code). ' ' You should have received a copy of the GNU Lesser General Public License ' version 3 along with OpenOffice.org. If not, see ' ' for a copy of the LGPLv3 License. ' '************************************************************************* ***** '************************************************************************* ' Be sure that all variables are dimensioned: option explicit ' REQUIRED VARIABLES for interface/service tests: Global cFileName As String Global oFileAcc As Object Global oInputStream As Object Global oOutputStream As Object Global bInputStream As Boolean Global bOutputStream As Boolean Sub CreateObj() '************************************************************************* ' COMPONENT: ' stm.MarkableOutputStream '************************************************************************* On Error Goto ErrHndl bInputStream = false bOutputStream = false cFileName = utils.getTempFileURL("BasicMarkableIOStream.dat") oFileAcc = createUnoService("com.sun.star.ucb.SimpleFileAccess") oObj = createUnoService("com.sun.star.io.MarkableOutputStream") ResetStreams() Exit Sub ErrHndl: Test.Exception() End Sub Function getOutStream() As Object On Error Goto ErrHndl CloseStreams() oOutputStream = oFileAcc.openFileWrite(cFileName) bOutputStream = true oObj.setOutputStream(oOutputStream) getOutStream() = oOutputStream Exit Function ErrHndl: Test.Exception() getOutStream() = NULL_OBJECT End Function Function getInStream() As Object On Error Goto ErrHndl Dim oFI As Object CloseStreams() oInputStream = createUnoService("com.sun.star.io.MarkableInputStream") oFI = oFileAcc.openFileRead(cFileName) oInputStream.setInputStream(oFI) bInputStream = true getInStream() = oInputStream Exit Function ErrHndl: Test.Exception() getInStream() = NULL_OBJECT End Function Sub ResetStreams() On Error goto ErrHndl CloseStreams() oFileAcc.Kill(cFileName) oOutputStream = oFileAcc.openFileWrite(cFileName) bOutputStream = true oObj.setOutputStream(oOutputStream) Exit Sub ErrHndl: Test.Exception() resume next End Sub Sub CloseStreams() if bOutputStream then oObj.closeOutput() bOutputStream = false end if if bInputStream then oInputStream.closeInput() bInputStream = false end if End Sub Sub DisposeObj() if NOT isNULL(oObj) then oObj.closeOutput() End Sub