summaryrefslogtreecommitdiff
path: root/cmake/platforms/windows/rawfiles.h
blob: 4903788ed09a2dc96cb617e6b5eb6ca2be922c51 (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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
/******************************************************************************
 *  rawfiles.h - code for class 'RawFiles'- a module that produces HTML HREFs
 *            pointing to actual text desired.  Uses standard
 *            files:    ot and nt using indexs ??.bks ??.cps ??.vss
 *
 * $Id: rawfiles.h 2599 2011-02-12 05:11:09Z scribe $
 *
 * Copyright 1998 CrossWire Bible Society (http://www.crosswire.org)
 *    CrossWire Bible Society
 *    P. O. Box 2528
 *    Tempe, AZ  85280-2528
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License as published by the
 * Free Software Foundation version 2.
 *
 * This program 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
 * General Public License for more details.
 *
 */

#ifndef RAWFILES_H
#define RAWFILES_H

#include <rawverse.h>
#include <swcom.h>

#include <defs.h>

SWORD_NAMESPACE_START

class SWDLLEXPORT RawFiles : public RawVerse, public SWCom {

    const char *getNextFilename();

public:


    RawFiles(const char *ipath, const char *iname = 0, const char *idesc = 0,
            SWDisplay *idisp = 0, SWTextEncoding encoding = ENC_UNKNOWN,
            SWTextDirection dir = DIRECTION_LTR, SWTextMarkup markup = FMT_UNKNOWN,
            const char *ilang = 0);
    virtual ~RawFiles();
    virtual SWBuf &getRawEntryBuf();

    // write interface ----------------------------
    /** Is the module writable? :)
    * @return yes or no
    */
    virtual bool isWritable();

    /** Creates a new module
    * @param path The first parameter is path of the new module
    * @return error
    */
    static char createModule(const char *);

    /** Modify the current module entry text
    * - only if module @ref isWritable
    * @return *this
    */
    virtual void setEntry(const char *inbuf, long len = -1);    // Modify current module entry

    /** Link the current module entry to another module entry
    * - only if module @ref isWritable
    * @return *this
    */
    virtual void linkEntry(const SWKey *linkKey);    // Link current module entry to other module entry

    /** Delete current module entry - only if module @ref isWritable
    *
    */
    virtual void deleteEntry();
    // end write interface ------------------------


    // OPERATORS -----------------------------------------------------------------

    SWMODULE_OPERATORS

};

SWORD_NAMESPACE_END
#endif