Mercurial > hg > orthanc
view OrthancFramework/Sources/SystemToolbox.h @ 4827:4cfd96732076
Support decoding of black-and-white images (with 1 bit per pixel), notably DICOM SEG
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Thu, 25 Nov 2021 15:52:54 +0100 |
parents | 8a7523da6a9b |
children | 7053502fbf97 |
line wrap: on
line source
/** * Orthanc - A Lightweight, RESTful DICOM Store * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics * Department, University Hospital of Liege, Belgium * Copyright (C) 2017-2021 Osimis S.A., Belgium * * This program is free software: you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public License * as published by the Free Software Foundation, either version 3 of * the License, or (at your option) 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this program. If not, see * <http://www.gnu.org/licenses/>. **/ #pragma once #include "OrthancFramework.h" // Must be before "ORTHANC_SANDBOXED" #if !defined(ORTHANC_SANDBOXED) # error The macro ORTHANC_SANDBOXED must be defined #endif #if ORTHANC_SANDBOXED == 1 # error The namespace SystemToolbox cannot be used in sandboxed environments #endif #include "Enumerations.h" #include <map> #include <vector> #include <string> #include <stdint.h> namespace Orthanc { class ORTHANC_PUBLIC SystemToolbox { public: static void USleep(uint64_t microSeconds); static ServerBarrierEvent ServerBarrier(const bool& stopFlag); static ServerBarrierEvent ServerBarrier(); static void ReadFile(std::string& content, const std::string& path, bool log); static void ReadFile(std::string& content, const std::string& path); static bool ReadHeader(std::string& header, const std::string& path, size_t headerSize); static void WriteFile(const void* content, size_t size, const std::string& path, bool callFsync); static void WriteFile(const void* content, size_t size, const std::string& path); static void WriteFile(const std::string& content, const std::string& path, bool callFsync); static void WriteFile(const std::string& content, const std::string& path); static void RemoveFile(const std::string& path); static uint64_t GetFileSize(const std::string& path); static void MakeDirectory(const std::string& path); static bool IsExistingFile(const std::string& path); static std::string GetPathToExecutable(); static std::string GetDirectoryOfExecutable(); static void ExecuteSystemCommand(const std::string& command, const std::vector<std::string>& arguments); static int GetProcessId(); static bool IsRegularFile(const std::string& path); static FILE* OpenFile(const std::string& path, FileMode mode); static std::string GetNowIsoString(bool utc); static void GetNowDicom(std::string& date, std::string& time, bool utc); static unsigned int GetHardwareConcurrency(); static MimeType AutodetectMimeType(const std::string& path); static void GetEnvironmentVariables(std::map<std::string, std::string>& env); static std::string InterpretRelativePath(const std::string& baseDirectory, const std::string& relativePath); static void ReadFileRange(std::string& content, const std::string& path, uint64_t start, // Inclusive uint64_t end, // Exclusive bool throwIfOverflow); static void GetMacAddresses(std::set<std::string>& target); }; }