Merge commit '2da3579818c8cbb50ad4b346f5fbc9e5304e682f'
This commit is contained in:
		
							
								
								
									
										36
									
								
								deps/nostalgia/deps/ox/src/ox/std/conv.hpp
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										36
									
								
								deps/nostalgia/deps/ox/src/ox/std/conv.hpp
									
									
									
									
										vendored
									
									
								
							| @@ -14,32 +14,20 @@ | |||||||
|  |  | ||||||
| namespace ox { | namespace ox { | ||||||
|  |  | ||||||
| constexpr Vec2::operator Point() const noexcept { | constexpr Point::Point(Vec2 const&pt) noexcept: | ||||||
| 	return { | 	x(static_cast<int32_t>(pt.x)), | ||||||
| 			static_cast<int32_t>(x), | 	y(static_cast<int32_t>(pt.y)) {} | ||||||
| 			static_cast<int32_t>(y), |  | ||||||
| 	}; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| constexpr Vec2::operator Size() const noexcept { | constexpr Size::Size(Vec2 const&pt) noexcept: | ||||||
| 	return { | 	width(static_cast<int32_t>(pt.x)), | ||||||
| 			static_cast<int32_t>(x), | 	height(static_cast<int32_t>(pt.y)) {} | ||||||
| 			static_cast<int32_t>(y), |  | ||||||
| 	}; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| constexpr Point::operator Vec2() const noexcept { | constexpr Vec2::Vec2(Point const&pt) noexcept: | ||||||
| 	return { | 		x(static_cast<float>(pt.x)), | ||||||
| 			static_cast<float>(x), | 		y(static_cast<float>(pt.y)) {} | ||||||
| 			static_cast<float>(y), |  | ||||||
| 	}; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| constexpr Size::operator Vec2() const noexcept { | constexpr Vec2::Vec2(Size const&pt) noexcept: | ||||||
| 	return { | 	x(static_cast<float>(pt.width)), | ||||||
| 		static_cast<float>(width), | 	y(static_cast<float>(pt.height)) {} | ||||||
| 		static_cast<float>(height), |  | ||||||
| 	}; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| } | } | ||||||
							
								
								
									
										2
									
								
								deps/nostalgia/deps/ox/src/ox/std/point.hpp
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								deps/nostalgia/deps/ox/src/ox/std/point.hpp
									
									
									
									
										vendored
									
									
								
							| @@ -24,6 +24,8 @@ class Point { | |||||||
|  |  | ||||||
| 		constexpr Point(int x, int y) noexcept; | 		constexpr Point(int x, int y) noexcept; | ||||||
|  |  | ||||||
|  | 		explicit constexpr Point(class Vec2 const&pt) noexcept; | ||||||
|  |  | ||||||
| 		constexpr Point operator+(const Point &p) const noexcept; | 		constexpr Point operator+(const Point &p) const noexcept; | ||||||
|  |  | ||||||
| 		constexpr Point operator-(const Point &p) const noexcept; | 		constexpr Point operator-(const Point &p) const noexcept; | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								deps/nostalgia/deps/ox/src/ox/std/size.hpp
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								deps/nostalgia/deps/ox/src/ox/std/size.hpp
									
									
									
									
										vendored
									
									
								
							| @@ -24,6 +24,8 @@ class Size { | |||||||
|  |  | ||||||
| 		constexpr Size(int width, int height) noexcept; | 		constexpr Size(int width, int height) noexcept; | ||||||
|  |  | ||||||
|  | 		explicit constexpr Size(class Vec2 const&pt) noexcept; | ||||||
|  |  | ||||||
| 		constexpr Size operator+(Size p) const noexcept; | 		constexpr Size operator+(Size p) const noexcept; | ||||||
|  |  | ||||||
| 		constexpr Size operator-(Size p) const noexcept; | 		constexpr Size operator-(Size p) const noexcept; | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								deps/nostalgia/deps/ox/src/ox/std/vec.hpp
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								deps/nostalgia/deps/ox/src/ox/std/vec.hpp
									
									
									
									
										vendored
									
									
								
							| @@ -142,6 +142,10 @@ class Vec2 { | |||||||
|  |  | ||||||
| 		constexpr Vec2() noexcept = default; | 		constexpr Vec2() noexcept = default; | ||||||
|  |  | ||||||
|  | 		explicit constexpr Vec2(class Point const&pt) noexcept; | ||||||
|  |  | ||||||
|  | 		explicit constexpr Vec2(class Size const&pt) noexcept; | ||||||
|  |  | ||||||
| 		template<typename ...Args> | 		template<typename ...Args> | ||||||
| 		constexpr Vec2(float pX, float pY) noexcept: x(pX), y(pY) { | 		constexpr Vec2(float pX, float pY) noexcept: x(pX), y(pY) { | ||||||
| 		} | 		} | ||||||
|   | |||||||
							
								
								
									
										12
									
								
								deps/nostalgia/developer-handbook.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								deps/nostalgia/developer-handbook.md
									
									
									
									
										vendored
									
									
								
							| @@ -265,7 +265,7 @@ ox::Error engineCode() noexcept { | |||||||
| 	auto [val, err] = foo(1); | 	auto [val, err] = foo(1); | ||||||
| 	oxReturnError(err); | 	oxReturnError(err); | ||||||
| 	doStuff(val); | 	doStuff(val); | ||||||
| 	return OxError(0); | 	return {}; | ||||||
| } | } | ||||||
|  |  | ||||||
| void anyCode() { | void anyCode() { | ||||||
| @@ -288,7 +288,7 @@ ox::Error engineCode() noexcept { | |||||||
| 	auto valerr = foo(1); | 	auto valerr = foo(1); | ||||||
| 	oxReturnError(valerr); | 	oxReturnError(valerr); | ||||||
| 	doStuff(valerr.value); | 	doStuff(valerr.value); | ||||||
| 	return OxError(0); | 	return {}; | ||||||
| } | } | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| @@ -426,7 +426,7 @@ constexpr ox::Error model(T *h, ox::CommonPtrWith<NostalgiaPalette> auto *pal) n | |||||||
| 	// it is also possible to provide the type name and type version as function arguments | 	// it is also possible to provide the type name and type version as function arguments | ||||||
| 	//h->setTypeInfo("net.drinkingtea.nostalgia.core.NostalgiaPalette", 1); | 	//h->setTypeInfo("net.drinkingtea.nostalgia.core.NostalgiaPalette", 1); | ||||||
| 	oxReturnError(h->field("colors", &pal->colors)); | 	oxReturnError(h->field("colors", &pal->colors)); | ||||||
| 	return OxError(0); | 	return {}; | ||||||
| } | } | ||||||
|  |  | ||||||
| template<typename T> | template<typename T> | ||||||
| @@ -438,7 +438,7 @@ constexpr ox::Error model(T *h, ox::CommonPtrWith<NostalgiaGraphic> auto *ng) no | |||||||
| 	oxReturnError(h->field("defaultPalette", &ng->defaultPalette)); | 	oxReturnError(h->field("defaultPalette", &ng->defaultPalette)); | ||||||
| 	oxReturnError(h->field("pal", &ng->pal)); | 	oxReturnError(h->field("pal", &ng->pal)); | ||||||
| 	oxReturnError(h->field("pixels", &ng->pixels)); | 	oxReturnError(h->field("pixels", &ng->pixels)); | ||||||
| 	return OxError(0); | 	return {}; | ||||||
| } | } | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| @@ -475,7 +475,7 @@ constexpr Error model(T *h, ox::CommonPtrWith<FileAddress::Data> auto *obj) noex | |||||||
| 	oxReturnError(h->fieldCString("path", &obj->path)); | 	oxReturnError(h->fieldCString("path", &obj->path)); | ||||||
| 	oxReturnError(h->fieldCString("constPath", &obj->path)); | 	oxReturnError(h->fieldCString("constPath", &obj->path)); | ||||||
| 	oxReturnError(h->field("inode", &obj->inode)); | 	oxReturnError(h->field("inode", &obj->inode)); | ||||||
| 	return OxError(0); | 	return {}; | ||||||
| } | } | ||||||
|  |  | ||||||
| template<typename T> | template<typename T> | ||||||
| @@ -492,7 +492,7 @@ constexpr Error model(T *io, ox::CommonPtrWith<FileAddress> auto *fa) noexcept { | |||||||
| 		fa->m_type = static_cast<FileAddressType>(type); | 		fa->m_type = static_cast<FileAddressType>(type); | ||||||
| 		oxReturnError(io->field("data", UnionView(&fa->m_data, static_cast<int>(fa->m_type)))); | 		oxReturnError(io->field("data", UnionView(&fa->m_data, static_cast<int>(fa->m_type)))); | ||||||
| 	} | 	} | ||||||
| 	return OxError(0); | 	return {}; | ||||||
| } | } | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
|   | |||||||
| @@ -39,7 +39,7 @@ ox::Result<T> readConfig(keel::Context &ctx, ox::CRStringView name) noexcept { | |||||||
| 	ox::PassThroughFS fs(configPath(ctx)); | 	ox::PassThroughFS fs(configPath(ctx)); | ||||||
| 	auto const [buff, err] = fs.read(path); | 	auto const [buff, err] = fs.read(path); | ||||||
| 	if (err) { | 	if (err) { | ||||||
| 		oxErrf("Could not read config file: {}\n", toStr(err)); | 		//oxErrf("Could not read config file: {} - {}\n", path, toStr(err)); | ||||||
| 		return err; | 		return err; | ||||||
| 	} | 	} | ||||||
| 	return ox::readOC<T>(buff); | 	return ox::readOC<T>(buff); | ||||||
| @@ -57,13 +57,13 @@ ox::Error writeConfig(keel::Context &ctx, ox::CRStringView name, T const&data) n | |||||||
| 	auto const path = ox::sfmt("/{}.json", detail::slashesToPct(name)); | 	auto const path = ox::sfmt("/{}.json", detail::slashesToPct(name)); | ||||||
| 	ox::PassThroughFS fs(configPath(ctx)); | 	ox::PassThroughFS fs(configPath(ctx)); | ||||||
| 	if (auto const err = fs.mkdir("/", true)) { | 	if (auto const err = fs.mkdir("/", true)) { | ||||||
| 		oxErrf("Could not create config directory: {}\n", toStr(err)); | 		//oxErrf("Could not create config directory: {} - {}\n", path, toStr(err)); | ||||||
| 		return err; | 		return err; | ||||||
| 	} | 	} | ||||||
| 	oxRequireM(buff, ox::writeOC(data)); | 	oxRequireM(buff, ox::writeOC(data)); | ||||||
| 	*buff.back().value = '\n'; | 	*buff.back().value = '\n'; | ||||||
| 	if (auto const err = fs.write(path, buff.data(), buff.size())) { | 	if (auto const err = fs.write(path, buff.data(), buff.size())) { | ||||||
| 		oxErrf("Could not read config file: {}\n", toStr(err)); | 		//oxErrf("Could not read config file: {} - {}\n", path, toStr(err)); | ||||||
| 		return OxError(2, "Could not read config file"); | 		return OxError(2, "Could not read config file"); | ||||||
| 	} | 	} | ||||||
| 	return {}; | 	return {}; | ||||||
|   | |||||||
| @@ -14,7 +14,7 @@ namespace turbine { | |||||||
|  |  | ||||||
| class Context { | class Context { | ||||||
| 	public: | 	public: | ||||||
| 		UpdateHandler updateHandler = [](Context&) -> int {return 0;}; | 		UpdateHandler updateHandler = [](Context&) -> int {return -1;}; | ||||||
| 		keel::Context keelCtx; | 		keel::Context keelCtx; | ||||||
| 		KeyEventHandler keyEventHandler = nullptr; | 		KeyEventHandler keyEventHandler = nullptr; | ||||||
| 		ox::AnyPtr applicationData; | 		ox::AnyPtr applicationData; | ||||||
|   | |||||||
| @@ -68,24 +68,26 @@ static void tickFps(Context &ctx, uint64_t nowMs) noexcept { | |||||||
| } | } | ||||||
|  |  | ||||||
| ox::Error run(Context &ctx) noexcept { | ox::Error run(Context &ctx) noexcept { | ||||||
| 	int sleepTime = 0; | 	uint64_t sleepTime = 0; | ||||||
| 	while (!glfwWindowShouldClose(ctx.window)) { | 	while (!glfwWindowShouldClose(ctx.window)) { | ||||||
| 		ctx.refreshWithinMs = 10 * 1000; // refresh within 10 seconds | 		ctx.refreshWithinMs = 10 * 1000; // refresh within 10 seconds | ||||||
| 		glfwPollEvents(); | 		glfwPollEvents(); | ||||||
| 		auto const ticks = ticksMs(ctx); | 		auto const ticks = ticksMs(ctx); | ||||||
| 		if (ctx.wakeupTime <= ticks) { | 		if (ctx.wakeupTime <= ticks) { | ||||||
| 			 sleepTime = ctx.updateHandler(ctx); | 			 auto const st = ctx.updateHandler(ctx); | ||||||
| 			 if (sleepTime >= 0) { | 			 if (st >= 0) { | ||||||
| 				  ctx.wakeupTime = ticks + static_cast<unsigned>(sleepTime); | 				  ctx.wakeupTime = ticks + static_cast<unsigned>(st); | ||||||
|  | 				  sleepTime = static_cast<uint64_t>(st); | ||||||
| 			 } else { | 			 } else { | ||||||
| 				  ctx.wakeupTime = ~uint64_t(0); | 				  ctx.wakeupTime = ~uint64_t(0); | ||||||
|  | 				  sleepTime = ctx.wakeupTime - ticks; | ||||||
| 			 } | 			 } | ||||||
| 		} else { | 		} else { | ||||||
| 			sleepTime = static_cast<int>(ctx.wakeupTime - ticks); | 			sleepTime = ctx.wakeupTime - ticks; | ||||||
| 		} | 		} | ||||||
| 		tickFps(ctx, ticks); | 		tickFps(ctx, ticks); | ||||||
| 		draw(ctx); | 		draw(ctx); | ||||||
| 		auto const realSleepTime = ox::min(ctx.refreshWithinMs, sleepTime); | 		auto const realSleepTime = ox::min(static_cast<uint64_t>(ctx.refreshWithinMs), sleepTime); | ||||||
| 		if (realSleepTime) { | 		if (realSleepTime) { | ||||||
| 			if (ctx.uninterruptedRefreshes) { | 			if (ctx.uninterruptedRefreshes) { | ||||||
| 				--ctx.uninterruptedRefreshes; | 				--ctx.uninterruptedRefreshes; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user