GCC Code Coverage Report
Directory: src/ Exec Total Coverage
File: src/resources/resource.cpp Lines: 12 16 75.0 %
Date: 2017-11-29 Branches: 5 6 83.3 %

Line Branch Exec Source
1
/*
2
 *  The ManaPlus Client
3
 *  Copyright (C) 2004-2009  The Mana World Development Team
4
 *  Copyright (C) 2009-2010  The Mana Developers
5
 *  Copyright (C) 2011-2017  The ManaPlus Developers
6
 *
7
 *  This file is part of The ManaPlus Client.
8
 *
9
 *  This program is free software; you can redistribute it and/or modify
10
 *  it under the terms of the GNU General Public License as published by
11
 *  the Free Software Foundation; either version 2 of the License, or
12
 *  any later version.
13
 *
14
 *  This program is distributed in the hope that it will be useful,
15
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
16
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17
 *  GNU General Public License for more details.
18
 *
19
 *  You should have received a copy of the GNU General Public License
20
 *  along with this program.  If not, see <http://www.gnu.org/licenses/>.
21
 */
22
23
#include "resources/resource.h"
24
25
#include "logger.h"
26
27
#include "utils/cast.h"
28
29
#include "resources/resourcemanager/resourcemanager.h"
30
31
#include "debug.h"
32
33
201156
Resource::~Resource()
34
{
35
67052
}
36
37
102222
void Resource::incRef()
38
{
39
#ifdef DEBUG_IMAGES
40
    logger->log("before incRef for: %p", static_cast<void*>(this));
41
    mRefCount++;
42
    logger->log("after incRef: %p, %u", static_cast<void*>(this), mRefCount);
43
#else  // DEBUG_IMAGES
44
45
102222
    mRefCount++;
46
#endif  // DEBUG_IMAGES
47
102222
}
48
49
102224
void Resource::decRef()
50
{
51
#ifdef DEBUG_IMAGES
52
    logger->log("before decRef for: %p", static_cast<void*>(this));
53
#endif  // DEBUG_IMAGES
54
55
    // Reference may not already have reached zero
56
102224
    if (mRefCount == 0)
57
    {
58
8
        logger->log("Warning: mRefCount already zero for %s", mIdPath.c_str());
59
4
        return;
60
    }
61
62
102220
    mRefCount--;
63
64
#ifdef DEBUG_IMAGES
65
    logger->log("after decRef: %p, %u", static_cast<void*>(this), mRefCount);
66
#endif  // DEBUG_IMAGES
67
68

102220
    if (mRefCount == 0 && !mNotCount)
69
    {
70
        // Warn the manager that this resource is no longer used.
71
20834
        ResourceManager::release(this);
72
    }
73
}
74
75
int Resource::calcMemoryLocal() const
76
{
77
    return CAST_S32(sizeof(Resource)) +
78
        CAST_S32(mIdPath.size()) +
79
        CAST_S32(mSource.size());
80
}