summaryrefslogtreecommitdiff
path: root/framebuffer/fb_frontend_vnc.c
diff options
context:
space:
mode:
Diffstat (limited to 'framebuffer/fb_frontend_vnc.c')
-rw-r--r--framebuffer/fb_frontend_vnc.c231
1 files changed, 0 insertions, 231 deletions
diff --git a/framebuffer/fb_frontend_vnc.c b/framebuffer/fb_frontend_vnc.c
deleted file mode 100644
index 837cddaaf..000000000
--- a/framebuffer/fb_frontend_vnc.c
+++ /dev/null
@@ -1,231 +0,0 @@
-/*
- * Copyright 2008 Vincent Sanders <vince@simtec.co.uk>
- *
- * This file is part of NetSurf, http://www.netsurf-browser.org/
- *
- * NetSurf is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; version 2 of the License.
- *
- * NetSurf is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-#include <sys/types.h>
-#include <sys/stat.h>
-#include <fcntl.h>
-#include <sys/ioctl.h>
-#include <unistd.h>
-#include <string.h>
-
-#include <rfb/rfb.h>
-#include <rfb/keysym.h>
-
-#include "css/css.h"
-#include "desktop/options.h"
-#include "desktop/gui.h"
-#include "desktop/options.h"
-#include "utils/messages.h"
-#include "desktop/history_core.h"
-#include "desktop/textinput.h"
-
-#include "framebuffer/fb_gui.h"
-#include "framebuffer/fb_tk.h"
-#include "framebuffer/fb_plotters.h"
-#include "framebuffer/fb_frontend.h"
-#include "framebuffer/fb_cursor.h"
-#include "framebuffer/fb_options.h"
-
-#include "utils/log.h"
-
-static rfbScreenInfoPtr vnc_screen;
-static fbtk_widget_t *vncroot;
-
-static void fb_vnc_doptr(int buttonMask,int x,int y,rfbClientPtr cl)
-{
- if (buttonMask == 0) {
- fbtk_move_pointer(vncroot, x, y, false);
- } else {
-
- /* left button */
- if (buttonMask && 0x1) {
- fbtk_click(vncroot, BROWSER_MOUSE_CLICK_1);
- }
-
- /* right button */
- if (buttonMask && 0x4) {
- fbtk_click(vncroot, BROWSER_MOUSE_CLICK_2);
- }
-
- if (buttonMask && 0x8) {
- /* wheelup */
- fbtk_input(vncroot, KEY_UP);
- }
-
- if (buttonMask && 0x10) {
- /* wheeldown */
- fbtk_input(vncroot, KEY_DOWN);
- }
- }
-}
-
-
-static void fb_vnc_dokey(rfbBool down, rfbKeySym key, rfbClientPtr cl)
-{
- int nskey;
-
- LOG(("Processing keycode %d",key));
- if (down) {
- switch (key) {
-
- case XK_Page_Down:
- nskey = KEY_PAGE_DOWN;
- break;
-
- case XK_Page_Up:
- nskey = KEY_PAGE_UP;
- break;
-
- case XK_Down:
- nskey = KEY_DOWN;
- break;
-
- case XK_Up:
- nskey = KEY_UP;
- break;
-
- case XK_Escape:
- nskey = 27;
- break;
-
- case XK_Left:
- nskey = KEY_LEFT;
- break;
-
- case XK_Right:
- nskey = KEY_RIGHT;
- break;
-
- case XK_BackSpace:
- nskey = 8;
- break;
-
- case XK_Return:
- nskey = 13;
- break;
-
- default:
- nskey = key;
- break;
- }
-
- fbtk_input(vncroot, nskey);
-
- }
-}
-
-framebuffer_t *fb_os_init(int argc, char** argv)
-{
- framebuffer_t *newfb;
- int fb_width;
- int fb_height;
- int fb_depth;
-
- if ((option_window_width != 0) && (option_window_height != 0)) {
- fb_width = option_window_width;
- fb_height = option_window_height;
- } else {
- fb_width = 800;
- fb_height = 600;
- }
-
- fb_depth = option_fb_depth;
- if ((fb_depth != 32) && (fb_depth != 16) && (fb_depth != 8))
- fb_depth = 16; /* sanity checked depth in bpp */
-
- newfb = calloc(1, sizeof(framebuffer_t));
- if (newfb == NULL)
- return NULL;
-
- newfb->width = fb_width;
- newfb->height = fb_height;
- newfb->bpp = fb_depth;
-
- vnc_screen = rfbGetScreen(&argc, argv,
- newfb->width, newfb->height,
- 8, 3, (fb_depth / 8));
-
- vnc_screen->frameBuffer = malloc(newfb->width * newfb->height * (fb_depth / 8));
-
- switch (fb_depth) {
- case 8:
- break;
-
- case 16:
- vnc_screen->serverFormat.trueColour=TRUE;
- vnc_screen->serverFormat.redShift = 11;
- vnc_screen->serverFormat.greenShift = 5;
- vnc_screen->serverFormat.blueShift = 0;
- vnc_screen->serverFormat.redMax = 31;
- vnc_screen->serverFormat.greenMax = 63;
- vnc_screen->serverFormat.blueMax = 31;
- break;
-
- case 32:
- vnc_screen->serverFormat.trueColour=TRUE;
- vnc_screen->serverFormat.redShift = 16;
- vnc_screen->serverFormat.greenShift = 8;
- vnc_screen->serverFormat.blueShift = 0;
- break;
- }
-
- vnc_screen->alwaysShared = TRUE;
- vnc_screen->ptrAddEvent = fb_vnc_doptr;
- vnc_screen->kbdAddEvent = fb_vnc_dokey;
-
- rfbInitServer(vnc_screen);
-
- newfb->ptr = vnc_screen->frameBuffer;
- newfb->linelen = newfb->width * (fb_depth / 8);
-
- //rfbUndrawCursor(vnc_screen);
-
- return newfb;
-}
-
-void fb_os_quit(framebuffer_t *fb)
-{
-}
-
-void fb_os_input(fbtk_widget_t *root, bool active)
-{
- vncroot = root;
-
- if (active)
- rfbProcessEvents(vnc_screen, 10000);
- else
- rfbProcessEvents(vnc_screen, 100000);
-}
-
-void
-fb_os_option_override(void)
-{
-}
-
-/* called by generic code to inform os code of screen update */
-void
-fb_os_redraw(struct bbox_s *box)
-{
- rfbMarkRectAsModified(vnc_screen, box->x0, box->y0, box->x1, box->y1);
-}
-
-/*
- * Local Variables:
- * c-basic-offset:8
- * End:
- */