diff --git a/Common/interface/BasicFileStream.hpp b/Common/interface/BasicFileStream.hpp index 7eb0f199d..8899192cd 100644 --- a/Common/interface/BasicFileStream.hpp +++ b/Common/interface/BasicFileStream.hpp @@ -1,5 +1,5 @@ /* - * Copyright 2019-2022 Diligent Graphics LLC + * Copyright 2019-2024 Diligent Graphics LLC * Copyright 2015-2019 Egor Yusov * * Licensed under the Apache License, Version 2.0 (the "License"); @@ -34,6 +34,7 @@ #include "../../Primitives/interface/DataBlob.h" #include "ObjectBase.hpp" #include "FileWrapper.hpp" +#include "RefCntAutoPtr.hpp" namespace Diligent { @@ -44,6 +45,8 @@ class BasicFileStream : public ObjectBase public: typedef ObjectBase TBase; + static RefCntAutoPtr Create(const Char* Path, EFileAccessMode Access = EFileAccessMode::Read); + BasicFileStream(IReferenceCounters* pRefCounters, const Char* Path, EFileAccessMode Access = EFileAccessMode::Read); diff --git a/Common/src/BasicFileStream.cpp b/Common/src/BasicFileStream.cpp index f550ff5e9..b9958425e 100644 --- a/Common/src/BasicFileStream.cpp +++ b/Common/src/BasicFileStream.cpp @@ -1,5 +1,5 @@ /* - * Copyright 2019-2022 Diligent Graphics LLC + * Copyright 2019-2024 Diligent Graphics LLC * Copyright 2015-2019 Egor Yusov * * Licensed under the Apache License, Version 2.0 (the "License"); @@ -31,6 +31,17 @@ namespace Diligent { +RefCntAutoPtr BasicFileStream::Create(const Char* Path, EFileAccessMode Access) +{ + if (Path == nullptr || Path[0] == '\0') + { + DEV_ERROR("Path must not be null or empty"); + return {}; + } + + return RefCntAutoPtr{MakeNewRCObj()(Path, Access)}; +} + BasicFileStream::BasicFileStream(IReferenceCounters* pRefCounters, const Char* Path, EFileAccessMode Access /* = EFileAccessMode::Read*/) : diff --git a/Graphics/GraphicsEngine/src/DefaultShaderSourceStreamFactory.cpp b/Graphics/GraphicsEngine/src/DefaultShaderSourceStreamFactory.cpp index 27a5fed2a..be1242573 100644 --- a/Graphics/GraphicsEngine/src/DefaultShaderSourceStreamFactory.cpp +++ b/Graphics/GraphicsEngine/src/DefaultShaderSourceStreamFactory.cpp @@ -1,5 +1,5 @@ /* - * Copyright 2019-2022 Diligent Graphics LLC + * Copyright 2019-2024 Diligent Graphics LLC * Copyright 2015-2019 Egor Yusov * * Licensed under the Apache License, Version 2.0 (the "License"); @@ -83,7 +83,7 @@ void DefaultShaderSourceStreamFactory::CreateInputStream2(const Char* RefCntAutoPtr pFileStream; if (FileSystem::FileExists(Path)) { - pFileStream = MakeNewRCObj()(Path, EFileAccessMode::Read); + pFileStream = BasicFileStream::Create(Path, EFileAccessMode::Read); if (!pFileStream->IsValid()) pFileStream.Release(); }