2002-10-07 16:45:23 +00:00
|
|
|
#ifndef PUTTY_UNIX_H
|
|
|
|
#define PUTTY_UNIX_H
|
|
|
|
|
2003-02-01 12:54:40 +00:00
|
|
|
#include <stdio.h> /* for FILENAME_MAX */
|
2002-12-31 12:20:34 +00:00
|
|
|
#include "charset.h"
|
|
|
|
|
2003-02-01 12:54:40 +00:00
|
|
|
struct Filename {
|
|
|
|
char path[FILENAME_MAX];
|
|
|
|
};
|
|
|
|
#define f_open(filename, mode) ( fopen((filename).path, (mode)) )
|
|
|
|
|
|
|
|
struct FontSpec {
|
|
|
|
char name[256];
|
|
|
|
};
|
|
|
|
|
2002-10-07 16:45:23 +00:00
|
|
|
typedef void *Context; /* FIXME: probably needs changing */
|
|
|
|
|
2002-10-09 18:09:42 +00:00
|
|
|
extern Backend pty_backend;
|
|
|
|
|
2002-10-13 11:24:25 +00:00
|
|
|
/*
|
|
|
|
* Under GTK, we send MA_CLICK _and_ MA_2CLK, or MA_CLICK _and_
|
|
|
|
* MA_3CLK, when a button is pressed for the second or third time.
|
|
|
|
*/
|
|
|
|
#define MULTICLICK_ONLY_EVENT 0
|
|
|
|
|
2003-03-13 19:52:28 +00:00
|
|
|
/*
|
|
|
|
* Under GTK, there is no context help available.
|
|
|
|
*/
|
|
|
|
#define HELPCTX(x) P(NULL)
|
|
|
|
#define FILTER_KEY_FILES NULL /* FIXME */
|
|
|
|
|
2002-10-13 11:24:25 +00:00
|
|
|
/*
|
|
|
|
* Under X, selection data must not be NUL-terminated.
|
|
|
|
*/
|
|
|
|
#define SELECTION_NUL_TERMINATED 0
|
|
|
|
|
2002-10-14 09:06:31 +00:00
|
|
|
/*
|
|
|
|
* Under X, copying to the clipboard terminates lines with just LF.
|
|
|
|
*/
|
|
|
|
#define SEL_NL { 10 }
|
|
|
|
|
2002-10-07 16:45:23 +00:00
|
|
|
/* Simple wraparound timer function */
|
|
|
|
unsigned long getticks(void); /* based on gettimeofday(2) */
|
|
|
|
#define GETTICKCOUNT getticks
|
|
|
|
#define TICKSPERSEC 1000000 /* gettimeofday returns microseconds */
|
2002-10-15 16:38:10 +00:00
|
|
|
#define CURSORBLINK 450000 /* no standard way to set this */
|
2002-10-07 16:45:23 +00:00
|
|
|
|
|
|
|
#define WCHAR wchar_t
|
|
|
|
#define BYTE unsigned char
|
|
|
|
|
2002-11-05 13:21:03 +00:00
|
|
|
GLOBAL void *logctx;
|
|
|
|
|
2002-10-15 15:16:21 +00:00
|
|
|
/* Things pty.c needs from pterm.c */
|
2002-10-26 12:58:13 +00:00
|
|
|
char *get_x_display(void *frontend);
|
|
|
|
int font_dimension(void *frontend, int which);/* 0 for width, 1 for height */
|
2003-03-06 12:57:37 +00:00
|
|
|
long get_windowid(void *frontend);
|
2002-10-15 12:29:52 +00:00
|
|
|
|
2003-03-31 11:21:07 +00:00
|
|
|
/* Things gtkdlg.c needs from pterm.c */
|
|
|
|
void *get_window(void *frontend); /* void * to avoid depending on gtk.h */
|
|
|
|
|
2003-04-01 18:10:25 +00:00
|
|
|
/* Things pterm.c needs from gtkdlg.c */
|
|
|
|
void fatal_message_box(void *window, char *msg);
|
2003-04-05 16:05:00 +00:00
|
|
|
void about_box(void);
|
2003-04-01 18:10:25 +00:00
|
|
|
|
2003-03-31 11:42:45 +00:00
|
|
|
/* Things pterm.c needs from {ptermm,uxputty}.c */
|
|
|
|
char *make_default_wintitle(char *hostname);
|
2003-03-31 12:10:53 +00:00
|
|
|
int process_nonoption_arg(char *arg, Config *cfg);
|
2003-03-31 11:42:45 +00:00
|
|
|
|
2002-10-16 14:32:06 +00:00
|
|
|
/* Things uxstore.c needs from pterm.c */
|
2003-01-14 18:43:45 +00:00
|
|
|
char *x_get_default(const char *key);
|
2002-10-16 14:32:06 +00:00
|
|
|
|
2002-10-16 22:54:58 +00:00
|
|
|
/* Things uxstore.c provides to pterm.c */
|
|
|
|
void provide_xrm_string(char *string);
|
|
|
|
|
2003-03-29 16:47:06 +00:00
|
|
|
/* The interface used by uxsel.c */
|
|
|
|
void uxsel_init(void);
|
|
|
|
typedef int (*uxsel_callback_fn)(int fd, int event);
|
|
|
|
void uxsel_set(int fd, int rwx, uxsel_callback_fn callback);
|
|
|
|
void uxsel_del(int fd);
|
2002-10-31 19:49:52 +00:00
|
|
|
int select_result(int fd, int event);
|
2003-03-29 16:47:06 +00:00
|
|
|
int first_fd(int *state, int *rwx);
|
|
|
|
int next_fd(int *state, int *rwx);
|
2003-03-29 18:30:14 +00:00
|
|
|
/* The following are expected to be provided _to_ uxsel.c by the frontend */
|
|
|
|
int uxsel_input_add(int fd, int rwx); /* returns an id */
|
|
|
|
void uxsel_input_remove(int id);
|
2002-10-31 19:49:52 +00:00
|
|
|
|
2003-03-14 18:35:01 +00:00
|
|
|
/* uxcfg.c */
|
|
|
|
struct controlbox;
|
|
|
|
void unix_setup_config_box(struct controlbox *b, int midsession);
|
|
|
|
|
2002-12-31 12:20:34 +00:00
|
|
|
/*
|
|
|
|
* In the Unix Unicode layer, DEFAULT_CODEPAGE is a special value
|
|
|
|
* which causes mb_to_wc and wc_to_mb to call _libc_ rather than
|
|
|
|
* libcharset. That way, we can interface the various charsets
|
|
|
|
* supported by libcharset with the one supported by mbstowcs and
|
|
|
|
* wcstombs (which will be the character set in which stuff read
|
|
|
|
* from the command line or config files is assumed to be encoded).
|
|
|
|
*/
|
|
|
|
#define DEFAULT_CODEPAGE 0xFFFF
|
|
|
|
#define CP_UTF8 CS_UTF8 /* from libcharset */
|
2002-10-07 16:45:23 +00:00
|
|
|
|
2002-10-30 17:57:31 +00:00
|
|
|
#define strnicmp strncasecmp
|
|
|
|
#define stricmp strcasecmp
|
|
|
|
|
2002-11-02 14:35:57 +00:00
|
|
|
/* BSD-semantics version of signal() */
|
|
|
|
void (*putty_signal(int sig, void (*func)(int)))(int);
|
|
|
|
|
2003-01-01 22:25:25 +00:00
|
|
|
/*
|
|
|
|
* Exports from unicode.c.
|
|
|
|
*/
|
2003-01-14 18:28:23 +00:00
|
|
|
struct unicode_data;
|
|
|
|
int init_ucs(struct unicode_data *ucsdata,
|
|
|
|
char *line_codepage, int font_charset);
|
2003-01-01 22:25:25 +00:00
|
|
|
|
2003-01-11 09:31:54 +00:00
|
|
|
/*
|
|
|
|
* Spare function exported directly from uxnet.c.
|
|
|
|
*/
|
|
|
|
int sk_getxdmdata(void *sock, unsigned long *ip, int *port);
|
|
|
|
|
2002-10-07 16:45:23 +00:00
|
|
|
#endif
|