summaryrefslogtreecommitdiff
path: root/src/plugins
diff options
context:
space:
mode:
Diffstat (limited to 'src/plugins')
-rw-r--r--src/plugins/plugins-interface.c223
-rw-r--r--src/plugins/plugins.c6
-rw-r--r--src/plugins/weechat-plugin.h247
3 files changed, 377 insertions, 99 deletions
diff --git a/src/plugins/plugins-interface.c b/src/plugins/plugins-interface.c
index 15bd6d2fd..0347368aa 100644
--- a/src/plugins/plugins-interface.c
+++ b/src/plugins/plugins-interface.c
@@ -391,7 +391,7 @@ weechat_plugin_exec_command (t_weechat_plugin *plugin,
/*
* weechat_plugin_get_info: get info about WeeChat
- * WARNING: caller should free string returned
+ * WARNING: caller has to free string returned
* by this function after use
*/
@@ -505,6 +505,8 @@ weechat_plugin_get_info (t_weechat_plugin *plugin, char *info, char *server)
/*
* weechat_plugin_get_dcc_info: get list of DCC files/chats info
+ * WARNING: caller has to free structure returned
+ * by this function after use
*/
t_plugin_dcc_info *
@@ -783,6 +785,8 @@ weechat_plugin_set_plugin_config (t_weechat_plugin *plugin, char *option, char *
/*
* weechat_plugin_get_server_info: get list of server info
+ * WARNING: caller has to free structure returned
+ * by this function after use
*/
t_plugin_server_info *
@@ -901,6 +905,8 @@ weechat_plugin_free_server_info (t_weechat_plugin *plugin, t_plugin_server_info
/*
* weechat_plugin_get_channel_info: get list of channel info from a server
+ * WARNING: caller has to free structure
+ * returned by this function after use
*/
t_plugin_channel_info *
@@ -982,6 +988,8 @@ weechat_plugin_free_channel_info (t_weechat_plugin *plugin, t_plugin_channel_inf
/*
* weechat_plugin_get_nick_info: get list of nick info from a server/channel
+ * * WARNING: caller has to free structure
+ * returned by this function after use
*/
t_plugin_nick_info *
@@ -1112,3 +1120,216 @@ weechat_plugin_get_irc_color (t_weechat_plugin *plugin, char *color_name)
/* color not found */
return -1;
}
+
+/*
+ * weechat_plugin_get_window_info: get list of window info
+ * WARNING: caller has to free structure
+ * returned by this function after use
+ */
+
+t_plugin_window_info *
+weechat_plugin_get_window_info (t_weechat_plugin *plugin)
+{
+ t_plugin_window_info *window_info, *last_window_info, *new_window_info;
+ t_gui_window *ptr_window;
+
+ if (!plugin)
+ return NULL;
+
+ if (gui_windows)
+ {
+ window_info = NULL;
+ last_window_info = NULL;
+ for (ptr_window = gui_windows; ptr_window; ptr_window = ptr_window->next_window)
+ {
+ new_window_info = (t_plugin_window_info *) malloc (sizeof (t_plugin_window_info));
+ if (new_window_info)
+ {
+ new_window_info->win_x = ptr_window->win_x;
+ new_window_info->win_y = ptr_window->win_y;
+ new_window_info->win_width = ptr_window->win_width;
+ new_window_info->win_height = ptr_window->win_height;
+ new_window_info->win_width_pct = ptr_window->win_width_pct;
+ new_window_info->win_height_pct = ptr_window->win_height_pct;
+ new_window_info->num_buffer = (ptr_window->buffer) ? ptr_window->buffer->number : 0;
+
+ new_window_info->prev_window = last_window_info;
+ new_window_info->next_window = NULL;
+ if (!window_info)
+ window_info = new_window_info;
+ else
+ last_window_info->next_window = new_window_info;
+ last_window_info = new_window_info;
+ }
+ }
+
+ return window_info;
+ }
+
+ return NULL;
+}
+
+/*
+ * weechat_plugin_free_window_info: free window info struct list
+ */
+
+void
+weechat_plugin_free_window_info (t_weechat_plugin *plugin, t_plugin_window_info *window_info)
+{
+ t_plugin_window_info *new_window_info;
+
+ if (!plugin || !window_info)
+ return;
+
+ while (window_info)
+ {
+ new_window_info = window_info->next_window;
+ free (window_info);
+ window_info = new_window_info;
+ }
+}
+
+/*
+ * weechat_plugin_get_buffer_info: get list of buffer info
+ * WARNING: caller has to free structure
+ * returned by this function after use
+ */
+
+t_plugin_buffer_info *
+weechat_plugin_get_buffer_info (t_weechat_plugin *plugin)
+{
+ t_plugin_buffer_info *buffer_info, *last_buffer_info, *new_buffer_info;
+ t_gui_buffer *ptr_buffer;
+
+ if (!plugin)
+ return NULL;
+
+ if (gui_buffers)
+ {
+ buffer_info = NULL;
+ last_buffer_info = NULL;
+ for (ptr_buffer = gui_buffers; ptr_buffer; ptr_buffer = ptr_buffer->next_buffer)
+ {
+ new_buffer_info = (t_plugin_buffer_info *) malloc (sizeof (t_plugin_buffer_info));
+ if (new_buffer_info)
+ {
+ new_buffer_info->type = ptr_buffer->type;
+ new_buffer_info->number = ptr_buffer->number;
+ new_buffer_info->num_displayed = ptr_buffer->num_displayed;
+ new_buffer_info->server_name = (SERVER(ptr_buffer)) ? strdup (SERVER(ptr_buffer)->name) : NULL;
+ new_buffer_info->channel_name = (CHANNEL(ptr_buffer)) ? strdup (CHANNEL(ptr_buffer)->name) : NULL;
+ new_buffer_info->notify_level = ptr_buffer->notify_level;
+ new_buffer_info->log_filename = (ptr_buffer->log_filename) ? strdup (ptr_buffer->log_filename) : NULL;
+
+ new_buffer_info->prev_buffer = last_buffer_info;
+ new_buffer_info->next_buffer = NULL;
+ if (!buffer_info)
+ buffer_info = new_buffer_info;
+ else
+ last_buffer_info->next_buffer = new_buffer_info;
+ last_buffer_info = new_buffer_info;
+ }
+ }
+
+ return buffer_info;
+ }
+
+ return NULL;
+}
+
+/*
+ * weechat_plugin_free_buffer_info: free buffer info struct list
+ */
+
+void
+weechat_plugin_free_buffer_info (t_weechat_plugin *plugin, t_plugin_buffer_info *buffer_info)
+{
+ t_plugin_buffer_info *new_buffer_info;
+
+ if (!plugin || !buffer_info)
+ return;
+
+ while (buffer_info)
+ {
+ if (buffer_info->server_name)
+ free (buffer_info->server_name);
+ if (buffer_info->channel_name)
+ free (buffer_info->channel_name);
+ if (buffer_info->log_filename)
+ free (buffer_info->log_filename);
+ new_buffer_info = buffer_info->next_buffer;
+ free (buffer_info);
+ buffer_info = new_buffer_info;
+ }
+}
+
+/*
+ * weechat_plugin_get_buffer_data: get buffer content
+ * WARNING: caller has to free structure
+ * returned by this function after use
+ */
+
+t_plugin_buffer_line *
+weechat_plugin_get_buffer_data (t_weechat_plugin *plugin, char *server, char *channel)
+{
+ t_irc_server *ptr_server;
+ t_irc_channel *ptr_channel;
+ t_plugin_buffer_line *buffer_line, *last_buffer_line, *new_buffer_line;
+ t_gui_line *ptr_line;
+
+ if (!plugin)
+ return NULL;
+
+ plugin_find_server_channel (server, channel, &ptr_server, &ptr_channel);
+
+ if (!ptr_channel || !ptr_channel->buffer)
+ return NULL;
+
+ buffer_line = NULL;
+ last_buffer_line = NULL;
+ for (ptr_line = ptr_channel->buffer->last_line; ptr_line;
+ ptr_line = ptr_line->prev_line)
+ {
+ new_buffer_line = (t_plugin_buffer_line *) malloc (sizeof (t_plugin_buffer_line));
+ if (new_buffer_line)
+ {
+ new_buffer_line->nick = (ptr_line->nick) ? strdup (ptr_line->nick) : NULL;
+ new_buffer_line->data = (ptr_line->data) ?
+ (char *) gui_color_decode ((unsigned char *)(ptr_line->data + ptr_line->ofs_start_message), 0) : NULL;
+
+ new_buffer_line->prev_line = last_buffer_line;
+ new_buffer_line->next_line = NULL;
+ if (!buffer_line)
+ buffer_line = new_buffer_line;
+ else
+ last_buffer_line->next_line = new_buffer_line;
+ last_buffer_line = new_buffer_line;
+ }
+ }
+
+ return buffer_line;
+}
+
+/*
+ * weechat_plugin_free_buffer_data: free buffer data (lines) struct list
+ */
+
+void
+weechat_plugin_free_buffer_data (t_weechat_plugin *plugin, t_plugin_buffer_line *buffer_line)
+{
+ t_plugin_buffer_line *new_buffer_line;
+
+ if (!plugin || !buffer_line)
+ return;
+
+ while (buffer_line)
+ {
+ if (buffer_line->nick)
+ free (buffer_line->nick);
+ if (buffer_line->data)
+ free (buffer_line->data);
+ new_buffer_line = buffer_line->next_line;
+ free (buffer_line);
+ buffer_line = new_buffer_line;
+ }
+}
diff --git a/src/plugins/plugins.c b/src/plugins/plugins.c
index 474d0e478..49e4771b0 100644
--- a/src/plugins/plugins.c
+++ b/src/plugins/plugins.c
@@ -877,6 +877,12 @@ plugin_load (char *filename)
new_plugin->free_nick_info = &weechat_plugin_free_nick_info;
new_plugin->input_color = &weechat_plugin_input_color;
new_plugin->get_irc_color = &weechat_plugin_get_irc_color;
+ new_plugin->get_window_info = &weechat_plugin_get_window_info;
+ new_plugin->free_window_info = &weechat_plugin_free_window_info;
+ new_plugin->get_buffer_info = &weechat_plugin_get_buffer_info;
+ new_plugin->free_buffer_info = &weechat_plugin_free_buffer_info;
+ new_plugin->get_buffer_data = &weechat_plugin_get_buffer_data;
+ new_plugin->free_buffer_data = &weechat_plugin_free_buffer_data;
/* handlers */
new_plugin->handlers = NULL;
diff --git a/src/plugins/weechat-plugin.h b/src/plugins/weechat-plugin.h
index 241356207..6c26ecedb 100644
--- a/src/plugins/weechat-plugin.h
+++ b/src/plugins/weechat-plugin.h
@@ -25,16 +25,16 @@
#include <sys/types.h>
/* return codes for init function and handlers */
-#define PLUGIN_RC_KO -1 /* function/handler failed */
-#define PLUGIN_RC_OK 0 /* function/handler ok */
+#define PLUGIN_RC_KO -1 /* function/handler failed */
+#define PLUGIN_RC_OK 0 /* function/handler ok */
/* return codes specific to message handlers: messages can be discarded for
WeeChat, for plugins, or both */
-#define PLUGIN_RC_OK_IGNORE_WEECHAT 1 /* ignore WeeChat for this message */
-#define PLUGIN_RC_OK_IGNORE_PLUGINS 2 /* ignore other plugins for this msg */
+#define PLUGIN_RC_OK_IGNORE_WEECHAT 1 /* ignore WeeChat for this message */
+#define PLUGIN_RC_OK_IGNORE_PLUGINS 2 /* ignore other plugins for this msg*/
#define PLUGIN_RC_OK_IGNORE_ALL (PLUGIN_RC_OK_IGNORE_WEECHAT \
| PLUGIN_RC_OK_IGNORE_PLUGINS)
- /* ignore WeeChat and other plugins */
+ /* ignore WeeChat and other plugins */
#define WEECHAT_IRC_COLOR_WHITE 0
#define WEECHAT_IRC_COLOR_BLACK 1
@@ -57,88 +57,126 @@ typedef struct t_plugin_dcc_info t_plugin_dcc_info;
struct t_plugin_dcc_info
{
- char *server; /* irc server */
- char *channel; /* irc channel (for DCC chat only) */
- int type; /* DCC type (send or receive) */
- int status; /* DCC status (waiting, sending, ..) */
- time_t start_time; /* the time when DCC started */
- time_t start_transfer; /* the time when DCC transfer started */
- unsigned long addr; /* IP address */
- int port; /* port */
- char *nick; /* remote nick */
- char *filename; /* filename (given by sender) */
- char *local_filename; /* local filename (with path) */
- int filename_suffix; /* suffix (.1 for ex) if renaming file */
- unsigned long size; /* file size */
- unsigned long pos; /* number of bytes received/sent */
- unsigned long start_resume; /* start of resume (in bytes) */
- unsigned long bytes_per_sec; /* bytes per second */
- t_plugin_dcc_info *prev_dcc; /* link to previous dcc file/chat */
- t_plugin_dcc_info *next_dcc; /* link to next dcc file/chat */
+ char *server; /* irc server */
+ char *channel; /* irc channel (for DCC chat only) */
+ int type; /* DCC type (send or receive) */
+ int status; /* DCC status (waiting, sending, ..) */
+ time_t start_time; /* the time when DCC started */
+ time_t start_transfer; /* the time when DCC transfer started */
+ unsigned long addr; /* IP address */
+ int port; /* port */
+ char *nick; /* remote nick */
+ char *filename; /* filename (given by sender) */
+ char *local_filename; /* local filename (with path) */
+ int filename_suffix; /* suffix (.1 for ex) if renaming file */
+ unsigned long size; /* file size */
+ unsigned long pos; /* number of bytes received/sent */
+ unsigned long start_resume; /* start of resume (in bytes) */
+ unsigned long bytes_per_sec; /* bytes per second */
+ t_plugin_dcc_info *prev_dcc; /* link to previous dcc file/chat */
+ t_plugin_dcc_info *next_dcc; /* link to next dcc file/chat */
};
typedef struct t_plugin_server_info t_plugin_server_info;
struct t_plugin_server_info
{
- char *name; /* name of server (only for display) */
- int autoconnect; /* = 1 if auto connect at startup */
- int autoreconnect; /* = 1 if auto reco when disconnected */
- int autoreconnect_delay; /* delay before trying again reconnect */
- int command_line; /* server was given on command line */
- char *address; /* address of server (IP or name) */
- int port; /* port for server (6667 by default) */
- int ipv6; /* use IPv6 protocol */
- int ssl; /* SSL protocol */
- char *password; /* password for server */
- char *nick1; /* first nickname for the server */
- char *nick2; /* alternate nickname */
- char *nick3; /* 2nd alternate nickname */
- char *username; /* user name */
- char *realname; /* real name */
- char *command; /* command to run once connected */
- int command_delay; /* delay after execution of command */
- char *autojoin; /* channels to automatically join */
- int autorejoin; /* auto rejoin channels when kicked */
- char *notify_levels; /* channels notify levels */
- char *charset_decode_iso; /* channels charsets for decoding ISO */
- char *charset_decode_utf; /* channels charsets for decoding UTF */
- char *charset_encode; /* channels charsets for encoding msgs */
- int is_connected; /* 1 if WeeChat is connected to server */
- int ssl_connected; /* = 1 if connected with SSL */
- char *nick; /* current nickname */
- int is_away; /* 1 is user is marker as away */
- time_t away_time; /* time() when user marking as away */
- int lag; /* lag (in milliseconds) */
- t_plugin_server_info *prev_server; /* link to previous server info */
- t_plugin_server_info *next_server; /* link to next server info */
+ char *name; /* name of server (only for display) */
+ int autoconnect; /* = 1 if auto connect at startup */
+ int autoreconnect; /* = 1 if auto reco when disconnected */
+ int autoreconnect_delay; /* delay before trying again reconnect */
+ int command_line; /* server was given on command line */
+ char *address; /* address of server (IP or name) */
+ int port; /* port for server (6667 by default) */
+ int ipv6; /* use IPv6 protocol */
+ int ssl; /* SSL protocol */
+ char *password; /* password for server */
+ char *nick1; /* first nickname for the server */
+ char *nick2; /* alternate nickname */
+ char *nick3; /* 2nd alternate nickname */
+ char *username; /* user name */
+ char *realname; /* real name */
+ char *command; /* command to run once connected */
+ int command_delay; /* delay after execution of command */
+ char *autojoin; /* channels to automatically join */
+ int autorejoin; /* auto rejoin channels when kicked */
+ char *notify_levels; /* channels notify levels */
+ char *charset_decode_iso; /* channels charsets for decoding ISO */
+ char *charset_decode_utf; /* channels charsets for decoding UTF */
+ char *charset_encode; /* channels charsets for encoding msgs */
+ int is_connected; /* 1 if WeeChat is connected to server */
+ int ssl_connected; /* = 1 if connected with SSL */
+ char *nick; /* current nickname */
+ int is_away; /* 1 is user is marker as away */
+ time_t away_time; /* time() when user marking as away */
+ int lag; /* lag (in milliseconds) */
+ t_plugin_server_info *prev_server; /* link to previous server info */
+ t_plugin_server_info *next_server; /* link to next server info */
};
typedef struct t_plugin_channel_info t_plugin_channel_info;
struct t_plugin_channel_info
{
- int type; /* channel type */
- char *name; /* name of channel (exemple: "#abc") */
- char *topic; /* topic of channel (host for private) */
- char *modes; /* channel modes */
- int limit; /* user limit (0 is limit not set) */
- char *key; /* channel key (NULL if no key is set) */
- int nicks_count; /* # nicks on channel (0 if dcc/pv) */
- t_plugin_channel_info *prev_channel; /* link to previous channel info */
- t_plugin_channel_info *next_channel; /* link to next channel info */
+ int type; /* channel type */
+ char *name; /* name of channel (exemple: "#abc") */
+ char *topic; /* topic of channel (host for private) */
+ char *modes; /* channel modes */
+ int limit; /* user limit (0 is limit not set) */
+ char *key; /* channel key (NULL if no key is set) */
+ int nicks_count; /* # nicks on channel (0 if dcc/pv) */
+ t_plugin_channel_info *prev_channel; /* link to previous channel info */
+ t_plugin_channel_info *next_channel; /* link to next channel info */
};
typedef struct t_plugin_nick_info t_plugin_nick_info;
struct t_plugin_nick_info
{
- char *nick; /* nickname */
- int flags; /* chanowner/chanadmin (unrealircd), */
- char *host; /* hostname */
- /* op, halfop, voice, away */
- t_plugin_nick_info *prev_nick; /* link to previous nick */
- t_plugin_nick_info *next_nick; /* link to next nick */
+ char *nick; /* nickname */
+ int flags; /* chanowner/chanadmin (unrealircd), */
+ char *host; /* hostname */
+ /* op, halfop, voice, away */
+ t_plugin_nick_info *prev_nick; /* link to previous nick */
+ t_plugin_nick_info *next_nick; /* link to next nick */
+};
+
+typedef struct t_plugin_window_info t_plugin_window_info;
+
+struct t_plugin_window_info
+{
+ int win_x, win_y; /* position of window */
+ int win_width, win_height; /* window geometry */
+ int win_width_pct; /* % of width (compared to term size) */
+ int win_height_pct; /* % of height (compared to term size) */
+ int num_buffer; /* # of displayed buffer */
+ t_plugin_window_info *prev_window; /* link to previous window */
+ t_plugin_window_info *next_window; /* link to next window */
+};
+
+typedef struct t_plugin_buffer_info t_plugin_buffer_info;
+
+struct t_plugin_buffer_info
+{
+ int type; /* buffer type (0=standard,1=dcc,2=raw) */
+ int number; /* buffer number */
+ int num_displayed; /* number of windows displaying buffer */
+ char *server_name; /* server name for buffer (may be NULL) */
+ char *channel_name; /* channel name for buffer (may be NULL)*/
+ int notify_level; /* notify level for buffer */
+ char *log_filename; /* log filename (NULL is disabled) */
+ t_plugin_buffer_info *prev_buffer; /* link to previous buffer */
+ t_plugin_buffer_info *next_buffer; /* link to next buffer */
+};
+
+typedef struct t_plugin_buffer_line t_plugin_buffer_line;
+
+struct t_plugin_buffer_line
+{
+ char *nick; /* nick */
+ char *data; /* line data */
+ t_plugin_buffer_line *prev_line; /* link to previous line */
+ t_plugin_buffer_line *next_line; /* link to next line */
};
typedef struct t_weechat_plugin t_weechat_plugin;
@@ -151,42 +189,42 @@ typedef enum t_handler_type t_handler_type;
enum t_handler_type
{
- HANDLER_MESSAGE = 0, /* IRC message handler */
- HANDLER_COMMAND, /* command handler */
- HANDLER_TIMER, /* timer handler */
- HANDLER_KEYBOARD /* keyboard handler */
+ HANDLER_MESSAGE = 0, /* IRC message handler */
+ HANDLER_COMMAND, /* command handler */
+ HANDLER_TIMER, /* timer handler */
+ HANDLER_KEYBOARD /* keyboard handler */
};
typedef struct t_plugin_handler t_plugin_handler;
struct t_plugin_handler
{
- t_handler_type type; /* handler type */
+ t_handler_type type; /* handler type */
/* data for message handler */
- char *irc_command; /* name of IRC command (PRIVMSG, ..) */
+ char *irc_command; /* name of IRC command (PRIVMSG, ..) */
/* data for command handler */
- char *command; /* name of command (without first '/') */
- char *description; /* (for /help) short cmd description */
- char *arguments; /* (for /help) command arguments */
- char *arguments_description; /* (for /help) args long description */
- char *completion_template; /* template for completion */
+ char *command; /* name of command (without first '/') */
+ char *description; /* (for /help) short cmd description */
+ char *arguments; /* (for /help) command arguments */
+ char *arguments_description; /* (for /help) args long description */
+ char *completion_template; /* template for completion */
/* data for timer handler */
- int interval; /* interval between two calls to fct */
- int remaining; /* seconds remaining before next call */
+ int interval; /* interval between two calls to fct */
+ int remaining; /* seconds remaining before next call */
/* data common to all handlers */
- t_plugin_handler_func *handler; /* pointer to handler */
- char *handler_args; /* arguments sent to handler */
- void *handler_pointer; /* pointer sent to handler */
+ t_plugin_handler_func *handler; /* pointer to handler */
+ char *handler_args; /* arguments sent to handler */
+ void *handler_pointer; /* pointer sent to handler */
/* for internal use */
- int running; /* 1 if currently running */
- /* (used to prevent circular call) */
- t_plugin_handler *prev_handler; /* link to previous handler */
- t_plugin_handler *next_handler; /* link to next handler */
+ int running; /* 1 if currently running */
+ /* (used to prevent circular call) */
+ t_plugin_handler *prev_handler; /* link to previous handler */
+ t_plugin_handler *next_handler; /* link to next handler */
};
/* plugin, a WeeChat plugin, which is a dynamic library */
@@ -194,19 +232,19 @@ struct t_plugin_handler
struct t_weechat_plugin
{
/* plugin variables */
- char *filename; /* name of plugin on disk */
- void *handle; /* handle of plugin (given by dlopen) */
- char *name; /* plugin name */
- char *description; /* plugin description */
- char *version; /* plugin version */
+ char *filename; /* name of plugin on disk */
+ void *handle; /* handle of plugin (given by dlopen) */
+ char *name; /* plugin name */
+ char *description; /* plugin description */
+ char *version; /* plugin version */
/* plugin handlers */
- t_plugin_handler *handlers; /* pointer to first handler */
- t_plugin_handler *last_handler; /* pointer to last handler */
+ t_plugin_handler *handlers; /* pointer to first handler */
+ t_plugin_handler *last_handler; /* pointer to last handler */
/* links to previous/next plugins */
- t_weechat_plugin *prev_plugin; /* link to previous plugin */
- t_weechat_plugin *next_plugin; /* link to next plugin */
+ t_weechat_plugin *prev_plugin; /* link to previous plugin */
+ t_weechat_plugin *next_plugin; /* link to next plugin */
/* plugin functions (interface) */
@@ -264,6 +302,13 @@ struct t_weechat_plugin
void (*input_color) (t_weechat_plugin *, int, int, int);
int (*get_irc_color) (t_weechat_plugin *, char *);
+
+ t_plugin_window_info *(*get_window_info) (t_weechat_plugin *);
+ void (*free_window_info) (t_weechat_plugin *, t_plugin_window_info *);
+ t_plugin_buffer_info *(*get_buffer_info) (t_weechat_plugin *);
+ void (*free_buffer_info) (t_weechat_plugin *, t_plugin_buffer_info *);
+ t_plugin_buffer_line *(*get_buffer_data) (t_weechat_plugin *, char *, char *);
+ void (*free_buffer_data) (t_weechat_plugin *, t_plugin_buffer_line *);
/* WeeChat developers: ALWAYS add new functions at the end */
};
@@ -321,5 +366,11 @@ extern t_plugin_nick_info *weechat_plugin_get_nick_info (t_weechat_plugin *, cha
extern void weechat_plugin_free_nick_info (t_weechat_plugin *, t_plugin_nick_info *);
extern void weechat_plugin_input_color (t_weechat_plugin *, int, int, int);
extern int weechat_plugin_get_irc_color (t_weechat_plugin *, char *);
+extern t_plugin_window_info *weechat_plugin_get_window_info (t_weechat_plugin *);
+extern void weechat_plugin_free_window_info (t_weechat_plugin *, t_plugin_window_info *);
+extern t_plugin_buffer_info *weechat_plugin_get_buffer_info (t_weechat_plugin *);
+extern void weechat_plugin_free_buffer_info (t_weechat_plugin *, t_plugin_buffer_info *);
+extern t_plugin_buffer_line *weechat_plugin_get_buffer_data (t_weechat_plugin *, char *, char *);
+extern void weechat_plugin_free_buffer_data (t_weechat_plugin *, t_plugin_buffer_line *);
#endif /* weechat-plugin.h */