Update to v094r40 release.

byuu says:

Changelog:
- updated to newest hiro API
- SFC performance profile builds once again
- hiro: Qt port completed

Errata 1: the hiro/Qt target won't run tomoko just yet. Starts by
crashing inside InputSettings because hiro/Qt isn't forcefully selecting
the first item added to a ComboButton just yet. Even with a monkey patch
to get around that, the UI is incredibly unstable. Lots of geometry
calculation bugs, and a crash when you try and access certain folders in
the browser dialog. Lots of work left to be done there, sadly.

Errata 2: the hiro/Windows port has black backgrounds on all ListView
items. It's because I need to test for unassigned colors and grab the
default Windows brush colors in those cases.

Note: alternating row colors on multi-column ListView widgets is gone
now. Not a bug. May add it back later, but I'm not sure. It doesn't
interact nicely with per-cell background colors.

Things left to do:

First, I have to fix the Windows and Qt target bugs.

Next, I need to go through and revise the hiro API even more (nothing
too major.)

Next, I need to update icarus to use the new hiro API, and add support
for the SFC games database.

Next, I have to rewrite my TSV->BML cheat code tool.

Next, I need to post a final WIP of higan+icarus publicly and wait a few
days.

Next, I need to fix any bugs reported from the final WIP that I can.

Finally, I should be able to release v095.
This commit is contained in:
Tim Allen
2015-08-18 20:18:00 +10:00
parent 0271d6a12b
commit 4344b916b6
200 changed files with 7246 additions and 5659 deletions

View File

@@ -1,71 +1,68 @@
namespace phoenix {
#if defined(Hiro_Viewport)
uintptr_t pViewport::handle() {
return (uintptr_t)qtViewport->winId();
}
namespace hiro {
void pViewport::setDroppable(bool droppable) {
qtViewport->setAcceptDrops(droppable);
}
void pViewport::constructor() {
auto pViewport::construct() -> void {
qtWidget = qtViewport = new QtViewport(*this);
qtViewport->setMouseTracking(true);
qtViewport->setAttribute(Qt::WA_PaintOnScreen, true);
qtViewport->setStyleSheet("background: #000000");
pWidget::synchronizeState();
pWidget::construct();
_setState();
}
void pViewport::destructor() {
auto pViewport::destruct() -> void {
delete qtViewport;
qtWidget = qtViewport = nullptr;
}
void pViewport::orphan() {
destructor();
constructor();
auto pViewport::handle() const -> uintptr_t {
return (uintptr_t)qtViewport->winId();
}
void pViewport::QtViewport::dragEnterEvent(QDragEnterEvent* event) {
auto pViewport::setDroppable(bool droppable) -> void {
_setState();
}
auto pViewport::_setState() -> void {
qtViewport->setAcceptDrops(state().droppable);
}
auto QtViewport::dragEnterEvent(QDragEnterEvent* event) -> void {
if(event->mimeData()->hasUrls()) {
event->acceptProposedAction();
}
}
void pViewport::QtViewport::dropEvent(QDropEvent* event) {
lstring paths = DropPaths(event);
if(paths.empty()) return;
if(self.viewport.onDrop) self.viewport.onDrop(paths);
auto QtViewport::dropEvent(QDropEvent* event) -> void {
if(auto paths = DropPaths(event)) p.self().doDrop(paths);
}
void pViewport::QtViewport::leaveEvent(QEvent* event) {
if(self.viewport.onMouseLeave) self.viewport.onMouseLeave();
auto QtViewport::leaveEvent(QEvent* event) -> void {
p.self().doMouseLeave();
}
void pViewport::QtViewport::mouseMoveEvent(QMouseEvent* event) {
if(self.viewport.onMouseMove) self.viewport.onMouseMove({event->pos().x(), event->pos().y()});
auto QtViewport::mouseMoveEvent(QMouseEvent* event) -> void {
p.self().doMouseMove({event->pos().x(), event->pos().y()});
}
void pViewport::QtViewport::mousePressEvent(QMouseEvent* event) {
if(!self.viewport.onMousePress) return;
auto QtViewport::mousePressEvent(QMouseEvent* event) -> void {
switch(event->button()) {
case Qt::LeftButton: self.viewport.onMousePress(Mouse::Button::Left); break;
case Qt::MidButton: self.viewport.onMousePress(Mouse::Button::Middle); break;
case Qt::RightButton: self.viewport.onMousePress(Mouse::Button::Right); break;
case Qt::LeftButton: p.self().doMousePress(Mouse::Button::Left); break;
case Qt::MidButton: p.self().doMousePress(Mouse::Button::Middle); break;
case Qt::RightButton: p.self().doMousePress(Mouse::Button::Right); break;
}
}
void pViewport::QtViewport::mouseReleaseEvent(QMouseEvent* event) {
if(!self.viewport.onMouseRelease) return;
auto QtViewport::mouseReleaseEvent(QMouseEvent* event) -> void {
switch(event->button()) {
case Qt::LeftButton: self.viewport.onMouseRelease(Mouse::Button::Left); break;
case Qt::MidButton: self.viewport.onMouseRelease(Mouse::Button::Middle); break;
case Qt::RightButton: self.viewport.onMouseRelease(Mouse::Button::Right); break;
case Qt::LeftButton: p.self().doMouseRelease(Mouse::Button::Left); break;
case Qt::MidButton: p.self().doMouseRelease(Mouse::Button::Middle); break;
case Qt::RightButton: p.self().doMouseRelease(Mouse::Button::Right); break;
}
}
pViewport::QtViewport::QtViewport(pViewport& self) : self(self) {
}
}
#endif