[ox] Remove panicing ModelValue operators
This commit is contained in:
		
							
								
								
									
										32
									
								
								deps/nostalgia/deps/ox/src/ox/mc/test/tests.cpp
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										32
									
								
								deps/nostalgia/deps/ox/src/ox/mc/test/tests.cpp
									
									
									
									
										vendored
									
									
								
							| @@ -320,27 +320,27 @@ std::map<ox::StringView, ox::Error(*)()> tests = { | ||||
| 				ox::ModelObject testOut; | ||||
| 				oxReturnError(testOut.setType(type)); | ||||
| 				oxAssert(ox::readMC(dataBuff.data(), dataBuff.size(), &testOut), "Data read failed"); | ||||
| 				oxAssert(testOut["Int"].get<int>() == testIn.Int, "testOut.Int failed"); | ||||
| 				oxAssert(testOut["Bool"].get<bool>() == testIn.Bool, "testOut.Bool failed"); | ||||
| 				oxAssert(testOut["BString"].get<ox::String>() == testIn.BString.c_str(), "testOut.String failed"); | ||||
| 				oxAssert(testOut["String"].get<ox::String>() == testIn.String, "testOut.String failed"); | ||||
| 				auto &testOutStruct = testOut["Struct"].get<ox::ModelObject>(); | ||||
| 				auto &testOutUnion = testOut["Union"].get<ox::ModelUnion>(); | ||||
| 				auto &testOutList = testOut["List"].get<ox::ModelValueVector>(); | ||||
| 				auto testOutStructCopy = testOut["Struct"].get<ox::ModelObject>(); | ||||
| 				auto testOutUnionCopy = testOut["Union"].get<ox::ModelUnion>(); | ||||
| 				auto testOutListCopy = testOut["List"].get<ox::ModelValueVector>(); | ||||
| 				oxAssert(testOut.at("Int").unwrap()->get<int>() == testIn.Int, "testOut.Int failed"); | ||||
| 				oxAssert(testOut.at("Bool").unwrap()->get<bool>() == testIn.Bool, "testOut.Bool failed"); | ||||
| 				oxAssert(testOut.at("BString").unwrap()->get<ox::String>() == testIn.BString.c_str(), "testOut.String failed"); | ||||
| 				oxAssert(testOut.at("String").unwrap()->get<ox::String>() == testIn.String, "testOut.String failed"); | ||||
| 				auto &testOutStruct = testOut.at("Struct").unwrap()->get<ox::ModelObject>(); | ||||
| 				auto &testOutUnion = testOut.at("Union").unwrap()->get<ox::ModelUnion>(); | ||||
| 				auto &testOutList = testOut.at("List").unwrap()->get<ox::ModelValueVector>(); | ||||
| 				auto testOutStructCopy = testOut.at("Struct").unwrap()->get<ox::ModelObject>(); | ||||
| 				auto testOutUnionCopy = testOut.at("Union").unwrap()->get<ox::ModelUnion>(); | ||||
| 				auto testOutListCopy = testOut.at("List").unwrap()->get<ox::ModelValueVector>(); | ||||
| 				oxAssert(testOutStruct.typeName() == TestStructNest::TypeName, "ModelObject TypeName failed"); | ||||
| 				oxAssert(testOutStruct.typeVersion() == TestStructNest::TypeVersion, "ModelObject TypeVersion failed"); | ||||
| 				oxAssert(testOutStruct["Bool"].get<bool>() == testIn.Struct.Bool, "testOut.Struct.Bool failed"); | ||||
| 				oxAssert(testOutStruct["BString"].get<ox::String>() == testIn.Struct.BString.c_str(), "testOut.Struct.BString failed"); | ||||
| 				oxAssert(testOut["unionIdx"].get<int>() == testIn.unionIdx, "testOut.unionIdx failed"); | ||||
| 				oxAssert(testOutStruct.at("Bool").unwrap()->get<bool>() == testIn.Struct.Bool, "testOut.Struct.Bool failed"); | ||||
| 				oxAssert(testOutStruct.at("BString").unwrap()->get<ox::String>() == testIn.Struct.BString.c_str(), "testOut.Struct.BString failed"); | ||||
| 				oxAssert(testOut.at("unionIdx").unwrap()->get<int>() == testIn.unionIdx, "testOut.unionIdx failed"); | ||||
| 				oxAssert(testOutUnion.unionIdx() == testIn.unionIdx, "testOut.Union idx wrong"); | ||||
| 				oxAssert(testOutUnion["Int"].get<uint32_t>() == testIn.Union.Int, "testOut.Union.Int failed"); | ||||
| 				oxAssert(testOutUnion.at("Int").unwrap()->get<uint32_t>() == testIn.Union.Int, "testOut.Union.Int failed"); | ||||
| 				oxAssert(testOutList[0].get<uint32_t>() == testIn.List[0], "testOut.List[0] failed"); | ||||
| 				oxAssert(testOutList[1].get<uint32_t>() == testIn.List[1], "testOut.Struct.List[1] failed"); | ||||
| 				oxAssert(testOutStructCopy["Bool"].get<bool>() == testIn.Struct.Bool, "testOut.Struct.Bool (copy) failed"); | ||||
| 				oxAssert(testOutStructCopy["BString"].get<ox::String>() == testIn.Struct.BString.c_str(), "testOut.Struct.BString (copy) failed"); | ||||
| 				oxAssert(testOutStructCopy.at("Bool").unwrap()->get<bool>() == testIn.Struct.Bool, "testOut.Struct.Bool (copy) failed"); | ||||
| 				oxAssert(testOutStructCopy.at("BString").unwrap()->get<ox::String>() == testIn.Struct.BString.c_str(), "testOut.Struct.BString (copy) failed"); | ||||
| 				oxAssert(testOutListCopy[0].get<uint32_t>() == testIn.List[0], "testOut.Struct.List[0] (copy) failed"); | ||||
| 				oxAssert(testOutListCopy[1].get<uint32_t>() == testIn.List[1], "testOut.Struct.List[1] (copy) failed"); | ||||
| 				return OxError(0); | ||||
|   | ||||
| @@ -642,12 +642,9 @@ class ModelObject { | ||||
| 			return {}; | ||||
| 		} | ||||
|  | ||||
| 		constexpr auto &operator[](StringView const&k) noexcept { | ||||
| 			auto [v, err] = m_fields.at(k); | ||||
| 			if (err) [[unlikely]] { | ||||
| 				oxPanic(err, ox::sfmt("field {} does not exist in type {}", k, buildTypeId(*m_type)).c_str()); | ||||
| 			} | ||||
| 			return **v; | ||||
| 		constexpr ox::Result<ModelValue*> at(StringView const&k) noexcept { | ||||
| 			oxRequire(v, m_fields.at(k)); | ||||
| 			return *v; | ||||
| 		} | ||||
|  | ||||
| 		constexpr auto &operator[](const std::size_t i) noexcept { | ||||
| @@ -731,12 +728,9 @@ class ModelUnion { | ||||
| 			return UniquePtr<ModelUnion>(new ModelUnion(other)); | ||||
| 		} | ||||
|  | ||||
| 		constexpr auto &operator[](StringView const&k) noexcept { | ||||
| 			const auto [v, err] = m_fields.at(k); | ||||
| 			if (err) [[unlikely]] { | ||||
| 				oxPanic(err, ox::sfmt("field {} does not exist in type {}", k, buildTypeId(*m_type)).c_str()); | ||||
| 			} | ||||
| 			return (*v)->value; | ||||
| 		constexpr ox::Result<ModelValue*> at(StringView const&k) noexcept { | ||||
| 			oxRequire(v, m_fields.at(k)); | ||||
| 			return &(*v)->value; | ||||
| 		} | ||||
|  | ||||
| 		constexpr auto &operator[](const std::size_t i) noexcept { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user