blob: 4d68e67800652497fc4c48171cb7381b18adce24 [file] [log] [blame]
/*
* Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* This code 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
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
#ifndef RESOURCES_H
#define RESOURCES_H
#include "WinSysInfo.h"
class StringResource;
/**
* Classes for resource loading.
* Common use cases:
* - check if resource is available and save it to file:
* Resource res(_T("MyResource"), _T("CustomResourceType"));
* if (res.available()) {
* res.saveToFile(_T("c:\\temp\\my_resource.bin"));
* }
*
* - get string resource:
* 1) if the resource is not available, exception is thrown:
* tstring str = StringResource(MAKEINTRESOURCE(resID)).string();
*
* 2) nothrow method (returns default value if the resource is not available):
* a) returns empty string on error:
* tstring str = StringResource(MAKEINTRESOURCE(resID)).string(std::nothrow);
*
* b) returns provided default value on error:
* tstring str = StringResource(MAKEINTRESOURCE(resID)).string(std::nothrow, _T("defaultValue"));
*/
class Resource {
public:
// name and type can be specified by string id,
// by integer id (RT_* constants or MAKEINTRESOURCE)
Resource(LPCWSTR name, LPCWSTR type,
HINSTANCE module = SysInfo::getCurrentModuleHandle());
Resource(UINT id, LPCWSTR type,
HINSTANCE module = SysInfo::getCurrentModuleHandle());
bool available() const;
// all this methods throw exception if the resource is not available
unsigned size() const;
// gets raw pointer to the resource data
LPCVOID rawData() const;
// save the resource to a file
void saveToFile(const std::wstring &filePath) const;
typedef std::vector<BYTE> ByteArray;
// returns the resource as byte array
ByteArray binary() const;
friend class StringResource;
private:
std::wstring nameStr;
LPCWSTR namePtr; // can be integer value or point to nameStr.c_str()
std::wstring typeStr;
LPCWSTR typePtr; // can be integer value or point to nameStr.c_str()
HINSTANCE instance;
void init(LPCWSTR name, LPCWSTR type, HINSTANCE module);
// generates error message
std::string getErrMsg(const std::string &descr) const;
HRSRC findResource() const;
LPVOID getPtr(DWORD &size) const;
private:
// disable copying
Resource(const Resource&);
Resource& operator = (const Resource&);
};
// Note: string resources are returned utf16 or utf8 encoded.
// To get Windows-encoded string (utf16/ACP) use tstrings::toWinString().
class StringResource {
public:
// string resource is always identified by integer id
StringResource(UINT resourceId, HINSTANCE moduleHandle = SysInfo::getCurrentModuleHandle())
: impl(resourceId, RT_STRING, moduleHandle) {}
// returns the resource as string
tstring string() const;
// nothrow version (logs error)
tstring string(const std::nothrow_t &, const tstring &defValue = tstring()) const throw();
bool available() const throw() {
return impl.available();
}
unsigned size() const {
return impl.size();
}
static tstring load(UINT resourceId,
HINSTANCE moduleHandle = SysInfo::getCurrentModuleHandle()) {
return StringResource(resourceId, moduleHandle).string();
}
static tstring load(const std::nothrow_t &, UINT resourceId,
HINSTANCE moduleHandle = SysInfo::getCurrentModuleHandle()) throw () {
return StringResource(resourceId, moduleHandle).string(std::nothrow);
}
private:
Resource impl;
};
#endif // RESOURCES_H