1
0
mirror of https://github.com/irssi/irssi.git synced 2024-12-04 14:46:39 -05:00

Merge pull request #42 from ailin-nemui/module-autoload

Protocol module autoloading
This commit is contained in:
ailin-nemui 2022-02-17 18:03:12 +01:00 committed by GitHub
commit d9b181e4a1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
35 changed files with 304 additions and 88 deletions

94
.github/workflows/termuxpkg.yml vendored Normal file
View File

@ -0,0 +1,94 @@
on:
push:
branches:
- master
pull_request:
name: Build Irssi Termux package
jobs:
termux-package:
runs-on: ubuntu-latest
steps:
- name: checkout termux-packages
uses: actions/checkout@main
with:
repository: termux/termux-packages
- name: checkout irssi
uses: actions/checkout@main
with:
path: src.irssi.git
- name: download termux docker container
uses: docker://termux/package-builder:latest
- name: build perl package
run: |
./scripts/run-docker.sh ./build-package.sh -i perl
- name: create irssi build receipe
run: |
mkdir packages/irssi-an
cat << 'BUILD_SH' > packages/irssi-an/build.sh
TERMUX_PKG_HOMEPAGE=https://ailin-nemui.github.io/irssi/
TERMUX_PKG_DESCRIPTION="Terminal based IRC client"
TERMUX_PKG_LICENSE="GPL-2.0"
TERMUX_PKG_MAINTAINER="@ailin-nemui"
TERMUX_PKG_VERSION=@VERSION@
TERMUX_PKG_REVISION=@REVISION@
TERMUX_PKG_SRCURL=file:///home/builder/termux-packages/src.irssi.git
TERMUX_PKG_AUTO_UPDATE=true
TERMUX_PKG_DEPENDS="glib, libandroid-glob, libiconv, libotr, ncurses, openssl, perl, utf8proc"
TERMUX_PKG_BREAKS="irssi"
TERMUX_PKG_REPLACES="irssi"
TERMUX_PKG_EXTRA_CONFIGURE_ARGS="
-Denable-true-color=yes
-Dfhs-prefix=$TERMUX_PREFIX
"
termux_step_configure_meson() {
termux_setup_meson
local perl_version=$(. $TERMUX_SCRIPTDIR/packages/perl/build.sh; echo $TERMUX_PKG_VERSION)
local perl_srcdir=$TERMUX_TOPDIR/perl/src
sed -i "/\\[binaries\\]/a\\
perl = ['$perl_srcdir/miniperl', '-I$TERMUX_PREFIX/lib/perl5/$perl_version/${TERMUX_ARCH}-android', '-I$TERMUX_PREFIX/lib/perl5/$perl_version']" \
$TERMUX_MESON_CROSSFILE
CC=gcc CXX=g++ CFLAGS= CXXFLAGS= CPPFLAGS= LDFLAGS= $TERMUX_MESON \
$TERMUX_PKG_SRCDIR \
$TERMUX_PKG_BUILDDIR \
--cross-file $TERMUX_MESON_CROSSFILE \
--prefix $TERMUX_PREFIX \
--libdir lib \
--buildtype minsize \
--strip \
$TERMUX_PKG_EXTRA_CONFIGURE_ARGS
}
termux_step_post_configure() {
sed -i "s:-I$TERMUX_PREFIX/:-isystem$TERMUX_PREFIX/:g" $TERMUX_PKG_BUILDDIR/build.ninja
}
termux_step_pre_configure() {
LDFLAGS+=" -landroid-glob"
# Make build log less noisy.
CFLAGS+=" -Wno-compound-token-split-by-macro"
# Make sure that perl stuff is reinstalled.
rm -rf $TERMUX_PREFIX/lib/irssi/perl
}
BUILD_SH
version=$(awk '/^v/ { $0=$1; gsub(/^v/,""); gsub(/-head/,"dev"); gsub(/-/,""); print; exit }' src.irssi.git/NEWS)
version=$version+g$(git -C src.irssi.git rev-parse --short HEAD)
sed -i \
-e "s:@VERSION@:$version:" \
-e "s:@REVISION@:$GITHUB_RUN_NUMBER:" \
packages/irssi-an/build.sh
git -C src.irssi.git tag v$version
- name: build irssi package
run: |
./scripts/run-docker.sh ./build-package.sh -I irssi-an
- uses: actions/upload-artifact@v2
with:
name: irssi-termux-pkg
path: output/irssi-an*.deb

View File

@ -6,7 +6,7 @@
#define IRSSI_GLOBAL_CONFIG "irssi.conf" /* config file name in /etc/ */ #define IRSSI_GLOBAL_CONFIG "irssi.conf" /* config file name in /etc/ */
#define IRSSI_HOME_CONFIG "config" /* config file name in ~/.irssi/ */ #define IRSSI_HOME_CONFIG "config" /* config file name in ~/.irssi/ */
#define IRSSI_ABI_VERSION 44 #define IRSSI_ABI_VERSION 45
#define DEFAULT_SERVER_ADD_PORT 6667 #define DEFAULT_SERVER_ADD_PORT 6667
#define DEFAULT_SERVER_ADD_TLS_PORT 6697 #define DEFAULT_SERVER_ADD_TLS_PORT 6697

