/*
* This source file is part of RmlUi, the HTML/CSS Interface Middleware
*
* For the latest information, see http://github.com/mikke89/RmlUi
*
* Copyright (c) 2008-2010 CodePoint Ltd, Shift Technology Ltd
* Copyright (c) 2019 The RmlUi Team, and contributors
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*
*/
#include "Shell.h"
#include
#ifdef RMLUI_PLATFORM_WIN32
#include
#else
#include
#endif
/// Loads the default fonts from the given path.
void Shell::LoadFonts(const char* directory)
{
Rml::String font_names[5];
font_names[0] = "Delicious-Roman.otf";
font_names[1] = "Delicious-Italic.otf";
font_names[2] = "Delicious-Bold.otf";
font_names[3] = "Delicious-BoldItalic.otf";
font_names[4] = "NotoEmoji-Regular.ttf";
const int fallback_face = 4;
for (size_t i = 0; i < sizeof(font_names) / sizeof(Rml::String); i++)
{
Rml::LoadFontFace(Rml::String(directory) + font_names[i], i == fallback_face);
}
}
enum class ListType { Files, Directories };
static Rml::StringList ListFilesOrDirectories(ListType type, const Rml::String& directory, const Rml::String& extension)
{
if (directory.empty())
return Rml::StringList();
Rml::StringList result;
#ifdef RMLUI_PLATFORM_WIN32
const Rml::String find_path = directory + "/*." + (extension.empty() ? Rml::String("*") : extension);
_finddata_t find_data;
intptr_t find_handle = _findfirst(find_path.c_str(), &find_data);
if (find_handle != -1)
{
do
{
if (strcmp(find_data.name, ".") == 0 ||
strcmp(find_data.name, "..") == 0)
continue;
bool is_directory = ((find_data.attrib & _A_SUBDIR) == _A_SUBDIR);
bool is_file = (!is_directory && ((find_data.attrib & _A_NORMAL) == _A_NORMAL));
if (((type == ListType::Files) && is_file) ||
((type == ListType::Directories) && is_directory))
{
result.push_back(find_data.name);
}
} while (_findnext(find_handle, &find_data) == 0);
_findclose(find_handle);
}
#else
struct dirent** file_list = nullptr;
const int file_count = scandir(directory.c_str(), &file_list, 0, alphasort);
if (file_count == -1)
return Rml::StringList();
for (int i = 0; i < file_count; i++)
{
if (strcmp(file_list[i]->d_name, ".") == 0 ||
strcmp(file_list[i]->d_name, "..") == 0)
continue;
bool is_directory = ((file_list[i]->d_type & DT_DIR) == DT_DIR);
bool is_file = ((file_list[i]->d_type & DT_REG) == DT_REG);
if (!extension.empty())
{
const char* last_dot = strrchr(file_list[i]->d_name, '.');
if (!last_dot || strcmp(last_dot + 1, extension.c_str()) != 0)
continue;
}
if ((type == ListType::Files && is_file) ||
(type == ListType::Directories && is_directory))
{
result.push_back(file_list[i]->d_name);
}
}
free(file_list);
#endif
return result;
}
Rml::StringList Shell::ListDirectories(const Rml::String& in_directory)
{
return ListFilesOrDirectories(ListType::Directories, in_directory, Rml::String());
}
Rml::StringList Shell::ListFiles(const Rml::String& in_directory, const Rml::String& extension)
{
return ListFilesOrDirectories(ListType::Files, in_directory, extension);
}