summaryrefslogtreecommitdiff
path: root/include/tools/tempfile.hxx
blob: 8ef8c574cf7cc7954c08ebd2a95cfc0317ab9c3c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
 * This file is part of the LibreOffice project.
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
 *
 * This file incorporates work covered by the following license notice:
 *
 *   Licensed to the Apache Software Foundation (ASF) under one or more
 *   contributor license agreements. See the NOTICE file distributed
 *   with this work for additional information regarding copyright
 *   ownership. The ASF licenses this file to you under the Apache
 *   License, Version 2.0 (the "License"); you may not use this file
 *   except in compliance with the License. You may obtain a copy of
 *   the License at http://www.apache.org/licenses/LICENSE-2.0 .
 */
#ifndef _TOOLS_TEMPFILE_HXX
#define _TOOLS_TEMPFILE_HXX

#include <tools/string.hxx>
#include "tools/toolsdllapi.h"

struct TempFile_Impl;
class TOOLS_DLLPUBLIC TempFile
{
    TempFile_Impl*  pImp;
    sal_Bool        bKillingFileEnabled;

public:
    /** Create a temporary file in the default tempfile folder. */
    TempFile();

    /** Create a temporary file in the default tempfile folder; its name starts
        with some given characters followed by a counter ( example:
        rLeadingChars="abc" means "abc0", "abc1" and so on, depending on
        existing files in that folder ).

        The extension string may be f.e. ".txt" or "", if no extension string is
        given, ".tmp" is used.
    */
    TempFile( const String& rLeadingChars, const String* pExtension=NULL );

    /** TempFile will be removed from disk in dtor if EnableKillingTempFile was
        called before. TempDirs will be removed recursively in that case. */
    ~TempFile();

    sal_Bool IsValid() const;

    /** Returns the real name of the tempfile in file URL scheme. */
    String GetName() const;

    /** If enabled the file will be removed from disk when the dtor is called
        (default is not enabled) */
    void EnableKillingFile( sal_Bool bEnable=sal_True ) { bKillingFileEnabled = bEnable; }

    sal_Bool IsKillingFileEnabled() const { return bKillingFileEnabled; }

    /** Only create a name for a temporary file that would be valid at that moment. */
    static String   CreateTempName();
};

#endif

/* vim:set shiftwidth=4 softtabstop=4 expandtab: */