diff options
author | Andrei Karas <akaras@inbox.ru> | 2016-05-25 22:17:03 +0300 |
---|---|---|
committer | Andrei Karas <akaras@inbox.ru> | 2016-05-25 22:17:03 +0300 |
commit | ea0809826d530f82dc84f8e046b3d11a797dd716 (patch) | |
tree | 65b8141e1c9d3591ad95f771a7ca2c4667865e81 /src/resources | |
parent | 5994a6198ac35ea149a7211213dc296ee7406f44 (diff) | |
download | mv-ea0809826d530f82dc84f8e046b3d11a797dd716.tar.gz mv-ea0809826d530f82dc84f8e046b3d11a797dd716.tar.bz2 mv-ea0809826d530f82dc84f8e046b3d11a797dd716.tar.xz mv-ea0809826d530f82dc84f8e046b3d11a797dd716.zip |
Move subimageset load function from resourcemanager into separate file.
Diffstat (limited to 'src/resources')
-rw-r--r-- | src/resources/loaders/subimagesetloader.cpp | 78 | ||||
-rw-r--r-- | src/resources/loaders/subimagesetloader.h | 38 | ||||
-rw-r--r-- | src/resources/resourcemanager/resourcemanager.cpp | 35 | ||||
-rw-r--r-- | src/resources/resourcemanager/resourcemanager.h | 4 |
4 files changed, 116 insertions, 39 deletions
diff --git a/src/resources/loaders/subimagesetloader.cpp b/src/resources/loaders/subimagesetloader.cpp new file mode 100644 index 000000000..39068bce3 --- /dev/null +++ b/src/resources/loaders/subimagesetloader.cpp @@ -0,0 +1,78 @@ +/* + * The ManaPlus Client + * Copyright (C) 2004-2009 The Mana World Development Team + * Copyright (C) 2009-2010 The Mana Developers + * Copyright (C) 2011-2016 The ManaPlus Developers + * + * This file is part of The ManaPlus Client. + * + * 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; either version 2 of the License, or + * any later version. + * + * 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. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + */ + +#include "logger.h" + +#include "resources/image.h" +#include "resources/imageset.h" + +#include "resources/resourcemanager/resourcemanager.h" + +#include "resources/loaders/subimagesetloader.h" + +#include "utils/checkutils.h" +#include "utils/stringutils.h" + +#include "debug.h" + +namespace +{ + struct SubImageSetLoader final + { + Image *parent; + int width; + int height; + static Resource *load(const void *const v) + { + if (!v) + return nullptr; + + const SubImageSetLoader *const + rl = static_cast<const SubImageSetLoader *const>(v); + + if (!rl->parent) + return nullptr; + ImageSet *const res = new ImageSet(rl->parent, + rl->width, rl->height); + return res; + } + }; +} // namespace + +ImageSet *Loader::getSubImageSet(Image *const parent, + const int width, + const int height) +{ + if (!parent) + return nullptr; + + const SubImageSetLoader rl = { parent, width, height }; + std::string str = std::string( + parent->getIdPath()).append( + ", set[").append(toString( + width)).append( + "x").append(toString( + height)).append( + "]"); + return static_cast<ImageSet*>(resourceManager->get(str, + SubImageSetLoader::load, &rl)); +} diff --git a/src/resources/loaders/subimagesetloader.h b/src/resources/loaders/subimagesetloader.h new file mode 100644 index 000000000..b50f58647 --- /dev/null +++ b/src/resources/loaders/subimagesetloader.h @@ -0,0 +1,38 @@ +/* + * The ManaPlus Client + * Copyright (C) 2004-2009 The Mana World Development Team + * Copyright (C) 2009-2010 The Mana Developers + * Copyright (C) 2011-2016 The ManaPlus Developers + * + * This file is part of The ManaPlus Client. + * + * 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; either version 2 of the License, or + * any later version. + * + * 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. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + */ + +#ifndef RESOURCES_LOADERS_SUBIMAGESETLOADER_H +#define RESOURCES_LOADERS_SUBIMAGESETLOADER_H + +#include "localconsts.h" + +class Image; +class ImageSet; + +namespace Loader +{ + ImageSet *getSubImageSet(Image *const parent, + const int width, + const int height) A_WARN_UNUSED; +} // namespace Loader + +#endif // RESOURCES_LOADERS_SUBIMAGESETLOADER_H diff --git a/src/resources/resourcemanager/resourcemanager.cpp b/src/resources/resourcemanager/resourcemanager.cpp index 2f32b7c71..539e89d3a 100644 --- a/src/resources/resourcemanager/resourcemanager.cpp +++ b/src/resources/resourcemanager/resourcemanager.cpp @@ -527,41 +527,6 @@ Resource *ResourceManager::get(const std::string &idPath, return resource; } -struct SubImageSetLoader final -{ - ResourceManager *manager; - Image *parent; - int width, height; - static Resource *load(const void *const v) - { - if (!v) - return nullptr; - - const SubImageSetLoader *const - rl = static_cast<const SubImageSetLoader *const>(v); - if (!rl->manager) - return nullptr; - - if (!rl->parent) - return nullptr; - ImageSet *const res = new ImageSet(rl->parent, rl->width, rl->height); - return res; - } -}; - -ImageSet *ResourceManager::getSubImageSet(Image *const parent, - const int width, const int height) -{ - if (!parent) - return nullptr; - - const SubImageSetLoader rl = { this, parent, width, height }; - std::stringstream ss; - ss << parent->getIdPath() << ", set[" << width << "x" << height << "]"; - return static_cast<ImageSet*>(get(ss.str(), - SubImageSetLoader::load, &rl)); -} - #ifdef USE_OPENGL struct AtlasLoader final { diff --git a/src/resources/resourcemanager/resourcemanager.h b/src/resources/resourcemanager/resourcemanager.h index 2c54aeb5a..d8b080b68 100644 --- a/src/resources/resourcemanager/resourcemanager.h +++ b/src/resources/resourcemanager/resourcemanager.h @@ -133,10 +133,6 @@ class ResourceManager final : public MemoryCounter */ bool addResource(const std::string &idPath, Resource *const resource); - ImageSet *getSubImageSet(Image *const parent, - const int width, - const int height) A_WARN_UNUSED; - #ifdef USE_OPENGL Resource *getAtlas(const std::string &name, const StringVect &files) A_WARN_UNUSED; |