]> git.proxmox.com Git - spiceterm.git/blobdiff - spiceterm.h
buildsys: update make upload target for stretch
[spiceterm.git] / spiceterm.h
index c2454f8b0ee0d5c39f844aa6dc6f963c8d091548..7993c6aa01318fd4a83fe065b7e3f9373115ea8c 100644 (file)
@@ -20,12 +20,26 @@ typedef struct TextCell {
     TextAttributes attrib;
 } TextCell;
 
-#define COMMANDS_SIZE 1024
-#define MAX_HEIGHT 2048
-#define MAX_WIDTH 2048
+#define COMMANDS_SIZE (1024)
+#define MAX_HEIGHT 1440
+#define MAX_WIDTH 2560
+
+typedef struct SpiceTermOptions {
+    guint timeout;
+    int port;
+    char *addr;
+    char *keymap;
+    gboolean noauth;
+    gboolean sasl;
+} SpiceTermOptions;
 
 typedef struct SpiceScreen SpiceScreen;
 
+typedef struct CachedImage {
+    uint8_t *bitmap;
+    int cache_id;
+} CachedImage;
+
 struct SpiceScreen {
     SpiceCoreInterface *core;
     SpiceServer *server;
@@ -40,26 +54,30 @@ struct SpiceScreen {
     SpiceTimer *conn_timeout_timer;
     SpiceWatch *mwatch; /* watch master pty */
 
-    int cursor_notify;
-
     // Current mode (set by create_primary)
     int width;
     int height;
 
-    GCond* command_cond;
-    GMutex* command_mutex;
+    GCond command_cond;
+    GMutex command_mutex;
 
     int commands_end;
     int commands_start;
     struct QXLCommandExt* commands[COMMANDS_SIZE];
 
+    //cache for glyphs bitmaps
+    GHashTable *image_cache;
+    
+    gboolean cursor_set;
+
     // callbacks
     void (*on_client_connected)(SpiceScreen *spice_screen);
     void (*on_client_disconnected)(SpiceScreen *spice_screen);
 };
 
-SpiceScreen* spice_screen_new(SpiceCoreInterface* core, guint timeout);
+SpiceScreen* spice_screen_new(SpiceCoreInterface* core, uint32_t width, uint32_t height, SpiceTermOptions *opts);
 
+void spice_screen_resize(SpiceScreen *spice_screen, uint32_t width, uint32_t height);
 void spice_screen_draw_char(SpiceScreen *spice_screen, int x, int y, gunichar2 ch, TextAttributes attrib);
 void spice_screen_scroll(SpiceScreen *spice_screen, int x1, int y1, int x2, int y2, int src_x, int src_y);
 void spice_screen_clear(SpiceScreen *spice_screen, int x1, int y1, int x2, int y2);
@@ -67,8 +85,7 @@ uint32_t spice_screen_get_width(void);
 uint32_t spice_screen_get_height(void);
 
 typedef struct spiceTerm {
-    int maxx;
-    int maxy;
+    int pty; // pty file descriptor
 
     int width;
     int height;
@@ -80,7 +97,7 @@ typedef struct spiceTerm {
     int altbuf:1;
 
     unsigned int utf8:1; // utf8 mode
-    long utf_char;       // used by utf8 parser
+    gunichar utf_char;   // used by utf8 parser
     int utf_count;       // used by utf8 parser
 
     TextAttributes default_attrib;
@@ -130,3 +147,27 @@ typedef struct spiceTerm {
     unsigned int report_mouse:1;
 
 } spiceTerm;
+
+void init_spiceterm(spiceTerm *vt, uint32_t width, uint32_t height);
+void spiceterm_refresh(spiceTerm *vt);
+
+void spiceterm_resize(spiceTerm *vt, uint32_t width, uint32_t height);
+void spiceterm_virtual_scroll(spiceTerm *vt, int lines);
+void spiceterm_clear_selection(spiceTerm *vt);
+void spiceterm_motion_event(spiceTerm *vt, uint32_t x, uint32_t y, 
+                            uint32_t buttons);
+
+void spiceterm_respond_esc(spiceTerm *vt, const char *esc);
+void spiceterm_respond_data(spiceTerm *vt, int len, uint8_t *data);
+void spiceterm_update_watch_mask(spiceTerm *vt, gboolean writable);
+
+spiceTerm *spiceterm_create(uint32_t width, uint32_t height, SpiceTermOptions *opts);
+
+gboolean vdagent_owns_clipboard(spiceTerm *vt);
+void vdagent_request_clipboard(spiceTerm *vt);
+void vdagent_grab_clipboard(spiceTerm *vt);
+
+int pve_auth_verify(const char *clientip, const char *username, const char *passwd);
+void pve_auth_set_path(char *path);
+void pve_auth_set_permissions(char *perm);
+