View File

@ -227,8 +227,7 @@ void channels_setup_init(void)
setupchannels = NULL; setupchannels = NULL;
source_host_ok = FALSE; source_host_ok = FALSE;
signal_add("setup reread", (SIGNAL_FUNC) channels_read_config); signal_add("setup reread channels", (SIGNAL_FUNC) channels_read_config);
signal_add("irssi init read settings", (SIGNAL_FUNC) channels_read_config);
} }
void channels_setup_deinit(void) void channels_setup_deinit(void)
@ -236,6 +235,5 @@ void channels_setup_deinit(void)
while (setupchannels != NULL) while (setupchannels != NULL)
channel_setup_destroy(setupchannels->data); channel_setup_destroy(setupchannels->data);
signal_remove("setup reread", (SIGNAL_FUNC) channels_read_config); signal_remove("setup reread channels", (SIGNAL_FUNC) channels_read_config);
signal_remove("irssi init read settings", (SIGNAL_FUNC) channels_read_config);
} }

View File

@ -47,7 +47,7 @@ int chat_protocol_lookup(const char *name)
g_return_val_if_fail(name != NULL, -1); g_return_val_if_fail(name != NULL, -1);
rec = chat_protocol_find(name); rec = chat_protocol_find(name);
return rec == NULL ? -1 : rec->id; return rec == NULL ? -1 : rec->not_initialized ? CHAT_PROTOCOL_NOT_INITIALIZED : rec->id;
} }
CHAT_PROTOCOL_REC *chat_protocol_find(const char *name) CHAT_PROTOCOL_REC *chat_protocol_find(const char *name)
@ -99,6 +99,22 @@ CHAT_PROTOCOL_REC *chat_protocol_find_net(GHashTable *optlist)
return NULL; return NULL;
} }
static void chat_protocol_destroy(CHAT_PROTOCOL_REC *rec)
{
g_return_if_fail(rec != NULL);
chat_protocols = g_slist_remove(chat_protocols, rec);
if (default_proto == rec) {
chat_protocol_set_default(chat_protocols == NULL ? NULL : chat_protocols->data);
}
signal_emit("chat protocol destroyed", 1, rec);
g_free(rec->name);
g_free(rec);
}
/* Register new chat protocol. */ /* Register new chat protocol. */
CHAT_PROTOCOL_REC *chat_protocol_register(CHAT_PROTOCOL_REC *rec) CHAT_PROTOCOL_REC *chat_protocol_register(CHAT_PROTOCOL_REC *rec)
{ {
@ -108,7 +124,11 @@ CHAT_PROTOCOL_REC *chat_protocol_register(CHAT_PROTOCOL_REC *rec)
g_return_val_if_fail(rec != NULL, NULL); g_return_val_if_fail(rec != NULL, NULL);
newrec = chat_protocol_find(rec->name); newrec = chat_protocol_find(rec->name);
created = newrec == NULL; if (newrec != NULL && newrec->not_initialized) {
chat_protocol_destroy(newrec);
newrec = NULL;
}
created = newrec == NULL;
if (newrec == NULL) { if (newrec == NULL) {
newrec = g_new0(CHAT_PROTOCOL_REC, 1); newrec = g_new0(CHAT_PROTOCOL_REC, 1);
chat_protocols = g_slist_append(chat_protocols, newrec); chat_protocols = g_slist_append(chat_protocols, newrec);
@ -131,23 +151,6 @@ CHAT_PROTOCOL_REC *chat_protocol_register(CHAT_PROTOCOL_REC *rec)
return newrec; return newrec;
} }
static void chat_protocol_destroy(CHAT_PROTOCOL_REC *rec)
{
g_return_if_fail(rec != NULL);
chat_protocols = g_slist_remove(chat_protocols, rec);
if (default_proto == rec) {
chat_protocol_set_default(chat_protocols == NULL ? NULL :
chat_protocols->data);
}
signal_emit("chat protocol destroyed", 1, rec);
g_free(rec->name);
g_free(rec);
}
/* Unregister chat protocol. */ /* Unregister chat protocol. */
void chat_protocol_unregister(const char *name) void chat_protocol_unregister(const char *name)
{ {
@ -191,15 +194,6 @@ static CHANNEL_SETUP_REC *create_channel_setup(void)
return g_new0(CHANNEL_SETUP_REC, 1); return g_new0(CHANNEL_SETUP_REC, 1);
} }
static SERVER_CONNECT_REC *create_server_connect(void)
{
return g_new0(SERVER_CONNECT_REC, 1);
}
static void destroy_server_connect(SERVER_CONNECT_REC *conn)
{
}
/* Return "unknown chat protocol" record. Used when protocol name is /* Return "unknown chat protocol" record. Used when protocol name is
specified but it isn't registered yet. */ specified but it isn't registered yet. */
CHAT_PROTOCOL_REC *chat_protocol_get_unknown(const char *name) CHAT_PROTOCOL_REC *chat_protocol_get_unknown(const char *name)
@ -218,8 +212,10 @@ CHAT_PROTOCOL_REC *chat_protocol_get_unknown(const char *name)
rec->create_chatnet = create_chatnet; rec->create_chatnet = create_chatnet;
rec->create_server_setup = create_server_setup; rec->create_server_setup = create_server_setup;
rec->create_channel_setup = create_channel_setup; rec->create_channel_setup = create_channel_setup;
/*
rec->create_server_connect = create_server_connect; rec->create_server_connect = create_server_connect;
rec->destroy_server_connect = destroy_server_connect; rec->destroy_server_connect = destroy_server_connect;
*/
newrec = chat_protocol_register(rec); newrec = chat_protocol_register(rec);
g_free(rec); g_free(rec);

View File

@ -35,6 +35,8 @@ void *chat_protocol_check_cast(void *object, int type_pos, const char *id);
((object) == NULL ? chat_protocol_get_default() : \ ((object) == NULL ? chat_protocol_get_default() : \
chat_protocol_find_id((object)->chat_type)) chat_protocol_find_id((object)->chat_type))
#define CHAT_PROTOCOL_NOT_INITIALIZED -2
/* Register new chat protocol. */ /* Register new chat protocol. */
CHAT_PROTOCOL_REC *chat_protocol_register(CHAT_PROTOCOL_REC *rec); CHAT_PROTOCOL_REC *chat_protocol_register(CHAT_PROTOCOL_REC *rec);

View File

@ -24,12 +24,13 @@
#include <irssi/src/core/special-vars.h> #include <irssi/src/core/special-vars.h>
#include <irssi/src/lib-config/iconfig.h> #include <irssi/src/lib-config/iconfig.h>
#include <irssi/src/core/settings.h> #include <irssi/src/core/settings.h>
#include <irssi/src/core/misc.h>
#include <irssi/src/core/chat-protocols.h> #include <irssi/src/core/chat-protocols.h>
#include <irssi/src/core/chatnets.h> #include <irssi/src/core/chatnets.h>
#include <irssi/src/core/servers.h> #include <irssi/src/core/servers.h>
GSList *chatnets; /* list of available chat networks */ GSList *chatnets, *chatnets_unavailable; /* list of available chat networks */
static void chatnet_config_save(CHATNET_REC *chatnet) static void chatnet_config_save(CHATNET_REC *chatnet)
{ {
@ -60,8 +61,9 @@ static void chatnet_config_remove(CHATNET_REC *chatnet)
void chatnet_create(CHATNET_REC *chatnet) void chatnet_create(CHATNET_REC *chatnet)
{ {
g_return_if_fail(chatnet != NULL); g_return_if_fail(chatnet != NULL);
g_return_if_fail(!CHAT_PROTOCOL(chatnet)->not_initialized);
chatnet->type = module_get_uniq_id("CHATNET", 0); chatnet->type = module_get_uniq_id("CHATNET", 0);
if (g_slist_find(chatnets, chatnet) == NULL) if (g_slist_find(chatnets, chatnet) == NULL)
chatnets = g_slist_append(chatnets, chatnet); chatnets = g_slist_append(chatnets, chatnet);
@ -112,6 +114,21 @@ CHATNET_REC *chatnet_find(const char *name)
return NULL; return NULL;
} }
gboolean chatnet_find_unavailable(const char *name)
{
CHAT_PROTOCOL_REC *proto;
if (i_slist_find_icase_string(chatnets_unavailable, name) != NULL)
return TRUE;
proto = CHAT_PROTOCOL(chatnet_find(name));
if (proto == NULL || proto->not_initialized)
return TRUE;
return FALSE;
}
static void sig_connected(SERVER_REC *server) static void sig_connected(SERVER_REC *server)
{ {
CHATNET_REC *rec; CHATNET_REC *rec;
@ -136,14 +153,22 @@ static void chatnet_read(CONFIG_NODE *node)
return; return;
type = config_node_get_str(node, "type", NULL); type = config_node_get_str(node, "type", NULL);
proto = type == NULL ? NULL : chat_protocol_find(type); if (type == NULL) {
if (proto == NULL) { proto = chat_protocol_get_default();
proto = type == NULL ? chat_protocol_get_default() : } else {
chat_protocol_get_unknown(type); proto = chat_protocol_find(type);
} }
if (type == NULL) if (proto == NULL) {
/* protocol not loaded */
if (i_slist_find_icase_string(chatnets_unavailable, node->key) == NULL)
chatnets_unavailable =
g_slist_append(chatnets_unavailable, g_strdup(node->key));
return;
} else if (type == NULL) {
iconfig_node_set_str(node, "type", proto->name); iconfig_node_set_str(node, "type", proto->name);
}
rec = proto->create_chatnet(); rec = proto->create_chatnet();
rec->type = module_get_uniq_id("CHATNET", 0); rec->type = module_get_uniq_id("CHATNET", 0);
@ -167,6 +192,12 @@ static void read_chatnets(void)
while (chatnets != NULL) while (chatnets != NULL)
chatnet_destroy(chatnets->data); chatnet_destroy(chatnets->data);
while (chatnets_unavailable != NULL) {
char *name = chatnets_unavailable->data;
chatnets_unavailable = g_slist_remove(chatnets_unavailable, name);
g_free(name);
}
node = iconfig_node_traverse("chatnets", FALSE); node = iconfig_node_traverse("chatnets", FALSE);
if (node != NULL) { if (node != NULL) {
tmp = config_node_first(node->value); tmp = config_node_first(node->value);
@ -180,8 +211,7 @@ void chatnets_init(void)
chatnets = NULL; chatnets = NULL;
signal_add_first("event connected", (SIGNAL_FUNC) sig_connected); signal_add_first("event connected", (SIGNAL_FUNC) sig_connected);
signal_add("setup reread", (SIGNAL_FUNC) read_chatnets); signal_add("setup reread chatnets", (SIGNAL_FUNC) read_chatnets);
signal_add_first("irssi init read settings", (SIGNAL_FUNC) read_chatnets);
} }
void chatnets_deinit(void) void chatnets_deinit(void)
@ -189,6 +219,5 @@ void chatnets_deinit(void)
module_uniq_destroy("CHATNET"); module_uniq_destroy("CHATNET");
signal_remove("event connected", (SIGNAL_FUNC) sig_connected); signal_remove("event connected", (SIGNAL_FUNC) sig_connected);
signal_remove("setup reread", (SIGNAL_FUNC) read_chatnets); signal_remove("setup reread chatnets", (SIGNAL_FUNC) read_chatnets);
signal_remove("irssi init read settings", (SIGNAL_FUNC) read_chatnets);
} }

View File

@ -25,6 +25,8 @@ void chatnet_destroy(CHATNET_REC *chatnet);
/* Find the chat network by name */ /* Find the chat network by name */
CHATNET_REC *chatnet_find(const char *name); CHATNET_REC *chatnet_find(const char *name);
/* Check if this chatnet is unavailable because the protocol is not loaded */
gboolean chatnet_find_unavailable(const char *name);
void chatnets_init(void); void chatnets_init(void);
void chatnets_deinit(void); void chatnets_deinit(void);

View File

@ -223,6 +223,13 @@ static void sig_irssi_init_finished(void)
irssi_init_finished = TRUE; irssi_init_finished = TRUE;
} }
static void reread_setup(void)
{
signal_emit("setup reread chatnets", 0);
signal_emit("setup reread servers", 0);
signal_emit("setup reread channels", 0);
}
void core_init(void) void core_init(void)
{ {
dialog_type_queue = NULL; dialog_type_queue = NULL;
@ -269,13 +276,16 @@ void core_init(void)
settings_add_str("misc", "ignore_signals", ""); settings_add_str("misc", "ignore_signals", "");
settings_add_bool("misc", "override_coredump_limit", FALSE); settings_add_bool("misc", "override_coredump_limit", FALSE);
settings_add_bool("misc", "quit_on_hup", FALSE); settings_add_bool("misc", "quit_on_hup", FALSE);
settings_add_str("misc", "autoload_modules", "perl otr"); settings_add_str("misc", "autoload_modules", "irc dcc flood notifylist perl otr");
#ifdef HAVE_SYS_RESOURCE_H #ifdef HAVE_SYS_RESOURCE_H
getrlimit(RLIMIT_CORE, &orig_core_rlimit); getrlimit(RLIMIT_CORE, &orig_core_rlimit);
#endif #endif
read_settings(); read_settings();
signal_add("setup changed", (SIGNAL_FUNC) read_settings); signal_add("setup changed", (SIGNAL_FUNC) read_settings);
signal_add("setup reread", (SIGNAL_FUNC) reread_setup);
signal_add("irssi init read settings", (SIGNAL_FUNC) reread_setup);
signal_add_last("chat protocol created", (SIGNAL_FUNC) reread_setup);
signal_add("irssi init finished", (SIGNAL_FUNC) sig_irssi_init_finished); signal_add("irssi init finished", (SIGNAL_FUNC) sig_irssi_init_finished);
settings_check(); settings_check();
@ -288,6 +298,9 @@ void core_deinit(void)
module_uniq_destroy("WINDOW ITEM TYPE"); module_uniq_destroy("WINDOW ITEM TYPE");
signal_remove("setup changed", (SIGNAL_FUNC) read_settings); signal_remove("setup changed", (SIGNAL_FUNC) read_settings);
signal_remove("setup reread", (SIGNAL_FUNC) reread_setup);
signal_remove("irssi init read settings", (SIGNAL_FUNC) reread_setup);
signal_remove("chat protocol created", (SIGNAL_FUNC) reread_setup);
signal_remove("irssi init finished", (SIGNAL_FUNC) sig_irssi_init_finished); signal_remove("irssi init finished", (SIGNAL_FUNC) sig_irssi_init_finished);
wcwidth_wrapper_deinit(); wcwidth_wrapper_deinit();

View File

@ -305,6 +305,8 @@ static SERVER_CONNECT_REC *create_addr_conn(int chat_type, const char *address,
proto = chat_type >= 0 ? chat_protocol_find_id(chat_type) : proto = chat_type >= 0 ? chat_protocol_find_id(chat_type) :
chat_protocol_get_default(); chat_protocol_get_default();
g_return_val_if_fail(proto != NULL, NULL);
conn = proto->create_server_connect(); conn = proto->create_server_connect();
server_connect_ref(conn); server_connect_ref(conn);
@ -469,6 +471,10 @@ static SERVER_SETUP_REC *server_setup_read(CONFIG_NODE *node)
chatnetrec = chatnet == NULL ? NULL : chatnet_find(chatnet); chatnetrec = chatnet == NULL ? NULL : chatnet_find(chatnet);
if (chatnetrec == NULL && chatnet != NULL) { if (chatnetrec == NULL && chatnet != NULL) {
/* chat network not found, create it. */ /* chat network not found, create it. */
if (chatnet_find_unavailable(chatnet)) {
/* no protocols loaded, skip loading servers */
return NULL;
}
chatnetrec = chat_protocol_get_default()->create_chatnet(); chatnetrec = chat_protocol_get_default()->create_chatnet();
chatnetrec->chat_type = chat_protocol_get_default()->id; chatnetrec->chat_type = chat_protocol_get_default()->id;
chatnetrec->name = g_strdup(chatnet); chatnetrec->name = g_strdup(chatnet);
@ -759,8 +765,7 @@ void servers_setup_init(void)
read_settings(); read_settings();
signal_add("setup changed", (SIGNAL_FUNC) read_settings); signal_add("setup changed", (SIGNAL_FUNC) read_settings);
signal_add("setup reread", (SIGNAL_FUNC) read_servers); signal_add("setup reread servers", (SIGNAL_FUNC) read_servers);
signal_add("irssi init read settings", (SIGNAL_FUNC) read_servers);
} }
void servers_setup_deinit(void) void servers_setup_deinit(void)
@ -773,8 +778,7 @@ void servers_setup_deinit(void)
server_setup_destroy(setupservers->data); server_setup_destroy(setupservers->data);
signal_remove("setup changed", (SIGNAL_FUNC) read_settings); signal_remove("setup changed", (SIGNAL_FUNC) read_settings);
signal_remove("setup reread", (SIGNAL_FUNC) read_servers); signal_remove("setup reread servers", (SIGNAL_FUNC) read_servers);
signal_remove("irssi init read settings", (SIGNAL_FUNC) read_servers);
module_uniq_destroy("SERVER SETUP"); module_uniq_destroy("SERVER SETUP");
} }

View File

@ -17,6 +17,11 @@ libfe_irc_dcc_a = static_library('fe_irc_dcc',
def_sysconfdir, def_sysconfdir,
], ],
dependencies : dep) dependencies : dep)
shared_module('fe_irc_dcc',
install : true,
install_dir : moduledir,
link_with : dl_cross_irc_dcc,
link_whole : libfe_irc_dcc_a)
install_headers( install_headers(
files( files(

View File

@ -30,8 +30,10 @@
#include <irssi/src/fe-common/irc/fe-irc-server.h> #include <irssi/src/fe-common/irc/fe-irc-server.h>
#include <irssi/src/fe-common/irc/fe-irc-channels.h> #include <irssi/src/fe-common/irc/fe-irc-channels.h>
#ifdef HAVE_STATIC_IRC
void fe_irc_modules_init(void); void fe_irc_modules_init(void);
void fe_irc_modules_deinit(void); void fe_irc_modules_deinit(void);
#endif
void fe_irc_queries_init(void); void fe_irc_queries_init(void);
void fe_irc_queries_deinit(void); void fe_irc_queries_deinit(void);
@ -104,12 +106,16 @@ void fe_common_irc_init(void)
settings_check(); settings_check();
module_register("irc", "fe-common"); module_register("irc", "fe-common");
#ifdef HAVE_STATIC_IRC
fe_irc_modules_init(); fe_irc_modules_init();
#endif
} }
void fe_common_irc_deinit(void) void fe_common_irc_deinit(void)
{ {
#ifdef HAVE_STATIC_IRC
fe_irc_modules_deinit(); fe_irc_modules_deinit();
#endif
fe_irc_channels_deinit(); fe_irc_channels_deinit();
fe_irc_queries_deinit(); fe_irc_queries_deinit();

View File

@ -1,4 +1,6 @@
#ifdef HAVE_STATIC_IRC
void fe_irc_dcc_init(void);void fe_irc_notifylist_init(void); void fe_irc_dcc_init(void);void fe_irc_notifylist_init(void);
void fe_irc_notifylist_deinit(void);void fe_irc_dcc_deinit(void); void fe_irc_notifylist_deinit(void);void fe_irc_dcc_deinit(void);
void fe_irc_modules_init(void) { fe_irc_dcc_init(); fe_irc_notifylist_init(); } void fe_irc_modules_init(void) { fe_irc_dcc_init(); fe_irc_notifylist_init(); }
void fe_irc_modules_deinit(void) { fe_irc_notifylist_deinit(); fe_irc_dcc_deinit(); } void fe_irc_modules_deinit(void) { fe_irc_notifylist_deinit(); fe_irc_dcc_deinit(); }
#endif

View File

@ -30,6 +30,11 @@ libfe_common_irc_a = static_library('fe_common_irc',
def_themesdir, def_themesdir,
], ],
dependencies : dep) dependencies : dep)
shared_module('fe_common_irc',
install : true,
install_dir : moduledir,
link_with : dl_cross_irc_core,
link_whole : libfe_common_irc_a)
install_headers( install_headers(
files( files(

View File

@ -12,6 +12,11 @@ libfe_irc_notifylist_a = static_library('fe_irc_notifylist',
def_sysconfdir, def_sysconfdir,
], ],
dependencies : dep) dependencies : dep)
shared_module('fe_irc_notifylist',
install : true,
install_dir : moduledir,
link_with : dl_cross_irc_notifylist,
link_whole : libfe_irc_notifylist_a)
install_headers( install_headers(
files( files(

View File

@ -9,7 +9,7 @@ executable('event-get-params-fuzz',
link_with : [ link_with : [
libconfig_a, libconfig_a,
libcore_a, libcore_a,
libirc_a, libirc_core_a,
libfuzzer_fe_common_core_a, libfuzzer_fe_common_core_a,
], ],
link_args : [fuzzer_lib], link_args : [fuzzer_lib],

View File

@ -32,7 +32,7 @@ executable('server-fuzz',
libconfig_a, libconfig_a,
libcore_a, libcore_a,
libfuzzer_fe_common_core_a, libfuzzer_fe_common_core_a,
libirc_a, libirc_core_a,
libfe_common_irc_a, libfe_common_irc_a,
libfe_irc_dcc_a, libfe_irc_dcc_a,
libfe_irc_notifylist_a, libfe_irc_notifylist_a,

View File

@ -43,9 +43,9 @@
#include <irssi/src/irc/core/irc-channels.h> #include <irssi/src/irc/core/irc-channels.h>
#include <irssi/src/fe-fuzz/null-logger.h> #include <irssi/src/fe-fuzz/null-logger.h>
/* irc.c */ /* irc-core.c */
void irc_init(void); void irc_core_init(void);
void irc_deinit(void); void irc_core_deinit(void);
/* irc-session.c */ /* irc-session.c */
void irc_session_init(void); void irc_session_init(void);
@ -153,7 +153,7 @@ int LLVMFuzzerInitialize(int *argc, char ***argv) {
core_preinit((*argv)[0]); core_preinit((*argv)[0]);
core_init(); core_init();
irssi_ssl_init(); irssi_ssl_init();
irc_init(); irc_core_init();
fe_common_core_init(); fe_common_core_init();
fe_common_irc_init(); fe_common_irc_init();
signal_add("event 001", (SIGNAL_FUNC) event_connected); signal_add("event 001", (SIGNAL_FUNC) event_connected);

View File

@ -23,6 +23,7 @@
#include <irssi/src/core/modules-load.h> #include <irssi/src/core/modules-load.h>
#include <irssi/src/core/args.h> #include <irssi/src/core/args.h>
#include <irssi/src/core/signals.h> #include <irssi/src/core/signals.h>
#include <irssi/src/core/settings.h>
#include <irssi/src/core/core.h> #include <irssi/src/core/core.h>
#ifdef HAVE_STATIC_PERL #ifdef HAVE_STATIC_PERL
@ -30,8 +31,10 @@ void perl_core_init(void);
void perl_core_deinit(void); void perl_core_deinit(void);
#endif #endif
#ifdef HAVE_STATIC_IRC
void irc_init(void); void irc_init(void);
void irc_deinit(void); void irc_deinit(void);
#endif
static GMainLoop *main_loop; static GMainLoop *main_loop;
static char *autoload_module; static char *autoload_module;
@ -47,13 +50,32 @@ static void sig_reload(void)
reload = TRUE; reload = TRUE;
} }
static void autoload_modules(void)
{
char **list, **module;
list = g_strsplit_set(settings_get_str("autoload_modules"), " ,", -1);
for (module = list; *module != NULL; module++) {
char *tmp;
if ((tmp = strchr(*module, ':')) != NULL) {
*tmp = '\0';
tmp++;
module_load_sub(*module, tmp, NULL);
} else {
module_load(*module, NULL);
}
}
g_strfreev(list);
}
void noui_init(void) void noui_init(void)
{ {
srand(time(NULL)); srand(time(NULL));
irssi_gui = IRSSI_GUI_NONE; irssi_gui = IRSSI_GUI_NONE;
core_init(); core_init();
#ifdef HAVE_STATIC_IRC
irc_init(); irc_init();
#endif
module_register("core", "fe-none"); module_register("core", "fe-none");
@ -64,6 +86,8 @@ void noui_init(void)
perl_core_init(); perl_core_init();
#endif #endif
autoload_modules();
signal_emit("irssi init finished", 0); signal_emit("irssi init finished", 0);
} }
@ -75,7 +99,9 @@ void noui_deinit(void)
signal_remove("reload", (SIGNAL_FUNC) sig_reload); signal_remove("reload", (SIGNAL_FUNC) sig_reload);
signal_remove("gui exit", (SIGNAL_FUNC) sig_exit); signal_remove("gui exit", (SIGNAL_FUNC) sig_exit);
#ifdef HAVE_STATIC_IRC
irc_deinit(); irc_deinit();
#endif
core_deinit(); core_deinit();
} }

View File

@ -10,7 +10,6 @@ executable('botti',
link_with : [ link_with : [
libconfig_a, libconfig_a,
libcore_a, libcore_a,
libirc_a,
], ],
install : true, install : true,
dependencies : dep dependencies : dep

View File

@ -59,11 +59,13 @@ void otr_core_init(void);
void otr_core_deinit(void); void otr_core_deinit(void);
#endif #endif
#ifdef HAVE_STATIC_IRC
void irc_init(void); void irc_init(void);
void irc_deinit(void); void irc_deinit(void);
void fe_common_irc_init(void); void fe_common_irc_init(void);
void fe_common_irc_deinit(void); void fe_common_irc_deinit(void);
#endif
void gui_expandos_init(void); void gui_expandos_init(void);
void gui_expandos_deinit(void); void gui_expandos_deinit(void);
@ -168,9 +170,13 @@ static void textui_init(void)
irssi_gui = IRSSI_GUI_TEXT; irssi_gui = IRSSI_GUI_TEXT;
core_init(); core_init();
#ifdef HAVE_STATIC_IRC
irc_init(); irc_init();
#endif
fe_common_core_init(); fe_common_core_init();
#ifdef HAVE_STATIC_IRC
fe_common_irc_init(); fe_common_irc_init();
#endif
theme_register(gui_text_formats); theme_register(gui_text_formats);
signal_add("settings userinfo changed", (SIGNAL_FUNC) sig_settings_userinfo_changed); signal_add("settings userinfo changed", (SIGNAL_FUNC) sig_settings_userinfo_changed);
@ -301,9 +307,13 @@ static void textui_deinit(void)
theme_unregister(); theme_unregister();
#ifdef HAVE_STATIC_IRC
fe_common_irc_deinit(); fe_common_irc_deinit();
#endif
fe_common_core_deinit(); fe_common_core_deinit();
#ifdef HAVE_STATIC_IRC
irc_deinit(); irc_deinit();
#endif
core_deinit(); core_deinit();
} }

View File

@ -35,10 +35,6 @@ executable('irssi',
libconfig_a, libconfig_a,
libcore_a, libcore_a,
libfe_common_core_a, libfe_common_core_a,
libirc_a,
libfe_common_irc_a,
libfe_irc_dcc_a,
libfe_irc_notifylist_a,
], ],
install : true, install : true,
install_rpath : get_option('prefix') / get_option('libdir'), install_rpath : get_option('prefix') / get_option('libdir'),

View File

@ -106,9 +106,6 @@ void irc_core_init(void)
(QUERY_REC *(*) (const char *, const char *, int)) (QUERY_REC *(*) (const char *, const char *, int))
irc_query_create; irc_query_create;
chat_protocol_register(rec);
g_free(rec);
irc_session_init(); irc_session_init();
irc_chatnets_init(); irc_chatnets_init();
irc_servers_init(); irc_servers_init();
@ -125,6 +122,10 @@ void irc_core_init(void)
sasl_init(); sasl_init();
settings_check(); settings_check();
chat_protocol_register(rec);
g_free(rec);
module_register("irc", "core"); module_register("irc", "core");
} }

View File

@ -38,6 +38,15 @@ libirc_core_a = static_library('irc_core',
def_sysconfdir, def_sysconfdir,
], ],
dependencies : dep) dependencies : dep)
libirc_core_sm = shared_module('irc_core',
install : true,
install_dir : moduledir,
link_whole : libirc_core_a)
dl_cross_irc_core = []
if need_dl_cross_link
dl_cross_irc_core += libirc_core_sm
endif
install_headers( install_headers(
files( files(

View File

@ -1,6 +1,6 @@
# this file is part of irssi # this file is part of irssi
libirc_dcc_a = static_library('irc_dcc', libirc_dcc_sm = shared_module('irc_dcc',
files( files(
'dcc-autoget.c', 'dcc-autoget.c',
'dcc-chat.c', 'dcc-chat.c',
@ -13,8 +13,16 @@ libirc_dcc_a = static_library('irc_dcc',
), ),
include_directories : rootinc, include_directories : rootinc,
implicit_include_directories : false, implicit_include_directories : false,
install : true,
install_dir : moduledir,
link_with : dl_cross_irc_core,
dependencies : dep) dependencies : dep)
dl_cross_irc_dcc = []
if need_dl_cross_link
dl_cross_irc_dcc += libirc_dcc_sm
endif
install_headers( install_headers(
files( files(
'dcc-chat.h', 'dcc-chat.h',

View File

@ -8,6 +8,11 @@ libirc_flood_a = static_library('irc_flood',
include_directories : rootinc, include_directories : rootinc,
implicit_include_directories : false, implicit_include_directories : false,
dependencies : dep) dependencies : dep)
shared_module('irc_flood',
install : true,
install_dir : moduledir,
link_with : dl_cross_irc_core,
link_whole : libirc_flood_a)
install_headers( install_headers(
files('module.h'), files('module.h'),

View File

@ -1,5 +1,7 @@
#ifdef HAVE_STATIC_IRC
void irc_core_init(void); void irc_core_deinit(void); void irc_core_init(void); void irc_core_deinit(void);
void irc_dcc_init(void);void irc_flood_init(void);void irc_notifylist_init(void); void irc_dcc_init(void);void irc_flood_init(void);void irc_notifylist_init(void);
void irc_notifylist_deinit(void);void irc_flood_deinit(void);void irc_dcc_deinit(void); void irc_notifylist_deinit(void);void irc_flood_deinit(void);void irc_dcc_deinit(void);
void irc_init(void) { irc_core_init(); irc_dcc_init(); irc_flood_init(); irc_notifylist_init(); } void irc_init(void) { irc_core_init(); irc_dcc_init(); irc_flood_init(); irc_notifylist_init(); }
void irc_deinit(void) { irc_notifylist_deinit(); irc_flood_deinit(); irc_dcc_deinit(); irc_core_deinit(); } void irc_deinit(void) { irc_notifylist_deinit(); irc_flood_deinit(); irc_dcc_deinit(); irc_core_deinit(); }
#endif

View File

@ -5,20 +5,6 @@ subdir('dcc')
subdir('flood') subdir('flood')
subdir('notifylist') subdir('notifylist')
libirc_a = static_library('irc',
files(
'irc.c',
),
link_with : [
libirc_core_a,
libirc_dcc_a,
libirc_flood_a,
libirc_notifylist_a,
],
include_directories : rootinc,
implicit_include_directories : false,
)
if want_proxy if want_proxy
subdir('proxy') subdir('proxy')
endif endif

View File

@ -1,6 +1,6 @@
# this file is part of irssi # this file is part of irssi
libirc_notifylist_a = static_library('irc_notifylist', libirc_notifylist_sm = shared_module('irc_notifylist',
files( files(
'notify-commands.c', 'notify-commands.c',
'notify-ison.c', 'notify-ison.c',
@ -10,8 +10,16 @@ libirc_notifylist_a = static_library('irc_notifylist',
), ),
include_directories : rootinc, include_directories : rootinc,
implicit_include_directories : false, implicit_include_directories : false,
install : true,
install_dir : moduledir,
link_with : dl_cross_irc_core,
dependencies : dep) dependencies : dep)
dl_cross_irc_notifylist = []
if need_dl_cross_link
dl_cross_irc_notifylist += libirc_notifylist_sm
endif
install_headers( install_headers(
files( files(
'module.h', 'module.h',

View File

@ -1,5 +1,5 @@
libperl_Irssi_a = shared_module('Irssi', shared_module('Irssi',
[ xsubpp.process( [ xsubpp.process(
files( files(
'Channel.xs', 'Channel.xs',

View File

@ -1,4 +1,4 @@
libperl_Irssi_Irc_a = shared_module('Irc', shared_module('Irc',
[ xsubpp.process( [ xsubpp.process(
files( files(
'Channel.xs', 'Channel.xs',
@ -26,7 +26,7 @@ libperl_Irssi_Irc_a = shared_module('Irc',
include_directories : rootinc, include_directories : rootinc,
implicit_include_directories : true, implicit_include_directories : true,
dependencies : dep + [ perl_dep ], dependencies : dep + [ perl_dep ],
link_with : dl_cross_perl_core, link_with : dl_cross_perl_core + dl_cross_irc_dcc + dl_cross_irc_notifylist,
) )
install_headers( install_headers(

View File

@ -17,7 +17,7 @@ irssi_core_pl_h = custom_target('irssi-core.pl.h',
# required as of Meson 0.58.0 # required as of Meson 0.58.0
generated_files_inc = include_directories('.') generated_files_inc = include_directories('.')
libperl_core_a = shared_module('perl_core', libperl_core_sm = shared_module('perl_core',
files( files(
'perl-common.c', 'perl-common.c',
'perl-core.c', 'perl-core.c',
@ -44,10 +44,10 @@ libperl_core_a = shared_module('perl_core',
dl_cross_perl_core = [] dl_cross_perl_core = []
if need_dl_cross_link if need_dl_cross_link
dl_cross_perl_core += libperl_core_a dl_cross_perl_core += libperl_core_sm
endif endif
libfe_perl_a = shared_module('fe_perl', shared_module('fe_perl',
files( files(
'module-formats.c', 'module-formats.c',
'perl-fe.c', 'perl-fe.c',

View File

@ -583,6 +583,10 @@ static void perl_register_protocol(CHAT_PROTOCOL_REC *rec)
SV *sv; SV *sv;
chat_type = chat_protocol_lookup(rec->name); chat_type = chat_protocol_lookup(rec->name);
if (chat_type == CHAT_PROTOCOL_NOT_INITIALIZED) {
return;
}
g_return_if_fail(chat_type >= 0); g_return_if_fail(chat_type >= 0);
name = g_ascii_strdown(rec->name,-1); name = g_ascii_strdown(rec->name,-1);

View File

@ -1,4 +1,4 @@
libperl_Irssi_TextUI_a = shared_module('TextUI', shared_module('TextUI',
[ xsubpp.process( [ xsubpp.process(
files( files(
'Statusbar.xs', 'Statusbar.xs',

View File

@ -1,4 +1,4 @@
libperl_Irssi_UI_a = shared_module('UI', shared_module('UI',
[ xsubpp.process( [ xsubpp.process(
files( files(
'Formats.xs', 'Formats.xs',

View File

@ -6,7 +6,8 @@ test_test_796 = executable('test-796',
libconfig_a, libconfig_a,
libcore_a, libcore_a,
libfe_common_core_a, libfe_common_core_a,
libirc_a, libirc_core_a,
libirc_flood_a,
libfe_common_irc_a, libfe_common_irc_a,
libfe_irc_dcc_a, libfe_irc_dcc_a,
libfe_irc_notifylist_a, libfe_irc_notifylist_a,