浏览代码

report shape file location that failed to load, set loaded status to badfilereference if getAssetById can't even find noshape

AzaezelX 4 年之前
父节点
当前提交
6495ee16c6
共有 1 个文件被更改,包括 9 次插入5 次删除
  1. 9 5
      Engine/source/T3D/assets/ShapeAsset.cpp

+ 9 - 5
Engine/source/T3D/assets/ShapeAsset.cpp

@@ -274,7 +274,7 @@ bool ShapeAsset::loadShape()
 
    if (!mShape)
    {
-      Con::errorf("ShapeAsset::loadShape : failed to load shape file!");
+      Con::errorf("ShapeAsset::loadShape : failed to load shape file %s!", mFilePath);
       mLoadedState = BadFileReference;
       return false; //if it failed to load, bail out
    }
@@ -437,12 +437,16 @@ U32 ShapeAsset::getAssetById(StringTableEntry assetId, AssetPtr<ShapeAsset>* sha
    if ((*shapeAsset))
       return (*shapeAsset)->mLoadedState;
 
-   //Didn't work, so have us fall back to a placeholder asset
-   StringTableEntry noShapeId = StringTable->insert("Core_Rendering:noshape");
-   shapeAsset->setAssetId(noShapeId);
-
    if (shapeAsset->notNull())
    {
+      //Didn't work, so have us fall back to a placeholder asset
+      StringTableEntry noShapeId = StringTable->insert("Core_Rendering:noshape");
+      shapeAsset->setAssetId(noShapeId);
+
+      //handle noshape not being loaded itself
+      if ((*shapeAsset)->mLoadedState == BadFileReference)
+         return AssetErrCode::Failed;
+
       (*shapeAsset)->mLoadedState = AssetErrCode::UsingFallback;
       return AssetErrCode::UsingFallback;
    }