aboutsummaryrefslogtreecommitdiffstats
path: root/src/main.cpp
diff options
context:
space:
mode:
authorMarcus Fritzsch <marcus_fritzsch@mentor.com>2017-06-22 14:19:36 +0200
committerMarcus Fritzsch <marcus_fritzsch@mentor.com>2017-08-08 17:24:00 +0200
commit3121d0b9b553ddc709be8b67e91395a796cc6b6e (patch)
tree9e25ea937ecb874fae89b81a400c3620c645ba4d /src/main.cpp
parent18bd98a7fc8a5cf8032eff3fd92ac22e7da569d1 (diff)
main/wayland: added a simple main loop
Signed-off-by: Marcus Fritzsch <marcus_fritzsch@mentor.com>
Diffstat (limited to 'src/main.cpp')
-rw-r--r--src/main.cpp51
1 files changed, 46 insertions, 5 deletions
diff --git a/src/main.cpp b/src/main.cpp
index 5e74ed8..a07a73c 100644
--- a/src/main.cpp
+++ b/src/main.cpp
@@ -1,6 +1,8 @@
#include "util.h"
#include "wayland.hpp"
+#include <unistd.h>
+
#include <stdlib.h>
#include <string.h>
@@ -9,11 +11,50 @@
#include <string>
#include <vector>
+#include <sys/poll.h>
+
struct conn {
std::vector<std::unique_ptr<wl::output>> outputs;
std::unique_ptr<genivi::controller> c;
};
+namespace {
+int check_events(struct wl::display *d, struct conn *c, int fd)
+{
+ struct pollfd pfd[2] = {
+ { .fd = d->get_fd(), .events = POLLIN, .revents = 0 },
+ { .fd = fd, .events = POLLIN, .revents = 0 }
+ };
+
+ d->flush();
+
+ if (poll(pfd, fd != -1 ? 2 : 1, -1) != -1 && errno != EINTR) {
+ int ret = 0;
+
+ if (pfd[0].revents & POLLIN) {
+ ret = d->dispatch();
+ }
+
+ if (ret == -1)
+ return ret;
+
+ if (fd != -1 && (pfd[1].revents & POLLIN)) {
+ char buf[10];
+
+ while (read(pfd[1].fd, buf, 10) == 10)
+ ;
+
+ // Display current status
+ for (auto const &i : c->c->surfaces) {
+ printf("Surface %d\n", i.first);
+ }
+ }
+ }
+
+ return 0;
+}
+}
+
int main(int argc, char **argv) {
lognotice("WinMan ver. %s", WINMAN_VERSION_STRING);
@@ -46,11 +87,11 @@ int main(int argc, char **argv) {
if (!c.c)
fatal("ivi_controller global not available");
- /* while (1) { */
- /* int ret = d->dispatch(); */
- /* if (ret != 0) */
- /* break; */
- /* } */
+ while (check_events(d.get(), &c, STDIN_FILENO) != -1) {
+ ;
+ }
+
+ d->roundtrip();
return 0;
}