forked from PsychoticNinja/irssi
Compare commits
820 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
cf4ea85ae4 | ||
|
684094aa85 | ||
|
c99c8b444d | ||
|
f9f6341c20 | ||
|
9a95edc69a | ||
|
93a94308bd | ||
|
afba148056 | ||
|
a661e2fb35 | ||
|
0c97433c7c | ||
|
26f9750ad1 | ||
|
277923aaac | ||
|
23419e5866 | ||
|
2c18da3cc6 | ||
|
c01b35b062 | ||
|
f51bc42429 | ||
|
be5f917f07 | ||
|
833f41179d | ||
|
c2457c7d94 | ||
|
093dcd423f | ||
|
55913ade13 | ||
|
de2bf6707f | ||
|
238d7cfd08 | ||
|
f76d41953f | ||
|
38b18bd84d | ||
|
d448ca3341 | ||
|
07041c37d4 | ||
|
fe77b7e06f | ||
|
03edebd54c | ||
|
f32d0ab51a | ||
|
7baefc3315 | ||
|
58109aeeed | ||
|
a237321b33 | ||
|
555030a2ad | ||
|
252656cad4 | ||
|
722d3c4c3d | ||
|
bc805f9bcd | ||
|
476774662a | ||
|
a57cc1c55e | ||
|
7fe7de3c2e | ||
|
1b6b92ffff | ||
|
730c3c1a12 | ||
|
c6a7f02042 | ||
|
f17fb68257 | ||
|
3404d822c8 | ||
|
5b0f7f7899 | ||
|
3fec4d894f | ||
|
0bf18beed7 | ||
|
f135339e27 | ||
|
593afc2e40 | ||
|
783dd37533 | ||
|
4dc3eb1048 | ||
|
453e65bbfe | ||
|
b028b8e19d | ||
|
48edd6f5fa | ||
|
a5f5ea7d79 | ||
|
891ef5df10 | ||
|
04b914dcb0 | ||
|
67aa2baf62 | ||
|
ae8ec99d5c | ||
|
68823eb6af | ||
|
545d97f8d6 | ||
|
279fa4e5b8 | ||
|
528632bba2 | ||
|
34d45ac678 | ||
|
88745d2941 | ||
|
07aa061b6d | ||
|
ac35fe010e | ||
|
de46fee864 | ||
|
f2c5e60766 | ||
|
531c68ed09 | ||
|
0e0bc17992 | ||
|
580b05a7f3 | ||
|
47b0661e96 | ||
|
a39bc0601c | ||
|
c33d0c2384 | ||
|
7207a26d1e | ||
|
a558430a0a | ||
|
612fdb9c2d | ||
|
cbb155e73c | ||
|
84de64d6da | ||
|
d6bc4cf5b7 | ||
|
d193ca1784 | ||
|
afed542bfb | ||
|
1598c88cfd | ||
|
3e9a270562 | ||
|
8530917397 | ||
|
aa54da3811 | ||
|
45b6df7902 | ||
|
44ad0fce90 | ||
|
dc15cc3969 | ||
|
5997b2654b | ||
|
baf2a43da2 | ||
|
26c4cd8bbf | ||
|
27046adabe | ||
|
ff0e76bbb9 | ||
|
af5feb16be | ||
|
66e3b0e578 | ||
|
7285da27e0 | ||
|
5b340d7d2b | ||
|
9f71a391c3 | ||
|
fb5c99d27f | ||
|
7d673653a1 | ||
|
6d2cfc24b7 | ||
|
2f700bebc7 | ||
|
4cec2d98c5 | ||
|
37e65ba168 | ||
|
b446d06b9d | ||
|
49479f151c | ||
|
4f1e5f35a3 | ||
|
ba16d71e9f | ||
|
f684c18867 | ||
|
48571389c7 | ||
|
41b3895ce3 | ||
|
1415ef5389 | ||
|
3a3301e19b | ||
|
e300fee93d | ||
|
7360944900 | ||
|
0bd7fc459c | ||
|
ae5a9283ee | ||
|
ed4ec313a2 | ||
|
cfd421a948 | ||
|
8381e13e4c | ||
|
884cabd55d | ||
|
84a98d0e08 | ||
|
c62505386f | ||
|
4986a4f9db | ||
|
0c49ba0bda | ||
|
344398dd2a | ||
|
82dd550184 | ||
|
8fa2d01a7f | ||
|
bb4859d3d5 | ||
|
4bf129084f | ||
|
4115e47434 | ||
|
c0929e3aaf | ||
|
883510a3fd | ||
|
06a7dcad99 | ||
|
10caed057a | ||
|
854c88da03 | ||
|
9b768abfd7 | ||
|
3a5f93bbcc | ||
|
0682cbed3c | ||
|
b34f16e9df | ||
|
58efc6371a | ||
|
e692f85f4a | ||
|
b8736225cf | ||
|
cf6bc31172 | ||
|
7ec61c4ec0 | ||
|
9b73d152fe | ||
|
bfcafa76c0 | ||
|
d9b181e4a1 | ||
|
b335e5526d | ||
|
1f8e167295 | ||
|
ef2c55fc18 | ||
|
2e6c376342 | ||
|
89bcff606f | ||
|
f4938a2804 | ||
|
3760fcd1ca | ||
|
bee057ff21 | ||
|
82f8ee57c3 | ||
|
738931762b | ||
|
76d140650a | ||
|
27008bf447 | ||
|
d523ceacf0 | ||
|
e5d02bd57b | ||
|
32ab41625f | ||
|
089cab715f | ||
|
75e56297fc | ||
|
d652055060 | ||
|
d6b55c6d43 | ||
|
de626250b5 | ||
|
cdda5ab759 | ||
|
f47154d1a9 | ||
|
cc411a1be0 | ||
|
d4ed3460fc | ||
|
5cd13d6ea2 | ||
|
17f185d833 | ||
|
5f29b35fbe | ||
|
4846e4f319 | ||
|
53187de6a2 | ||
|
2e6375d4ff | ||
|
7b22f41ec5 | ||
|
29e36a8fb0 | ||
|
c0123a1487 | ||
|
b60b0f0ff9 | ||
|
3603d47990 | ||
|
c96a8d9fae | ||
|
95e3fea622 | ||
|
937786b731 | ||
|
d4e3655f1f | ||
|
f7fd4d72e4 | ||
|
3e4d7ded77 | ||
|
d4ad71c831 | ||
|
85a6ade7e8 | ||
|
dbf9fc3dfc | ||
|
6763be847f | ||
|
bb1957bafb | ||
|
a2feef5e73 | ||
|
60cb9451b3 | ||
|
8281b10310 | ||
|
62eff3d2a7 | ||
|
d33fd0c5da | ||
|
8088353ed0 | ||
|
920e827ae5 | ||
|
0e3f6aa4a2 | ||
|
9579105748 | ||
|
9b79749f6c | ||
|
608c7b09d7 | ||
|
05063da999 | ||
|
eed9b32f97 | ||
|
bdadbb183f | ||
|
a54a00c803 | ||
|
2f99f3a5d3 | ||
|
c5dc3fc2a0 | ||
|
b9f773ba6a | ||
|
8f40b3ba7b | ||
|
815ee7b2dd | ||
|
47f8582e68 | ||
|
23abfb9123 | ||
|
6db881d8ef | ||
|
3bb8c619e2 | ||
|
44298db814 | ||
|
f5d74bd81b | ||
|
bec9e04714 | ||
|
b22588a9ad | ||
|
ea961623f5 | ||
|
db200f266b | ||
|
b878c7f079 | ||
|
1d3cdfa2d2 | ||
|
96d99534c3 | ||
|
5bff40593f | ||
|
0ba449d8be | ||
|
117758fb90 | ||
|
0932bbed7b | ||
|
235c5b0328 | ||
|
2d9c27d617 | ||
|
4943cc5e58 | ||
|
85a9dc146d | ||
|
9f9d49a2f1 | ||
|
6a83eddf84 | ||
|
32a3f4463c | ||
|
db705278d2 | ||
|
df227eb094 | ||
|
b0fdbb144d | ||
|
bcea697e7c | ||
|
8b49cd012d | ||
|
ad8221835c | ||
|
515e493db3 | ||
|
949dc06af3 | ||
|
0f3e95892d | ||
|
42f749346b | ||
|
d3e105a396 | ||
|
7e14011404 | ||
|
27a73e253b | ||
|
85eb4f118f | ||
|
521c0d4e6f | ||
|
2003446e98 | ||
|
2cdcf86174 | ||
|
921c40f09b | ||
|
69358fbe7c | ||
|
9e12890110 | ||
|
3e08ac538d | ||
|
37eb6c351c | ||
|
fe09dccdcb | ||
|
ce1eed94d1 | ||
|
cb11fd9cf7 | ||
|
03217a487e | ||
|
10b5087ded | ||
|
cf90384023 | ||
|
37237f377e | ||
|
2de9c25376 | ||
|
157913bd98 | ||
|
240b79aa26 | ||
|
0e8717acf6 | ||
|
82d2cd88e7 | ||
|
1a30e646d9 | ||
|
939b773b8b | ||
|
1a6d74ac26 | ||
|
6c47fcf10d | ||
|
21701a1299 | ||
|
b7b91ed2bf | ||
|
3324c5da89 | ||
|
d3115f3855 | ||
|
215cf08828 | ||
|
e10e1c2da7 | ||
|
92ade2f591 | ||
|
6710b35736 | ||
|
63a5b80ba7 | ||
|
4b506fc45c | ||
|
c4fd417cce | ||
|
49903f4185 | ||
|
4001871552 | ||
|
a07a4c1ea8 | ||
|
e88f476115 | ||
|
b3f74fe0ab | ||
|
6a33139939 | ||
|
fdd61f5898 | ||
|
d6f876d5ca | ||
|
0c82a3adfd | ||
|
a6722f5c71 | ||
|
5a8b23cab0 | ||
|
85f0a4c1f0 | ||
|
96e9ab41e9 | ||
|
ed23d89a5a | ||
|
425178e793 | ||
|
1602b506a6 | ||
|
6a52b5ac07 | ||
|
5953b675b9 | ||
|
8d314eadf1 | ||
|
9677b07488 | ||
|
7d13cfba07 | ||
|
554a8556d2 | ||
|
7452ec34ad | ||
|
b38d254d04 | ||
|
3aeebd310d | ||
|
d2062e34cf | ||
|
be7a3a85e7 | ||
|
77741b187c | ||
|
a6ca512150 | ||
|
aecf087014 | ||
|
53b2e0775a | ||
|
471046f5b6 | ||
|
6591c94635 | ||
|
f147589e52 | ||
|
e31d42b381 | ||
|
a5d4fd5aa7 | ||
|
1773fa8d19 | ||
|
a4486c236a | ||
|
700ec4c472 | ||
|
ca9fcbc124 | ||
|
1ba48840a1 | ||
|
5779306df0 | ||
|
58c9aecf86 | ||
|
5df2d6e300 | ||
|
a3248d43ec | ||
|
768658f5d5 | ||
|
af489b2d5f | ||
|
da21a7f279 | ||
|
dcbc895e26 | ||
|
f5303c153c | ||
|
b4b040d93d | ||
|
2122daa3f3 | ||
|
4fa72e857c | ||
|
9503d4bcba | ||
|
3dbfac5699 | ||
|
afcb48384e | ||
|
4432b0bf0d | ||
|
afdd9f8f05 | ||
|
f93879baff | ||
|
90003a2bf6 | ||
|
fa913091bd | ||
|
3a54c85b15 | ||
|
8bb4875007 | ||
|
645d80d3b8 | ||
|
8a5d5d384e | ||
|
61237ee6c0 | ||
|
085c08e65c | ||
|
244a8c72b4 | ||
|
2a0f1d7636 | ||
|
f2795abcc5 | ||
|
db2fed0d38 | ||
|
9668217509 | ||
|
51508ff1d3 | ||
|
9b02424f30 | ||
|
308400154b | ||
|
46493c051b | ||
|
1e54b92220 | ||
|
efd705ba59 | ||
|
b4ab8c1ada | ||
|
d20d2753da | ||
|
628ca79e6a | ||
|
7a3a383772 | ||
|
80926476fc | ||
|
e0b98e1fa5 | ||
|
4c25bef29c | ||
|
cdb30695f9 | ||
|
a731525012 | ||
|
437accdfa6 | ||
|
9362c59cd2 | ||
|
eeccfc3db1 | ||
|
cd866c548a | ||
|
9a8fc7112a | ||
|
8b597cb753 | ||
|
c5cc58d34e | ||
|
0b82f14151 | ||
|
6f38095cd6 | ||
|
a0142ce384 | ||
|
030da3ec9c | ||
|
25ad30d5e4 | ||
|
7d213da88a | ||
|
9ce3420440 | ||
|
f5339edbbc | ||
|
bf41bfa2f7 | ||
|
5f1fe607e4 | ||
|
5223ff1bcc | ||
|
f4e64e488d | ||
|
4e1aad6679 | ||
|
53c91623c5 | ||
|
b957d3ad4b | ||
|
18ee6bb6f9 | ||
|
6eeec6a112 | ||
|
04b44a8f8d | ||
|
b2c9365623 | ||
|
4c069f5c8f | ||
|
73e73df1c5 | ||
|
a8144cd98f | ||
|
3a929898e2 | ||
|
79be775f2b | ||
|
b11f973345 | ||
|
09c17c3302 | ||
|
a0a9a82673 | ||
|
04089d5866 | ||
|
04035ab7ca | ||
|
dc87199100 | ||
|
bf1376e34e | ||
|
7adf81f9b5 | ||
|
b47257048c | ||
|
3ea25fb704 | ||
|
322df0d2c8 | ||
|
d535a79730 | ||
|
33d8cc3254 | ||
|
395453aa23 | ||
|
ccf59868e2 | ||
|
672f127544 | ||
|
a426d669dc | ||
|
0dd60755f0 | ||
|
33b4154b0c | ||
|
23e4bfa1db | ||
|
39ed1ba055 | ||
|
5e88c107f1 | ||
|
33bfd88d9e | ||
|
95f131da2d | ||
|
e7f3946583 | ||
|
c108cae02f | ||
|
feb83b2058 | ||
|
db9aa817d5 | ||
|
adb50a7409 | ||
|
a76debde58 | ||
|
ea5121da3b | ||
|
cd8a0cb701 | ||
|
24999a066c | ||
|
8e69b2bbb4 | ||
|
8f23e6c6db | ||
|
b7bea3d2f3 | ||
|
4db0535b32 | ||
|
16b1d58703 | ||
|
68da49db78 | ||
|
504cf21783 | ||
|
aa653aa389 | ||
|
b5ddc55fe6 | ||
|
8405c6970a | ||
|
50ed476623 | ||
|
9181796472 | ||
|
edb2f699d1 | ||
|
9cbdf9175e | ||
|
168ba937c1 | ||
|
57408b19d5 | ||
|
7379833b53 | ||
|
8f6e67b9b3 | ||
|
1f05f86167 | ||
|
1e7af8bf61 | ||
|
0ae27530d6 | ||
|
18a1a0ba7c | ||
|
a1cbb8d28f | ||
|
e08aca6c85 | ||
|
9f1822be3d | ||
|
0706ad14fc | ||
|
cfc2ddf56a | ||
|
06396e9c8f | ||
|
ae5e2fe5e5 | ||
|
581c43ed1e | ||
|
69396482be | ||
|
f57dcfe90d | ||
|
c9ccf9867f | ||
|
5f7d274ec5 | ||
|
e0292665c1 | ||
|
dd8478dcde | ||
|
323b60f339 | ||
|
5c0d798ef4 | ||
|
11b9cbdf35 | ||
|
8f4f0be6d4 | ||
|
4fb10322d1 | ||
|
eb4174ee1e | ||
|
17c6c22c89 | ||
|
447e565309 | ||
|
561619f23c | ||
|
a88806640b | ||
|
300cd14a70 | ||
|
dfba73225d | ||
|
ec2f269e98 | ||
|
556cb25239 | ||
|
fcf2919348 | ||
|
f8052b7f57 | ||
|
cd10745711 | ||
|
79c32cefe7 | ||
|
f4f2350d3c | ||
|
ffe0c71554 | ||
|
468d8b0c78 | ||
|
4e9dab4aeb | ||
|
40ed4122b1 | ||
|
e55f1f5cea | ||
|
ad30d568d6 | ||
|
12685f8074 | ||
|
af5987827c | ||
|
cc759e1179 | ||
|
70626d86ae | ||
|
76802985a4 | ||
|
37cac5a862 | ||
|
1b5bb8cdd7 | ||
|
357beb91f5 | ||
|
9593be14f5 | ||
|
26f3049a86 | ||
|
2d59df8162 | ||
|
7daeaa25b6 | ||
|
6012ec9e56 | ||
|
6684e5cc41 | ||
|
0cc1e4b7cd | ||
|
108f57ac7b | ||
|
0d2997b36f | ||
|
fe9a443380 | ||
|
964c067b1e | ||
|
01ecb879a6 | ||
|
4b2c710ebe | ||
|
fbe62a34d0 | ||
|
d5017cfc7c | ||
|
99b941db8e | ||
|
7c1237de98 | ||
|
2a2f7b826d | ||
|
214c7ad7da | ||
|
451e3692b2 | ||
|
1fef8f82a5 | ||
|
28768e40a3 | ||
|
ae6c8a1bd5 | ||
|
3ba8eeba4b | ||
|
3cb6627973 | ||
|
5ba58d9067 | ||
|
b0cd72aadd | ||
|
3ea854816d | ||
|
4330dbec62 | ||
|
784373a7b3 | ||
|
ba57684d73 | ||
|
9bfbb5cdf3 | ||
|
08ead5ef06 | ||
|
86b72d5829 | ||
|
bbd73ce58c | ||
|
66a7cc3c34 | ||
|
675696aa84 | ||
|
449d86caf0 | ||
|
8fd6dccaf1 | ||
|
57fb173130 | ||
|
a0544571a8 | ||
|
6b93d6e338 | ||
|
d2291ec6eb | ||
|
f95fc81130 | ||
|
4b24d0a51d | ||
|
94ae7f9cd3 | ||
|
244ebaaa2e | ||
|
316c8157a5 | ||
|
9ec9a9afc8 | ||
|
0bedcfccbd | ||
|
6d67cadcdb | ||
|
0548bb1a3c | ||
|
3d3305a893 | ||
|
6317db5ccb | ||
|
261631a6e1 | ||
|
f1647bdfa9 | ||
|
1bfe27c66e | ||
|
485ed2f52b | ||
|
f9595c03b1 | ||
|
cae37e37ca | ||
|
81dc94c406 | ||
|
8b7bf1f04e | ||
|
5d6baeb0b5 | ||
|
46ae8c20c5 | ||
|
8a446d24de | ||
|
ae89ba7164 | ||
|
4594b0c4cf | ||
|
b69074bb39 | ||
|
97670d1dc1 | ||
|
be467111fa | ||
|
aab5349256 | ||
|
6fc9362c65 | ||
|
597afa4043 | ||
|
d5a55f5e6e | ||
|
c8440d49d8 | ||
|
22851686f5 | ||
|
f0c1bc4dde | ||
|
1ad1083f84 | ||
|
7e898fdcf4 | ||
|
ca04e0ba5d | ||
|
43092a5bcc | ||
|
03295b73b4 | ||
|
b38ae68fb5 | ||
|
5dba9fd0cc | ||
|
e59c42bcc0 | ||
|
363a79dc7a | ||
|
b8be290640 | ||
|
6e14acee17 | ||
|
7d44964dcd | ||
|
1cdb4bc311 | ||
|
4c5f708b9b | ||
|
942462f23f | ||
|
664c38afba | ||
|
bdf5d748f2 | ||
|
50f8791f1e | ||
|
b7f165a609 | ||
|
a827c69183 | ||
|
d84f285b91 | ||
|
bf3565a720 | ||
|
453b648e7e | ||
|
ebdfd2e08c | ||
|
156d02c5cf | ||
|
5776ca5e0b | ||
|
7e6d24420c | ||
|
f9db4019af | ||
|
34effcec01 | ||
|
1639425217 | ||
|
4476fbbad9 | ||
|
145d1040ac | ||
|
ef5579c212 | ||
|
e4d34380e5 | ||
|
2af7db2dfa | ||
|
a68be4dcca | ||
|
49c6c2b69f | ||
|
03eb8d032a | ||
|
4cc286634a | ||
|
7e694fd223 | ||
|
ed65499d76 | ||
|
f6cca3de4e | ||
|
8a1a96c12c | ||
|
e36d6b9b8c | ||
|
51190f69b2 | ||
|
9ff224d05d | ||
|
96562e460b | ||
|
9a9f9cc22a | ||
|
69dec1de33 | ||
|
f875d252d2 | ||
|
3642dbad97 | ||
|
6d58052c4a | ||
|
7cebff503d | ||
|
948e7bb317 | ||
|
c271609a49 | ||
|
6646e49d42 | ||
|
1e9cd62aac | ||
|
0df21bcbb4 | ||
|
7aa67b142b | ||
|
887950db0f | ||
|
3447904a5c | ||
|
991e24fb27 | ||
|
401fff7c34 | ||
|
5a4e7ab659 | ||
|
570d6714ec | ||
|
44b060ce17 | ||
|
d627bf5f7a | ||
|
447e357e07 | ||
|
3f0afa91f3 | ||
|
a305cf8971 | ||
|
a8b695b890 | ||
|
487d9434bd | ||
|
3a654a9e01 | ||
|
7abec34668 | ||
|
e18708243b | ||
|
bdb25aa609 | ||
|
54781a34ee | ||
|
38df7bfd29 | ||
|
11887cf3e1 | ||
|
504d50c9a3 | ||
|
4359e4a5ff | ||
|
d5329bc811 | ||
|
4d01170aa1 | ||
|
255d850c4d | ||
|
587098199e | ||
|
b6f1bf8fcd | ||
|
d191c6e94e | ||
|
e20900a7ca | ||
|
44d480ca99 | ||
|
a54c2071e2 | ||
|
8f65f58a4a | ||
|
4dbbbf47a4 | ||
|
95d695de8c | ||
|
5f13614d47 | ||
|
61d215acdd | ||
|
6c37099407 | ||
|
200020da93 | ||
|
da9adec47f | ||
|
d418989f0c | ||
|
506f2fb327 | ||
|
f7e67b9e02 | ||
|
0f361d2673 | ||
|
2576064982 | ||
|
eb3a44a713 | ||
|
24154ced0d | ||
|
e62e55c0ab | ||
|
c87919235a | ||
|
47518b4b75 | ||
|
6e32c1f638 | ||
|
76bcd01da0 | ||
|
ebd17348a6 | ||
|
ad7ad063ca | ||
|
0a12bf682d | ||
|
4ae1dbbd00 | ||
|
2f82d9cd33 | ||
|
ab8385d2bb | ||
|
25270e0465 | ||
|
ed4297c41b | ||
|
27546354ca | ||
|
1c99bf78c7 | ||
|
fa0ecb688d | ||
|
3ea22fb535 | ||
|
256b6aa2f5 | ||
|
d512647b3f | ||
|
e0ff13f6c1 | ||
|
a865b07a67 | ||
|
0495c67d9f | ||
|
89686681c1 | ||
|
f3e037f434 | ||
|
ec32e39ae7 | ||
|
d7fcb846d3 | ||
|
f612f2ee51 | ||
|
c92ff1701f | ||
|
7e767e1444 | ||
|
dde5fff4a5 | ||
|
6c7fa15417 | ||
|
05d50ffa1b | ||
|
9a90213ba9 | ||
|
f8f2428cfb | ||
|
7f99bbfd00 | ||
|
69a91bbcce | ||
|
6277ccf67f | ||
|
66ac295818 | ||
|
12c8cb1f37 | ||
|
aa9bb36a0d | ||
|
fa7539b616 | ||
|
99b2c0b04a | ||
|
afde106cdc | ||
|
73f6964d4f | ||
|
d55a74587c | ||
|
00a7efc69f | ||
|
84301a29f8 | ||
|
c3bd917cf2 | ||
|
ddb9d5c15f | ||
|
2599124bc8 | ||
|
cfca498a1d | ||
|
905bf86921 | ||
|
9a93e71474 | ||
|
db16a0a853 | ||
|
fb85fdec5c | ||
|
7286da0f9e | ||
|
87a2ceb27d | ||
|
beea28bbbc | ||
|
8551dd99cc | ||
|
d23b0d22cc | ||
|
d34bd858d0 | ||
|
8d11060fbc | ||
|
5a67b983dc | ||
|
38b6284535 | ||
|
0ffc515264 | ||
|
fb720e76de | ||
|
399c922524 | ||
|
1d6aeb08fd | ||
|
d9fef37131 | ||
|
085888d1c0 | ||
|
1910b67b97 | ||
|
cd5958079c | ||
|
a210df942d | ||
|
38a81026b9 | ||
|
7e7bc98396 | ||
|
5d70eb18f5 | ||
|
78ae00910e | ||
|
7654f30d04 | ||
|
9e13892e28 | ||
|
20f7792748 | ||
|
d0e1786267 | ||
|
d45993dba4 | ||
|
4a3a064d55 | ||
|
6933134352 | ||
|
845431aa31 | ||
|
9bbacf861b | ||
|
37f7c7f374 | ||
|
03ca37c12e | ||
|
7e6e1f2e10 | ||
|
d5fd789674 | ||
|
2db6e99038 | ||
|
da266691bb | ||
|
ad3b8df97e | ||
|
796b60dd45 | ||
|
9d9d99eeb1 | ||
|
530393140a | ||
|
04ca271d77 | ||
|
6d3e763248 | ||
|
2b48ddd3c9 | ||
|
8789027617 | ||
|
690e441771 | ||
|
a2f2d1899b | ||
|
791071f6e4 | ||
|
3e0bc1eb3c | ||
|
dd5b611c72 | ||
|
2f5f342977 | ||
|
c66fe616e1 | ||
|
9cdeed2894 | ||
|
d0bc5b8cf2 | ||
|
1fe6fd8057 | ||
|
1247b37ff7 | ||
|
40d800637a | ||
|
22502abf2c | ||
|
8479ff7a2e | ||
|
6a2823ad3e | ||
|
26d96a7bb2 | ||
|
bc94100114 | ||
|
6242d25055 | ||
|
c61a171114 | ||
|
a37672361a | ||
|
01ce66c684 | ||
|
c25d24220f | ||
|
2db359fbb3 | ||
|
e793d7af9f | ||
|
df532d4461 | ||
|
80fe52cb59 | ||
|
c1b604ee6a | ||
|
3664484bef | ||
|
63cc937e67 |
@ -27,7 +27,7 @@ Language: Cpp
|
||||
Cpp11BracedListStyle: false
|
||||
MaxEmptyLinesToKeep: 1
|
||||
PointerAlignment: Right
|
||||
SortIncludes: true
|
||||
SortIncludes: false
|
||||
SpaceAfterCStyleCast: true
|
||||
SpaceBeforeAssignmentOperators: true
|
||||
SpaceBeforeParens: ControlStatements
|
||||
|
127
.github/workflows/abicheck.yml
vendored
Normal file
127
.github/workflows/abicheck.yml
vendored
Normal file
@ -0,0 +1,127 @@
|
||||
on: [pull_request]
|
||||
name: abicheck
|
||||
env:
|
||||
build_options: -Dbuildtype=debug -Denable-true-color=yes -Dwith-proxy=yes -Dc_args=-DPERL_EUPXS_ALWAYS_EXPORT
|
||||
prefix: /usr/local
|
||||
apt_build_deps: ninja-build libutf8proc-dev libperl-dev libotr5-dev
|
||||
get_pip_build_deps: pip3 install setuptools; pip3 install wheel; pip3 install 'meson<0.59.0'
|
||||
getabidef_def: getabidef() { awk '$1=="#define" && $2=="IRSSI_ABI_VERSION" { print $3 }' "$1"/include/irssi/src/common.h; }
|
||||
jobs:
|
||||
build-base-ref:
|
||||
runs-on: ubuntu-latest
|
||||
outputs:
|
||||
base_abi: ${{ steps.out.outputs.base_abi }}
|
||||
steps:
|
||||
- name: set PATH
|
||||
run: |
|
||||
echo "$HOME/.local/bin" >> $GITHUB_PATH
|
||||
- name: prepare required software
|
||||
run: |
|
||||
sudo apt install $apt_build_deps
|
||||
eval "$get_pip_build_deps"
|
||||
- name: checkout base ref
|
||||
uses: actions/checkout@main
|
||||
with:
|
||||
path: base.src
|
||||
ref: ${{ github.base_ref }}
|
||||
- name: build base ref
|
||||
run: |
|
||||
meson Build.base base.src $build_options
|
||||
ninja -C Build.base
|
||||
DESTDIR=$PWD/base ninja -C Build.base install
|
||||
- id: out
|
||||
run: |
|
||||
# print versions and abi versions
|
||||
eval "$getabidef_def"
|
||||
base_abi=$(getabidef base$prefix)
|
||||
echo base abi : $base_abi
|
||||
./base$prefix/bin/irssi --version
|
||||
echo "::set-output name=base_abi::$base_abi"
|
||||
- uses: actions/upload-artifact@v2
|
||||
with:
|
||||
name: base.inst
|
||||
path: base
|
||||
retention-days: 1
|
||||
build-merge-ref:
|
||||
runs-on: ubuntu-latest
|
||||
outputs:
|
||||
merge_abi: ${{ steps.out.outputs.merge_abi }}
|
||||
steps:
|
||||
- name: set PATH
|
||||
run: |
|
||||
echo "$HOME/.local/bin" >> $GITHUB_PATH
|
||||
- name: prepare required software
|
||||
run: |
|
||||
sudo apt install $apt_build_deps
|
||||
eval "$get_pip_build_deps"
|
||||
- name: checkout merge ref
|
||||
uses: actions/checkout@main
|
||||
with:
|
||||
path: merge.src
|
||||
- name: build merge ref
|
||||
run: |
|
||||
meson Build.merge merge.src $build_options
|
||||
ninja -C Build.merge
|
||||
DESTDIR=$PWD/merge ninja -C Build.merge install
|
||||
- id: out
|
||||
run: |
|
||||
# print versions and abi versions
|
||||
eval "$getabidef_def"
|
||||
merge_abi=$(getabidef merge$prefix)
|
||||
echo merge abi : $merge_abi
|
||||
./merge$prefix/bin/irssi --version
|
||||
echo "::set-output name=merge_abi::$merge_abi"
|
||||
- uses: actions/upload-artifact@v2
|
||||
with:
|
||||
name: merge.inst
|
||||
path: merge
|
||||
retention-days: 1
|
||||
check-abi-diff:
|
||||
runs-on: ubuntu-latest
|
||||
needs:
|
||||
- build-merge-ref
|
||||
- build-base-ref
|
||||
env:
|
||||
base_abi: ${{ needs.build-base-ref.outputs.base_abi }}
|
||||
merge_abi: ${{ needs.build-merge-ref.outputs.merge_abi }}
|
||||
steps:
|
||||
- name: prepare required software
|
||||
run: |
|
||||
sudo apt install abigail-tools
|
||||
- name: fetch base build
|
||||
uses: actions/download-artifact@v2
|
||||
with:
|
||||
name: base.inst
|
||||
path: base
|
||||
- name: fetch merge build
|
||||
uses: actions/download-artifact@v2
|
||||
with:
|
||||
name: merge.inst
|
||||
path: merge
|
||||
- run: |
|
||||
# abipkgdiff
|
||||
abipkgdiff -l base merge >abipkgdiff.out && diff_ret=0 || diff_ret=$?
|
||||
echo "diff_ret=$diff_ret" >> $GITHUB_ENV
|
||||
cat abipkgdiff.out
|
||||
- uses: actions/upload-artifact@v2
|
||||
with:
|
||||
path: abipkgdiff.out
|
||||
- run: |
|
||||
# Check if no changes are needed
|
||||
if [ "$diff_ret" -ne 0 ]; then
|
||||
if [ "$base_abi" -lt "$merge_abi" ]; then
|
||||
echo "::warning ::abigail found changes and ABI changed from $base_abi to $merge_abi"
|
||||
exit 0
|
||||
else
|
||||
echo "::error ::Looks like the ABI changed but the IRSSI_ABI_VERSION did not"
|
||||
exit $diff_ret
|
||||
fi
|
||||
else
|
||||
if [ "$base_abi" -ne "$merge_abi" ]; then
|
||||
echo "::error ::abigail found no changes yet the IRSSI_ABI_VERSION changed. Is this correct?"
|
||||
exit 1
|
||||
else
|
||||
: "No changes detected and IRSSI_ABI_VERSION untouched"
|
||||
exit 0
|
||||
fi
|
||||
fi
|
101
.github/workflows/check.yml
vendored
Normal file
101
.github/workflows/check.yml
vendored
Normal file
@ -0,0 +1,101 @@
|
||||
on:
|
||||
push:
|
||||
branches:
|
||||
- master
|
||||
pull_request:
|
||||
name: Check Irssi
|
||||
env:
|
||||
apt_build_deps: libutf8proc-dev libperl-dev libotr5-dev
|
||||
apt_build_deps_meson: ninja-build
|
||||
get_pip_build_deps_meson: pip3 install setuptools${setuptools_ver}; pip3 install wheel; pip3 install meson${meson_ver}
|
||||
build_options_meson: -Dwith-proxy=yes -Dwith-bot=yes -Dwith-perl=yes -Dwith-otr=yes
|
||||
prefix: ~/irssi-build
|
||||
jobs:
|
||||
dist:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: prepare required software
|
||||
run: |
|
||||
sudo apt update && sudo apt install $apt_build_deps
|
||||
- uses: actions/checkout@main
|
||||
- name: make dist
|
||||
run: |
|
||||
./utils/make-dist.sh
|
||||
- uses: actions/upload-artifact@v2
|
||||
with:
|
||||
path: irssi-*.tar.gz
|
||||
retention-days: 1
|
||||
install:
|
||||
runs-on: ${{ matrix.os }}
|
||||
env:
|
||||
CC: ${{ matrix.compiler }}
|
||||
needs: dist
|
||||
continue-on-error: ${{ contains(matrix.flags, 'FAILURE-OK') }}
|
||||
strategy:
|
||||
fail-fast: false
|
||||
matrix:
|
||||
os: [ubuntu-18.04, ubuntu-latest]
|
||||
builder: [meson]
|
||||
compiler: [clang, gcc]
|
||||
flags: [regular]
|
||||
include:
|
||||
- os: ubuntu-18.04
|
||||
builder: meson
|
||||
meson_ver: ==0.53.2
|
||||
setuptools_ver: <51
|
||||
- os: ubuntu-latest
|
||||
builder: meson
|
||||
meson_ver: <0.63.0
|
||||
- os: ubuntu-latest
|
||||
builder: meson
|
||||
flags: meson-latest FAILURE-OK
|
||||
steps:
|
||||
- name: fetch dist
|
||||
uses: actions/download-artifact@v2
|
||||
- name: set PATH
|
||||
run: |
|
||||
echo "$HOME/.local/bin" >> $GITHUB_PATH
|
||||
- name: prepare required software
|
||||
env:
|
||||
meson_ver: ${{ matrix.meson_ver }}
|
||||
setuptools_ver: ${{ matrix.setuptools_ver }}
|
||||
run: |
|
||||
sudo apt update && sudo apt install $apt_build_deps $apt_build_deps_${{ matrix.builder }}
|
||||
eval "$get_pip_build_deps_${{ matrix.builder }}"
|
||||
curl -SLf https://github.com/irssi-import/actions-irssi/raw/master/check-irssi/render.pl -o ~/render.pl && chmod +x ~/render.pl
|
||||
- name: unpack archive
|
||||
run: tar xaf artifact/irssi-*.tar.gz
|
||||
- name: build and install with meson
|
||||
run: |
|
||||
# ninja install
|
||||
cd irssi-*/
|
||||
meson Build $build_options_meson --prefix=${prefix/\~/~}
|
||||
ninja -C Build
|
||||
ninja -C Build install
|
||||
if: ${{ matrix.builder == 'meson' }}
|
||||
- name: run tests with Meson
|
||||
run: |
|
||||
# ninja test
|
||||
cd irssi-*/
|
||||
ninja -C Build test
|
||||
find -name testlog.txt -exec sed -i -e '/Inherited environment:.* GITHUB/d' {} + -exec cat {} +
|
||||
if: ${{ matrix.builder == 'meson' }}
|
||||
- name: run launch test
|
||||
env:
|
||||
TERM: xterm
|
||||
run: |
|
||||
# automated irssi launch test
|
||||
cd
|
||||
mkdir irssi-test
|
||||
echo 'echo automated irssi launch test
|
||||
^set settings_autosave off
|
||||
^set -clear log_close_string
|
||||
^set -clear log_day_changed
|
||||
^set -clear log_open_string
|
||||
^set log_timestamp *
|
||||
^window log on' > irssi-test/startup
|
||||
echo load perl >> irssi-test/startup
|
||||
echo load proxy >> irssi-test/startup
|
||||
echo ^quit >> irssi-test/startup
|
||||
irssi-build/bin/irssi --home irssi-test | perl -Mutf8 -C ~/render.pl
|
||||
cat irc.log.*
|
51
.github/workflows/cifuzz.yml
vendored
Normal file
51
.github/workflows/cifuzz.yml
vendored
Normal file
@ -0,0 +1,51 @@
|
||||
name: CIFuzz
|
||||
on:
|
||||
pull_request:
|
||||
paths:
|
||||
- 'src/core/**/*.c'
|
||||
- 'src/fe-common/core/**/*.c'
|
||||
- 'src/fe-text/gui-*.c'
|
||||
- 'src/irc/**/*.c'
|
||||
- 'src/fe-common/irc/**/*.c'
|
||||
- 'src/lib-config/**/*.c'
|
||||
- 'src/fe-fuzz/**/*.c'
|
||||
- 'tests/**/*.c'
|
||||
- '.github/workflows/cifuzz.yml'
|
||||
jobs:
|
||||
Fuzzing:
|
||||
runs-on: ubuntu-latest
|
||||
strategy:
|
||||
fail-fast: false
|
||||
matrix:
|
||||
sanitizer: [address, undefined, memory]
|
||||
steps:
|
||||
- uses: actions/checkout@main
|
||||
with:
|
||||
path: irssi
|
||||
- name: Docker build build_fuzzers container
|
||||
run: |
|
||||
# google/oss-fuzz/infra/cifuzz/actions/build_fuzzers@master
|
||||
docker build -t build_fuzzers:actions -f "/home/runner/work/_actions/google/oss-fuzz/master/infra/build_fuzzers.Dockerfile" "/home/runner/work/_actions/google/oss-fuzz/master/infra"
|
||||
- name: Build Fuzzers (${{ matrix.sanitizer }})
|
||||
id: build
|
||||
env:
|
||||
OSS_FUZZ_PROJECT_NAME: 'irssi'
|
||||
DRY_RUN: false
|
||||
SANITIZER: ${{ matrix.sanitizer }}
|
||||
PROJECT_SRC_PATH: /github/workspace/irssi
|
||||
REPOSITORY: 'irssi'
|
||||
run: |
|
||||
docker run --workdir /github/workspace --rm -e OSS_FUZZ_PROJECT_NAME -e DRY_RUN -e SANITIZER -e PROJECT_SRC_PATH -e REPOSITORY -e WORKSPACE=/github/workspace -e CI=true -v "/var/run/docker.sock":"/var/run/docker.sock" -v "$GITHUB_WORKSPACE":"/github/workspace" build_fuzzers:actions
|
||||
- name: Run Fuzzers (${{ matrix.sanitizer }})
|
||||
uses: google/oss-fuzz/infra/cifuzz/actions/run_fuzzers@master
|
||||
with:
|
||||
oss-fuzz-project-name: 'irssi'
|
||||
fuzz-seconds: 600
|
||||
dry-run: false
|
||||
sanitizer: ${{ matrix.sanitizer }}
|
||||
- name: Upload Crash
|
||||
uses: actions/upload-artifact@v1
|
||||
if: failure() && steps.build.outcome == 'success'
|
||||
with:
|
||||
name: ${{ matrix.sanitizer }}-artifacts
|
||||
path: ./out/artifacts
|
29
.github/workflows/clangformat.yml
vendored
Normal file
29
.github/workflows/clangformat.yml
vendored
Normal file
@ -0,0 +1,29 @@
|
||||
on: [pull_request]
|
||||
name: clang-format
|
||||
jobs:
|
||||
check-clang-format:
|
||||
runs-on: ubuntu-22.04
|
||||
steps:
|
||||
- name: install clang-format
|
||||
run: sudo apt install clang-format-14
|
||||
- uses: actions/checkout@main
|
||||
- name: fetch target ref
|
||||
run:
|
||||
|
|
||||
refs=($(git log -1 --format=%s))
|
||||
git fetch --depth=1 origin "${refs[3]}"
|
||||
- name: configure clang-format
|
||||
run:
|
||||
|
|
||||
git config clangformat.binary $PWD/utils/clang-format-xs/clang-format-xs
|
||||
git config clangformat.extensions c,h,xs
|
||||
- name: run git-clang-format and Check if no changes are needed
|
||||
run:
|
||||
|
|
||||
CLANG_FORMAT=clang-format-14 git-clang-format-14 --diff FETCH_HEAD HEAD | tee git-clang-format.diff
|
||||
cmp -s <(echo no modified files to format) git-clang-format.diff || cmp -s <(echo -n) git-clang-format.diff
|
||||
- uses: actions/upload-artifact@v1
|
||||
if: failure()
|
||||
with:
|
||||
name: git-clang-format.diff
|
||||
path: git-clang-format.diff
|
79
.github/workflows/termuxpkg.yml
vendored
Normal file
79
.github/workflows/termuxpkg.yml
vendored
Normal file
@ -0,0 +1,79 @@
|
||||
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: create irssi build receipe
|
||||
run: |
|
||||
mkdir packages/irssi-an
|
||||
cat << 'BUILD_SH' > packages/irssi-an/build.sh
|
||||
TERMUX_PKG_HOMEPAGE=https://irssi.org/
|
||||
TERMUX_PKG_DESCRIPTION="Terminal based IRC client"
|
||||
TERMUX_PKG_LICENSE="GPL-2.0"
|
||||
TERMUX_PKG_MAINTAINER="@irssi"
|
||||
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_MESON_PERL_CROSS_FILE=$TERMUX_PKG_TMPDIR/meson-perl-cross-$TERMUX_ARCH.txt
|
||||
TERMUX_PKG_EXTRA_CONFIGURE_ARGS="
|
||||
-Dfhs-prefix=$TERMUX_PREFIX
|
||||
--cross-file $TERMUX_MESON_PERL_CROSS_FILE
|
||||
"
|
||||
|
||||
termux_step_pre_configure() {
|
||||
LDFLAGS+=" -landroid-glob"
|
||||
|
||||
# Make build log less noisy.
|
||||
CFLAGS+=" -Wno-compound-token-split-by-macro"
|
||||
|
||||
local perl_version=$(. $TERMUX_SCRIPTDIR/packages/perl/build.sh; echo $TERMUX_PKG_VERSION)
|
||||
|
||||
cat << MESON_PERL_CROSS >$TERMUX_MESON_PERL_CROSS_FILE
|
||||
[properties]
|
||||
perl_version = '$perl_version'
|
||||
perl_ccopts = ['-I$TERMUX_PREFIX/include', '-D_LARGEFILE_SOURCE', '-D_FILE_OFFSET_BITS=64', '-I$TERMUX_PREFIX/lib/perl5/$perl_version/${TERMUX_ARCH}-android/CORE']
|
||||
perl_ldopts = ['-Wl,-E', '-I$TERMUX_PREFIX/include', '-L$TERMUX_PREFIX/lib/perl5/$perl_version/${TERMUX_ARCH}-android/CORE', '-lperl', '-lm', '-ldl']
|
||||
perl_archname = '${TERMUX_ARCH}-android'
|
||||
perl_installsitearch = '$TERMUX_PREFIX/lib/perl5/site_perl/$perl_version/${TERMUX_ARCH}-android'
|
||||
perl_installvendorarch = ''
|
||||
perl_inc = ['$TERMUX_PREFIX/lib/perl5/site_perl/$perl_version/${TERMUX_ARCH}-android', '$TERMUX_PREFIX/lib/perl5/site_perl/$perl_version', '$TERMUX_PREFIX/lib/perl5/$perl_version/${TERMUX_ARCH}-android', '$TERMUX_PREFIX/lib/perl5/$perl_version']
|
||||
MESON_PERL_CROSS
|
||||
}
|
||||
|
||||
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: prepare output folder
|
||||
run: |
|
||||
install -m a+rwx -d output
|
||||
- name: build irssi package
|
||||
run: |
|
||||
sudo ./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
|
20
.github/workflows/trigger-pages.yml
vendored
Normal file
20
.github/workflows/trigger-pages.yml
vendored
Normal file
@ -0,0 +1,20 @@
|
||||
on:
|
||||
push:
|
||||
branches:
|
||||
- master
|
||||
|
||||
jobs:
|
||||
rebuild-pages:
|
||||
if: github.repository == 'irssi/irssi'
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/github-script@v6
|
||||
with:
|
||||
github-token: ${{ secrets.PAT_TOKEN }}
|
||||
script: |
|
||||
await github.rest.actions.createWorkflowDispatch({
|
||||
owner: context.repo.owner,
|
||||
repo: 'irssi.github.io',
|
||||
workflow_id: 'pages.yml',
|
||||
ref: 'main'
|
||||
})
|
13
.gitignore
vendored
13
.gitignore
vendored
@ -27,6 +27,7 @@ MYMETA.*
|
||||
|
||||
docs/help/Makefile.am
|
||||
docs/help/[a-z]*
|
||||
!docs/help/meson.build
|
||||
!docs/help/in
|
||||
docs/help/in/Makefile.am
|
||||
|
||||
@ -35,9 +36,6 @@ src/fe-fuzz/irssi-fuzz
|
||||
src/fe-fuzz/irc/core/event-get-params-fuzz
|
||||
src/fe-fuzz/fe-common/core/theme-load-fuzz
|
||||
|
||||
src/fe-common/irc/irc-modules.c
|
||||
src/irc/irc.c
|
||||
|
||||
src/perl/perl-signals-list.h
|
||||
src/perl/irssi-core.pl.h
|
||||
|
||||
@ -52,6 +50,8 @@ src/fe-fuzz/crash-*
|
||||
src/fe-fuzz/oom-*
|
||||
|
||||
/core
|
||||
/irssi-1.pc
|
||||
/irssi/
|
||||
/tests/fe-common/core/test-formats
|
||||
/tests/fe-common/core/test-formats.log
|
||||
/tests/fe-common/core/test-formats.trs
|
||||
@ -82,3 +82,10 @@ src/fe-fuzz/oom-*
|
||||
|
||||
.deps
|
||||
.libs
|
||||
|
||||
Build
|
||||
subprojects/*
|
||||
!subprojects/*.wrap
|
||||
Irssi-Dist
|
||||
setup.cfg
|
||||
*.egg-info
|
||||
|
13
.obs/workflows.yml
Normal file
13
.obs/workflows.yml
Normal file
@ -0,0 +1,13 @@
|
||||
workflow:
|
||||
steps:
|
||||
- branch_package:
|
||||
source_project: home:ailin_nemui:irssi-git-an
|
||||
source_package: irssi-git-an
|
||||
target_project: home:ailin_nemui:CI
|
||||
- set_flags:
|
||||
flags:
|
||||
- type: publish
|
||||
status: enable
|
||||
project: home:ailin_nemui:CI
|
||||
filters:
|
||||
event: pull_request
|
69
.travis.yml
69
.travis.yml
@ -1,69 +0,0 @@
|
||||
sudo: false
|
||||
dist: trusty
|
||||
language: perl
|
||||
perl:
|
||||
# ~stretch
|
||||
- "5.24-shrplib"
|
||||
# ~xenial
|
||||
# - "5.22-shrplib"
|
||||
# ~jessie
|
||||
# - "5.20-shrplib"
|
||||
# ~trusty
|
||||
# - "5.18-shrplib"
|
||||
- "system-perl"
|
||||
env:
|
||||
- CC=clang UNITTESTS=false
|
||||
- CC=gcc UNITTESTS=false
|
||||
- CC=clang UNITTESTS=true
|
||||
matrix:
|
||||
exclude:
|
||||
- env: CC=clang UNITTESTS=true
|
||||
perl: "system-perl"
|
||||
allow_failures:
|
||||
- env: CC=clang UNITTESTS=true
|
||||
|
||||
addons:
|
||||
apt:
|
||||
packages:
|
||||
- libperl-dev
|
||||
- elinks
|
||||
- libgcrypt11-dev
|
||||
|
||||
before_install:
|
||||
- perl -V
|
||||
- wget https://github.com/irssi-import/libotr/releases/download/4.1.1/travis-trusty-libotr-4.1.1.tar.gz
|
||||
- tar zxf travis-trusty-libotr*.tar.gz -C $HOME
|
||||
- ./autogen.sh --with-proxy --with-bot --with-perl=module --with-otr=yes --with-libotr-prefix=$HOME/otr-build/lib --with-libotr-inc-prefix=$HOME/otr-build/include
|
||||
- make dist
|
||||
- cd ..
|
||||
- tar xaf */irssi-*.tar.*
|
||||
- cd irssi-*
|
||||
|
||||
install:
|
||||
- ./configure --with-proxy --with-bot --with-perl=module --with-otr=yes --with-libotr-prefix=$HOME/otr-build/lib --with-libotr-inc-prefix=$HOME/otr-build/include --prefix=$HOME/irssi-build
|
||||
$( $UNITTESTS && echo --enable-always-build-tests )
|
||||
- make CFLAGS="-Wall -Werror -Werror=declaration-after-statement"
|
||||
- make install
|
||||
|
||||
before_script:
|
||||
- pushd ~
|
||||
- mkdir irssi-test
|
||||
- echo echo automated irssi launch test > irssi-test/startup;
|
||||
echo ^set settings_autosave off >> irssi-test/startup;
|
||||
echo ^set -clear log_close_string >> irssi-test/startup;
|
||||
echo ^set -clear log_day_changed >> irssi-test/startup;
|
||||
echo ^set -clear log_open_string >> irssi-test/startup;
|
||||
echo ^set log_timestamp '* ' >> irssi-test/startup;
|
||||
echo ^window log on >> irssi-test/startup
|
||||
- echo load perl >> irssi-test/startup
|
||||
- echo load proxy >> irssi-test/startup
|
||||
- echo ^quit >> irssi-test/startup
|
||||
|
||||
script:
|
||||
- irssi-build/bin/irssi --home irssi-test
|
||||
- popd
|
||||
- if $UNITTESTS; then make -C tests -sk check; fi
|
||||
|
||||
after_script:
|
||||
- cat ~/irc.log.*
|
||||
- find -name test-suite.log -exec cat {} +
|
93
INSTALL
93
INSTALL
@ -2,64 +2,63 @@
|
||||
Irssi installation instructions
|
||||
-------------------------------
|
||||
|
||||
To compile irssi you need:
|
||||
To compile Irssi you need:
|
||||
|
||||
- glib-2.6 or greater
|
||||
- pkg-config
|
||||
- meson-0.53 build system with ninja-1.8 or greater
|
||||
- glib-2.32 or greater
|
||||
- openssl (for ssl support)
|
||||
- perl-5.6 or greater (for perl support)
|
||||
- perl-5.6 or greater (for Perl support)
|
||||
- terminfo or ncurses (for text frontend)
|
||||
|
||||
For most people, this should work just fine:
|
||||
|
||||
./autogen.sh (for people who just cloned the repository)
|
||||
./configure (if this script already exists, skip ./autogen.sh)
|
||||
make
|
||||
meson Build
|
||||
ninja -C Build
|
||||
su
|
||||
make install (not _really_ required except for perl support)
|
||||
ninja -C Build install
|
||||
|
||||
meson options
|
||||
|
||||
configure options
|
||||
These options can be given to meson.
|
||||
|
||||
For a complete list of options, run
|
||||
meson configure
|
||||
|
||||
--prefix
|
||||
|
||||
Specifies the path where irssi will be installed.
|
||||
YES, you can install irssi WITHOUT ROOT permissions
|
||||
Specifies the path where Irssi will be installed.
|
||||
YES, you can install Irssi WITHOUT ROOT permissions
|
||||
by using --prefix=/home/dir
|
||||
|
||||
--with-proxy
|
||||
-Dwith-proxy=yes
|
||||
|
||||
Build the irssi proxy (see startup-HOWTO).
|
||||
Build the Irssi proxy (see startup-HOWTO).
|
||||
|
||||
--with-perl=[yes|no|module]
|
||||
-Dwith-perl=[yes|no]
|
||||
|
||||
Enable Perl support
|
||||
yes enable builtin (default)
|
||||
no disable
|
||||
module enable as module
|
||||
|
||||
--with-perl-lib=[site|vendor|DIR]
|
||||
-Dwith-perl-lib=[site|vendor|DIR]
|
||||
|
||||
Specify installation dir for Perl libraries
|
||||
site install in dir for site-specific modules (default)
|
||||
vendor install in dir for vendor-specific modules
|
||||
DIR install in DIR
|
||||
|
||||
--with-socks
|
||||
|
||||
Build with socks library
|
||||
|
||||
--with-bot
|
||||
-Dwith-bot=yes
|
||||
|
||||
Build irssi-bot
|
||||
|
||||
--without-textui
|
||||
-Dwithout-textui=yes
|
||||
|
||||
Build without text frontend
|
||||
|
||||
If anything is in non-standard path, you can just give the paths in
|
||||
CPPFLAGS and LIBS environment variable, eg.:
|
||||
the -Dc_args and -Dc_link_args options variable, eg.:
|
||||
|
||||
CPPFLAGS=-I/opt/openssl/include LDFLAGS=-L/opt/openssl/lib ./configure
|
||||
meson Build -Dc_args='-I/opt/openssl/include' -Dc_link_args='-L/opt/openssl/lib'
|
||||
|
||||
|
||||
|
||||
@ -69,47 +68,43 @@ CPPFLAGS and LIBS environment variable, eg.:
|
||||
Perl support generates most of the problems. There's quite a many
|
||||
things that can go wrong:
|
||||
|
||||
- Compiling fails if you compile irssi with GCC in a system that has
|
||||
perl compiled with some other C compiler. Very common problem with
|
||||
non-Linux/BSD systems. You'll need to edit src/perl/*/Makefile files
|
||||
and remove the parameters that gcc doesn't like. Mostly you'll just
|
||||
need to keep the -I and -D parameters and add -fPIC.
|
||||
- If there's any weird crashing at startup, you might have older irssi's
|
||||
perl libraries installed somewhere, and you should remove those.
|
||||
- Dynamic libraries don't want to work with some systems, so if your
|
||||
system complains about some missing symbol in Irssi.so file, configure
|
||||
irssi with --with-perl-staticlib option (NOT same as --with-perl=static).
|
||||
- If configure complains that it doesn't find some perl stuff, you're
|
||||
- If meson complains that it doesn't find some perl stuff, you're
|
||||
probably missing libperl.so or libperl.a. In debian, you'll need to do
|
||||
apt-get install libperl-dev
|
||||
- For unprivileged home directory installations, you probably do not want
|
||||
to specify --with-perl-lib=(site|vendor). Instead, you can use the
|
||||
default perl installation target (below the irssi prefix). If you are
|
||||
using local::lib you can also choose to install there by specifying
|
||||
--with-perl-lib=$PERL_LOCAL_LIB_ROOT/lib/perl5
|
||||
|
||||
You can verify that the perl module is loaded and working with "/LOAD"
|
||||
command. It should print something like:
|
||||
|
||||
Module Type Submodules
|
||||
...
|
||||
perl static core fe
|
||||
perl dynamic fe core
|
||||
|
||||
|
||||
System specific notes
|
||||
---------------------
|
||||
|
||||
Android
|
||||
|
||||
When cross compiling Irssi for Android, you can specify the path of
|
||||
the cross-perl in the cross file.
|
||||
|
||||
You may not have a cross-perl available. In that case, you will have
|
||||
to manually supply the required Perl arguments in the cross file. See
|
||||
the commented properties in the example cross file.
|
||||
|
||||
An example cross file can be found in the docs folder. To use it, you
|
||||
would call:
|
||||
|
||||
meson Build --cross-file cross-android-aarch64.txt \
|
||||
--prefix /data/data/com.termux/files/usr \
|
||||
--libdir lib \
|
||||
-Dfhs-prefix=/data/data/com.termux/files/usr \
|
||||
|
||||
|
||||
Cygwin
|
||||
|
||||
Getting perl scripting to work needs a few things:
|
||||
|
||||
- configure with --with-perl-staticlib
|
||||
|
||||
- libperl.dll is required in linking and running irssi, it's normally
|
||||
located somewhere around /usr/lib/perl5/5.6.1/cygwin/CORE/libperl5_6_1.dll
|
||||
copy it to eg. /usr/bin/libperl.dll
|
||||
|
||||
- -DUSEIMPORTLIB is needed to be defined while compiling src/perl directory.
|
||||
It doesn't hurt to be defined everywhere, so configure irssi with:
|
||||
|
||||
CFLAGS='-DUSEIMPORTLIB' ./configure --with-perl-staticlib
|
||||
- TODO
|
||||
|
35
MANIFEST.in
Normal file
35
MANIFEST.in
Normal file
@ -0,0 +1,35 @@
|
||||
global-include meson.build
|
||||
|
||||
recursive-include src *.c *.h meson.build
|
||||
recursive-include src/perl *.c *.h *.xs *.pm *.pl typemap meson.build
|
||||
recursive-include src/fe-fuzz *.c *.h *.txt meson.build
|
||||
recursive-include tests *.c meson.build
|
||||
|
||||
include meson_options.txt
|
||||
|
||||
include subprojects/*.wrap
|
||||
# prune subprojects/*
|
||||
|
||||
include utils/*.pl utils/*.sh
|
||||
exclude utils/make-dist.sh
|
||||
|
||||
include irssi.conf
|
||||
include themes/*.theme
|
||||
include docs/*.1 docs/*.txt docs/*.html
|
||||
include docs/help/in/[a-z]*.in
|
||||
include scripts/*.pl scripts/examples/*.pl
|
||||
include irssi-icon.png
|
||||
|
||||
include NEWS
|
||||
include INSTALL
|
||||
include TODO
|
||||
include ChangeLog
|
||||
|
||||
include .clang-format
|
||||
|
||||
# prune Build
|
||||
# prune dist
|
||||
prune *.egg-info
|
||||
|
||||
# ignore fuzz-support/fuzz.diff
|
||||
# ignore utils/clang-format-xs/*
|
32
Makefile.am
32
Makefile.am
@ -1,32 +0,0 @@
|
||||
ACLOCAL_AMFLAGS = -I m4 ${ACLOCAL_FLAGS}
|
||||
|
||||
# create default-config.h
|
||||
BUILT_SOURCES = default-config.h default-theme.h irssi-version.h
|
||||
CLEANFILES = default-config.h default-theme.h
|
||||
|
||||
@MAINTAINER_MODE_TRUE@.PHONY: irssi-version.h
|
||||
|
||||
default-config.h: $(srcdir)/irssi.conf
|
||||
$(srcdir)/utils/file2header.sh $(srcdir)/irssi.conf default_config > default-config.h
|
||||
|
||||
default-theme.h: $(srcdir)/themes/default.theme
|
||||
$(srcdir)/utils/file2header.sh $(srcdir)/themes/default.theme default_theme > default-theme.h
|
||||
|
||||
irssi-version.h:
|
||||
VERSION="$(VERSION)" $(srcdir)/utils/irssi-version.sh $(srcdir) | \
|
||||
cmp -s - $@ || VERSION="$(VERSION)" $(srcdir)/utils/irssi-version.sh $(srcdir) >$@
|
||||
|
||||
SUBDIRS = src tests docs scripts themes utils
|
||||
|
||||
confdir = $(sysconfdir)
|
||||
conf_DATA = irssi.conf
|
||||
|
||||
pkginclude_HEADERS = irssi-config.h irssi-version.h
|
||||
|
||||
EXTRA_DIST = \
|
||||
ChangeLog \
|
||||
autogen.sh \
|
||||
README.md \
|
||||
$(conf_DATA) \
|
||||
irssi-config.in \
|
||||
irssi-icon.png
|
363
NEWS
363
NEWS
@ -1,4 +1,337 @@
|
||||
v1.2.3 2021-04-11 The Irssi team <staff@irssi.org>
|
||||
v1.5-head 202x-xx-xx The Irssi team <staff@irssi.org>
|
||||
|
||||
v1.4.3 2022-10-31 The Irssi team <staff@irssi.org>
|
||||
- Fix freeze on Alt+arrows (#1416, #1417)
|
||||
- Fix crash on /upgrade (#1399, #1419)
|
||||
- Fix saving of -disallow_starttls (#1401, #1420)
|
||||
- Fix libnv detection on FreeBSD (freebsd#265397, #1407). By
|
||||
Guido Falsi and Kristof Provost
|
||||
- Minor help and script fixes (#1380, #1393, #1411, #1413,
|
||||
#1414, #1415)
|
||||
|
||||
v1.4.2 2022-07-17 The Irssi team <staff@irssi.org>
|
||||
* Add irssimoduledir to irssi-1.pc in the Meson build (#1383,
|
||||
#1378)
|
||||
- Use -isystem includes, limiting warnings to Irssi
|
||||
code. Fixes compilation with Perl 5.36 (#1381,
|
||||
gentoo#851522, #1384)
|
||||
- Fix missing lines when changing dynamic textbuffer contents
|
||||
(#1382, #1387). Reported by externalserver15
|
||||
- Fix Perl cross compilation with Meson 0.60.0 (#1377)
|
||||
- Fix default channel prefix used for /JOIN to default to `#'
|
||||
(#1385, #1388)
|
||||
- Fix crash in /LASTLOG by getting line texts before printing
|
||||
(#1367, #1398)
|
||||
|
||||
v1.4.1 2022-06-12 The Irssi team <staff@irssi.org>
|
||||
! Note: botti no longer compiles; get in touch if you use it
|
||||
* Format the output of /QUOTE HELP (#1371, an#82). By Val
|
||||
Lorentz. Add /SHELP as default alias (an#83)
|
||||
+ GLib log message filter: /SET glib_log_domains (an#50,
|
||||
an#59). By Andrej Kacian
|
||||
+ An option to clear the cutbuffer:
|
||||
/SET empty_kill_clears_cutbuffer (an#58). By Mikael
|
||||
Magnusson
|
||||
+ Scriptable pastebin (an#60, an#88)
|
||||
+ Configurable actlist separator: /SET actlist_separator
|
||||
(#1364, an#61)
|
||||
- Fix window left/right not skipping visible windows
|
||||
(an#57). By Mikael Magnusson
|
||||
- Fix wrong printf-format on OpenBSD (an#66, an#68). Reported
|
||||
by Aaron Bieber
|
||||
- Fix erroneous output produced by autoload_modules (an#72)
|
||||
- Fix scroll_page_count setting with `.' (#1365, an#76)
|
||||
- Fix memory leak in /IGNORE (#1373, an#84). Found by Jookia
|
||||
- Misc fixes (an#45, an#67, an#70, #1368, an#77)
|
||||
|
||||
- CHANTYPES take precedence over (missing) STATUSMSG in /join
|
||||
(#1358, an#54)
|
||||
- Fix crash in Perl's $view->set_bookmark (freebsd#254237,
|
||||
an#56)
|
||||
|
||||
- Minor help fixes (an#51, an#52)
|
||||
- Fix regression where own channel status was forgotten after
|
||||
/UPGRADE (#1357, an#53)
|
||||
|
||||
* /SET resolve_reverse_lookup setting was removed (#1034,
|
||||
#1135)
|
||||
* Irssi will try to connect on IPv4 if IPv6 connection failed
|
||||
(#1146). By Shivaram Lingamneni
|
||||
|
||||
* The display system now renders formats on the fly (#1079,
|
||||
#1188, #1191, #1192, #1204, #1205, #1209, #1349, #1355,
|
||||
an#13, an#14, an#28, an#29, an#36, an#37, an#49)
|
||||
|
||||
This major change will break scripts that try to modify
|
||||
printed text during "print text" signal (#1189). They need
|
||||
to be ported to modify the text during "print format"
|
||||
instead. It also breaks the usage of using /FORMAT to add
|
||||
different colours to a line. Such usage needs to be ported
|
||||
to using $expando variables instead. Affected scripts
|
||||
include format_identify.pl, friends_peder.pl, nickcolor.pl,
|
||||
nm.pl, people.pl
|
||||
|
||||
The "gui print text finished" and "gui print text after
|
||||
finished" signals gained a TEXT_DEST_REC *parameter in the
|
||||
process.
|
||||
|
||||
A new "gui render line text" signal is available to change
|
||||
the rendering of a line
|
||||
|
||||
* made the $Z expando (time) dynamic (#1087, #1207, #1208)
|
||||
|
||||
This change breaks the usage of /SET timestamp_format to
|
||||
supply a custom displayed time stamp. Affected scripts
|
||||
include binary_time.pl
|
||||
|
||||
* /HILIGHT -priority now affects which hilight rule gets
|
||||
applied (#1228, #1232)
|
||||
* The NAMES list is now hidden by default if there are more
|
||||
than 18 users on the channel (an#7)
|
||||
|
||||
To revert to the previous behaviour
|
||||
|
||||
/SET show_names_on_join_limit -1
|
||||
|
||||
* -tls_verify is now enabled by default (#1170, an#18, #1309,
|
||||
an#23, #1343, #1351)
|
||||
|
||||
This may cause an ugly display of notls_verify in the output
|
||||
of /SERVER LIST, even on plain-text connection, on old
|
||||
configs. Kindly remove the "tls_verify = "no";" entries from
|
||||
your config file manually.
|
||||
|
||||
* Irssi will now attempt STARTTLS if advertised (#1170, #1312,
|
||||
an#19)
|
||||
|
||||
Use -disallow_starttls if you absolutely do not want this
|
||||
|
||||
In order to check for a STARTTLS advertisement, Irssi will
|
||||
now wait for a response (even an error) to CAP LS 302. If
|
||||
your bouncer/server does not want to communicate before
|
||||
receiving USER/PASS at all, use -nocap to disable the CAP
|
||||
check.
|
||||
|
||||
* Channel sync requests (WHO, MODE) are now sent "later" than
|
||||
user commands. This should improve responsiveness to user
|
||||
commands in the autojoin phase (an#26, an#32, an#33)
|
||||
* Irssi is now using full paths in #include directives and
|
||||
consequently does not add all directories to the include
|
||||
path anymore (#1040)
|
||||
* The Build System was ported to Meson (#1064, #1065, #1068,
|
||||
#1071, #1072, #1073, #1074, #1075, #1084, #1085, #1118, #1166,
|
||||
#1223, #1224, #1245, #1313, #1314, an#31)
|
||||
* Scriptassist was changed to use a YAML database (#1163)
|
||||
|
||||
It will tell you when you need to update your setting
|
||||
|
||||
* /BIND shows all partial matches (#1155)
|
||||
* Cleanup of unused functions (#1017, #1132, #1145, #1182,
|
||||
#1246, #1264)
|
||||
|
||||
Functions removed:
|
||||
|
||||
NET_CALLBACK
|
||||
NET_HOST_CALLBACK
|
||||
RESOLVED_NAME_REC
|
||||
net_gethostbyaddr_nonblock
|
||||
net_connect_nonblock
|
||||
[ SIMPLE_THREAD_REC, simple_init, simple_readpipe ]
|
||||
hash_save_key
|
||||
|
||||
Functions deprecated:
|
||||
|
||||
dec2octal
|
||||
g_timeval_cmp
|
||||
get_timeval_diff
|
||||
|
||||
Function names corrected:
|
||||
|
||||
g_input -> i_input
|
||||
g_istr -> i_istr
|
||||
g_io_channel -> i_io_channel
|
||||
g_hash_free_value -> i_hash_free_value
|
||||
remove g_free_true
|
||||
gslist -> i_slist
|
||||
glog_func -> i_log_func
|
||||
glist -> i_list
|
||||
|
||||
If multi-version compatibility is desired, module authors
|
||||
can find an example of backwards compatible code in
|
||||
cdidier/irssi-xmpp#55
|
||||
|
||||
+ Add MSGLEVEL_HIDDEN to Perl (#1044)
|
||||
+ Add $view->set_hidden_level and $view->remove_lines_by_level
|
||||
to Perl (#1026)
|
||||
+ Add a /SET scrollback_max_age setting (#1022). By Heikki
|
||||
Orsila
|
||||
+ Add /SET actlist_prefer_window_name (#1025)
|
||||
+ Add -window option to /CAT (#1023, #1159)
|
||||
+ Add an option to list specific sections with
|
||||
|
||||
/SET -section lookandfeel
|
||||
|
||||
(#1048)
|
||||
|
||||
+ Add support for IRCv3 CAP LS 302 (#1091)
|
||||
+ Add a new "print noformat" signal that goes together with
|
||||
"print format" (#1088, #1192)
|
||||
+ Add support for IRCv3 extended-join. /SET show_extended_join
|
||||
to enable (#1097, #1107, #1124)
|
||||
|
||||
There are two new /FORMATs, join_extended and
|
||||
join_extended_account, that theme writers need to take into
|
||||
account if desired.
|
||||
|
||||
+ Add support for IRCv3 setname (#1093, #1104, #1254, GL#33)
|
||||
+ Add support for IRCv3 account-notify (#1100, #1098, GL#33,
|
||||
#1105, #1131). Credit to oss-fuzz
|
||||
/SET show_account_notify to enable
|
||||
+ Add support for IRCv3 invite-notify (#1094)
|
||||
+ Add support for receiving IRCv3 message-tags (#576, #1090)
|
||||
+ Add support for sending IRCv3 message-tags (#1092, an#34)
|
||||
+ Enable the znc.in/self-message CAP by default (#1123)
|
||||
+ Add support for IRCv3 away-notify. /SET away_notify_public
|
||||
to enable (#1099, GL#33, #1105)
|
||||
+ Add support for IRCv3 chghost (#1096, GL#33, #1105)
|
||||
|
||||
For servers with broken chghost implementation that fill the
|
||||
status window with host changed messages, one may add "quote
|
||||
cap req -chghost" to the -autosendcmd or, if the host change
|
||||
messages are entirely undesired, "/format -delete
|
||||
host_changed"
|
||||
|
||||
+ Add support for IRCv3 server-time. /SET show_server_time to
|
||||
enable (#1108)
|
||||
+ Add support for logging IRCv3 server-time.
|
||||
/SET log_server_time to disable (#1318, an#16)
|
||||
+ Add IRCv3 features to signals.txt (#1111)
|
||||
|
||||
In particular, "message join" now takes 2 additional
|
||||
arguments, script and module authors must beware of this
|
||||
change.
|
||||
|
||||
+ Show the unignore time in /IGNORE output (#1158, #1161)
|
||||
+ Add /SET quit_on_hup to make the behaviour of SIGHUP
|
||||
configurable (#828, #1169). By Pinguin1234
|
||||
+ Support numeric 489 as ERR_SECUREONLYCHAN (#1193, #1196). By
|
||||
Michael Hansen
|
||||
+ Improve support for building Irssi in Termux-Android with
|
||||
Meson (#1199)
|
||||
+ Add usermode key to Irssi::Irc::Chatnet in Perl (#1288). By
|
||||
Jessica Sophie Porter
|
||||
+ Add format_string_expand and format_string_unexpand
|
||||
functions to Perl (#1286)
|
||||
+ Add ...->format_create_dest(...)->printformat("format",
|
||||
args...) and ...->printformat_module("module", "format",
|
||||
args...) methods to Perl (#1284)
|
||||
|
||||
You can avoid any CORE::GLOBAL::caller hacks using the
|
||||
printformat_module method, especially sind that hack was not
|
||||
safe during signal emissions
|
||||
|
||||
+ Add tracking of user accounts in the channel nicklist using
|
||||
WHOX on join (#1250)
|
||||
+ Add auto-loading of the Perl and otr module from /SET
|
||||
autoload_modules (#1295)
|
||||
+ Add /IGNORE ... NOHILIGHT to ignore some hilights (#1260)
|
||||
+ Do not beep on hidden lines with /SET beep_msg_level
|
||||
... -HIDDEN (#1259)
|
||||
+ Added /CS, /MS, /NS, and /OS aliases to the default config
|
||||
(#1316). By Mathis Beer
|
||||
+ Allow -tls_ca{file,path} '' to unset an argument (#730,
|
||||
#1060, an#30)
|
||||
+ Add a "server outgoing modify" signal to intercept outgoing
|
||||
messages (#1148, #1151, an#15, an#43). Original by
|
||||
JustAnotherArchivist
|
||||
- remove some hard-coded 510 byte assumptions (#1086)
|
||||
- Several fixes for error checks in SSL (#944, #1037, #943,
|
||||
#1036). Reported by Chi Li
|
||||
- Wrong variable tested in mask_match (#902, #1035)
|
||||
- Fix bug where irssi-proxy with `?'-port would not reconnect
|
||||
(#1041)
|
||||
- Allow shrinking of /SET rawlog_lines (#957, #1020). By
|
||||
Marcus "Teschi" Prinz
|
||||
- Fix /WINDOW BALANCE warning (#1054)
|
||||
- fix overflow when first command history entry expires
|
||||
(#1070)
|
||||
- begin modularising IRC module (#1067, #1112, #1113)
|
||||
- fix some memory leaks in /DCC RESUME and settings_add
|
||||
(#1077). By Zero King
|
||||
- fix cut-off text with theme_indent module and /SET
|
||||
indent_always OFF (#1078)
|
||||
- fix the cap_queue order (#1095)
|
||||
- add reference counted strings (#1089)
|
||||
- Fix irc_op_public messages not triggering hilights (#354,
|
||||
#891, #1129). By Dan Collins
|
||||
- Fix /IGNORE not setting the right level in irc_op_public
|
||||
messages (#1280). Credit to oss-fuzz
|
||||
- Fix GTimeVal deprecation (#1141, #1144, #1145, #1350, an#44)
|
||||
|
||||
If multi-version compatibility is desired, module authors
|
||||
can find an example of backwards compatible code in
|
||||
cdidier/irssi-xmpp#53
|
||||
|
||||
- Fix /IGNORE ... MODES NO_ACT not working (#1164)
|
||||
- Deprecated -ssl* options are hidden from tab completion
|
||||
(#1171)
|
||||
- Make /SET actlist_sort a choice type (#1198)
|
||||
- Fix crash from self-unloading script (#1206). By Thomas
|
||||
Stagner
|
||||
- Fix crash during Perl signal emission (#1233, #1234)
|
||||
- Fix a case where empty lines or comments inside channels or
|
||||
servers in the config would confuse Irssi (#1062, #1242,
|
||||
#1243)
|
||||
- Fix reported freezing in DCC GET on slow disks (#159, #1271)
|
||||
- Fix message-tags parsing (#1274, #1275). Credit to oss-fuzz
|
||||
- Fail redirects when receiving numeric 263 (RPL_TRYAGAIN) in
|
||||
response to /WHO (#1283)
|
||||
- Some updates to .gitignore (#1302). By Rene Kita
|
||||
- Fix build on operating systems with X/Open Curses, version 2
|
||||
(#1305, #1308). By Nia Alarie (Regression introduced with
|
||||
#1290, alternative fix for Irssi 1.2.3 no-term.h.patch)
|
||||
- Fix otr module not using g_strndup, e.g. on Solaris 10
|
||||
(#1315). By Claes Nästén
|
||||
- Fix cursor getting stuck for auto completions that changes
|
||||
case (#1176, #1322, an#8). By ffrogman
|
||||
- Restore operation of tag/* in /SET activity_hide_targets
|
||||
(#1337, an#11) nb. the ::all syntax was working in Irssi 1.1
|
||||
and 1.2 (and continues to work)
|
||||
- Fix /SERVER ADD -matrix -network my_matrix_network
|
||||
(an#12). By Andrej Kacian
|
||||
- Fix /SERVER ADD creating duplicated entries in the config
|
||||
file (#1317, an#22, an#41)
|
||||
- Fix critical when SASL user is set and SASL password is
|
||||
empty (#1325, an#21)
|
||||
- Misc fixes (#1106, #1141, #1272, #1297, an#35)
|
||||
- Fuzz fixes (#1116, #1117, #1119, #1125, #1126, an#20)
|
||||
- Build system fixes (#1101, #1102, #1069, #1140, #1181, #1253)
|
||||
- Sync docs and scripts (an#39)
|
||||
- Text and Help updates
|
||||
- add -tls_* options to manual (#1029, #1030). By Jacob
|
||||
V. Rasmussen
|
||||
- missing targets in /MSG (#1032)
|
||||
- wrong parameter in /ECHO (#1024)
|
||||
- Spelling in OTR (#1047). By David Gall
|
||||
- Clarify statusbar priority (#1049). By Marius Gedminas
|
||||
- Document get_irssi_dir in Perl (#1051, #1052). By Alex
|
||||
Shafer
|
||||
- typo in /HILIGHT help (#1081). By DFrostByte
|
||||
- improved clarity of your_nick_owned (#1138). By Mike Quin
|
||||
- Update some URLs to https (#1163)
|
||||
- Add documentation for escaping some characters (#1329,
|
||||
#1330, an#9). By Guntbert Reiter
|
||||
- Fix some typos (#1336, an#10). By Francis Mteo
|
||||
- Document $abiversion and parse_special (an#38). By bw1
|
||||
- Infrastructure updates:
|
||||
- Support for Github Actions (#1039, #1103, #1160, #1212,
|
||||
#1231, #1252, #1261, an#40)
|
||||
- Run clang-format on pull requests (#1172, #1173, #1184,
|
||||
#1230, #1247, #1287)
|
||||
- Run abidiff on pull requests (#1179, #1195)
|
||||
- Test CI-Fuzz (#1279, #1304, an#17)
|
||||
|
||||
v1.2.3 2021-04-11 The Irssi team <staff@irssi.org>
|
||||
- Fix the compilation of utf8proc (#1021)
|
||||
- Fix wrong call to free. By Zero King (#1076)
|
||||
- Fix a colour reset in true colour themes when encountering
|
||||
@ -36,13 +369,13 @@ v1.2.3 2021-04-11 The Irssi team <staff@irssi.org>
|
||||
- Fix memory leak when receiving bogus SASL authentication
|
||||
data. Found and fixed by Sergey Valentey (#1293)
|
||||
|
||||
v1.2.2 2019-08-29 The Irssi team <staff@irssi.org>
|
||||
v1.2.2 2019-08-29 The Irssi team <staff@irssi.org>
|
||||
- Fix a use after free issue when receiving IRCv3 CAP
|
||||
information from the server (GL#34)
|
||||
information from the server (GL#34, GL!35)
|
||||
- Fix a crash during startup when windows weren't fully
|
||||
initialised yet (#1114, bdo#935813)
|
||||
|
||||
v1.2.1 2019-06-29 The Irssi team <staff@irssi.org>
|
||||
v1.2.1 2019-06-29 The Irssi team <staff@irssi.org>
|
||||
! Contains all changes from 1.1.3
|
||||
- Fix a test on big endian machines (#1014)
|
||||
- Fix the compile time conditionality of wcwidth
|
||||
@ -53,17 +386,17 @@ v1.2.1 2019-06-29 The Irssi team <staff@irssi.org>
|
||||
encoding) in the input prompt was broken (#1018,
|
||||
#1057). Initial patch by Артём Курашов
|
||||
|
||||
v1.1.3 2019-06-29 The Irssi team <staff@irssi.org>
|
||||
v1.1.3 2019-06-29 The Irssi team <staff@irssi.org>
|
||||
! Contains all changes from 1.0.8
|
||||
- Fix regression of #779 where autolog_ignore_targets would
|
||||
not matching itemless windows anymore (#1012, #1013)
|
||||
|
||||
v1.0.8 2019-06-29 The Irssi team <staff@irssi.org>
|
||||
v1.0.8 2019-06-29 The Irssi team <staff@irssi.org>
|
||||
- Fix a use after free issue when sending the SASL login on
|
||||
(automatic and manual) reconnects (#1055, #1058). Reported
|
||||
by ilbelkyr
|
||||
|
||||
v1.2.0 2019-02-11 The Irssi team <staff@irssi.org>
|
||||
v1.2.0 2019-02-11 The Irssi team <staff@irssi.org>
|
||||
! Contains all changes from 1.1.2
|
||||
* Improved the /STATUSBAR commands (#858)
|
||||
* /SET no longer shows `=' between setting and value (#886)
|
||||
@ -75,16 +408,18 @@ v1.2.0 2019-02-11 The Irssi team <staff@irssi.org>
|
||||
* Private notices intended for channels are now displayed on
|
||||
the channel (new setting notice_channel_context) (#959)
|
||||
+ Imported the "Off-the-record" module into Irssi tree (#854,
|
||||
#589, #196)
|
||||
#589, #196, #881)
|
||||
+ Initial support for sideways split windows (#697, #431,
|
||||
#224, #807, FS#310, #947, #955, #989)
|
||||
+ Change the implementation of `wcwidth'. This is used to
|
||||
calculate the width of emojis on your terminal screen (#917,
|
||||
#720)
|
||||
+ Make the wcwidth functions available from Perl (#973):
|
||||
|
||||
string_width(str)
|
||||
string_chars_for_width(str, width)
|
||||
wcwidth(char)
|
||||
|
||||
+ Added completion_keep_word setting (#979)
|
||||
+ Allow activity_hide_targets to hide activity in itemless
|
||||
windows (#967, #997, #1001, #1003)
|
||||
@ -98,6 +433,7 @@ v1.2.0 2019-02-11 The Irssi team <staff@irssi.org>
|
||||
channels that are in the config (#968)
|
||||
+ Add format support for the input line. By Ben Paxton,
|
||||
originally by Jonas Hurrelmann (#764, FS#621, #1004)
|
||||
|
||||
use Irssi::TextUI;
|
||||
gui_input_set_extent(pos, text)
|
||||
gui_input_set_extents(pos, len, left, right)
|
||||
@ -105,6 +441,7 @@ v1.2.0 2019-02-11 The Irssi team <staff@irssi.org>
|
||||
gui_input_get_extent(pos)
|
||||
gui_input_get_text_and_extents()
|
||||
gui_input_set_text_and_extents(...)
|
||||
|
||||
+ Parsing of IRCv3 CAP 3.2 (#775, #869)
|
||||
+ Show CAP-related events in the user interface (#918, #916,
|
||||
#870, #704)
|
||||
@ -147,7 +484,7 @@ v1.2.0 2019-02-11 The Irssi team <staff@irssi.org>
|
||||
- Misc fixes (#840, #839, #843, #953, #962). Tests (#806,
|
||||
#875, #905, #964, #1011). Fuzzing (#929).
|
||||
|
||||
v1.1.2 2019-01-09 The Irssi team <staff@irssi.org>
|
||||
v1.1.2 2019-01-09 The Irssi team <staff@irssi.org>
|
||||
- Fix the resetting of window hiddenlevel (#861)
|
||||
- Fix clearing of hidelevel in layout (#951)
|
||||
- Fix accessing unallocated text when checking entry position
|
||||
@ -166,14 +503,14 @@ v1.1.2 2019-01-09 The Irssi team <staff@irssi.org>
|
||||
- Fix Perl detection on MacOS. By Dominyk Tiller (#927)
|
||||
- Misc fixes. By Jaroslav Škarvada (#981, #982)
|
||||
|
||||
v1.1.1 2018-02-15 The Irssi team <staff@irssi.org>
|
||||
v1.1.1 2018-02-15 The Irssi team <staff@irssi.org>
|
||||
! Contains all changes from 1.0.7
|
||||
- Restore compatibility with OpenSSL < 1.0.2 (#820, #831)
|
||||
- Fix test compilation on some platforms (#815, #816)
|
||||
- Fix portability and backwards compatibility of test runner
|
||||
(#818, #845)
|
||||
|
||||
v1.0.7 2018-02-15 The Irssi team <staff@irssi.org>
|
||||
v1.0.7 2018-02-15 The Irssi team <staff@irssi.org>
|
||||
- Prevent use after free error during the execution of some
|
||||
commands. Found by Joseph Bisch (GL#17, GL!24).
|
||||
- Revert netsplit print optimisation due to crashes (#465, #809,
|
||||
@ -192,7 +529,7 @@ v1.0.7 2018-02-15 The Irssi team <staff@irssi.org>
|
||||
resize (GL#25, GL#29, #836).
|
||||
- Minor help correction. By William Jackson (#834).
|
||||
|
||||
v1.1.0 2018-01-15 The Irssi team <staff@irssi.org>
|
||||
v1.1.0 2018-01-15 The Irssi team <staff@irssi.org>
|
||||
! Warning. Irssi is broken and will crash with OpenSSL < 1.0.2
|
||||
due to openssl/openssl commit
|
||||
5b4b9ce976fce09a7a92e2f25b91a1635cb840fe
|
||||
@ -274,7 +611,7 @@ v1.1.0 2018-01-15 The Irssi team <staff@irssi.org>
|
||||
#738)
|
||||
- Fix space issue in glib-2.0.m4 (#621)
|
||||
|
||||
v1.0.6 2018-01-07 The Irssi team <staff@irssi.org>
|
||||
v1.0.6 2018-01-07 The Irssi team <staff@irssi.org>
|
||||
! Note: Code and aliases using `$($'-like constructs are no
|
||||
longer supported due to issue GL#18. Sorry about the
|
||||
inconvenience.
|
||||
|
33
README.md
33
README.md
@ -1,11 +1,10 @@
|
||||
# [Irssi](https://irssi.org/)
|
||||
# [Irssi](https://irssi.org)
|
||||
|
||||
[](https://travis-ci.org/irssi/irssi)
|
||||

|
||||
|
||||
Irssi is a modular chat client that is most commonly known for its
|
||||
text mode user interface, but 80% of the code isn't text mode
|
||||
specific. Irssi comes with IRC support built in, and there are
|
||||
third party [ICB](https://github.com/jperkin/irssi-icb),
|
||||
Irssi is a modular text mode chat client. It comes with IRC support
|
||||
built in, and there are third party
|
||||
[ICB](https://github.com/jperkin/irssi-icb),
|
||||
[SILC](http://www.silcnet.org/),
|
||||
[XMPP](http://cybione.org/~irssi-xmpp/) (Jabber),
|
||||
[PSYC](http://about.psyc.eu/Irssyc) and
|
||||
@ -18,27 +17,29 @@ available.
|
||||
|
||||
#### Development source installation
|
||||
|
||||
[Ninja](https://ninja-build.org/) 1.8 and [Meson](https://mesonbuild.com/) 0.53
|
||||
|
||||
```
|
||||
git clone https://github.com/irssi/irssi
|
||||
cd irssi
|
||||
./autogen.sh
|
||||
make && sudo make install
|
||||
meson Build
|
||||
ninja -C Build && sudo ninja -C Build install
|
||||
```
|
||||
|
||||
#### Release source installation
|
||||
|
||||
* Download [release](https://github.com/irssi/irssi/releases)
|
||||
* [Verify](https://irssi.org/download/#release-sources) signature
|
||||
* Verify signature
|
||||
```
|
||||
tar xJf irssi-*.tar.xz
|
||||
cd irssi-*
|
||||
./configure
|
||||
make && sudo make install
|
||||
meson Build
|
||||
ninja -C Build && sudo ninja -C Build install
|
||||
```
|
||||
|
||||
### Requirements
|
||||
|
||||
- [glib-2.28](https://wiki.gnome.org/Projects/GLib) or greater
|
||||
- [glib-2.32](https://wiki.gnome.org/Projects/GLib) or greater
|
||||
- [openssl](https://www.openssl.org/)
|
||||
- [perl-5.6](https://www.perl.org/) or greater (for perl support)
|
||||
- terminfo or ncurses (for text frontend)
|
||||
@ -47,8 +48,8 @@ make && sudo make install
|
||||
|
||||
## [Documentation](https://irssi.org/documentation/)
|
||||
|
||||
* [Frequently Asked Questions](https://irssi.org/documentation/faq)
|
||||
* [Startup How-To](https://irssi.org/documentation/startup)
|
||||
* [New users guide](https://irssi.org/New-users/)
|
||||
* [Questions and Answers](https://irssi.org/documentation/qna/)
|
||||
* Check the built-in `/HELP`, it has all the details on command syntax
|
||||
|
||||
## [Themes](https://irssi-import.github.io/themes/)
|
||||
@ -61,7 +62,7 @@ make && sudo make install
|
||||
|
||||
Please report security issues to staff@irssi.org. Thanks!
|
||||
|
||||
## [Bugs](https://github.com/irssi/irssi/issues) / Suggestions / [Contributing](https://irssi.org/development/)
|
||||
## [Bugs](https://github.com/irssi/irssi/issues) / Suggestions / Contributing
|
||||
|
||||
Check the GitHub issues if it is already listed in there; if not, open
|
||||
an issue on GitHub or send a mail to [staff@irssi.org](mailto:staff@irssi.org).
|
||||
@ -70,4 +71,4 @@ Irssi is always looking for developers. Feel free to submit patches through
|
||||
GitHub pull requests.
|
||||
|
||||
You can also contact the Irssi developers in
|
||||
[#irssi](https://irssi.org/support/irc/) on freenode.
|
||||
[#irssi](https://irssi.org/support/irc/) on irc.libera.chat.
|
||||
|
67
autogen.sh
67
autogen.sh
@ -1,67 +0,0 @@
|
||||
#!/bin/sh
|
||||
# Run this to generate all the initial makefiles, etc.
|
||||
|
||||
PKG_NAME="Irssi"
|
||||
|
||||
srcdir=`dirname "$0"`
|
||||
test -z "$srcdir" && srcdir=.
|
||||
mydir=`pwd`
|
||||
|
||||
if test ! -f "$srcdir"/configure.ac; then
|
||||
echo -n "**Error**: Directory \`$srcdir' does not look like the"
|
||||
echo " top-level $PKG_NAME directory"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
cd "$srcdir"
|
||||
|
||||
# create help files
|
||||
echo "Creating help files..."
|
||||
perl utils/syntax.pl
|
||||
|
||||
echo "Creating ChangeLog..."
|
||||
git log > ChangeLog
|
||||
if test "$?" -ne 0; then
|
||||
echo "**Error**: ${PKG_NAME} Autogen must be run in a git clone, cannot proceed."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
files=`echo docs/help/in/*.in|sed -e 's,docs/help/in/Makefile.in ,,' -e 's,docs/help/in/,!,g' -e 's/\.in /.in ?/g'`
|
||||
cat docs/help/in/Makefile.am.gen|sed "s/@HELPFILES@/$files/g"|sed 's/?/\\?/g'|tr '!?' '\t\n' > docs/help/in/Makefile.am
|
||||
|
||||
files=`echo $files|sed 's/\.in//g'`
|
||||
cat docs/help/Makefile.am.gen|sed "s/@HELPFILES@/$files/g"|sed 's/?/\\?/g'|tr '!?' '\t\n' > docs/help/Makefile.am
|
||||
|
||||
if test x$NOCONFIGURE = x && test -z "$*"; then
|
||||
echo "**Warning**: I am going to run \`configure' with no arguments."
|
||||
echo "If you wish to pass any to it, please specify them on the"
|
||||
echo \`$0\'" command line."
|
||||
echo
|
||||
fi
|
||||
|
||||
rm -f aclocal.m4
|
||||
echo "Running autoreconf ..."
|
||||
autoreconf -i || exit $?
|
||||
|
||||
# make sure perl hashes have correct length
|
||||
find src/perl -name '*.c' -o -name '*.xs' -exec grep -n hv_store {} + | perl -l -ne 'if (/"(\w+)",\s*(\d+)/ && $2 != length $1) { $X=1; print "Incorrect key length in $_" } END { exit $X }'
|
||||
|
||||
cd "$mydir"
|
||||
|
||||
conf_flags="--enable-maintainer-mode"
|
||||
|
||||
if test x$NOCONFIGURE = x; then
|
||||
echo Running "$srcdir"/configure $conf_flags "$@" ...
|
||||
"$srcdir"/configure $conf_flags "$@" \
|
||||
&& echo Now type \`make\' to compile $PKG_NAME || exit 1
|
||||
else
|
||||
echo Skipping configure process.
|
||||
fi
|
||||
|
||||
if grep -q '==\|\[\[' "$srcdir"/build-aux/test-driver; then
|
||||
echo
|
||||
echo "************************************************************************"
|
||||
echo "**Warning**: your build is not portable, please do not make dist"
|
||||
echo " see https://bugzilla.opensuse.org/show_bug.cgi?id=1076146"
|
||||
echo "************************************************************************"
|
||||
fi
|
860
configure.ac
860
configure.ac
@ -1,860 +0,0 @@
|
||||
AC_INIT(irssi, 1.2.3)
|
||||
AC_CONFIG_SRCDIR([src])
|
||||
AC_CONFIG_AUX_DIR(build-aux)
|
||||
AC_PREREQ(2.50)
|
||||
|
||||
AC_CONFIG_HEADERS([irssi-config.h])
|
||||
AC_CONFIG_MACRO_DIR([m4])
|
||||
AM_INIT_AUTOMAKE([1.9 no-define foreign subdir-objects nostdinc])
|
||||
|
||||
AM_SILENT_RULES([yes])
|
||||
|
||||
AM_MAINTAINER_MODE
|
||||
|
||||
AC_PROG_CC
|
||||
AC_PROG_CPP
|
||||
AM_PROG_LIBTOOL
|
||||
|
||||
AC_PATH_PROG(sedpath, sed)
|
||||
AC_PATH_PROG(perlpath, perl)
|
||||
|
||||
AC_CHECK_HEADERS(unistd.h dirent.h sys/ioctl.h sys/resource.h)
|
||||
|
||||
# check posix headers..
|
||||
AC_CHECK_HEADERS(sys/socket.h sys/time.h sys/utsname.h)
|
||||
|
||||
AC_SYS_LARGEFILE
|
||||
|
||||
AC_ARG_WITH(socks,
|
||||
[ --with-socks Build with socks support],
|
||||
if test x$withval = xno; then
|
||||
want_socks=no
|
||||
else
|
||||
want_socks=yes
|
||||
fi,
|
||||
want_socks=no)
|
||||
|
||||
AC_ARG_WITH(textui,
|
||||
[ --without-textui Build without text frontend],
|
||||
if test x$withval = xno; then
|
||||
want_textui=no
|
||||
else
|
||||
want_textui=yes
|
||||
fi,
|
||||
want_textui=yes)
|
||||
|
||||
AC_ARG_WITH(bot,
|
||||
[ --with-bot Build irssi-bot],
|
||||
if test x$withval = xno; then
|
||||
want_irssibot=no
|
||||
else
|
||||
want_irssibot=yes
|
||||
fi,
|
||||
want_irssibot=no)
|
||||
|
||||
AC_ARG_WITH(fuzzer,
|
||||
[ --with-fuzzer Build irssi-fuzzer],
|
||||
if test x$withval = xno; then
|
||||
want_irssifuzzer=no
|
||||
else
|
||||
want_irssifuzzer=yes
|
||||
fi,
|
||||
want_irssifuzzer=no)
|
||||
|
||||
AC_ARG_WITH(fuzzer-lib,
|
||||
[ --with-fuzzer-lib Specify path to fuzzer library],
|
||||
fuzzerlibpath="$withval")
|
||||
|
||||
AC_ARG_WITH(proxy,
|
||||
[ --with-proxy Build irssi-proxy],
|
||||
if test x$withval = xno; then
|
||||
want_irssiproxy=no
|
||||
else
|
||||
want_irssiproxy=yes
|
||||
fi,
|
||||
want_irssiproxy=no)
|
||||
|
||||
AC_ARG_WITH(modules,
|
||||
[ --with-modules Specify what modules to build in binary],
|
||||
if test x$withval != xyes -a x$withval != xno; then
|
||||
build_modules="$withval"
|
||||
fi)
|
||||
|
||||
if test "x$prefix" != "xNONE"; then
|
||||
prefix=`eval echo $prefix`
|
||||
PERL_MM_PARAMS="INSTALLDIRS=perl INSTALL_BASE=$prefix"
|
||||
perl_set_use_lib=yes
|
||||
|
||||
perl_prefix_note=yes
|
||||
fi
|
||||
|
||||
AC_ARG_WITH(perl-staticlib,
|
||||
[ --with-perl-staticlib Specify that we want to link perl libraries
|
||||
statically in irssi, default is no],
|
||||
if test x$withval = xno; then
|
||||
want_staticperllib=no
|
||||
else
|
||||
want_staticperllib=yes
|
||||
fi,
|
||||
want_staticperllib=no)
|
||||
|
||||
|
||||
AC_ARG_WITH(perl-lib,
|
||||
[ --with-perl-lib=[perl|site|vendor|DIR] Specify where to install the
|
||||
Perl libraries for irssi, default is site],
|
||||
if test "x$withval" = xyes; then
|
||||
want_perl=yes
|
||||
elif test "x$withval" = xno; then
|
||||
want_perl=no
|
||||
elif test "x$withval" = xperl; then
|
||||
want_perl=yes
|
||||
perl_prefix_note=no
|
||||
PERL_MM_PARAMS="INSTALLDIRS=perl"
|
||||
perl_set_use_lib=no
|
||||
elif test "x$withval" = xsite; then
|
||||
want_perl=yes
|
||||
perl_prefix_note=no
|
||||
PERL_MM_PARAMS=""
|
||||
perl_set_use_lib=no
|
||||
elif test "x$withval" = xvendor; then
|
||||
want_perl=yes
|
||||
perl_prefix_note=no
|
||||
if test -z "`$perlpath -v|grep '5\.0'`"; then
|
||||
PERL_MM_PARAMS="INSTALLDIRS=vendor"
|
||||
else
|
||||
PERL_MM_PARAMS="INSTALLDIRS=perl PREFIX=`$perlpath -e 'use Config; print $Config{prefix}'`"
|
||||
fi
|
||||
perl_set_use_lib=no
|
||||
else
|
||||
want_perl=yes
|
||||
perl_prefix_note=no
|
||||
PERL_MM_PARAMS="INSTALLDIRS=perl LIB=$withval"
|
||||
perl_set_use_lib=yes
|
||||
fi,
|
||||
want_perl=yes)
|
||||
|
||||
AC_ARG_WITH(perl,
|
||||
[ --with-perl[=yes|no|module] Build with Perl support - also specifies
|
||||
if it should be built into main irssi binary
|
||||
(static, default) or as module],
|
||||
if test x$withval = xyes; then
|
||||
want_perl=static
|
||||
elif test x$withval = xstatic; then
|
||||
want_perl=static
|
||||
elif test x$withval = xmodule; then
|
||||
want_perl=module
|
||||
else
|
||||
want_perl=no
|
||||
fi,
|
||||
want_perl=static)
|
||||
|
||||
AC_ARG_WITH(otr,
|
||||
[ --with-otr[=yes|no|static] Build with OTR support - also specifies
|
||||
if it should be built into the main irssi
|
||||
binary (static) or as a module (default)],
|
||||
if test x$withval = xyes; then
|
||||
want_otr=module
|
||||
elif test x$withval = xstatic; then
|
||||
want_otr=static
|
||||
elif test x$withval = xmodule; then
|
||||
want_otr=module
|
||||
else
|
||||
want_otr=no
|
||||
fi,
|
||||
want_otr=no)
|
||||
|
||||
AC_ARG_ENABLE(true-color,
|
||||
[ --enable-true-color Build with true color support in terminal],
|
||||
if test x$enableval = xno ; then
|
||||
want_truecolor=no
|
||||
else
|
||||
want_truecolor=yes
|
||||
fi,
|
||||
want_truecolor=no)
|
||||
|
||||
AC_ARG_ENABLE(gregex,
|
||||
[ --disable-gregex Build without GRegex (fall back to regex.h)],
|
||||
if test x$enableval = xno ; then
|
||||
want_gregex=no
|
||||
else
|
||||
want_gregex=yes
|
||||
fi,
|
||||
want_gregex=yes)
|
||||
|
||||
AC_ARG_ENABLE(utf8proc,
|
||||
[ --disable-utf8proc Build without Julia's utf8proc],
|
||||
if test x$enableval = xno ; then
|
||||
want_utf8proc=no
|
||||
else
|
||||
want_utf8proc=yes
|
||||
fi,
|
||||
want_utf8proc=yes)
|
||||
|
||||
AC_ARG_WITH(capsicum,
|
||||
[ --with-capsicum Build with Capsicum support],
|
||||
if test x$withval = xno; then
|
||||
want_capsicum=no
|
||||
else
|
||||
want_capsicum=yes
|
||||
fi,
|
||||
want_capsicum=yes)
|
||||
|
||||
dnl **
|
||||
dnl ** just some generic stuff...
|
||||
dnl **
|
||||
|
||||
dnl * OS specific options
|
||||
case "$host_os" in
|
||||
hpux*)
|
||||
CFLAGS="$CFLAGS -D_XOPEN_SOURCE_EXTENDED"
|
||||
;;
|
||||
*)
|
||||
;;
|
||||
esac
|
||||
|
||||
|
||||
AC_SEARCH_LIBS([socket], [network socket])
|
||||
|
||||
AC_SEARCH_LIBS([inet_addr], [nsl])
|
||||
|
||||
dnl * gcc specific options
|
||||
if test "x$ac_cv_prog_gcc" = "xyes"; then
|
||||
CFLAGS="$CFLAGS -Wall"
|
||||
fi
|
||||
|
||||
AC_CHECK_TYPE(socklen_t, ,
|
||||
[AC_DEFINE([socklen_t], [int], [Define to 'int' if <sys/socket.h> doesn't define.])], [
|
||||
AC_INCLUDES_DEFAULT
|
||||
#ifdef HAVE_SYS_SOCKET_H
|
||||
# include <sys/socket.h>
|
||||
#endif
|
||||
])
|
||||
|
||||
AC_CHECK_SIZEOF(int)
|
||||
AC_CHECK_SIZEOF(long)
|
||||
AC_CHECK_SIZEOF(long long)
|
||||
AC_CHECK_SIZEOF(off_t)
|
||||
|
||||
if test $ac_cv_sizeof_off_t = 8; then
|
||||
offt_64bit=yes
|
||||
else
|
||||
offt_64bit=no
|
||||
fi
|
||||
|
||||
if test x$ac_cv_sizeof_off_t = x$ac_cv_sizeof_long; then
|
||||
# try to use unsigned long always first
|
||||
AC_DEFINE_UNQUOTED(PRIuUOFF_T, "lu")
|
||||
AC_DEFINE(UOFF_T_LONG)
|
||||
elif test x$ac_cv_sizeof_off_t = x$ac_cv_sizeof_int; then
|
||||
# next try int
|
||||
AC_DEFINE_UNQUOTED(PRIuUOFF_T, "u")
|
||||
AC_DEFINE(UOFF_T_INT)
|
||||
elif test x$ac_cv_sizeof_off_t = x$ac_cv_sizeof_long_long; then
|
||||
# and finally long long
|
||||
AC_DEFINE_UNQUOTED(PRIuUOFF_T, "llu")
|
||||
AC_DEFINE(UOFF_T_LONG_LONG)
|
||||
else
|
||||
AC_ERROR([Couldn't find integer type for off_t])
|
||||
fi
|
||||
|
||||
dnl **
|
||||
dnl ** check for socks
|
||||
dnl **
|
||||
|
||||
if test "x$want_socks" = "xyes"; then
|
||||
AC_CHECK_LIB(socks, connect, [
|
||||
AC_DEFINE(HAVE_SOCKS,, Build with socks support)
|
||||
LIBS="$LIBS -lsocks"
|
||||
AC_CHECK_HEADER(socks.h, [
|
||||
AC_DEFINE(HAVE_SOCKS_H)
|
||||
CFLAGS="$CFLAGS -DSOCKS"
|
||||
AC_MSG_RESULT(["socks5 library found, building with it"])
|
||||
], [
|
||||
AC_MSG_RESULT(["socks4 library found, building with it"])
|
||||
CFLAGS="$CFLAGS -Dconnect=Rconnect -Dgetsockname=Rgetsockname -Dgetpeername=Rgetpeername -Dbind=Rbind -Daccept=Raccept -Dlisten=Rlisten -Dselect=Rselect"
|
||||
])
|
||||
])
|
||||
fi
|
||||
|
||||
dnl **
|
||||
dnl ** fe-text checks
|
||||
dnl **
|
||||
|
||||
for try in 1 2; do
|
||||
if test $try = 1; then
|
||||
glib_modules=gmodule
|
||||
else
|
||||
echo "*** trying without -lgmodule"
|
||||
glib_modules=
|
||||
fi
|
||||
AM_PATH_GLIB_2_0(2.28.0,,, $glib_modules)
|
||||
if test "$GLIB_LIBS"; then
|
||||
if test $glib_modules = gmodule; then
|
||||
AC_DEFINE(HAVE_GMODULE)
|
||||
have_gmodule=yes
|
||||
fi
|
||||
break
|
||||
fi
|
||||
done
|
||||
|
||||
if test -z "$GLIB_LIBS"; then
|
||||
echo
|
||||
echo "*** If you don't have GLIB, you can get it from ftp://ftp.gtk.org/pub/glib/"
|
||||
echo "*** We recommend you get the latest stable GLIB 2 version."
|
||||
echo "*** Compile and install it, and make sure pkg-config finds it,"
|
||||
echo "*** by adding the path where the .pc file is located to PKG_CONFIG_PATH"
|
||||
echo -n "*** Or alternatively install your distribution's package"
|
||||
if test -f /etc/debian_version; then
|
||||
echo :
|
||||
echo "*** sudo apt-get install libglib2.0-dev"
|
||||
elif test -f /etc/redhat-release; then
|
||||
echo " (glib2-devel)"
|
||||
else
|
||||
echo .
|
||||
fi
|
||||
echo
|
||||
|
||||
AC_ERROR([GLIB is required to build irssi.])
|
||||
fi
|
||||
|
||||
LIBS="$LIBS $GLIB_LIBS"
|
||||
|
||||
GLIB_TESTS
|
||||
|
||||
dnl **
|
||||
dnl ** OpenSSL checks
|
||||
dnl **
|
||||
PKG_CHECK_MODULES([OPENSSL], [openssl], [
|
||||
CFLAGS="$CFLAGS $OPENSSL_CFLAGS"
|
||||
LIBS="$LIBS $OPENSSL_LIBS"
|
||||
], [
|
||||
AC_CHECK_LIB([ssl], [SSL_library_init], [
|
||||
LIBS="$LIBS -lssl -lcrypto"
|
||||
], [
|
||||
AC_MSG_ERROR([The OpenSSL library was not found])
|
||||
])
|
||||
])
|
||||
|
||||
dnl **
|
||||
dnl ** utf8proc
|
||||
dnl **
|
||||
if test "x$want_utf8proc" != "xno"; then
|
||||
AC_CHECK_HEADER([utf8proc.h], [
|
||||
AC_CHECK_LIB([utf8proc], [utf8proc_version], [
|
||||
want_utf8proc=yes
|
||||
AC_DEFINE(HAVE_LIBUTF8PROC,, [Define to 1 if you have the `utf8proc' library (-lutf8proc).])
|
||||
LIBS="$LIBS -lutf8proc"
|
||||
], [
|
||||
want_utf8proc="no, library not found"
|
||||
])
|
||||
], [
|
||||
want_utf8proc="no, library header not found"
|
||||
])
|
||||
fi
|
||||
|
||||
dnl **
|
||||
dnl ** curses checks
|
||||
dnl **
|
||||
|
||||
if test "x$want_textui" != "xno"; then
|
||||
|
||||
TEXTUI_NO_LIBS="$LIBS"
|
||||
LIBS=
|
||||
AC_SEARCH_LIBS([setupterm], [tinfo ncursesw ncurses terminfo], [want_textui=yes], [
|
||||
AC_ERROR(Terminfo not found - install libncurses-dev or ncurses-devel package)
|
||||
want_textui="no, Terminfo not found"
|
||||
])
|
||||
|
||||
TEXTUI_LIBS="$LIBS"
|
||||
AC_SUBST(TEXTUI_LIBS)
|
||||
LIBS="$TEXTUI_NO_LIBS"
|
||||
|
||||
AC_CHECK_HEADER([term.h], [
|
||||
AC_DEFINE(HAVE_TERM_H, [], [Define to 1 if you have the `term.h' header.])
|
||||
])
|
||||
|
||||
fi
|
||||
|
||||
dnl **
|
||||
dnl ** irssifuzzer checks
|
||||
dnl **
|
||||
|
||||
if test "$want_irssifuzzer" != "no"; then
|
||||
dnl * we need to build with -fsanitize-coverage=trace-pc-guard
|
||||
dnl * otherwise fuzzer won't be very successful at finding bugs :)
|
||||
if test -z "$SANFLAGS"; then
|
||||
SANFLAGS="-g -fsanitize=address -fsanitize-coverage=trace-pc-guard"
|
||||
fi
|
||||
CFLAGS="$CFLAGS $SANFLAGS"
|
||||
CXXFLAGS="$CXXFLAGS $SANFLAGS"
|
||||
|
||||
AC_MSG_CHECKING(for fuzzer library)
|
||||
|
||||
if test -z "$fuzzerlibpath"; then
|
||||
AC_MSG_RESULT([not found, building without fuzzer front end])
|
||||
want_irssifuzzer=no
|
||||
else
|
||||
FUZZER_LIBS="$fuzzerlibpath"
|
||||
AC_SUBST(FUZZER_LIBS)
|
||||
fi
|
||||
fi
|
||||
|
||||
dnl **
|
||||
dnl ** perl checks
|
||||
dnl **
|
||||
|
||||
if test "$want_perl" != "no"; then
|
||||
AC_MSG_CHECKING(for working Perl support)
|
||||
|
||||
if test -z "$perlpath"; then
|
||||
perl_check_error="perl binary not found"
|
||||
else
|
||||
PERL_CFLAGS=`$perlpath -MExtUtils::Embed -e ccopts 2>/dev/null`
|
||||
fi
|
||||
|
||||
if test "x$ac_cv_prog_gcc" = "xyes" -a -z "`echo $host_os|grep 'bsd\|linux'`"; then
|
||||
dnl * several systems have Perl compiled with native compiler
|
||||
dnl * but irssi is being compiled with GCC. Here we try to
|
||||
dnl * fix those command line options a bit so GCC won't
|
||||
dnl * complain about them. Normally there's only few options
|
||||
dnl * that we want to keep:
|
||||
dnl * -Ddefine -Uundef -I/path -fopt -mopt -iwithsysroot
|
||||
PERL_CFLAGS=`echo $PERL_CFLAGS | $perlpath -pe 's/^(.* )?-@<:@^DUIifm@:>@@<:@^ @:>@+/\1/g; s/^(.* )?\+@<:@^ @:>@+/\1/g'`
|
||||
|
||||
PERL_EXTRA_OPTS="CCCDLFLAGS=\"-fPIC\""
|
||||
AC_SUBST(PERL_EXTRA_OPTS)
|
||||
fi
|
||||
|
||||
if test -z "$PERL_CFLAGS"; then
|
||||
if test -n "$perl_check_error"; then
|
||||
perl_check_error="Error getting perl CFLAGS"
|
||||
fi
|
||||
AC_MSG_RESULT([not found, building without Perl])
|
||||
want_perl=no
|
||||
else
|
||||
PERL_LDFLAGS=`$perlpath -MExtUtils::Embed -e ldopts 2>/dev/null`
|
||||
|
||||
dnl * remove all database stuffs
|
||||
dnl * nsl is already in ldflags
|
||||
dnl * libc is of course linked without needing -lc
|
||||
dnl * -rdynamic must not be in LIBADD line
|
||||
for word in -ldb -ldbm -lndbm -lgdbm -lc -rdynamic; do
|
||||
PERL_LDFLAGS=`echo $PERL_LDFLAGS | $sedpath -e "s/$word //" -e "s/$word$//"`
|
||||
done
|
||||
|
||||
case "$host_os" in
|
||||
linux*)
|
||||
PERL_LDFLAGS=`echo $PERL_LDFLAGS | $sedpath -e 's/-lposix //' -e 's/-lposix$//'`
|
||||
;;
|
||||
hpux*)
|
||||
if test "x$ac_cv_prog_gcc" = "xyes"; then
|
||||
PERL_CFLAGS=`echo $PERL_CFLAGS | $sedpath -e 's/-Ae //' -e 's/-Ae$//'`
|
||||
PERL_LDFLAGS=`echo $PERL_LDFLAGS | $sedpath -e 's/-Ae //' -e 's/-Ae$//'`
|
||||
fi
|
||||
;;
|
||||
*)
|
||||
;;
|
||||
esac
|
||||
|
||||
dnl * check that perl's ldflags actually work
|
||||
echo "#include <EXTERN.h>" > conftest.c
|
||||
echo "#include <perl.h>" >> conftest.c
|
||||
echo "int main(){perl_alloc(); return 0;}" >> conftest.c
|
||||
$CC $CFLAGS $PERL_CFLAGS conftest.c -o conftest $LDFLAGS $PERL_LDFLAGS 2> perl.error.tmp > /dev/null
|
||||
if test ! -s conftest -a "x$ignore_perl_errors" = "x"; then
|
||||
perl_check_error="Error linking with perl libraries: $PERL_LDFLAGS: `cat perl.error.tmp`"
|
||||
AC_MSG_RESULT([error linking with perl libraries, building without Perl])
|
||||
want_perl=no
|
||||
fi
|
||||
|
||||
rm -f perl.error.tmp
|
||||
fi
|
||||
|
||||
if test "x$want_perl" != "xno"; then
|
||||
AC_MSG_RESULT(ok)
|
||||
|
||||
if test "x$want_perl" = "xstatic"; then
|
||||
dnl * building with static perl support
|
||||
dnl * all PERL_LDFLAGS linking is done in fe-text
|
||||
PERL_LINK_FLAGS="$PERL_LDFLAGS"
|
||||
PERL_LINK_LIBS="../perl/libperl_core_static.la"
|
||||
PERL_FE_LINK_LIBS="../perl/libfe_perl_static.la"
|
||||
PERL_LDFLAGS=
|
||||
AC_DEFINE(HAVE_STATIC_PERL)
|
||||
|
||||
dnl * build only static library of perl module
|
||||
perl_module_lib=
|
||||
perl_module_fe_lib=
|
||||
perl_static_lib=libperl_core_static.la
|
||||
perl_static_fe_lib=libfe_perl_static.la
|
||||
else
|
||||
dnl * build dynamic library of perl module
|
||||
perl_module_lib=libperl_core.la
|
||||
perl_module_fe_lib=libfe_perl.la
|
||||
perl_static_lib=
|
||||
perl_static_fe_lib=
|
||||
fi
|
||||
|
||||
if test "x$want_staticperllib" = "xyes"; then
|
||||
PERL_MM_PARAMS="$PERL_MM_PARAMS LINKTYPE=static"
|
||||
PERL_LINK_LIBS="$PERL_LINK_LIBS ../perl/common/blib/arch/auto/Irssi/Irssi.a ../perl/irc/blib/arch/auto/Irssi/Irc/Irc.a ../perl/ui/blib/arch/auto/Irssi/UI/UI.a ../perl/textui/blib/arch/auto/Irssi/TextUI/TextUI.a"
|
||||
PERL_STATIC_LIBS=1
|
||||
else
|
||||
PERL_STATIC_LIBS=0
|
||||
fi
|
||||
|
||||
# remove any prefix from PERL_MM_OPT
|
||||
PERL_MM_OPT=`perl -MText::ParseWords -e 'sub qu{$_=shift;s{^(.*?)=(.*)$}{($a,$b)=($1,$2);$b=~s/"/\\\\"/g;qq{$a="$b"}}ge if /@<:@\s"@:>@/;$_} local $,=" "; print map qu($_), grep !/^(INSTALL_BASE|PREFIX)=/, shellwords(@ARGV)' "$PERL_MM_OPT"`
|
||||
# figure out the correct @INC path - we'll need to do this
|
||||
# through MakeMaker since it's difficult to get it right
|
||||
# otherwise.
|
||||
$perlpath -MExtUtils::MakeMaker -e 'WriteMakefile(NAME => "test", MAKEFILE => "Makefile.test", FIRST_MAKEFILE => "/dev/null", NO_META => 1, NO_MYMETA => 1);' $PERL_MM_PARAMS >/dev/null
|
||||
echo 'show-INSTALLDIRS:' >> Makefile.test
|
||||
echo ' @echo $(INSTALLDIRS)' >> Makefile.test
|
||||
perl_INSTALLDIRS=`$am_make -s -f Makefile.test show-INSTALLDIRS`
|
||||
if test "x$perl_INSTALLDIRS" = "xsite"; then
|
||||
perl_library_dir="site default"
|
||||
perl_INSTALL_VAR=INSTALLSITEARCH
|
||||
elif test "x$perl_INSTALLDIRS" = "xvendor"; then
|
||||
perl_library_dir="vendor default"
|
||||
perl_INSTALL_VAR=INSTALLVENDORARCH
|
||||
else
|
||||
perl_library_dir="module default"
|
||||
perl_INSTALL_VAR=INSTALLARCHLIB
|
||||
fi
|
||||
echo 'show-ARCHLIB:' >> Makefile.test
|
||||
echo ' @echo $('"$perl_INSTALL_VAR"')' >> Makefile.test
|
||||
perl_use_lib=`$am_make -s -f Makefile.test show-ARCHLIB`
|
||||
rm -f Makefile.test
|
||||
if test "x$perl_set_use_lib" = "xyes"; then
|
||||
if $perlpath -e 'exit ! grep $_ eq $ARGV@<:@0@:>@, grep /^\//, @INC' "$perl_use_lib"; then
|
||||
perl_library_dir="other path in @INC"
|
||||
perl_set_use_lib=no
|
||||
else
|
||||
perl_library_dir="prepends to @INC with /set perl_use_lib"
|
||||
PERL_USE_LIB="$perl_use_lib"
|
||||
fi
|
||||
fi
|
||||
|
||||
AC_SUBST(perl_module_lib)
|
||||
AC_SUBST(perl_static_lib)
|
||||
AC_SUBST(perl_module_fe_lib)
|
||||
AC_SUBST(perl_static_fe_lib)
|
||||
|
||||
AC_SUBST(PERL_LINK_FLAGS)
|
||||
AC_SUBST(PERL_LINK_LIBS)
|
||||
AC_SUBST(PERL_FE_LINK_LIBS)
|
||||
|
||||
AC_SUBST(PERL_LDFLAGS)
|
||||
AC_SUBST(PERL_CFLAGS)
|
||||
|
||||
AC_SUBST(PERL_USE_LIB)
|
||||
AC_SUBST(PERL_MM_OPT)
|
||||
AC_SUBST(PERL_MM_PARAMS)
|
||||
AC_SUBST(PERL_STATIC_LIBS)
|
||||
fi
|
||||
fi
|
||||
|
||||
dnl **
|
||||
dnl ** check for capsicum
|
||||
dnl **
|
||||
|
||||
if test "x$want_capsicum" = "xyes"; then
|
||||
AC_CHECK_LIB(c, cap_enter, [
|
||||
AC_CHECK_LIB(nv, nvlist_create, [
|
||||
AC_DEFINE(HAVE_CAPSICUM,, Build with Capsicum support)
|
||||
LIBS="$LIBS -lnv"
|
||||
], [
|
||||
want_capsicum="no, nvlist_create not found"
|
||||
])
|
||||
], [
|
||||
want_capsicum="no, cap_enter not found"
|
||||
])
|
||||
fi
|
||||
|
||||
dnl **
|
||||
dnl ** OTR checks
|
||||
dnl **
|
||||
|
||||
have_otr=no
|
||||
if test "x$want_otr" != "xno"; then
|
||||
AM_PATH_LIBGCRYPT(1:1.2.0, [], [AC_ERROR(libgcrypt 1.2.0 or newer is required.)])
|
||||
AM_PATH_LIBOTR(4.1.0, [], [AC_ERROR([libotr 4.1.0 or newer is required.])])
|
||||
|
||||
OTR_CFLAGS="$LIBOTR_CFLAGS $LIBGCRYPT_CFLAGS"
|
||||
OTR_LDFLAGS="$LIBOTR_LIBS $LIBGCRYPT_LIBS"
|
||||
|
||||
AC_SUBST(otr_module_lib)
|
||||
AC_SUBST(otr_static_lib)
|
||||
|
||||
if test "x$want_otr" != "xno"; then
|
||||
if test "x$want_otr" = "xstatic"; then
|
||||
otr_module_lib=
|
||||
otr_static_lib=libotr_core_static.la
|
||||
|
||||
OTR_LINK_LIBS="../otr/libotr_core_static.la"
|
||||
OTR_LINK_FLAGS="$OTR_LDFLAGS"
|
||||
|
||||
AC_DEFINE(HAVE_STATIC_OTR)
|
||||
else
|
||||
otr_module_lib=libotr_core.la
|
||||
otr_static_lib=
|
||||
fi
|
||||
fi
|
||||
|
||||
AC_SUBST(otr_module_lib)
|
||||
AC_SUBST(otr_static_lib)
|
||||
|
||||
AC_SUBST(OTR_CFLAGS)
|
||||
AC_SUBST(OTR_LDFLAGS)
|
||||
|
||||
AC_SUBST(OTR_LINK_LIBS)
|
||||
AC_SUBST(OTR_LINK_FLAGS)
|
||||
|
||||
have_otr=yes
|
||||
fi
|
||||
|
||||
dnl ** check what we want to build
|
||||
AM_CONDITIONAL(BUILD_TEXTUI, test "$want_textui" = "yes")
|
||||
AM_CONDITIONAL(BUILD_IRSSIBOT, test "$want_irssibot" = "yes")
|
||||
AM_CONDITIONAL(BUILD_IRSSIFUZZER, test "$want_irssifuzzer" = "yes")
|
||||
AM_CONDITIONAL(BUILD_IRSSIPROXY, test "$want_irssiproxy" = "yes")
|
||||
AM_CONDITIONAL(HAVE_PERL, test "$want_perl" != "no")
|
||||
AM_CONDITIONAL(HAVE_CAPSICUM, test "x$want_capsicum" = "xyes")
|
||||
AM_CONDITIONAL(USE_GREGEX, test "x$want_gregex" = "xyes")
|
||||
AM_CONDITIONAL(HAVE_OTR, test "x$have_otr" != "xno")
|
||||
|
||||
# move LIBS to PROG_LIBS so they're not tried to be used when linking eg. perl libraries
|
||||
PROG_LIBS=$LIBS
|
||||
LIBS=
|
||||
AC_SUBST(PROG_LIBS)
|
||||
|
||||
dnl **
|
||||
dnl ** Keep all the libraries here so each frontend doesn't need to
|
||||
dnl ** keep track of them all
|
||||
dnl **
|
||||
dnl ** (these could be made configurable)
|
||||
|
||||
CHAT_MODULES="irc"
|
||||
irc_MODULES="dcc flood notifylist"
|
||||
if test -n "$build_modules"; then
|
||||
irc_MODULES="$irc_MODULES $build_modules"
|
||||
fi
|
||||
|
||||
dnl ****************************************
|
||||
|
||||
AC_SUBST(CHAT_MODULES)
|
||||
AC_SUBST(irc_MODULES)
|
||||
|
||||
CORE_LIBS="../core/libcore.a ../lib-config/libirssi_config.a"
|
||||
FE_COMMON_LIBS=""
|
||||
|
||||
CHAT_LIBS=""
|
||||
for c in $CHAT_MODULES; do
|
||||
module_inits=""
|
||||
module_deinits=""
|
||||
fe_module_inits=""
|
||||
fe_module_deinits=""
|
||||
CHAT_LIBS="$CHAT_LIBS ../$c/lib$c.a ../$c/core/lib${c}_core.a"
|
||||
if test -f $srcdir/src/fe-common/$c/module.h; then
|
||||
FE_COMMON_LIBS="$FE_COMMON_LIBS../fe-common/$c/libfe_common_$c.a "
|
||||
fi
|
||||
for s in `eval echo \\$${c}_MODULES`; do
|
||||
CHAT_LIBS="$CHAT_LIBS ../$c/$s/lib${c}_$s.a"
|
||||
module_inits="$module_inits ${c}_${s}_init();"
|
||||
module_deinits="${c}_${s}_deinit(); $module_deinits"
|
||||
if test -f $srcdir/src/fe-common/$c/$s/module.h; then
|
||||
FE_COMMON_LIBS="$FE_COMMON_LIBS../fe-common/$c/$s/libfe_${c}_$s.a "
|
||||
fe_module_inits="$fe_module_inits fe_${c}_${s}_init();"
|
||||
fe_module_deinits="fe_${c}_${s}_deinit(); $fe_module_deinits"
|
||||
fi
|
||||
done
|
||||
|
||||
mkdir -p src/$c
|
||||
file="src/$c/$c.c"
|
||||
echo "/* this file is automatically generated by configure - don't change */" > $file
|
||||
echo "void ${c}_core_init(void); void ${c}_core_deinit(void);" >> $file
|
||||
if test -n "$module_inits"; then
|
||||
echo "$module_inits" | $sedpath -e 's/()/(void)/g' -e 's/ /void /g' >> $file
|
||||
echo "$module_deinits" | $sedpath -e 's/ *$//' -e 's/()/(void)/g' -e 's/ /void /g' -e 's/^/void /' >> $file
|
||||
fi
|
||||
echo "void ${c}_init(void) { ${c}_core_init(); $module_inits }" >> $file
|
||||
echo "void ${c}_deinit(void) { $module_deinits ${c}_core_deinit(); }" >> $file
|
||||
|
||||
if test -f $srcdir/src/fe-common/$c/module.h; then
|
||||
mkdir -p src/fe-common/$c
|
||||
file="src/fe-common/$c/${c}-modules.c"
|
||||
echo "/* this file is automatically generated by configure - don't change */" > $file
|
||||
if test -n "$fe_module_inits"; then
|
||||
echo "$fe_module_inits" | $sedpath -e 's/()/(void)/g' -e 's/ /void /g' >> $file
|
||||
echo "$fe_module_deinits" | $sedpath -e 's/ *$//' -e 's/()/(void)/g' -e 's/ /void /g' -e 's/^/void /' >> $file
|
||||
fi
|
||||
echo "void fe_${c}_modules_init(void) { $fe_module_inits }" >> $file
|
||||
echo "void fe_${c}_modules_deinit(void) { $fe_module_deinits }" >> $file
|
||||
fi
|
||||
done
|
||||
|
||||
FE_COMMON_LIBS="$FE_COMMON_LIBS../fe-common/core/libfe_common_core.a"
|
||||
|
||||
dnl ** common libraries needed by frontends
|
||||
COMMON_NOUI_LIBS="$CHAT_LIBS $CORE_LIBS"
|
||||
COMMON_LIBS="$FE_COMMON_LIBS $COMMON_NOUI_LIBS"
|
||||
AC_SUBST(COMMON_NOUI_LIBS)
|
||||
AC_SUBST(COMMON_LIBS)
|
||||
|
||||
if test "x$want_truecolor" = "xyes"; then
|
||||
AC_DEFINE([TERM_TRUECOLOR], [], [true color support in terminal])
|
||||
else
|
||||
want_truecolor=no
|
||||
fi
|
||||
|
||||
if test "x$want_gregex" = "xyes"; then
|
||||
AC_DEFINE([USE_GREGEX], [], [use GRegex for regular expressions])
|
||||
else
|
||||
want_gregex=no
|
||||
fi
|
||||
|
||||
AH_TEMPLATE(HAVE_GMODULE)
|
||||
AH_TEMPLATE(HAVE_SOCKS_H, [misc..])
|
||||
AH_TEMPLATE(HAVE_STATIC_PERL)
|
||||
AH_TEMPLATE(HAVE_STATIC_OTR)
|
||||
AH_TEMPLATE(PRIuUOFF_T, [printf()-format for uoff_t, eg. "u" or "lu" or "llu"])
|
||||
AH_TEMPLATE(UOFF_T_INT, [What type should be used for uoff_t])
|
||||
AH_TEMPLATE(UOFF_T_LONG)
|
||||
AH_TEMPLATE(UOFF_T_LONG_LONG)
|
||||
|
||||
AC_CONFIG_FILES([
|
||||
Makefile
|
||||
src/Makefile
|
||||
src/core/Makefile
|
||||
src/irc/Makefile
|
||||
src/irc/core/Makefile
|
||||
src/irc/dcc/Makefile
|
||||
src/irc/notifylist/Makefile
|
||||
src/irc/proxy/Makefile
|
||||
src/irc/flood/Makefile
|
||||
src/fe-common/Makefile
|
||||
src/fe-common/core/Makefile
|
||||
src/fe-common/irc/Makefile
|
||||
src/fe-common/irc/dcc/Makefile
|
||||
src/fe-common/irc/notifylist/Makefile
|
||||
src/fe-fuzz/Makefile
|
||||
src/fe-fuzz/irc/Makefile
|
||||
src/fe-fuzz/irc/core/Makefile
|
||||
src/fe-fuzz/fe-common/Makefile
|
||||
src/fe-fuzz/fe-common/core/Makefile
|
||||
src/fe-none/Makefile
|
||||
src/fe-text/Makefile
|
||||
src/lib-config/Makefile
|
||||
src/perl/Makefile
|
||||
src/perl/common/Makefile.PL
|
||||
src/perl/irc/Makefile.PL
|
||||
src/perl/ui/Makefile.PL
|
||||
src/perl/textui/Makefile.PL
|
||||
src/otr/Makefile
|
||||
scripts/Makefile
|
||||
scripts/examples/Makefile
|
||||
tests/Makefile
|
||||
tests/fe-common/Makefile
|
||||
tests/fe-common/core/Makefile
|
||||
tests/fe-text/Makefile
|
||||
tests/irc/Makefile
|
||||
tests/irc/core/Makefile
|
||||
tests/irc/flood/Makefile
|
||||
docs/Makefile
|
||||
docs/help/Makefile
|
||||
docs/help/in/Makefile
|
||||
utils/Makefile
|
||||
themes/Makefile
|
||||
irssi-config
|
||||
])
|
||||
|
||||
AC_OUTPUT
|
||||
|
||||
dnl ** for building from objdir
|
||||
old_dir=`pwd` && cd $srcdir && whole_dir=`pwd` && cd $old_dir
|
||||
if test "x$old_dir" != "x$whole_dir"; then
|
||||
$LN_S $srcdir/irssi-version.h irssi-version.h
|
||||
if test "x$want_perl" != "xno"; then
|
||||
subdirfiles=""
|
||||
for i in $whole_dir/src/perl/common $whole_dir/src/perl/irc $whole_dir/src/perl/ui $whole_dir/src/perl/textui; do
|
||||
subdirfiles=`echo $subdirfiles $i/typemap $i/module.h $i/*.pm $i/*.xs`
|
||||
done
|
||||
for file in $whole_dir/src/perl/module.h $subdirfiles; do
|
||||
link=`echo $file|$sedpath "s?$whole_dir/??"`
|
||||
rm -f $link
|
||||
$LN_S $file $link
|
||||
done
|
||||
fi
|
||||
fi
|
||||
|
||||
echo
|
||||
|
||||
echo "Building text frontend ........... : $want_textui"
|
||||
echo "Building irssi bot ............... : $want_irssibot"
|
||||
echo "Building irssi proxy ............. : $want_irssiproxy"
|
||||
if test "x$have_gmodule" = "xyes"; then
|
||||
echo "Building with module support ..... : yes"
|
||||
else
|
||||
echo "Building with module support : NO!! /LOAD will not work!"
|
||||
echo " - You're missing gmodule (comes with glib) for some reason,"
|
||||
echo " or it doesn't work in your system."
|
||||
fi
|
||||
|
||||
if test "x$want_perl" = "xstatic"; then
|
||||
echo "Building with Perl support ....... : static (in irssi binary)"
|
||||
elif test "x$want_perl" = "xmodule"; then
|
||||
echo "Building with Perl support ....... : module"
|
||||
else
|
||||
if test -z "$perl_check_error"; then
|
||||
echo "Building with Perl support ....... : no"
|
||||
else
|
||||
echo "Building with Perl support ....... : NO!"
|
||||
echo " - $perl_check_error"
|
||||
if test -f /etc/debian_version; then
|
||||
echo " - Try: sudo apt-get install libperl-dev"
|
||||
elif test -f /etc/redhat-release; then
|
||||
echo " - Try installing perl-devel"
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
|
||||
if test "x$want_perl" != "xno" -a "x$perl_mod_error" != "x"; then
|
||||
echo " - NOTE: Perl support will be compiled statically to irssi, not as"
|
||||
echo " a module as requested. Reason:"
|
||||
echo " $perl_mod_error"
|
||||
|
||||
if test -f /etc/debian_version; then
|
||||
echo " - Try: sudo apt-get install libperl-dev"
|
||||
fi
|
||||
fi
|
||||
|
||||
if test "x$want_perl" != "xno"; then
|
||||
echo "Perl library directory ........... : ($perl_library_dir - $perl_use_lib)"
|
||||
if test "x$perl_prefix_note" = "xyes"; then
|
||||
echo " - NOTE: This was automatically set to the same directory you gave with"
|
||||
echo " --prefix. If you want the perl libraries to install to their 'correct'"
|
||||
echo " path, you'll need to give --with-perl-lib=site option to configure."
|
||||
echo " Anyway, installing perl to this directory should work just as well."
|
||||
fi
|
||||
fi
|
||||
echo "Install prefix ................... : $prefix"
|
||||
|
||||
echo
|
||||
|
||||
echo "Building with 64bit DCC support .. : $offt_64bit"
|
||||
echo "Building with true color support.. : $want_truecolor"
|
||||
echo "Building with GRegex ............. : $want_gregex"
|
||||
echo "Building with Capsicum ........... : $want_capsicum"
|
||||
echo "Building with utf8proc ........... : $want_utf8proc"
|
||||
if test "x$want_otr" = "xstatic"; then
|
||||
echo "Building with OTR support ........ : static (in irssi binary)"
|
||||
elif test "x$want_otr" = "xmodule"; then
|
||||
echo "Building with OTR support ........ : module"
|
||||
else
|
||||
echo "Building with OTR support ........ : no"
|
||||
fi
|
||||
|
||||
|
||||
echo
|
||||
echo "If there are any problems, read the INSTALL file."
|
@ -1,20 +0,0 @@
|
||||
man_MANS = \
|
||||
irssi.1
|
||||
|
||||
doc_DATA = \
|
||||
capsicum.txt \
|
||||
design.html \
|
||||
design.txt \
|
||||
formats.txt \
|
||||
manual.txt \
|
||||
faq.html \
|
||||
faq.txt \
|
||||
perl.txt \
|
||||
signals.txt \
|
||||
special_vars.txt \
|
||||
startup-HOWTO.html \
|
||||
startup-HOWTO.txt
|
||||
|
||||
EXTRA_DIST = $(doc_DATA) $(man_MANS)
|
||||
|
||||
SUBDIRS = help
|
@ -1,7 +1,6 @@
|
||||
<base href='https://irssi.org/documentation/design/'>
|
||||
<h1>Design</h1>
|
||||
|
||||
<p>Irssi’s hierarchy is something like this:</p>
|
||||
<p>Irssi’s hierarchy is something like this:</p>
|
||||
|
||||
<pre class="repl" id="fig1"><code class="language-ascidia">
|
||||
sub1 sub2
|
||||
|
47
docs/example-cross-android-aarch64.txt
Normal file
47
docs/example-cross-android-aarch64.txt
Normal file
@ -0,0 +1,47 @@
|
||||
[binaries]
|
||||
ar = 'aarch64-linux-android-ar'
|
||||
c = 'aarch64-linux-android-clang'
|
||||
cpp = 'aarch64-linux-android-clang++'
|
||||
ld = 'aarch64-linux-android-ld'
|
||||
pkgconfig = '/home/builder/.termux-build/_cache/android-r20-api-24-v3/bin/aarch64-linux-android-pkg-config'
|
||||
strip = 'aarch64-linux-android-strip'
|
||||
|
||||
;; you have to substitute 5.30.2 with the Perl version, that can be
|
||||
;; obtained by running ` miniperl -e 'print substr $^V, 1' `
|
||||
|
||||
perl = ['/home/builder/.termux-build/perl/src/miniperl', '-I/data/data/com.termux/files/usr/lib/perl5/5.30.2/aarch64-android', '-I/data/data/com.termux/files/usr/lib/perl5/5.30.2']
|
||||
|
||||
[properties]
|
||||
needs_exe_wrapper = true
|
||||
c_args = ['-fstack-protector-strong', '-Oz', '-I/data/data/com.termux/files/usr/include']
|
||||
cpp_args = ['-fstack-protector-strong', '-Oz', '-I/data/data/com.termux/files/usr/include']
|
||||
c_link_args = ['-L/data/data/com.termux/files/usr/lib', '-Wl,-rpath=/data/data/com.termux/files/usr/lib', '-Wl,--enable-new-dtags', '-Wl,--as-needed', '-Wl,-z,relro,-z,now', '-landroid-glob']
|
||||
cpp_link_args = ['-L/data/data/com.termux/files/usr/lib', '-Wl,-rpath=/data/data/com.termux/files/usr/lib', '-Wl,--enable-new-dtags', '-Wl,--as-needed', '-Wl,-z,relro,-z,now', '-landroid-glob']
|
||||
|
||||
;; if you do not have a cross-perl like miniperl available, you have
|
||||
;; to specify the required options by uncommenting the following
|
||||
;; properties
|
||||
|
||||
;; you can get the proper values by running the commands on your
|
||||
;; Android device:
|
||||
|
||||
;; ` perl -V::version: `
|
||||
; perl_version = '5.30.2'
|
||||
;; ` perl -MExtUtils::Embed -o ccopts `
|
||||
; perl_ccopts = ['-I/data/data/com.termux/files/usr/include', '-D_LARGEFILE_SOURCE', '-D_FILE_OFFSET_BITS=64', '-I/data/data/com.termux/files/usr/lib/perl5/5.30.2/aarch64-android/CORE']
|
||||
;; ` perl -MExtUtils::Embed -o ldopts `
|
||||
; perl_ldopts = ['-Wl,-E', '-I/data/data/com.termux/files/usr/include', '-L/data/data/com.termux/files/usr/lib/perl5/5.30.2/aarch64-android/CORE', '-lperl', '-lm', '-ldl']
|
||||
;; ` perl -V::archname: `
|
||||
; perl_archname = 'aarch64-android'
|
||||
;; ` perl -V::installsitearch: `
|
||||
; perl_installsitearch = '/data/data/com.termux/files/usr/lib/perl5/site_perl/5.30.2/aarch64-android'
|
||||
;; ` perl -V::installvendorarch: `
|
||||
; perl_installvendorarch = ''
|
||||
;; ` perl -E 'say for @INC' `
|
||||
; perl_inc = ['/data/data/com.termux/files/usr/lib/perl5/site_perl/5.30.2/aarch64-android', '/data/data/com.termux/files/usr/lib/perl5/site_perl/5.30.2', '/data/data/com.termux/files/usr/lib/perl5/5.30.2/aarch64-android', '/data/data/com.termux/files/usr/lib/perl5/5.30.2']
|
||||
|
||||
[host_machine]
|
||||
cpu_family = 'arm'
|
||||
cpu = 'aarch64'
|
||||
endian = 'little'
|
||||
system = 'android'
|
@ -1,9 +1,8 @@
|
||||
<base href='https://irssi.org/documentation/faq/'>
|
||||
<h1>Frequently Asked Questions</h1>
|
||||
<h3 id="q-why-doesnt-irssi-display-colors-even-when-ircii-etc-displays-them">Q: Why doesn’t irssi display colors even when ircii etc. displays them?</h3>
|
||||
|
||||
<h3 id="q-why-doesnt-irssi-display-colors-even-when-ircii-etc-displays-them">Q: Why doesn’t irssi display colors even when ircii etc. displays them?</h3>
|
||||
|
||||
<p>A: They force ANSI colors even if terminal doesn’t support them. By default, irssi uses colors only if terminfo/termcap so says. The correct way to fix this would be to change your TERM environment to a value where colors work, like xterm-color or color_xterm (eg. <code>TERM=xterm-color irssi</code>). If this doesn’t help, then use the evil way of <code>/SET term_force_colors ON</code>.</p>
|
||||
<p>A: They force ANSI colors even if terminal doesn’t support them. By default, irssi uses colors only if terminfo/termcap so says. The correct way to fix this would be to change your TERM environment to a value where colors work, like xterm-256color or color_xterm (eg. <code>TERM=xterm-256color irssi</code>). If this doesn’t help, then use the evil way of <code>/SET term_force_colors ON</code>.</p>
|
||||
|
||||
<h3 id="q-how-do-i-easily-write-text-to-channel-that-starts-with--character">Q: How do I easily write text to channel that starts with ‘/’ character?</h3>
|
||||
|
||||
@ -55,7 +54,7 @@
|
||||
|
||||
<h3 id="q-will-there-be-detach-like-feature">Q: Will there be /DETACH-like feature?</h3>
|
||||
|
||||
<p>A: <a href="http://tmux.github.io/">tmux</a>, <a href="http://www.gnu.org/software/screen/screen.html">screen</a> and <a href="http://dtach.sf.net/">dtach</a> can be used to do it just fine.</p>
|
||||
<p>A: <a href="https://tmux.github.io/">tmux</a>, <a href="https://www.gnu.org/software/screen/screen.html">screen</a> and <a href="https://sourceforge.net/projects/dtach/">dtach</a> can be used to do it just fine.</p>
|
||||
|
||||
<h3 id="q-how-do-i-run-scripts-automatically-at-startup">Q: How do I run scripts automatically at startup?</h3>
|
||||
|
||||
@ -71,7 +70,7 @@
|
||||
|
||||
<h3 id="q-how-can-i-have-whois-replies-to-active-window">Q: How can I have /WHOIS replies to active window?</h3>
|
||||
|
||||
<p>A: You can disable the status window, or do <code>/WINDOW LEVEL -CRAP</code> in it which would also make several other messages show up in active window. You can also use a <a href="http://dgl.cx/irssi/hack-whois-in-current-window.pl">script</a>.</p>
|
||||
<p>A: You can disable the status window, or do <code>/WINDOW LEVEL -CRAP</code> in it which would also make several other messages show up in active window. You can also use a <a href="https://dgl.cx/irssi/hack-whois-in-current-window.pl">script</a>.</p>
|
||||
|
||||
<h3 id="q-how-do-i-add-the-active-network-to-the-statusbar">Q: How do I add the active network to the statusbar</h3>
|
||||
|
||||
|
12
docs/faq.txt
12
docs/faq.txt
@ -4,8 +4,8 @@ Q: Why doesn’t irssi display colors even when ircii etc. displays them?
|
||||
A: They force ANSI colors even if terminal doesn’t support them. By default,
|
||||
irssi uses colors only if terminfo/termcap so says. The correct way to fix this
|
||||
would be to change your TERM environment to a value where colors work, like
|
||||
xterm-color or color_xterm (eg. TERM=xterm-color irssi). If this doesn’t help,
|
||||
then use the evil way of /SET term_force_colors ON.
|
||||
xterm-256color or color_xterm (eg. TERM=xterm-256color irssi). If this doesn’t
|
||||
help, then use the evil way of /SET term_force_colors ON.
|
||||
|
||||
Q: How do I easily write text to channel that starts with ‘/’ character?
|
||||
A: / /text
|
||||
@ -117,8 +117,8 @@ A: Check [6]here
|
||||
References:
|
||||
|
||||
[1] https://github.com/irssi-import/xirssi
|
||||
[2] http://tmux.github.io/
|
||||
[3] http://www.gnu.org/software/screen/screen.html
|
||||
[4] http://dtach.sf.net/
|
||||
[5] http://dgl.cx/irssi/hack-whois-in-current-window.pl
|
||||
[2] https://tmux.github.io/
|
||||
[3] https://www.gnu.org/software/screen/screen.html
|
||||
[4] https://sourceforge.net/projects/dtach/
|
||||
[5] https://dgl.cx/irssi/hack-whois-in-current-window.pl
|
||||
[6] https://irssi.org/assets/irssi.wav
|
||||
|
@ -1,12 +0,0 @@
|
||||
# Makefile.am is autogenerated by autogen.sh from Makefile.am.gen
|
||||
|
||||
helpdir = $(datadir)/irssi/help
|
||||
|
||||
help_DATA = \
|
||||
@HELPFILES@
|
||||
|
||||
EXTRA_DIST = \
|
||||
Makefile.am.gen \
|
||||
$(help_DATA)
|
||||
|
||||
SUBDIRS = in
|
@ -1,5 +0,0 @@
|
||||
# Makefile.am is autogenerated by autogen.sh from Makefile.am.gen
|
||||
|
||||
EXTRA_DIST = \
|
||||
Makefile.am.gen \
|
||||
@HELPFILES@
|
@ -15,7 +15,7 @@
|
||||
%9Examples:%9
|
||||
|
||||
/ADMIN
|
||||
/ADMIN orwell.freenode.net
|
||||
/ADMIN irc.libera.chat
|
||||
/ADMIN mike
|
||||
|
||||
%9See also:%9 INFO
|
||||
|
@ -5,19 +5,22 @@
|
||||
|
||||
%9Parameters:%9
|
||||
|
||||
-window: Displays the output in the active window.
|
||||
|
||||
The file to display and optionally a position to seek in the file,
|
||||
in bytes.
|
||||
|
||||
%9Description:%9
|
||||
|
||||
Displays the contents of the specified file into the active window.
|
||||
Displays the contents of the specified file in the active window if -window
|
||||
is specified, otherwise to the closest matching window depending on levels.
|
||||
|
||||
The seek position parameter is used internally to display away logs, if
|
||||
omitted the whole file is shown.
|
||||
|
||||
%9Examples:%9
|
||||
|
||||
/CAT /etc/network/interfaces
|
||||
/CAT -window /etc/network/interfaces
|
||||
/CAT /home/mike/resume.txt
|
||||
/CAT contact_details.txt
|
||||
|
||||
|
@ -33,12 +33,12 @@
|
||||
|
||||
/CHANNEL
|
||||
/CHANNEL LIST
|
||||
/CHANNEL ADD -auto #irssi Freenode
|
||||
/CHANNEL ADD -auto #irssi liberachat
|
||||
/CHANNEL ADD -auto #basementcat Quakenet secret_lair
|
||||
/CHANNEL ADD -auto -bots '*!@*.irssi.org *!bot@irssi.org' -botcmd 'msg $0 op WzerTrzq' #hideout Freenode
|
||||
/CHANNEL ADD -auto -bots '*!@*.irssi.org *!bot@irssi.org' -botcmd 'msg $0 op WzerTrzq' #hideout liberachat
|
||||
/CHANNEL ADD -auto -bots 'Q!TheQBot@CServe.quakenet.org' -botcmd '^MSG Q op #irssi' #irssi Quakenet
|
||||
/CHANNEL MODIFY -noauto #irssi Freenode
|
||||
/CHANNEL REMOVE #hideout Freenode
|
||||
/CHANNEL MODIFY -noauto #irssi liberachat
|
||||
/CHANNEL REMOVE #hideout liberachat
|
||||
|
||||
%9Special Example:%9
|
||||
|
||||
|
@ -17,6 +17,7 @@
|
||||
-tls_ciphers: TLS cipher suite preference lists.
|
||||
-tls_pinned_cert: Pinned x509 certificate fingerprint.
|
||||
-tls_pinned_pubkey: Pinned public key fingerprint.
|
||||
-nocap: Disable CAPREQ during connect
|
||||
-noproxy: Ignores the global proxy configuration.
|
||||
-network: The network this connection belongs to.
|
||||
-host: The hostname you would like to connect from.
|
||||
@ -34,9 +35,9 @@
|
||||
|
||||
%9Examples:%9
|
||||
|
||||
/CONNECT Freenode
|
||||
/CONNECT -6 Freenode
|
||||
/CONNECT -4 -! -host staff.irssi.org -network Freenode orwell.freenode.net
|
||||
/CONNECT liberachat
|
||||
/CONNECT -6 liberachat
|
||||
/CONNECT -4 -! -host staff.irssi.org -network liberachat irc.libera.chat
|
||||
/CONNECT irc.irssi.org 6667 WzerT8zq mike
|
||||
|
||||
%9See also:%9 DISCONNECT, RMRECONNS, SERVER
|
||||
|
@ -18,7 +18,7 @@
|
||||
|
||||
%9Examples:%9
|
||||
|
||||
/DISCONNECT Freenode I'm off for today, take care!
|
||||
/DISCONNECT liberachat I'm off for today, take care!
|
||||
/DISCONNECT * Vacation time :D
|
||||
/DISCONNECT
|
||||
|
||||
|
@ -5,7 +5,6 @@
|
||||
|
||||
%9Parameters:%9
|
||||
|
||||
-current: Displays the output in the active window.
|
||||
-window: Displays the output in the target window.
|
||||
-level: Displays the output with a given message level.
|
||||
|
||||
@ -18,7 +17,7 @@
|
||||
%9Examples:%9
|
||||
|
||||
/ECHO 1 + 1 = 2 :D
|
||||
/ECHO -current Testing the ECHO command
|
||||
/ECHO Testing the ECHO command
|
||||
/ECHO -window #irssi Special variables such as ${N} will not be expanded.
|
||||
|
||||
%9See also:%9 CAT, EVAL, EXEC, LEVELS
|
||||
|
@ -10,13 +10,23 @@
|
||||
%9Description:%9
|
||||
|
||||
Evaluates the given commands and executes them; you can use internal
|
||||
variables and separate multiple commands by using the ';' character.
|
||||
variables and separate multiple commands by using the `;' character.
|
||||
If the command contains a string with `$', `\' or `;' those characters
|
||||
need to be escaped:
|
||||
|
||||
`$' -> `$$'
|
||||
`\' -> `\\' (or even `\\\\', depending on where they are used)
|
||||
`;' -> `\;'
|
||||
|
||||
%9Examples:%9
|
||||
|
||||
/EVAL echo I am connected to ${S} on ${chatnet} as ${N}
|
||||
/EVAL echo My user privileges are +${usermode}; echo Let's party!
|
||||
|
||||
to print `1;2$3\4':
|
||||
|
||||
/EVAL echo 1\;2$$3\\4
|
||||
|
||||
%9References:%9
|
||||
|
||||
https://github.com/irssi/irssi/blob/master/docs/special_vars.txt
|
||||
|
@ -12,7 +12,7 @@
|
||||
-full: The text must match the full word.
|
||||
-matchcase: The text must match case.
|
||||
-regexp: The text is a regular expression.
|
||||
-color: The color the display the highlight in.
|
||||
-color: The color to display the highlight in.
|
||||
-actcolor: The color to mark the highlight activity in the statusbar.
|
||||
-level: Matches only on the given message level.
|
||||
-network: Matches only on the given network.
|
||||
|
@ -14,6 +14,8 @@
|
||||
-network: Ignores only on a specific network.
|
||||
-channels: Ignores only on specific channels.
|
||||
-time: The timeout to automatically remove the ignore.
|
||||
Accepts units specified in days, hours, minutes, seconds,
|
||||
milliseconds, or no unit for seconds.
|
||||
|
||||
The mask, channels and levels to ignore; if no argument is provided, the
|
||||
list of ignores will be displayed.
|
||||
@ -44,6 +46,8 @@
|
||||
/IGNORE #irssi NO_ACT JOINS PARTS QUITS
|
||||
/IGNORE mike NO_ACT -MSGS
|
||||
/IGNORE mike HIDDEN PUBLIC JOINS PARTS QUITS
|
||||
/IGNORE -time 5days christmas PUBLICS
|
||||
/IGNORE -time 300 mike PUBLICS
|
||||
|
||||
%9See also:%9 ACCEPT, SILENCE, UNIGNORE
|
||||
|
||||
|
@ -15,7 +15,7 @@
|
||||
%9Examples:%9
|
||||
|
||||
/INFO
|
||||
/INFO orwell.freenode.net
|
||||
/INFO irc.libera.chat
|
||||
|
||||
%9See also:%9 ADMIN
|
||||
|
||||
|
@ -20,7 +20,7 @@
|
||||
/JOIN #irssi
|
||||
/JOIN #basementcat secret_lair
|
||||
/JOIN -invite
|
||||
/JOIN -freenode #github,#freenode,#irssi
|
||||
/JOIN -liberachat #github,#libera,#irssi
|
||||
|
||||
%9See also:%9 KICK, PART
|
||||
|
||||
|
@ -23,7 +23,7 @@
|
||||
%9Examples:%9
|
||||
|
||||
/KNOCK #irssi
|
||||
/KNOCK #freenode
|
||||
/KNOCK #libera
|
||||
/KNOCK #github
|
||||
|
||||
%9See also:%9 INVITE, JOIN
|
||||
|
@ -20,9 +20,10 @@
|
||||
MODES A channel mode is modified.
|
||||
MSGS Private messages.
|
||||
NICKS A nickname changes to another nickname.
|
||||
NOTICES Notices sent from a nickname.
|
||||
NOTICES Private notices.
|
||||
PARTS A nickname leaves a channel.
|
||||
PUBLIC Public messages in a channel.
|
||||
PUBNOTICES Public notices in a channel.
|
||||
QUITS A nickname disconnects from IRC.
|
||||
SNOTES Notices sent from a server.
|
||||
TOPICS A channel topic is modified.
|
||||
|
@ -33,10 +33,10 @@
|
||||
%9Examples:%9
|
||||
|
||||
/LOG OPEN -targets mike ~/irclogs/mike.log MSGS
|
||||
/LOG OPEN -targets #irssi-freenode ~/irclogs/freenode/irssi-%%Y-%%m-%%d
|
||||
/LOG CLOSE ~/irclogs/freenode/irssi-%%Y-%%m-%%d
|
||||
/LOG STOP ~/irclogs/freenode/irssi-%%Y-%%m-%%d
|
||||
/LOG START ~/irclogs/freenode/irssi-%%Y-%%m-%%d
|
||||
/LOG OPEN -targets #irssi ~/irclogs/liberachat/irssi-%%Y-%%m-%%d
|
||||
/LOG CLOSE ~/irclogs/liberachat/irssi-%%Y-%%m-%%d
|
||||
/LOG STOP ~/irclogs/liberachat/irssi-%%Y-%%m-%%d
|
||||
/LOG START ~/irclogs/liberachat/irssi-%%Y-%%m-%%d
|
||||
|
||||
/SET autolog ON
|
||||
|
||||
|
1
docs/help/in/meson.build
Normal file
1
docs/help/in/meson.build
Normal file
@ -0,0 +1 @@
|
||||
# don't forget to add new help files to ../meson.build
|
@ -15,7 +15,7 @@
|
||||
%9Examples:%9
|
||||
|
||||
/MOTD
|
||||
/MOTD orwel.freenode.org
|
||||
/MOTD irc.libera.chat
|
||||
/MOTD bob
|
||||
|
||||
%9See also:%9 ADMIN, INFO, LINKS, MAP
|
||||
|
@ -11,8 +11,13 @@
|
||||
|
||||
The target nickname or channel and the message to send.
|
||||
|
||||
Use the wildcard character '*' if you want to use the active nickname or
|
||||
channel.
|
||||
The target can be a comma delimited list of targets, ie
|
||||
nick1,nick2 or #chan1,#chan2
|
||||
|
||||
Or one of the following special targets:
|
||||
* : Use the active nickname or channel
|
||||
, : Last person who sent you a /msg
|
||||
. : Last person you sent a /msg to
|
||||
|
||||
%9Description:%9
|
||||
|
||||
|
@ -21,7 +21,7 @@
|
||||
%9Examples:%9
|
||||
|
||||
/NAMES -ops
|
||||
/NAMES -voices #irssi,#freenode
|
||||
/NAMES -voices #irssi,#libera
|
||||
|
||||
%9See also:%9 JOIN, PART, WHO, WHOIS
|
||||
|
||||
|
@ -15,7 +15,7 @@
|
||||
%9Examples:%9
|
||||
|
||||
/NCTCP #irssi VERSION King of the Jungle v1.0
|
||||
/NCTCP bob,#freenode USERINFO I am bob :p
|
||||
/NCTCP bob,#libera USERINFO I am bob :p
|
||||
|
||||
%9See also:%9 CTCP
|
||||
|
||||
|
@ -18,7 +18,8 @@
|
||||
-usermode: Specifies the user modes to set on yourself.
|
||||
-autosendcmd: Specifies the commands, separated by the ';' character,
|
||||
and enclosed within two "'" characters, to perform after
|
||||
connecting.
|
||||
connecting.
|
||||
(Some characters need to be escaped - see /help eval)
|
||||
-querychans: Specifies the maximum number of channels to put in one MODE
|
||||
or WHO command when synchronizing.
|
||||
-whois: Specifies the maximum number of nicknames in one WHOIS
|
||||
@ -59,11 +60,11 @@
|
||||
%9Examples:%9
|
||||
|
||||
/NETWORK ADD -usermode +giw EFnet
|
||||
/NETWORK ADD -usermode +iw -nick mike -realname 'The one and only mike!' -host staff.irssi.org Freenode
|
||||
/NETWORK ADD -autosendcmd '^MSG NickServ identify WzerT8zq' Freenode
|
||||
/NETWORK ADD -usermode +iw -nick mike -realname 'The one and only mike!' -host staff.irssi.org liberachat
|
||||
/NETWORK ADD -autosendcmd '^MSG NickServ identify WzerT8zq' liberachat
|
||||
/NETWORK ADD -autosendcmd '^MSG Q@CServe.quakenet.org AUTH mike WzerT8zq; WAIT 2000; OPER mike WzerT8zq; WAIT 2000; MODE mike +kXP' Quakenet
|
||||
/NETWORK MODIFY -usermode +gi EFnet
|
||||
/NETWORK REMOVE Freenode
|
||||
/NETWORK REMOVE liberachat
|
||||
|
||||
%9See also:%9 CHANNEL, CONNECT, SERVER
|
||||
|
||||
|
@ -51,7 +51,7 @@ GENKEY <name>
|
||||
|
||||
This process is done in a background worker and can take an arbitrary
|
||||
amount of time. The completion is checked when another irssi event is
|
||||
catched.
|
||||
caught.
|
||||
|
||||
HELP
|
||||
Print this help.
|
||||
|
@ -14,7 +14,7 @@
|
||||
%9Examples:%9
|
||||
|
||||
/PART #irssi
|
||||
/PART #freenode,#irssi
|
||||
/PART #libera,#irssi
|
||||
|
||||
%9See also:%9 JOIN, KICK
|
||||
|
||||
|
@ -17,8 +17,8 @@
|
||||
%9Examples:%9
|
||||
|
||||
/QUERY mike
|
||||
/QUERY -freenode bob
|
||||
/QUERY -freenode -window sarah
|
||||
/QUERY -liberachat bob
|
||||
/QUERY -liberachat -window sarah
|
||||
|
||||
%9See also:%9 MSG, UNQUERY, WINDOW
|
||||
|
||||
|
@ -22,7 +22,7 @@
|
||||
%9Examples:%9
|
||||
|
||||
/RECODE
|
||||
/RECODE ADD Freenode/mike utf-8
|
||||
/RECODE ADD liberachat/mike utf-8
|
||||
/RECODE ADD #korea euc-kr
|
||||
/RECODE REMOVE #korea
|
||||
|
||||
|
@ -15,7 +15,7 @@
|
||||
%9Examples:%9
|
||||
|
||||
/RECONNECT
|
||||
/RECONNECT Freenode
|
||||
/RECONNECT liberachat
|
||||
/RECONNECT EFnet BRB :)
|
||||
|
||||
%9See also:%9 CONNECT, DISCONNECT, NETWORK, RMRECONNS, SERVER
|
||||
|
@ -5,7 +5,7 @@
|
||||
|
||||
%9Parameters:%9
|
||||
|
||||
LIST: Displays the list of servers you are connected to.
|
||||
LIST: Displays the list of servers you have configured.
|
||||
CONNECT: Connects to the given server.
|
||||
ADD: Adds a server to your configuration.
|
||||
MODIFY: Modifies a server in your configuration.
|
||||
@ -28,6 +28,8 @@
|
||||
-tls_pinned_pubkey: Pinned public key fingerprint.
|
||||
-auto: Automatically connects to the server on startup.
|
||||
-noauto: Doesn't connect to the server on startup.
|
||||
-cap: Enable CAPREQ for server.
|
||||
-nocap: Disable CAPREQ for server.
|
||||
-network: The network the server belongs to.
|
||||
-host: The hostname you would like to connect from.
|
||||
-cmdspeed: Specifies the minimum amount of time, expressed in
|
||||
@ -51,25 +53,24 @@
|
||||
When using the ADD parameter on a server that already exists, the
|
||||
configuration will be merged with each other.
|
||||
|
||||
When using the command without any of the given parameters, it will
|
||||
connect to the specified server; the server in the active window will be
|
||||
disconnected unless you prepend the server with the '+' character; the same
|
||||
method is applicable to the CONNECT parameter.
|
||||
When using the CONNECT parameter, it will connect to the specified
|
||||
server; the server in the active window will be disconnected
|
||||
unless you prepend the server with the '+' character.
|
||||
|
||||
Specify '-' as password to remove a server password
|
||||
|
||||
%9Examples:%9
|
||||
|
||||
/SERVER
|
||||
/SERVER CONNECT chat.freenode.net
|
||||
/SERVER CONNECT +chat.freenode.net
|
||||
/SERVER ADD -network Freenode -noautosendcmd orwell.freenode.net
|
||||
/SERVER ADD -! -auto -host staff.irssi.org -4 -network Freenode -noproxy orwell.freenode.net 6667
|
||||
/SERVER MODIFY -network Freenode -noauto orwell.freenode.net
|
||||
/SERVER MODIFY -network Freenode orwell.freenode.net 6697 -
|
||||
/SERVER REMOVE orwell.freenode.net 6667 Freenode
|
||||
/SERVER CONNECT irc.libera.chat
|
||||
/SERVER CONNECT +irc.libera.chat
|
||||
/SERVER ADD -network liberachat -noautosendcmd irc.libera.chat
|
||||
/SERVER ADD -! -auto -host staff.irssi.org -4 -network liberachat -noproxy irc.libera.chat 6667
|
||||
/SERVER MODIFY -network liberachat -noauto irc.libera.chat
|
||||
/SERVER MODIFY -network liberachat irc.libera.chat 6697 -
|
||||
/SERVER REMOVE irc.libera.chat 6667 liberachat
|
||||
/SERVER PURGE
|
||||
/SERVER PURGE orwell.freenode.net
|
||||
/SERVER PURGE irc.libera.chat
|
||||
|
||||
%9See also:%9 CHANNEL, CONNECT, DISCONNECT, NETWORK, RECONNECT, RMRECONNS
|
||||
|
||||
|
@ -7,6 +7,7 @@
|
||||
|
||||
-clear: Removes the setting's value from the configuration.
|
||||
-default: Restore the setting to its default value.
|
||||
-section: Print settings under the specified section
|
||||
|
||||
The setting and the value; if no value is given, the list of settings that
|
||||
matched will be returned. If no arguments are given, all the settings will
|
||||
@ -27,6 +28,7 @@
|
||||
/SET -clear nick
|
||||
/SET log_timestamp %%H:%%H:%%S
|
||||
/SET -default log_timestamp
|
||||
/SET -section lookandfeel
|
||||
/SET close
|
||||
|
||||
%9See also:%9 SAVE, TOGGLE
|
||||
|
@ -30,7 +30,9 @@
|
||||
-before: This item is added before the other item.
|
||||
-after: This item is added after the other item.
|
||||
-priority: When the statusbar items overflow, the item with the
|
||||
lowest priority is removed first
|
||||
lowest priority is removed or truncated first.
|
||||
Priority can be negative, in which case it'll have to be
|
||||
quoted (e.g. -priority "-1")
|
||||
-alignment: Display the item on the right side.
|
||||
|
||||
Where statusbar refers to the name of the statusbar; if no argument is
|
||||
|
@ -33,12 +33,12 @@
|
||||
THEME: %|Applies or removes a per-window theme.
|
||||
GROW: %|Increase the size of the active split window by the specified number of lines.
|
||||
SHRINK: %|Decrease the size of the active split window by the specified number of lines.
|
||||
SIZE: %|Set the current split window size to the specified numer of lines.
|
||||
SIZE: %|Set the current split window size to the specified number of lines.
|
||||
BALANCE: %|Balance the heights of all split windows.
|
||||
HIDE: %|Hides the current split window, or the split window specified by number or item name.
|
||||
SHOW: %|Show the window specified by number or item name as a new split windows. It is made sticky when autostick_split_windows is turned on.
|
||||
UP: %|Set the split window left or above the current one active. At the top, wraps to the bottom.
|
||||
DOWN: %|Set the split window right or below the current one active. At the bottom, wraps teft.
|
||||
DOWN: %|Set the split window right or below the current one active. At the bottom, wraps left.
|
||||
LEFT: %|Go to the previous window numerically that is part of the current sticky group (or not part of any sticky group).
|
||||
RIGHT: %|Go to the next window numerically that is part of the current sticky group (or not part of any sticky group).
|
||||
STICK: %|Make the currently active window sticky, or stick the window specified by number to the currently visible split window. Or turn off stickyness of the currently active window or the window specified by number.
|
||||
|
121
docs/help/meson.build
Normal file
121
docs/help/meson.build
Normal file
@ -0,0 +1,121 @@
|
||||
install_data(
|
||||
files(
|
||||
'accept',
|
||||
'action',
|
||||
'admin',
|
||||
'alias',
|
||||
'away',
|
||||
'ban',
|
||||
'beep',
|
||||
'bind',
|
||||
'cat',
|
||||
'cd',
|
||||
'channel',
|
||||
'clear',
|
||||
'completion',
|
||||
'connect',
|
||||
'ctcp',
|
||||
'cycle',
|
||||
'dcc',
|
||||
'dehilight',
|
||||
'deop',
|
||||
'devoice',
|
||||
'die',
|
||||
'disconnect',
|
||||
'echo',
|
||||
'eval',
|
||||
'exec',
|
||||
'flushbuffer',
|
||||
'format',
|
||||
'hash',
|
||||
'help',
|
||||
'hilight',
|
||||
'ignore',
|
||||
'info',
|
||||
'invite',
|
||||
'irssiproxy',
|
||||
'ison',
|
||||
'join',
|
||||
'kick',
|
||||
'kickban',
|
||||
'kill',
|
||||
'knock',
|
||||
'knockout',
|
||||
'lastlog',
|
||||
'layout',
|
||||
'levels',
|
||||
'links',
|
||||
'list',
|
||||
'load',
|
||||
'log',
|
||||
'lusers',
|
||||
'map',
|
||||
'me',
|
||||
'mircdcc',
|
||||
'mode',
|
||||
'motd',
|
||||
'msg',
|
||||
'names',
|
||||
'nctcp',
|
||||
'netsplit',
|
||||
'network',
|
||||
'nick',
|
||||
'notice',
|
||||
'notify',
|
||||
'op',
|
||||
'oper',
|
||||
'otr',
|
||||
'part',
|
||||
'ping',
|
||||
'query',
|
||||
'quit',
|
||||
'quote',
|
||||
'rawlog',
|
||||
'recode',
|
||||
'reconnect',
|
||||
'rehash',
|
||||
'reload',
|
||||
'restart',
|
||||
'rmreconns',
|
||||
'rmrejoins',
|
||||
'save',
|
||||
'sconnect',
|
||||
'script',
|
||||
'scrollback',
|
||||
'server',
|
||||
'servlist',
|
||||
'set',
|
||||
'silence',
|
||||
'squery',
|
||||
'squit',
|
||||
'stats',
|
||||
'statusbar',
|
||||
'time',
|
||||
'toggle',
|
||||
'topic',
|
||||
'trace',
|
||||
'ts',
|
||||
'unalias',
|
||||
'unban',
|
||||
'unignore',
|
||||
'unload',
|
||||
'unnotify',
|
||||
'unquery',
|
||||
'unsilence',
|
||||
'upgrade',
|
||||
'uptime',
|
||||
'userhost',
|
||||
'ver',
|
||||
'version',
|
||||
'voice',
|
||||
'wait',
|
||||
'wall',
|
||||
'wallops',
|
||||
'who',
|
||||
'whois',
|
||||
'whowas',
|
||||
'window',
|
||||
),
|
||||
install_dir : helpdir)
|
||||
|
||||
# subdir('in')
|
@ -349,7 +349,7 @@
|
||||
after connecting to the network. This is useful for automatically
|
||||
identifying yourself to NickServ, for example
|
||||
|
||||
/NETWORK ADD -autosendcmd "/^msg NickServ identify secret" freenode
|
||||
/NETWORK ADD -autosendcmd "/^msg NickServ identify secret" liberachat
|
||||
|
||||
/NETWORK REMOVE <name>
|
||||
|
||||
@ -394,10 +394,26 @@
|
||||
|
||||
5.4 Server settings
|
||||
|
||||
/SERVER ADD [-auto | -noauto] [-network <network>] [-host <hostname>]
|
||||
/SERVER ADD [-tls] [-tls_cert <cert>] [-tls_pkey <pkey>]
|
||||
[-tls_pass <password>] [-tls_verify] [-tls_cafile <cafile>]
|
||||
[-tls_capath <capath>] [-tls_ciphers <list>]
|
||||
[-tls_pinned_cert <fingerprint>] [-tls_pinned_pubkey <fingerprint>]
|
||||
[-auto | -noauto] [-network <network>] [-host <hostname>]
|
||||
[-cmdspeed <ms>] [-cmdmax <count>] [-port <port>]
|
||||
<address> [<port> [<password>]]
|
||||
|
||||
-tls: Connects using TLS encryption.
|
||||
-tls_cert: The TLS client certificate file.
|
||||
-tls_pkey: The TLS client private key, if not included in the
|
||||
certificate file.
|
||||
-tls_pass: The password for the TLS client private key or
|
||||
certificate.
|
||||
-tls_verify: Verifies the TLS certificate of the server.
|
||||
-tls_cafile: The file with the list of CA certificates.
|
||||
-tls_capath: The directory which contains the CA certificates.
|
||||
-tls_ciphers: TLS cipher suite preference lists.
|
||||
-tls_pinned_cert: Pinned x509 certificate fingerprint.
|
||||
-tls_pinned_pubkey: Pinned public key fingerprint.
|
||||
-auto: Automatically connect to server at startup
|
||||
-noauto: Don't connect to server at startup (default)
|
||||
-network: Specify what IRC network this server belongs to
|
||||
|
18
docs/meson.build
Normal file
18
docs/meson.build
Normal file
@ -0,0 +1,18 @@
|
||||
install_data(
|
||||
files(
|
||||
'capsicum.txt',
|
||||
'design.html',
|
||||
'design.txt',
|
||||
'faq.html',
|
||||
'faq.txt',
|
||||
'formats.txt',
|
||||
'manual.txt',
|
||||
'perl.txt',
|
||||
'signals.txt',
|
||||
'special_vars.txt',
|
||||
'startup-HOWTO.html',
|
||||
'startup-HOWTO.txt',
|
||||
),
|
||||
install_dir : docdir)
|
||||
|
||||
subdir('help')
|
@ -178,6 +178,9 @@ listed after the generic ones.
|
||||
Window active_win() - return active window
|
||||
Server active_server() - return server in active window
|
||||
|
||||
get_irssi_dir() - returns the absolute path to the user configuration
|
||||
directory - either the value passed to --home at startup, or ~/.irssi
|
||||
|
||||
windows() - return list of all windows
|
||||
servers() - return list of all servers
|
||||
reconnects() - return list of all server reconnections
|
||||
@ -202,6 +205,12 @@ Window::command(cmd)
|
||||
Windowitem::command(cmd)
|
||||
Send a command `cmd' (in current channel). The '/' char isn't needed.
|
||||
|
||||
version() - return client release date and time (format YYYYMMDD.hhmm)
|
||||
|
||||
parse_special(cmd, data="", flags=0)
|
||||
Server::parse_special(cmd, data="", flags=0)
|
||||
Windowitem::parse_special(cmd, data="", flags=0)
|
||||
evaluate a string with special vars
|
||||
|
||||
*** Themes
|
||||
|
||||
|
@ -24,7 +24,7 @@ You really should set some password for the proxy with:
|
||||
Then you'll need to configure the ports/ircnets the proxy listens in,
|
||||
something like:
|
||||
|
||||
/SET irssiproxy_ports ircnet=2777 efnet=2778 freenode=2779
|
||||
/SET irssiproxy_ports IRCnet=2777 EFNet=2778 liberachat=2779
|
||||
|
||||
There we have 3 different irc networks answering in 3 ports. Note that
|
||||
you'll have to make the correct /IRCNET ADD and /SERVER ADD commands to
|
||||
|
@ -63,6 +63,7 @@ nicklist.c:
|
||||
"nicklist remove", CHANNEL_REC, NICK_REC
|
||||
"nicklist changed", CHANNEL_REC, NICK_REC, char *old_nick
|
||||
"nicklist host changed", CHANNEL_REC, NICK_REC
|
||||
"nicklist account changed", CHANNEL_REC, NICK_REC, char *account
|
||||
"nicklist gone changed", CHANNEL_REC, NICK_REC
|
||||
"nicklist serverop changed", CHANNEL_REC, NICK_REC
|
||||
|
||||
@ -144,11 +145,13 @@ sasl.c
|
||||
irc.c:
|
||||
|
||||
"server event", SERVER_REC, char *data, char *sender_nick, char *sender_address
|
||||
"server event tags", SERVER_REC, char *data, char *sender_nick, char *sender_address, char *tags
|
||||
"event "<cmd>, SERVER_REC, char *args, char *sender_nick, char *sender_address
|
||||
"default event", SERVER_REC, char *data, char *sender_nick, char *sender_address
|
||||
"whois default event", SERVER_REC, char *args, char *sender_nick, char *sender_address
|
||||
|
||||
"server incoming", SERVER_REC, char *data
|
||||
"server outgoing modify", SERVER_REC, GString *data, int crlf
|
||||
|
||||
(for perl parser..)
|
||||
"redir "<cmd>, SERVER_REC, char *args, char *sender_nick, char *sender_address
|
||||
@ -244,12 +247,12 @@ FE common
|
||||
"gui print text", WINDOW_REC, int fg, int bg, int flags, char *text, TEXT_DEST_REC
|
||||
|
||||
(Can be used to determine when all "gui print text"s are sent (not required))
|
||||
"gui print text finished", WINDOW_REC
|
||||
"gui print text finished", WINDOW_REC, TEXT_DEST_REC
|
||||
|
||||
* Provides signals:
|
||||
|
||||
completion.c:
|
||||
"complete word", GList * of char*, WINDOW_REC, char *word, char *linestart, int *want_space
|
||||
"complete word", GList * of char *s, WINDOW_REC, char *word, char *linestart, int *want_space
|
||||
|
||||
fe-common-core.c:
|
||||
"irssi init read settings"
|
||||
@ -264,14 +267,18 @@ fe-messages.c:
|
||||
"message private", SERVER_REC, char *msg, char *nick, char *address, char *target
|
||||
"message own_public", SERVER_REC, char *msg, char *target
|
||||
"message own_private", SERVER_REC, char *msg, char *target, char *orig_target
|
||||
"message join", SERVER_REC, char *channel, char *nick, char *address
|
||||
"message join", SERVER_REC, char *channel, char *nick, char *address, char *account, char *realname
|
||||
"message part", SERVER_REC, char *channel, char *nick, char *address, char *reason
|
||||
"message quit", SERVER_REC, char *nick, char *address, char *reason
|
||||
"message kick", SERVER_REC, char *channel, char *nick, char *kicker, char *address, char *reason
|
||||
"message nick", SERVER_REC, char *newnick, char *oldnick, char *address
|
||||
"message own_nick", SERVER_REC, char *newnick, char *oldnick, char *address
|
||||
"message invite", SERVER_REC, char *channel, char *nick, char *address
|
||||
"message invite_other", SERVER_REC, char *channel, char *invited, char *nick, char *address
|
||||
"message topic", SERVER_REC, char *channel, char *topic, char *nick, char *address
|
||||
"message host_changed", SERVER_REC, char *nick, char *newaddress, char *oldaddress
|
||||
"message account_changed", SERVER_REC, char *nick, char *address, char *account
|
||||
"message away_notify", SERVER_REC, char *nick, char *address, char *awaymsg
|
||||
|
||||
keyboard.c:
|
||||
"keyinfo created", KEYINFO_REC
|
||||
@ -279,6 +286,8 @@ keyboard.c:
|
||||
|
||||
printtext.c:
|
||||
"print text", TEXT_DEST_REC *dest, char *text, char *stripped
|
||||
"print format", THEME_REC *theme, char *module, TEXT_DEST_REC *dest, formatnum_args
|
||||
"print noformat", TEXT_DEST_REC *dest, char *text
|
||||
|
||||
themes.c:
|
||||
"theme created", THEME_REC
|
||||
@ -342,14 +351,18 @@ Text FE
|
||||
|
||||
gui-readline.c:
|
||||
"gui key pressed", int key
|
||||
"paste event", char *paste, char *arg
|
||||
|
||||
gui-printtext.c:
|
||||
"beep"
|
||||
"gui print text after finished", WINDOW_REC, LINE_REC *line, LINE_REC *prev_line
|
||||
"gui print text after finished", WINDOW_REC, LINE_REC *line, LINE_REC *prev_line, TEXT_DEST_REC
|
||||
|
||||
textbuffer-view.c
|
||||
"gui textbuffer line removed", TEXTBUFFER_VIEW_REC *view, LINE_REC *line, LINE_REC *prev_line
|
||||
|
||||
textbuffer-formats.c
|
||||
"gui render line text", TEXT_DEST_REC, GString *str, LINE_INFO_META_REC
|
||||
|
||||
Perl
|
||||
----
|
||||
|
||||
|
@ -94,6 +94,8 @@ $A .. $Z is important.
|
||||
$winname window name
|
||||
$itemname like $T, but use item's visible_name which may be
|
||||
different (eg. $T = !12345chan, $itemname = !chan)
|
||||
$abiversion IRSSI_ABI_VERSION
|
||||
https://github.com/irssi/irssi/wiki/irssi_abi_version
|
||||
|
||||
For example, assume you have the following alias:
|
||||
|
||||
|
@ -1,9 +1,8 @@
|
||||
<base href='https://irssi.org/documentation/startup/'>
|
||||
<h1>Startup How-To</h1>
|
||||
<h3 id="to-new-irssi-users-not-to-new-irc-users-">To new Irssi users (not to new IRC users ..)</h3>
|
||||
|
||||
<h3 id="to-new-irssi-users-not-to-new-irc-users-">To new Irssi users (not to new IRC users ..)</h3>
|
||||
|
||||
<p>Copyright (c) 2000-2002 by Timo Sirainen, release under <a href="http://www.gnu.org/licenses/fdl.html">GNU FDL</a> 1.1 license.</p>
|
||||
<p>Copyright (c) 2000-2002 by Timo Sirainen, release under <a href="https://www.gnu.org/licenses/fdl.html">GNU FDL</a> 1.1 license.</p>
|
||||
|
||||
<p>Index with some FAQ questions that are answered in the chapter:</p>
|
||||
|
||||
@ -69,7 +68,7 @@
|
||||
|
||||
<p>And to connect to one of those networks and join a channel:</p>
|
||||
|
||||
<div><div><pre><code>/CONNECT Freenode
|
||||
<div><div><pre><code>/CONNECT liberachat
|
||||
/JOIN #irssi
|
||||
</code></pre></div></div>
|
||||
|
||||
@ -95,7 +94,7 @@
|
||||
|
||||
<p>If you have irssi 0.8.18 or higher and the irc network supports it, you can use SASL instead of nickserv, which is more reliable:</p>
|
||||
|
||||
<div><div><pre><code>/NETWORK ADD -sasl_username yourname -sasl_password yourpassword -sasl_mechanism PLAIN Freenode
|
||||
<div><div><pre><code>/NETWORK ADD -sasl_username yourname -sasl_password yourpassword -sasl_mechanism PLAIN liberachat
|
||||
</code></pre></div></div>
|
||||
|
||||
<p>These commands have many more options, see their help for details:</p>
|
||||
@ -161,7 +160,7 @@ Ctrl-P, Ctrl-N - Jump to previous / next window
|
||||
|
||||
<h3 id="split-windows-and-window-items">Split windows and window items</h3>
|
||||
|
||||
<p><em>Note: <a href="http://quadpoint.org/articles/irssisplit/">this guide</a> might be a better introduction to window splits</em></p>
|
||||
<p><em>Note: <a href="https://quadpoint.org/articles/irssisplit/">this guide</a> might be a better introduction to window splits</em></p>
|
||||
|
||||
<p>Irssi also supports split windows, they’ve had some problems in past but I think they should work pretty well now :) Here’s some commands related to them:</p>
|
||||
|
||||
@ -227,7 +226,7 @@ Ctrl-P, Ctrl-N - Jump to previous / next window
|
||||
|
||||
<p>And finally channels:</p>
|
||||
|
||||
<div><div><pre><code>/CHANNEL ADD -auto -bots *!*user@host -botcmd "/^msg $0 op pass" #irssi efnet
|
||||
<div><div><pre><code>/CHANNEL ADD -auto -bots *!*bot@host.org -botcmd "/^msg $0 op pass" #irssi efnet
|
||||
/CHANNEL ADD -auto #secret IRCnet password
|
||||
</code></pre></div></div>
|
||||
|
||||
@ -396,7 +395,7 @@ Ctrl-X - set the next server in list active
|
||||
|
||||
<p><code>/HELP bind</code> tells pretty much everything there is to know about keyboard bindings. However, there’s the problem of how to bind some non-standard keys. They might differ a bit with each terminal, so you’ll need to find out what exactly the keypress produces. Easiest way to check that would be to see what it prints in <code>cat</code>. Here’s an example for pressing F1 key:</p>
|
||||
|
||||
<div><div><pre><code> [user@host] ~% cat
|
||||
<div><div><pre><code> [cras@hurina] ~% cat
|
||||
^[OP
|
||||
</code></pre></div></div>
|
||||
|
||||
@ -516,12 +515,12 @@ Ctrl-X - set the next server in list active
|
||||
|
||||
<p><strong>SOCKS</strong></p>
|
||||
|
||||
<p>Irssi can be compiled with socks support (<code>\--with-socks</code> option to configure), which requires “dante” and routes all connections through the proxy specified in the system-wide /etc/socks.conf. This method is known to have issues in Mac OS X.</p>
|
||||
<p>Using <a href="https://github.com/rofl0r/proxychains-ng">proxychains-ng</a> is recommended for using irssi with a socks proxy.</p>
|
||||
|
||||
<p>Irssi does not support socks proxy natively.</p>
|
||||
|
||||
<p>Note that <code>/SET proxy</code> settings don’t have anything to do with socks.</p>
|
||||
|
||||
<p>Using <a href="https://github.com/rofl0r/proxychains-ng">proxychains-ng</a> is recommended over recompiling irssi.</p>
|
||||
|
||||
<p><strong>Others</strong></p>
|
||||
|
||||
<p>IRC bouncers usually work like IRC servers, and want a password. You can give it with:</p>
|
||||
@ -684,4 +683,4 @@ Ctrl-X - set the next server in list active
|
||||
/STATUSBAR <name> REMOVE <item>
|
||||
</code></pre></div></div>
|
||||
|
||||
<p>For statusbar scripts, the item name is usually equivalent to the script name. The documentation of the script ought to tell you if this is not the case. For example, to add mail.pl before the window activity item, use: <code>/STATUSBAR window ADD -before act mail</code>.</p>
|
||||
<p>For statusbar scripts, the item name is usually equivalent to the script name. The documentation of the script ought to tell you if this is not the case. For example, to add mail.pl before the window activity item, use: <code>/STATUSBAR window ADD -before act mail</code>.</p>
|
||||
|
@ -43,7 +43,7 @@ has a few predefined networks, to list them:
|
||||
|
||||
And to connect to one of those networks and join a channel:
|
||||
|
||||
/CONNECT Freenode
|
||||
/CONNECT liberachat
|
||||
/JOIN #irssi
|
||||
|
||||
To add more networks:
|
||||
@ -67,7 +67,7 @@ wait for 2 seconds before joining channels:
|
||||
If you have irssi 0.8.18 or higher and the irc network supports it, you can use
|
||||
SASL instead of nickserv, which is more reliable:
|
||||
|
||||
/NETWORK ADD -sasl_username yourname -sasl_password yourpassword -sasl_mechanism PLAIN Freenode
|
||||
/NETWORK ADD -sasl_username yourname -sasl_password yourpassword -sasl_mechanism PLAIN liberachat
|
||||
|
||||
These commands have many more options, see their help for details:
|
||||
|
||||
@ -218,7 +218,7 @@ IRC network, other servers are automatically connected in same network if the
|
||||
|
||||
And finally channels:
|
||||
|
||||
/CHANNEL ADD -auto -bots *!*user@host -botcmd "/^msg $0 op pass" #irssi efnet
|
||||
/CHANNEL ADD -auto -bots *!*bot@host.org -botcmd "/^msg $0 op pass" #irssi efnet
|
||||
/CHANNEL ADD -auto #secret IRCnet password
|
||||
|
||||
-bots and -botcmd should be the only ones needing a bit of explaining. They’re
|
||||
@ -442,7 +442,7 @@ They might differ a bit with each terminal, so you’ll need to find out what
|
||||
exactly the keypress produces. Easiest way to check that would be to see what
|
||||
it prints in cat. Here’s an example for pressing F1 key:
|
||||
|
||||
[user@host] ~% cat
|
||||
[cras@hurina] ~% cat
|
||||
^[OP
|
||||
|
||||
So in irssi you would use /BIND ^[OP /ECHO F1 pressed. If you use multiple
|
||||
@ -578,15 +578,12 @@ Irssi proxy works fine with other IRC clients as well.
|
||||
|
||||
SOCKS
|
||||
|
||||
Irssi can be compiled with socks support (\--with-socks option to configure),
|
||||
which requires “dante” and routes all connections through the proxy specified
|
||||
in the system-wide /etc/socks.conf. This method is known to have issues in Mac
|
||||
OS X.
|
||||
Using [4]proxychains-ng is recommended for using irssi with a socks proxy.
|
||||
|
||||
Irssi does not support socks proxy natively.
|
||||
|
||||
Note that /SET proxy settings don’t have anything to do with socks.
|
||||
|
||||
Using [4]proxychains-ng is recommended over recompiling irssi.
|
||||
|
||||
Others
|
||||
|
||||
IRC bouncers usually work like IRC servers, and want a password. You can give
|
||||
@ -792,8 +789,8 @@ ADD -before act mail.
|
||||
|
||||
References:
|
||||
|
||||
[1] http://www.gnu.org/licenses/fdl.html
|
||||
[1] https://www.gnu.org/licenses/fdl.html
|
||||
[2] https://www.iterm2.com/
|
||||
[3] http://quadpoint.org/articles/irssisplit/
|
||||
[3] https://quadpoint.org/articles/irssisplit/
|
||||
[4] https://github.com/rofl0r/proxychains-ng
|
||||
[5] https://irssi.org/documentation/settings/
|
||||
|
@ -150,7 +150,7 @@ index ad79e0c..84d0c5c 100644
|
||||
+++ b/src/fe-text/irssi.c
|
||||
@@ -314,20 +314,16 @@ int main(int argc, char **argv)
|
||||
textui_finish_init();
|
||||
main_loop = g_main_new(TRUE);
|
||||
main_loop = g_main_loop_new(NULL, TRUE);
|
||||
|
||||
+#ifdef __AFL_HAVE_MANUAL_CONTROL
|
||||
+ __AFL_INIT();
|
||||
@ -162,7 +162,7 @@ index ad79e0c..84d0c5c 100644
|
||||
can call our dirty-checker after each iteration */
|
||||
while (!quitting) {
|
||||
- term_refresh_freeze();
|
||||
g_main_iteration(TRUE);
|
||||
g_main_context_iteration(NULL, TRUE);
|
||||
- term_refresh_thaw();
|
||||
-
|
||||
- if (reload_config) {
|
||||
@ -174,7 +174,7 @@ index ad79e0c..84d0c5c 100644
|
||||
- dirty_check();
|
||||
}
|
||||
|
||||
g_main_destroy(main_loop);
|
||||
g_main_loop_unref(main_loop);
|
||||
diff --git a/src/fe-text/term-terminfo.c b/src/fe-text/term-terminfo.c
|
||||
index b2478c6..cebe260 100644
|
||||
--- a/src/fe-text/term-terminfo.c
|
||||
|
@ -1,9 +0,0 @@
|
||||
PROG_LIBS="@PROG_LIBS@"
|
||||
COMMON_LIBS="@COMMON_LIBS@"
|
||||
|
||||
PERL_LINK_LIBS="@PERL_LINK_LIBS@"
|
||||
PERL_FE_LINK_LIBS="@PERL_FE_LINK_LIBS@"
|
||||
PERL_LINK_FLAGS="@PERL_LINK_FLAGS@"
|
||||
|
||||
CHAT_MODULES="@CHAT_MODULES@"
|
||||
irc_MODULES="@irc_MODULES@"
|
17
irssi.conf
17
irssi.conf
@ -1,10 +1,10 @@
|
||||
servers = (
|
||||
{ address = "irc.dal.net"; chatnet = "DALnet"; port = "6667"; },
|
||||
{ address = "ssl.efnet.org"; chatnet = "EFNet"; port = "9999"; use_tls = "yes"; },
|
||||
{ address = "ssl.efnet.org"; chatnet = "EFNet"; port = "9999"; use_tls = "yes"; tls_verify = "no"; },
|
||||
{ address = "irc.esper.net"; chatnet = "EsperNet"; port = "6697"; use_tls = "yes"; tls_verify = "yes"; },
|
||||
{ address = "chat.freenode.net"; chatnet = "Freenode"; port = "6697"; use_tls = "yes"; tls_verify = "yes"; },
|
||||
{ address = "irc.libera.chat"; chatnet = "liberachat";port = "6697"; use_tls = "yes"; tls_verify = "yes"; },
|
||||
{ address = "irc.gamesurge.net"; chatnet = "GameSurge"; port = "6667"; },
|
||||
{ address = "eu.irc6.net"; chatnet = "IRCnet"; port = "6667"; use_tls = "yes"; },
|
||||
{ address = "ssl.ircnet.ovh"; chatnet = "IRCnet"; port = "6697"; use_tls = "yes"; tls_verify = "yes"; },
|
||||
{ address = "open.ircnet.net"; chatnet = "IRCnet"; port = "6667"; },
|
||||
{ address = "irc.ircsource.net"; chatnet = "IRCSource"; port = "6667"; },
|
||||
{ address = "irc.netfuze.net"; chatnet = "NetFuze"; port = "6667"; },
|
||||
@ -34,7 +34,7 @@ chatnets = {
|
||||
max_msgs = "4";
|
||||
max_whois = "1";
|
||||
};
|
||||
Freenode = {
|
||||
liberachat = {
|
||||
type = "IRC";
|
||||
max_kicks = "1";
|
||||
max_msgs = "4";
|
||||
@ -95,8 +95,8 @@ chatnets = {
|
||||
|
||||
channels = (
|
||||
{ name = "#lobby"; chatnet = "EsperNet"; autojoin = "No"; },
|
||||
{ name = "#freenode"; chatnet = "Freenode"; autojoin = "No"; },
|
||||
{ name = "#irssi"; chatnet = "Freenode"; autojoin = "No"; },
|
||||
{ name = "#libera"; chatnet = "liberachat";autojoin = "No"; },
|
||||
{ name = "#irssi"; chatnet = "liberachat";autojoin = "No"; },
|
||||
{ name = "#gamesurge"; chatnet = "GameSurge"; autojoin = "No"; },
|
||||
{ name = "#irssi"; chatnet = "IRCNet"; autojoin = "No"; },
|
||||
{ name = "#ircsource"; chatnet = "IRCSource"; autojoin = "No"; },
|
||||
@ -115,6 +115,7 @@ aliases = {
|
||||
C = "CLEAR";
|
||||
CALC = "EXEC - if command -v bc >/dev/null 2>&1\\; then printf '%s=' '$*'\\; echo '$*' | bc -l\\; else echo bc was not found\\; fi";
|
||||
CHAT = "DCC CHAT";
|
||||
CS = "QUOTE CS";
|
||||
DATE = "TIME";
|
||||
DEHIGHLIGHT = "DEHILIGHT";
|
||||
DESCRIBE = "ACTION";
|
||||
@ -133,9 +134,12 @@ aliases = {
|
||||
LAST = "LASTLOG";
|
||||
LEAVE = "PART";
|
||||
M = "MSG";
|
||||
MS = "QUOTE MS";
|
||||
MUB = "UNBAN *";
|
||||
N = "NAMES";
|
||||
NMSG = "^MSG";
|
||||
NS = "QUOTE NS";
|
||||
OS = "QUOTE OS";
|
||||
P = "PART";
|
||||
Q = "QUERY";
|
||||
RESET = "SET -default";
|
||||
@ -143,6 +147,7 @@ aliases = {
|
||||
SAY = "MSG *";
|
||||
SB = "SCROLLBACK";
|
||||
SBAR = "STATUSBAR";
|
||||
SHELP = "QUOTE HELP";
|
||||
SIGNOFF = "QUIT";
|
||||
SV = "MSG * Irssi $J ($V) - https://irssi.org";
|
||||
T = "TOPIC";
|
||||
|
208
m4/glib-2.0.m4
208
m4/glib-2.0.m4
@ -1,208 +0,0 @@
|
||||
# Configure paths for GLIB
|
||||
# Owen Taylor 1997-2001
|
||||
|
||||
dnl AM_PATH_GLIB_2_0([MINIMUM-VERSION, [ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND [, MODULES]]]])
|
||||
dnl Test for GLIB, and define GLIB_CFLAGS and GLIB_LIBS, if gmodule, gobject or
|
||||
dnl gthread is specified in MODULES, pass to pkg-config
|
||||
dnl
|
||||
AC_DEFUN([AM_PATH_GLIB_2_0],
|
||||
[dnl
|
||||
dnl Get the cflags and libraries from pkg-config
|
||||
dnl
|
||||
AC_ARG_ENABLE(glibtest, [ --disable-glibtest do not try to compile and run a test GLIB program],
|
||||
, enable_glibtest=yes)
|
||||
|
||||
pkg_config_args=glib-2.0
|
||||
for module in . $4
|
||||
do
|
||||
case "$module" in
|
||||
gmodule)
|
||||
pkg_config_args="$pkg_config_args gmodule-2.0"
|
||||
;;
|
||||
gmodule-no-export)
|
||||
pkg_config_args="$pkg_config_args gmodule-no-export-2.0"
|
||||
;;
|
||||
gobject)
|
||||
pkg_config_args="$pkg_config_args gobject-2.0"
|
||||
;;
|
||||
gthread)
|
||||
pkg_config_args="$pkg_config_args gthread-2.0"
|
||||
;;
|
||||
esac
|
||||
done
|
||||
|
||||
PKG_PROG_PKG_CONFIG([0.7])
|
||||
|
||||
no_glib=""
|
||||
|
||||
if test "x$PKG_CONFIG" = x ; then
|
||||
no_glib=yes
|
||||
PKG_CONFIG=no
|
||||
fi
|
||||
|
||||
min_glib_version=ifelse([$1], ,2.0.0,$1)
|
||||
AC_MSG_CHECKING(for GLIB - version >= $min_glib_version)
|
||||
|
||||
if test "x$PKG_CONFIG" != xno ; then
|
||||
## don't try to run the test against uninstalled libtool libs
|
||||
if $PKG_CONFIG --uninstalled $pkg_config_args; then
|
||||
echo "Will use uninstalled version of GLib found in PKG_CONFIG_PATH"
|
||||
enable_glibtest=no
|
||||
fi
|
||||
|
||||
if $PKG_CONFIG --atleast-version $min_glib_version $pkg_config_args; then
|
||||
:
|
||||
else
|
||||
no_glib=yes
|
||||
fi
|
||||
fi
|
||||
|
||||
if test x"$no_glib" = x ; then
|
||||
GLIB_GENMARSHAL=`$PKG_CONFIG --variable=glib_genmarshal glib-2.0`
|
||||
GOBJECT_QUERY=`$PKG_CONFIG --variable=gobject_query glib-2.0`
|
||||
GLIB_MKENUMS=`$PKG_CONFIG --variable=glib_mkenums glib-2.0`
|
||||
|
||||
GLIB_CFLAGS=`$PKG_CONFIG --cflags $pkg_config_args`
|
||||
GLIB_LIBS=`$PKG_CONFIG --libs $pkg_config_args`
|
||||
glib_config_major_version=`$PKG_CONFIG --modversion glib-2.0 | \
|
||||
sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\1/'`
|
||||
glib_config_minor_version=`$PKG_CONFIG --modversion glib-2.0 | \
|
||||
sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\2/'`
|
||||
glib_config_micro_version=`$PKG_CONFIG --modversion glib-2.0 | \
|
||||
sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\3/'`
|
||||
if test "x$enable_glibtest" = "xyes" ; then
|
||||
ac_save_CFLAGS="$CFLAGS"
|
||||
ac_save_LIBS="$LIBS"
|
||||
CFLAGS="$CFLAGS $GLIB_CFLAGS"
|
||||
LIBS="$GLIB_LIBS $LIBS"
|
||||
dnl
|
||||
dnl Now check if the installed GLIB is sufficiently new. (Also sanity
|
||||
dnl checks the results of pkg-config to some extent)
|
||||
dnl
|
||||
rm -f conf.glibtest
|
||||
AC_TRY_RUN([
|
||||
#include <glib.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
int
|
||||
main ()
|
||||
{
|
||||
int major, minor, micro;
|
||||
char *tmp_version;
|
||||
|
||||
system ("touch conf.glibtest");
|
||||
|
||||
/* HP/UX 9 (%@#!) writes to sscanf strings */
|
||||
tmp_version = g_strdup("$min_glib_version");
|
||||
if (sscanf(tmp_version, "%d.%d.%d", &major, &minor, µ) != 3) {
|
||||
printf("%s, bad version string\n", "$min_glib_version");
|
||||
exit(1);
|
||||
}
|
||||
|
||||
if ((glib_major_version != $glib_config_major_version) ||
|
||||
(glib_minor_version != $glib_config_minor_version) ||
|
||||
(glib_micro_version != $glib_config_micro_version))
|
||||
{
|
||||
printf("\n*** 'pkg-config --modversion glib-2.0' returned %d.%d.%d, but GLIB (%d.%d.%d)\n",
|
||||
$glib_config_major_version, $glib_config_minor_version, $glib_config_micro_version,
|
||||
glib_major_version, glib_minor_version, glib_micro_version);
|
||||
printf ("*** was found! If pkg-config was correct, then it is best\n");
|
||||
printf ("*** to remove the old version of GLib. You may also be able to fix the error\n");
|
||||
printf("*** by modifying your LD_LIBRARY_PATH enviroment variable, or by editing\n");
|
||||
printf("*** /etc/ld.so.conf. Make sure you have run ldconfig if that is\n");
|
||||
printf("*** required on your system.\n");
|
||||
printf("*** If pkg-config was wrong, set the environment variable PKG_CONFIG_PATH\n");
|
||||
printf("*** to point to the correct configuration files\n");
|
||||
}
|
||||
else if ((glib_major_version != GLIB_MAJOR_VERSION) ||
|
||||
(glib_minor_version != GLIB_MINOR_VERSION) ||
|
||||
(glib_micro_version != GLIB_MICRO_VERSION))
|
||||
{
|
||||
printf("*** GLIB header files (version %d.%d.%d) do not match\n",
|
||||
GLIB_MAJOR_VERSION, GLIB_MINOR_VERSION, GLIB_MICRO_VERSION);
|
||||
printf("*** library (version %d.%d.%d)\n",
|
||||
glib_major_version, glib_minor_version, glib_micro_version);
|
||||
}
|
||||
else
|
||||
{
|
||||
if ((glib_major_version > major) ||
|
||||
((glib_major_version == major) && (glib_minor_version > minor)) ||
|
||||
((glib_major_version == major) && (glib_minor_version == minor) && (glib_micro_version >= micro)))
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
else
|
||||
{
|
||||
printf("\n*** An old version of GLIB (%d.%d.%d) was found.\n",
|
||||
glib_major_version, glib_minor_version, glib_micro_version);
|
||||
printf("*** You need a version of GLIB newer than %d.%d.%d. The latest version of\n",
|
||||
major, minor, micro);
|
||||
printf("*** GLIB is always available from ftp://ftp.gtk.org.\n");
|
||||
printf("***\n");
|
||||
printf("*** If you have already installed a sufficiently new version, this error\n");
|
||||
printf("*** probably means that the wrong copy of the pkg-config shell script is\n");
|
||||
printf("*** being found. The easiest way to fix this is to remove the old version\n");
|
||||
printf("*** of GLIB, but you can also set the PKG_CONFIG environment to point to the\n");
|
||||
printf("*** correct copy of pkg-config. (In this case, you will have to\n");
|
||||
printf("*** modify your LD_LIBRARY_PATH enviroment variable, or edit /etc/ld.so.conf\n");
|
||||
printf("*** so that the correct libraries are found at run-time))\n");
|
||||
}
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
],, no_glib=yes,[echo $ac_n "cross compiling; assumed OK... $ac_c"])
|
||||
CFLAGS="$ac_save_CFLAGS"
|
||||
LIBS="$ac_save_LIBS"
|
||||
fi
|
||||
fi
|
||||
if test "x$no_glib" = x ; then
|
||||
AC_MSG_RESULT(yes (version $glib_config_major_version.$glib_config_minor_version.$glib_config_micro_version))
|
||||
ifelse([$2], , :, [$2])
|
||||
else
|
||||
AC_MSG_RESULT(no)
|
||||
if test "$PKG_CONFIG" = "no" ; then
|
||||
echo "*** A new enough version of pkg-config was not found."
|
||||
echo "*** See http://www.freedesktop.org/software/pkgconfig/"
|
||||
else
|
||||
if test -f conf.glibtest ; then
|
||||
:
|
||||
else
|
||||
echo "*** Could not run GLIB test program, checking why..."
|
||||
ac_save_CFLAGS="$CFLAGS"
|
||||
ac_save_LIBS="$LIBS"
|
||||
CFLAGS="$CFLAGS $GLIB_CFLAGS"
|
||||
LIBS="$LIBS $GLIB_LIBS"
|
||||
AC_TRY_LINK([
|
||||
#include <glib.h>
|
||||
#include <stdio.h>
|
||||
], [ return ((glib_major_version) || (glib_minor_version) || (glib_micro_version)); ],
|
||||
[ echo "*** The test program compiled, but did not run. This usually means"
|
||||
echo "*** that the run-time linker is not finding GLIB or finding the wrong"
|
||||
echo "*** version of GLIB. If it is not finding GLIB, you'll need to set your"
|
||||
echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point"
|
||||
echo "*** to the installed location Also, make sure you have run ldconfig if that"
|
||||
echo "*** is required on your system"
|
||||
echo "***"
|
||||
echo "*** If you have an old version installed, it is best to remove it, although"
|
||||
echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH" ],
|
||||
[ echo "*** The test program failed to compile or link. See the file config.log for the"
|
||||
echo "*** exact error that occurred. This usually means GLIB is incorrectly installed."])
|
||||
CFLAGS="$ac_save_CFLAGS"
|
||||
LIBS="$ac_save_LIBS"
|
||||
fi
|
||||
fi
|
||||
GLIB_CFLAGS=""
|
||||
GLIB_LIBS=""
|
||||
GLIB_GENMARSHAL=""
|
||||
GOBJECT_QUERY=""
|
||||
GLIB_MKENUMS=""
|
||||
ifelse([$3], , :, [$3])
|
||||
fi
|
||||
AC_SUBST(GLIB_CFLAGS)
|
||||
AC_SUBST(GLIB_LIBS)
|
||||
AC_SUBST(GLIB_GENMARSHAL)
|
||||
AC_SUBST(GOBJECT_QUERY)
|
||||
AC_SUBST(GLIB_MKENUMS)
|
||||
rm -f conf.glibtest
|
||||
])
|
@ -1,28 +0,0 @@
|
||||
dnl GLIB_TESTS
|
||||
dnl
|
||||
|
||||
AC_DEFUN([GLIB_TESTS],
|
||||
[
|
||||
AC_ARG_ENABLE(installed-tests,
|
||||
AS_HELP_STRING([--enable-installed-tests],
|
||||
[Enable installation of some test cases]),
|
||||
[case ${enableval} in
|
||||
yes) ENABLE_INSTALLED_TESTS="1" ;;
|
||||
no) ENABLE_INSTALLED_TESTS="" ;;
|
||||
*) AC_MSG_ERROR([bad value ${enableval} for --enable-installed-tests]) ;;
|
||||
esac])
|
||||
AM_CONDITIONAL([ENABLE_INSTALLED_TESTS], test "$ENABLE_INSTALLED_TESTS" = "1")
|
||||
AC_ARG_ENABLE(always-build-tests,
|
||||
AS_HELP_STRING([--enable-always-build-tests],
|
||||
[Enable always building tests during 'make all']),
|
||||
[case ${enableval} in
|
||||
yes) ENABLE_ALWAYS_BUILD_TESTS="1" ;;
|
||||
no) ENABLE_ALWAYS_BUILD_TESTS="" ;;
|
||||
*) AC_MSG_ERROR([bad value ${enableval} for --enable-always-build-tests]) ;;
|
||||
esac])
|
||||
AM_CONDITIONAL([ENABLE_ALWAYS_BUILD_TESTS], test "$ENABLE_ALWAYS_BUILD_TESTS" = "1")
|
||||
if test "$ENABLE_INSTALLED_TESTS" = "1"; then
|
||||
AC_SUBST(installed_test_metadir, [${datadir}/installed-tests/]AC_PACKAGE_NAME)
|
||||
AC_SUBST(installed_testdir, [${libexecdir}/installed-tests/]AC_PACKAGE_NAME)
|
||||
fi
|
||||
])
|
143
m4/libgcrypt.m4
143
m4/libgcrypt.m4
@ -1,143 +0,0 @@
|
||||
# libgcrypt.m4 - Autoconf macros to detect libgcrypt
|
||||
# Copyright (C) 2002, 2003, 2004, 2011, 2014 g10 Code GmbH
|
||||
#
|
||||
# This file is free software; as a special exception the author gives
|
||||
# unlimited permission to copy and/or distribute it, with or without
|
||||
# modifications, as long as this notice is preserved.
|
||||
#
|
||||
# This file is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY, to the extent permitted by law; without even the
|
||||
# implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
#
|
||||
# Last-changed: 2014-10-02
|
||||
|
||||
|
||||
dnl AM_PATH_LIBGCRYPT([MINIMUM-VERSION,
|
||||
dnl [ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND ]]])
|
||||
dnl Test for libgcrypt and define LIBGCRYPT_CFLAGS and LIBGCRYPT_LIBS.
|
||||
dnl MINIMUN-VERSION is a string with the version number optionalliy prefixed
|
||||
dnl with the API version to also check the API compatibility. Example:
|
||||
dnl a MINIMUN-VERSION of 1:1.2.5 won't pass the test unless the installed
|
||||
dnl version of libgcrypt is at least 1.2.5 *and* the API number is 1. Using
|
||||
dnl this features allows to prevent build against newer versions of libgcrypt
|
||||
dnl with a changed API.
|
||||
dnl
|
||||
dnl If a prefix option is not used, the config script is first
|
||||
dnl searched in $SYSROOT/bin and then along $PATH. If the used
|
||||
dnl config script does not match the host specification the script
|
||||
dnl is added to the gpg_config_script_warn variable.
|
||||
dnl
|
||||
AC_DEFUN([AM_PATH_LIBGCRYPT],
|
||||
[ AC_REQUIRE([AC_CANONICAL_HOST])
|
||||
AC_ARG_WITH(libgcrypt-prefix,
|
||||
AC_HELP_STRING([--with-libgcrypt-prefix=PFX],
|
||||
[prefix where LIBGCRYPT is installed (optional)]),
|
||||
libgcrypt_config_prefix="$withval", libgcrypt_config_prefix="")
|
||||
if test x"${LIBGCRYPT_CONFIG}" = x ; then
|
||||
if test x"${libgcrypt_config_prefix}" != x ; then
|
||||
LIBGCRYPT_CONFIG="${libgcrypt_config_prefix}/bin/libgcrypt-config"
|
||||
else
|
||||
case "${SYSROOT}" in
|
||||
/*)
|
||||
if test -x "${SYSROOT}/bin/libgcrypt-config" ; then
|
||||
LIBGCRYPT_CONFIG="${SYSROOT}/bin/libgcrypt-config"
|
||||
fi
|
||||
;;
|
||||
'')
|
||||
;;
|
||||
*)
|
||||
AC_MSG_WARN([Ignoring \$SYSROOT as it is not an absolute path.])
|
||||
;;
|
||||
esac
|
||||
fi
|
||||
fi
|
||||
|
||||
AC_PATH_PROG(LIBGCRYPT_CONFIG, libgcrypt-config, no)
|
||||
tmp=ifelse([$1], ,1:1.2.0,$1)
|
||||
if echo "$tmp" | grep ':' >/dev/null 2>/dev/null ; then
|
||||
req_libgcrypt_api=`echo "$tmp" | sed 's/\(.*\):\(.*\)/\1/'`
|
||||
min_libgcrypt_version=`echo "$tmp" | sed 's/\(.*\):\(.*\)/\2/'`
|
||||
else
|
||||
req_libgcrypt_api=0
|
||||
min_libgcrypt_version="$tmp"
|
||||
fi
|
||||
|
||||
AC_MSG_CHECKING(for LIBGCRYPT - version >= $min_libgcrypt_version)
|
||||
ok=no
|
||||
if test "$LIBGCRYPT_CONFIG" != "no" ; then
|
||||
req_major=`echo $min_libgcrypt_version | \
|
||||
sed 's/\([[0-9]]*\)\.\([[0-9]]*\)\.\([[0-9]]*\)/\1/'`
|
||||
req_minor=`echo $min_libgcrypt_version | \
|
||||
sed 's/\([[0-9]]*\)\.\([[0-9]]*\)\.\([[0-9]]*\)/\2/'`
|
||||
req_micro=`echo $min_libgcrypt_version | \
|
||||
sed 's/\([[0-9]]*\)\.\([[0-9]]*\)\.\([[0-9]]*\)/\3/'`
|
||||
libgcrypt_config_version=`$LIBGCRYPT_CONFIG --version`
|
||||
major=`echo $libgcrypt_config_version | \
|
||||
sed 's/\([[0-9]]*\)\.\([[0-9]]*\)\.\([[0-9]]*\).*/\1/'`
|
||||
minor=`echo $libgcrypt_config_version | \
|
||||
sed 's/\([[0-9]]*\)\.\([[0-9]]*\)\.\([[0-9]]*\).*/\2/'`
|
||||
micro=`echo $libgcrypt_config_version | \
|
||||
sed 's/\([[0-9]]*\)\.\([[0-9]]*\)\.\([[0-9]]*\).*/\3/'`
|
||||
if test "$major" -gt "$req_major"; then
|
||||
ok=yes
|
||||
else
|
||||
if test "$major" -eq "$req_major"; then
|
||||
if test "$minor" -gt "$req_minor"; then
|
||||
ok=yes
|
||||
else
|
||||
if test "$minor" -eq "$req_minor"; then
|
||||
if test "$micro" -ge "$req_micro"; then
|
||||
ok=yes
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
if test $ok = yes; then
|
||||
AC_MSG_RESULT([yes ($libgcrypt_config_version)])
|
||||
else
|
||||
AC_MSG_RESULT(no)
|
||||
fi
|
||||
if test $ok = yes; then
|
||||
# If we have a recent libgcrypt, we should also check that the
|
||||
# API is compatible
|
||||
if test "$req_libgcrypt_api" -gt 0 ; then
|
||||
tmp=`$LIBGCRYPT_CONFIG --api-version 2>/dev/null || echo 0`
|
||||
if test "$tmp" -gt 0 ; then
|
||||
AC_MSG_CHECKING([LIBGCRYPT API version])
|
||||
if test "$req_libgcrypt_api" -eq "$tmp" ; then
|
||||
AC_MSG_RESULT([okay])
|
||||
else
|
||||
ok=no
|
||||
AC_MSG_RESULT([does not match. want=$req_libgcrypt_api got=$tmp])
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
if test $ok = yes; then
|
||||
LIBGCRYPT_CFLAGS=`$LIBGCRYPT_CONFIG --cflags`
|
||||
LIBGCRYPT_LIBS=`$LIBGCRYPT_CONFIG --libs`
|
||||
ifelse([$2], , :, [$2])
|
||||
libgcrypt_config_host=`$LIBGCRYPT_CONFIG --host 2>/dev/null || echo none`
|
||||
if test x"$libgcrypt_config_host" != xnone ; then
|
||||
if test x"$libgcrypt_config_host" != x"$host" ; then
|
||||
AC_MSG_WARN([[
|
||||
***
|
||||
*** The config script $LIBGCRYPT_CONFIG was
|
||||
*** built for $libgcrypt_config_host and thus may not match the
|
||||
*** used host $host.
|
||||
*** You may want to use the configure option --with-libgcrypt-prefix
|
||||
*** to specify a matching config script or use \$SYSROOT.
|
||||
***]])
|
||||
gpg_config_script_warn="$gpg_config_script_warn libgcrypt"
|
||||
fi
|
||||
fi
|
||||
else
|
||||
LIBGCRYPT_CFLAGS=""
|
||||
LIBGCRYPT_LIBS=""
|
||||
ifelse([$3], , :, [$3])
|
||||
fi
|
||||
AC_SUBST(LIBGCRYPT_CFLAGS)
|
||||
AC_SUBST(LIBGCRYPT_LIBS)
|
||||
])
|
134
m4/libotr.m4
134
m4/libotr.m4
@ -1,134 +0,0 @@
|
||||
dnl
|
||||
dnl Off-the-Record Messaging library
|
||||
dnl Copyright (C) 2004-2007 Ian Goldberg, Chris Alexander, Nikita Borisov
|
||||
dnl <otr@cypherpunks.ca>
|
||||
dnl
|
||||
dnl This library is free software; you can redistribute it and/or
|
||||
dnl modify it under the terms of version 2.1 of the GNU Lesser General
|
||||
dnl Public License as published by the Free Software Foundation.
|
||||
dnl
|
||||
dnl This library is distributed in the hope that it will be useful,
|
||||
dnl but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
dnl Lesser General Public License for more details.
|
||||
dnl
|
||||
dnl You should have received a copy of the GNU Lesser General Public
|
||||
dnl License along with this library; if not, write to the Free Software
|
||||
dnl Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
dnl
|
||||
|
||||
dnl AM_PATH_LIBOTR([MINIMUM-VERSION [, ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND]]])
|
||||
dnl Test for libotr, and define LIBOTR_CFLAGS and LIBOTR_LIBS as appropriate.
|
||||
dnl enables arguments --with-libotr-prefix=
|
||||
dnl --with-libotr-inc-prefix=
|
||||
dnl
|
||||
dnl You must already have found libgcrypt with AM_PATH_LIBGCRYPT
|
||||
dnl
|
||||
dnl Adapted from alsa.m4, originally by
|
||||
dnl Richard Boulton <richard-alsa@tartarus.org>
|
||||
dnl Christopher Lansdown <lansdoct@cs.alfred.edu>
|
||||
dnl Jaroslav Kysela <perex@suse.cz>
|
||||
|
||||
AC_DEFUN([AM_PATH_LIBOTR],
|
||||
[dnl Save the original CFLAGS, LDFLAGS, and LIBS
|
||||
libotr_save_CFLAGS="$CFLAGS"
|
||||
libotr_save_LDFLAGS="$LDFLAGS"
|
||||
libotr_save_LIBS="$LIBS"
|
||||
libotr_found=yes
|
||||
|
||||
dnl
|
||||
dnl Get the cflags and libraries for libotr
|
||||
dnl
|
||||
AC_ARG_WITH(libotr-prefix,
|
||||
[ --with-libotr-prefix=PFX Prefix where libotr is installed(optional)],
|
||||
[libotr_prefix="$withval"], [libotr_prefix=""])
|
||||
|
||||
AC_ARG_WITH(libotr-inc-prefix,
|
||||
[ --with-libotr-inc-prefix=PFX Prefix where libotr includes are (optional)],
|
||||
[libotr_inc_prefix="$withval"], [libotr_inc_prefix=""])
|
||||
|
||||
dnl Add any special include directories
|
||||
AC_MSG_CHECKING(for libotr CFLAGS)
|
||||
if test "$libotr_inc_prefix" != "" ; then
|
||||
LIBOTR_CFLAGS="$LIBOTR_CFLAGS -I$libotr_inc_prefix"
|
||||
CFLAGS="$CFLAGS $LIBOTR_CFLAGS"
|
||||
fi
|
||||
AC_MSG_RESULT($LIBOTR_CFLAGS)
|
||||
|
||||
dnl add any special lib dirs
|
||||
AC_MSG_CHECKING(for libotr LIBS)
|
||||
if test "$libotr_prefix" != "" ; then
|
||||
LIBOTR_LIBS="$LIBOTR_LIBS -L$libotr_prefix"
|
||||
LDFLAGS="$LDFLAGS $LIBOTR_LIBS"
|
||||
fi
|
||||
|
||||
dnl add the libotr library
|
||||
LIBOTR_LIBS="$LIBOTR_LIBS -lotr"
|
||||
LIBS="$LIBOTR_LIBS $LIBS"
|
||||
AC_MSG_RESULT($LIBOTR_LIBS)
|
||||
|
||||
dnl Check for a working version of libotr that is of the right version.
|
||||
min_libotr_version=ifelse([$1], ,3.0.0,$1)
|
||||
no_libotr=""
|
||||
libotr_min_major_version=`echo $min_libotr_version | \
|
||||
sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\1/'`
|
||||
libotr_min_minor_version=`echo $min_libotr_version | \
|
||||
sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\2/'`
|
||||
libotr_min_sub_version=`echo $min_libotr_version | \
|
||||
sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\3/'`
|
||||
AC_MSG_CHECKING(for libotr headers version $libotr_min_major_version.x >= $min_libotr_version)
|
||||
|
||||
AC_LANG_SAVE
|
||||
AC_LANG_C
|
||||
AC_TRY_COMPILE([
|
||||
#include <stdlib.h>
|
||||
#include <libotr/version.h>
|
||||
], [
|
||||
# if(OTRL_VERSION_MAJOR != $libotr_min_major_version)
|
||||
# error not present
|
||||
# else
|
||||
|
||||
# if(OTRL_VERSION_MINOR > $libotr_min_minor_version)
|
||||
exit(0);
|
||||
# else
|
||||
# if(OTRL_VERSION_MINOR < $libotr_min_minor_version)
|
||||
# error not present
|
||||
# endif
|
||||
|
||||
# if(OTRL_VERSION_SUB < $libotr_min_sub_version)
|
||||
# error not present
|
||||
# endif
|
||||
# endif
|
||||
# endif
|
||||
exit(0);
|
||||
],
|
||||
[AC_MSG_RESULT(found.)],
|
||||
[AC_MSG_RESULT(not present.)
|
||||
ifelse([$3], , [AC_MSG_ERROR(Sufficiently new version of libotr not found.)])
|
||||
libotr_found=no]
|
||||
)
|
||||
AC_LANG_RESTORE
|
||||
|
||||
dnl Now that we know that we have the right version, let's see if we have the library and not just the headers.
|
||||
AC_CHECK_LIB([otr], [otrl_message_receiving],,
|
||||
[ifelse([$3], , [AC_MSG_ERROR(No linkable libotr was found.)])
|
||||
libotr_found=no],
|
||||
$LIBGCRYPT_LIBS
|
||||
)
|
||||
|
||||
LDFLAGS="$libotr_save_LDFLAGS"
|
||||
LIBS="$libotr_save_LIBS"
|
||||
|
||||
if test "x$libotr_found" = "xyes" ; then
|
||||
ifelse([$2], , :, [$2])
|
||||
else
|
||||
LIBOTR_CFLAGS=""
|
||||
LIBOTR_LIBS=""
|
||||
ifelse([$3], , :, [$3])
|
||||
fi
|
||||
|
||||
dnl That should be it. Now just export our symbols:
|
||||
AC_SUBST(LIBOTR_CFLAGS)
|
||||
AC_SUBST(LIBOTR_LIBS)
|
||||
])
|
||||
|
648
meson.build
Normal file
648
meson.build
Normal file
@ -0,0 +1,648 @@
|
||||
project('irssi', 'c',
|
||||
version : '1.5-head',
|
||||
meson_version : '>=0.53',
|
||||
default_options : ['warning_level=1'])
|
||||
|
||||
############################
|
||||
############################
|
||||
|
||||
glib_internal_version = 'glib-2.58.3' # keep this in sync with subprojects/glib.wrap
|
||||
cc = meson.get_compiler('c')
|
||||
rootinc = include_directories('.')
|
||||
dep = []
|
||||
textui_dep = []
|
||||
need_dl_cross_link = false
|
||||
# The Android environment requires that all modules are linked to each other.
|
||||
# See https://github.com/android/ndk/issues/201
|
||||
if host_machine.system() == 'android'
|
||||
need_dl_cross_link = true
|
||||
endif
|
||||
|
||||
includedir = get_option('includedir')
|
||||
incdir = 'irssi'
|
||||
moduledir = get_option('libdir') / incdir / 'modules'
|
||||
helpdir = get_option('datadir') / incdir / 'help'
|
||||
themedir = get_option('datadir') / incdir / 'themes'
|
||||
scriptdir = get_option('datadir') / incdir / 'scripts'
|
||||
docdir = get_option('docdir') != '' ? get_option('docdir') : (get_option('datadir') / 'doc' / incdir)
|
||||
|
||||
want_textui = get_option('without-textui') != 'yes'
|
||||
want_bot = get_option('with-bot') == 'yes'
|
||||
want_fuzzer = get_option('with-fuzzer') == 'yes'
|
||||
fuzzer_lib = get_option('with-fuzzer-lib')
|
||||
fuzzer_link_language = get_option('fuzzer-link-language')
|
||||
want_proxy = get_option('with-proxy') == 'yes'
|
||||
|
||||
require_capsicum = get_option('with-capsicum') == 'yes'
|
||||
want_capsicum = get_option('with-capsicum') != 'no'
|
||||
|
||||
require_libutf8proc = get_option('disable-utf8proc') == 'no'
|
||||
want_libutf8proc = get_option('disable-utf8proc') != 'yes'
|
||||
|
||||
require_perl = get_option('with-perl') == 'yes'
|
||||
want_perl = get_option('with-perl') != 'no'
|
||||
with_perl_lib = get_option('with-perl-lib')
|
||||
|
||||
require_otr = get_option('with-otr') == 'yes'
|
||||
want_otr = get_option('with-otr') != 'no'
|
||||
|
||||
want_glib_internal = get_option('install-glib') != 'no'
|
||||
require_glib_internal = get_option('install-glib') == 'force'
|
||||
|
||||
want_static_dependency = get_option('static-dependency') == 'yes'
|
||||
|
||||
package_version = get_option('PACKAGE_VERSION') != '' ? get_option('PACKAGE_VERSION') : meson.project_version()
|
||||
|
||||
fs = import('fs')
|
||||
if fs.exists('config.status') or fs.exists('irssi-version.h') or fs.exists('default-config.h') or fs.exists('default-theme.h') or fs.exists('src/perl/irssi-core.pl.h') or fs.exists('src/perl/perl-signals-list.h') or fs.exists('irssi-config.h')
|
||||
error('this tree has been configured with autotools, cannot proceed')
|
||||
endif
|
||||
|
||||
UNSET = '=INVALID='
|
||||
UNSET_ARR = [UNSET]
|
||||
|
||||
chat_modules = ['irc']
|
||||
|
||||
run_command('mkdir', meson.current_build_dir() / incdir, check : false)
|
||||
run_command('ln', '-s', meson.current_source_dir() / 'src', meson.current_build_dir() / incdir, check : false)
|
||||
run_command('ln', '-s', meson.current_build_dir() / 'irssi-config.h', meson.current_build_dir() / incdir, check : false)
|
||||
run_command('ln', '-s', meson.current_build_dir() / 'irssi-version.h', meson.current_build_dir() / incdir, check : false)
|
||||
|
||||
def_moduledir = '-D' + 'MODULEDIR' + '="' + (get_option('prefix') / moduledir) + '"'
|
||||
def_sysconfdir = '-D' + 'SYSCONFDIR' + '="' + (get_option('prefix') / get_option('sysconfdir')) + '"'
|
||||
def_helpdir = '-D' + 'HELPDIR' + '="' + (get_option('prefix') / helpdir) + '"'
|
||||
def_themesdir = '-D' + 'THEMESDIR' + '="' + (get_option('prefix') / themedir) + '"'
|
||||
def_scriptdir = '-D' + 'SCRIPTDIR' + '="' + (get_option('prefix') / scriptdir) + '"'
|
||||
|
||||
def_suppress_printf_fallback = '-D' + 'SUPPRESS_PRINTF_FALLBACK'
|
||||
|
||||
##############
|
||||
# Help files #
|
||||
##############
|
||||
|
||||
build_perl = find_program('perl', native : true)
|
||||
if meson.is_cross_build()
|
||||
cross_perl = find_program('perl')
|
||||
else
|
||||
cross_perl = build_perl
|
||||
endif
|
||||
run_command(build_perl, files('utils/syntax.pl'), check : true)
|
||||
|
||||
###################
|
||||
# irssi-version.h #
|
||||
###################
|
||||
|
||||
env = find_program('env')
|
||||
irssi_version_sh = find_program('utils/irssi-version.sh')
|
||||
irssi_version_h = custom_target('irssi-version.h',
|
||||
build_by_default : true,
|
||||
build_always_stale : true,
|
||||
capture : true,
|
||||
command : [env, 'VERSION=' + meson.project_version(),
|
||||
irssi_version_sh, meson.current_source_dir()],
|
||||
output : 'irssi-version.h',
|
||||
install : true,
|
||||
install_dir : includedir / incdir,
|
||||
)
|
||||
|
||||
####################
|
||||
# default-config.h #
|
||||
####################
|
||||
|
||||
file2header = find_program('utils/file2header.sh')
|
||||
default_config_h = custom_target('default-config.h',
|
||||
input : files('irssi.conf'),
|
||||
output : 'default-config.h',
|
||||
capture : true,
|
||||
command : [file2header, '@INPUT@', 'default_config'],
|
||||
)
|
||||
|
||||
###################
|
||||
# default-theme.h #
|
||||
###################
|
||||
|
||||
default_theme_h = custom_target('default-theme.h',
|
||||
input : files('themes/default.theme'),
|
||||
output : 'default-theme.h',
|
||||
capture : true,
|
||||
command : [file2header, '@INPUT@', 'default_theme'],
|
||||
)
|
||||
|
||||
################
|
||||
# Dependencies #
|
||||
################
|
||||
|
||||
#### inet_addr ####
|
||||
inet_addr_found = false
|
||||
foreach inet_addr_provider : ['', 'nsl']
|
||||
prov_lib = []
|
||||
if inet_addr_provider != ''
|
||||
prov_lib += cc.find_library(inet_addr_provider, required : false)
|
||||
endif
|
||||
if (prov_lib.length() == 0 or prov_lib[0].found()) and cc.has_function('inet_addr', dependencies : prov_lib)
|
||||
dep += prov_lib
|
||||
inet_addr_found = true
|
||||
break
|
||||
endif
|
||||
endforeach
|
||||
if not inet_addr_found
|
||||
error('inet_addr not found')
|
||||
endif
|
||||
|
||||
#### socket ####
|
||||
socket_found = false
|
||||
foreach socket_provider : ['', 'socket', 'network']
|
||||
prov_lib = []
|
||||
if socket_provider != ''
|
||||
prov_lib += cc.find_library(socket_provider, required : false)
|
||||
endif
|
||||
if (prov_lib.length() == 0 or prov_lib[0].found()) and cc.has_function('socket', dependencies : prov_lib)
|
||||
dep += prov_lib
|
||||
socket_found = true
|
||||
break
|
||||
endif
|
||||
endforeach
|
||||
if not socket_found
|
||||
error('socket not found')
|
||||
endif
|
||||
|
||||
built_src = []
|
||||
glib_internal = false
|
||||
message('*** If you don\'t have GLib, you can run meson ... -Dinstall-glib=yes')
|
||||
message('*** to download and build it automatically')
|
||||
message('*** Or alternatively install your distribution\'s package')
|
||||
message('*** On Debian: sudo apt-get install libglib2.0-dev')
|
||||
message('*** On Redhat: dnf install glib2-devel')
|
||||
if not require_glib_internal
|
||||
glib_dep = dependency('glib-2.0', version : '>=2.32', required : not want_glib_internal, static : want_static_dependency, include_type : 'system')
|
||||
else
|
||||
glib_dep = dependency('', required : false)
|
||||
endif
|
||||
if not glib_dep.found()
|
||||
glib_internal = true
|
||||
meson_cmd = find_program('meson')
|
||||
ninja = find_program('ninja')
|
||||
|
||||
glib_internal_download_t = custom_target('glib-internal-download',
|
||||
command : [ meson_cmd, 'subprojects', 'download', 'glib', '--sourcedir', meson.current_source_dir() ],
|
||||
console : true,
|
||||
output : ['glib-internal-download'],
|
||||
)
|
||||
|
||||
glib_internal_dependencies = [
|
||||
dependency('threads'),
|
||||
]
|
||||
glib_internal_configure_args = []
|
||||
|
||||
glib_internal_usr_local = false
|
||||
if not cc.has_function('iconv_open')
|
||||
prov_lib = cc.find_library('iconv', required : false)
|
||||
if not prov_lib.found()
|
||||
prov_lib = cc.find_library('iconv', dirs : '/usr/local/lib')
|
||||
glib_internal_usr_local = true
|
||||
endif
|
||||
if cc.has_function('libiconv_open', dependencies : prov_lib)
|
||||
glib_internal_configure_args += '-Diconv=gnu'
|
||||
else
|
||||
glib_internal_configure_args += '-Diconv=native'
|
||||
endif
|
||||
glib_internal_dependencies += prov_lib
|
||||
endif
|
||||
|
||||
if not cc.has_function('ngettext')
|
||||
prov_lib = cc.find_library('intl', required : false)
|
||||
if not prov_lib.found()
|
||||
prov_lib = cc.find_library('intl', dirs : '/usr/local/lib')
|
||||
glib_internal_usr_local = true
|
||||
endif
|
||||
glib_internal_dependencies += prov_lib
|
||||
endif
|
||||
|
||||
if glib_internal_usr_local
|
||||
glib_internal_configure_args += ['-Dc_args=-I/usr/local/include', '-Dc_link_args=-L/usr/local/lib']
|
||||
endif
|
||||
|
||||
if not cc.has_function('getxattr') or not cc.has_header('sys/xattr.h')
|
||||
if cc.has_header_symbol('attr/xattr.h', 'getxattr')
|
||||
prov_lib = cc.find_library('xattr', required : false)
|
||||
else
|
||||
prov_lib = dependency('', required : false)
|
||||
endif
|
||||
if prov_lib.found()
|
||||
glib_internal_dependencies += prov_lib
|
||||
else
|
||||
glib_internal_configure_args += '-Dxattr=false'
|
||||
endif
|
||||
endif
|
||||
|
||||
glib_internal_configure_t = custom_target('glib-internal-configure',
|
||||
command : [ meson_cmd, 'setup', '--prefix=/irssi-glib-internal',
|
||||
'--buildtype=' + get_option('buildtype'),
|
||||
'-Dlibmount=false', '-Dselinux=false', '-Ddefault_library=static', '-Dinternal_pcre=true',
|
||||
glib_internal_configure_args,
|
||||
(meson.current_build_dir() / 'build-subprojects' / 'glib'),
|
||||
(meson.current_source_dir() / 'subprojects' / glib_internal_version) ],
|
||||
console : true,
|
||||
output : ['glib-internal-configure'],
|
||||
depends : glib_internal_download_t,)
|
||||
glib_internal_build_t = custom_target('glib-internal-build',
|
||||
command : [ ninja, '-C', meson.current_build_dir() / 'build-subprojects' / 'glib',
|
||||
'glib' / 'libglib-2.0.a',
|
||||
'gmodule' / 'libgmodule-2.0.a'],
|
||||
console : true,
|
||||
output : ['glib-internal-build'],
|
||||
depends : glib_internal_configure_t,)
|
||||
glib_dep = declare_dependency(
|
||||
dependencies : glib_internal_dependencies,
|
||||
sources : glib_internal_build_t,
|
||||
compile_args : [
|
||||
'-isystem' + (meson.current_source_dir() / 'subprojects' / glib_internal_version / 'glib'),
|
||||
'-isystem' + (meson.current_source_dir() / 'subprojects' / glib_internal_version),
|
||||
'-isystem' + (meson.current_build_dir() / 'build-subprojects' / 'glib' / 'glib'),
|
||||
],
|
||||
link_args : [ meson.current_build_dir() / 'build-subprojects' / 'glib' / 'glib' / 'libglib-2.0.a' ],
|
||||
)
|
||||
built_src += glib_internal_build_t
|
||||
libdl_dep = []
|
||||
prov_lib = cc.find_library('dl', required : false)
|
||||
if prov_lib.found() and cc.has_function('dlopen', dependencies : prov_lib)
|
||||
libdl_dep += prov_lib
|
||||
endif
|
||||
gmodule_dep = declare_dependency(sources : glib_internal_build_t,
|
||||
dependencies : libdl_dep,
|
||||
compile_args : [
|
||||
'-isystem' + (meson.current_source_dir() / 'subprojects' / glib_internal_version / 'gmodule'),
|
||||
],
|
||||
link_args : [ meson.current_build_dir() / 'build-subprojects' / 'glib' / 'gmodule' / 'libgmodule-2.0.a' ],
|
||||
)
|
||||
else
|
||||
gmodule_dep = dependency('gmodule-2.0', static : want_static_dependency, include_type : 'system')
|
||||
endif
|
||||
dep += glib_dep
|
||||
dep += gmodule_dep
|
||||
|
||||
if glib_internal and want_static_dependency and want_fuzzer
|
||||
openssl_proj = subproject('openssl', default_options : ['default_library=static', 'asm=disabled'])
|
||||
openssl_dep = openssl_proj.get_variable('openssl_dep')
|
||||
else
|
||||
openssl_dep = dependency('openssl', static : want_static_dependency, include_type : 'system')
|
||||
endif
|
||||
dep += openssl_dep
|
||||
|
||||
############
|
||||
# utf8proc #
|
||||
############
|
||||
|
||||
have_libutf8proc = false
|
||||
libutf8proc = []
|
||||
if want_libutf8proc
|
||||
libutf8proc = cc.find_library('utf8proc', required : require_libutf8proc)
|
||||
have_libutf8proc = cc.has_function('utf8proc_version', dependencies : libutf8proc)
|
||||
if have_libutf8proc
|
||||
dep += libutf8proc
|
||||
endif
|
||||
endif
|
||||
|
||||
############################
|
||||
############################
|
||||
|
||||
############
|
||||
# terminfo #
|
||||
############
|
||||
|
||||
if want_textui
|
||||
setupterm_found = false
|
||||
foreach setupterm_provider : ['tinfo', 'ncursesw', 'ncurses', 'terminfo']
|
||||
prov_lib = cc.find_library(setupterm_provider, required : false)
|
||||
if prov_lib.found() and cc.has_function('setupterm', dependencies : prov_lib)
|
||||
textui_dep += prov_lib
|
||||
setupterm_found = true
|
||||
break
|
||||
endif
|
||||
endforeach
|
||||
if not setupterm_found
|
||||
error('Terminfo not found')
|
||||
endif
|
||||
endif
|
||||
|
||||
########
|
||||
# perl #
|
||||
########
|
||||
|
||||
have_perl = false
|
||||
if want_perl
|
||||
perl_cflags = []
|
||||
perl_ldflags = []
|
||||
perl_rpath_flags = []
|
||||
perl_rpath = ''
|
||||
|
||||
#### ccopts ####
|
||||
perl_ccopts = meson.get_cross_property('perl_ccopts', UNSET_ARR)
|
||||
if perl_ccopts == UNSET_ARR
|
||||
res = run_command(cross_perl, '-MExtUtils::Embed', '-e', 'ccopts', check : true)
|
||||
perl_ccopts = res.stdout().strip().split()
|
||||
endif
|
||||
foreach fl : perl_ccopts
|
||||
if fl.startswith('-D') or fl.startswith('-U') or fl.startswith('-I') or fl.startswith('-i') or fl.startswith('-f') or fl.startswith('-m')
|
||||
if fl.startswith('-I')
|
||||
fl = '-isystem' + fl.split('-I')[1]
|
||||
endif
|
||||
perl_cflags += fl
|
||||
endif
|
||||
endforeach
|
||||
|
||||
perl_cflags += cc.get_supported_arguments('-fPIC')
|
||||
|
||||
#### ldopts ####
|
||||
perl_ldopts = meson.get_cross_property('perl_ldopts', UNSET_ARR)
|
||||
if perl_ldopts == UNSET_ARR
|
||||
res = run_command(cross_perl, '-MExtUtils::Embed', '-e', 'ldopts', check : true)
|
||||
perl_ldopts = res.stdout().strip().split()
|
||||
endif
|
||||
skip_libs = ['-ldb', '-ldbm', '-lndbm', '-lgdbm', '-lc', '-lposix', '-rdynamic']
|
||||
foreach fl : perl_ldopts
|
||||
if not fl.startswith('-A') and not skip_libs.contains(fl)
|
||||
if fl.startswith('-Wl,-rpath,')
|
||||
perl_rpath = fl.split(',')[2]
|
||||
perl_rpath_flags += fl
|
||||
else
|
||||
perl_ldflags += fl
|
||||
endif
|
||||
endif
|
||||
endforeach
|
||||
|
||||
perl_version = meson.get_cross_property('perl_version', UNSET)
|
||||
if perl_version == UNSET
|
||||
perl_version = run_command(cross_perl, '-V::version:', check : true).stdout().split('\'')[1]
|
||||
endif
|
||||
perl_dep = declare_dependency(compile_args : perl_cflags, link_args : perl_ldflags,
|
||||
version : perl_version)
|
||||
|
||||
####
|
||||
if not cc.links('''
|
||||
#include <EXTERN.h>
|
||||
#include <perl.h>
|
||||
int main()
|
||||
{
|
||||
perl_alloc();
|
||||
return 0;
|
||||
}
|
||||
''', args : perl_cflags + perl_ldflags + perl_rpath_flags,
|
||||
name : 'working Perl support')
|
||||
if require_perl
|
||||
error('error linking with perl libraries')
|
||||
else
|
||||
warning('error linking with perl libraries')
|
||||
endif
|
||||
else
|
||||
xsubpp_file_c = meson.get_cross_property('perl_xsubpp', UNSET)
|
||||
if xsubpp_file_c == UNSET
|
||||
xsubpp_file_c = run_command(build_perl, '-MExtUtils::ParseXS', '-Eprint $INC{"ExtUtils/ParseXS.pm"} =~ s{ParseXS\\.pm$}{xsubpp}r', check : true).stdout()
|
||||
endif
|
||||
xsubpp = generator(build_perl,
|
||||
output : '@BASENAME@.c',
|
||||
capture : true,
|
||||
arguments : [ xsubpp_file_c, '@EXTRA_ARGS@', '@INPUT@' ],
|
||||
)
|
||||
xsubpp_file = files(xsubpp_file_c)
|
||||
|
||||
if with_perl_lib == 'module'
|
||||
perl_install_base = run_command(build_perl, '-MText::ParseWords=shellwords', '-e', 'grep { s/^INSTALL_BASE=// && print && exit } shellwords $ENV{PERL_MM_OPT}', check : true).stdout()
|
||||
if perl_install_base == ''
|
||||
with_perl_lib = ''
|
||||
endif
|
||||
endif
|
||||
if with_perl_lib == ''
|
||||
if get_option('prefix') in ['/usr/local', 'C:/']
|
||||
with_perl_lib = 'site'
|
||||
elif get_option('prefix') in ['/usr']
|
||||
with_perl_lib = 'vendor'
|
||||
endif
|
||||
endif
|
||||
perlmoddir = ''
|
||||
if with_perl_lib in ['site', 'vendor', 'module']
|
||||
set_perl_use_lib = false
|
||||
perl_library_dir = with_perl_lib + ' default'
|
||||
if with_perl_lib in ['site', 'vendor']
|
||||
perlmoddir = meson.get_cross_property('perl_install' + with_perl_lib + 'arch', UNSET)
|
||||
if perlmoddir == UNSET
|
||||
perlmoddir = run_command(cross_perl, '-V::install' + with_perl_lib + 'arch:', check : true).stdout().split('\'')[1]
|
||||
endif
|
||||
elif with_perl_lib == 'module'
|
||||
perl_archname = meson.get_cross_property('perl_archname', UNSET)
|
||||
if perl_archname == UNSET
|
||||
perl_archname = run_command(cross_perl, '-V::archname:', check : true).stdout().split('\'')[1]
|
||||
endif
|
||||
perlmoddir = perl_install_base / 'lib' / 'perl5' / perl_archname
|
||||
endif
|
||||
elif with_perl_lib == ''
|
||||
set_perl_use_lib = true
|
||||
perl_library_dir = 'in prefix'
|
||||
perlmoddir = get_option('libdir') / incdir / 'perl'
|
||||
elif with_perl_lib.startswith('/')
|
||||
set_perl_use_lib = true
|
||||
perl_library_dir = 'custom'
|
||||
perlmoddir = with_perl_lib
|
||||
endif
|
||||
if perlmoddir == ''
|
||||
error('Unrecognised with-perl-lib value: ' + with_perl_lib)
|
||||
endif
|
||||
|
||||
perl_use_lib = get_option('prefix') / perlmoddir
|
||||
if set_perl_use_lib
|
||||
perl_inc = meson.get_cross_property('perl_inc', UNSET_ARR)
|
||||
if perl_inc == UNSET_ARR
|
||||
set_perl_use_lib = run_command(cross_perl, '-e', 'exit ! grep $_ eq $ARGV[0], grep /^\\//, @INC', perl_use_lib, check : false).returncode() != 0
|
||||
else
|
||||
set_perl_use_lib = not perl_inc.contains(perl_use_lib)
|
||||
endif
|
||||
if not set_perl_use_lib
|
||||
perl_library_dir += ' - other path in @INC'
|
||||
else
|
||||
perl_library_dir += ' - prepends to @INC with /set perl_use_lib'
|
||||
endif
|
||||
endif
|
||||
def_perl_use_lib = '-D' + 'PERL_USE_LIB' + '="'
|
||||
if set_perl_use_lib
|
||||
def_perl_use_lib += perl_use_lib
|
||||
endif
|
||||
def_perl_use_lib += '"'
|
||||
|
||||
have_perl = true
|
||||
endif
|
||||
endif
|
||||
|
||||
#######
|
||||
# OTR #
|
||||
#######
|
||||
|
||||
have_otr = false
|
||||
if want_otr
|
||||
libgcrypt = dependency('libgcrypt', version : '>=1.2.0', required : require_otr, static : want_static_dependency, include_type : 'system')
|
||||
libotr = dependency('libotr', version : '>=4.1.0', required : require_otr, static : want_static_dependency, include_type : 'system')
|
||||
if libgcrypt.found() and libotr.found()
|
||||
dep += libgcrypt
|
||||
dep += libotr
|
||||
have_otr = true
|
||||
endif
|
||||
endif
|
||||
|
||||
############
|
||||
# capsicum #
|
||||
############
|
||||
|
||||
have_capsicum = false
|
||||
if want_capsicum
|
||||
if cc.has_function('cap_enter', dependencies : cc.find_library('c'))
|
||||
libnv = cc.find_library('nv', required : require_capsicum)
|
||||
nvlist_create_found = libnv.found() and cc.has_function('nvlist_create', dependencies : libnv, prefix : '#include <sys/nv.h>')
|
||||
if nvlist_create_found
|
||||
dep += libnv
|
||||
have_capsicum = true
|
||||
else
|
||||
if require_capsicum
|
||||
error('nvlist_create not found')
|
||||
endif
|
||||
endif
|
||||
else
|
||||
if require_capsicum
|
||||
error('cap_enter not found')
|
||||
endif
|
||||
endif
|
||||
endif
|
||||
|
||||
# dependency helper sets
|
||||
dep_cflagsonly = []
|
||||
foreach d : dep
|
||||
dep_cflagsonly += d.partial_dependency(includes : true, compile_args : true)
|
||||
endforeach
|
||||
dl_cross_dep = []
|
||||
if need_dl_cross_link
|
||||
dl_cross_dep = dep
|
||||
endif
|
||||
|
||||
##################
|
||||
# irssi-config.h #
|
||||
##################
|
||||
|
||||
conf = configuration_data()
|
||||
|
||||
conf.set('HAVE_CAPSICUM', have_capsicum, description : 'Build with Capsicum support')
|
||||
conf.set('HAVE_GMODULE', true)
|
||||
conf.set('TERM_TRUECOLOR', true)
|
||||
conf.set('USE_GREGEX', true)
|
||||
conf.set10('_DARWIN_USE_64_BIT_INODE', true, description : 'Enable large inode numbers on Mac OS X 10.5.')
|
||||
conf.set_quoted('FHS_PREFIX', get_option('fhs-prefix'))
|
||||
|
||||
headers = [
|
||||
'sys/ioctl.h',
|
||||
'sys/resource.h',
|
||||
'sys/time.h',
|
||||
'sys/utsname.h',
|
||||
'dirent.h',
|
||||
'term.h',
|
||||
'unistd.h',
|
||||
]
|
||||
foreach h : headers
|
||||
if cc.has_header(h)
|
||||
conf.set('HAVE_' + h.underscorify().to_upper(), 1, description : 'Define to 1 if you have the <' + h + '> header file.')
|
||||
endif
|
||||
endforeach
|
||||
|
||||
conf.set('HAVE_LIBUTF8PROC', have_libutf8proc)
|
||||
conf.set_quoted('PACKAGE_VERSION', package_version)
|
||||
conf.set_quoted('PACKAGE_TARNAME', meson.project_name())
|
||||
|
||||
configure_file(output : 'irssi-config.h',
|
||||
configuration : conf,
|
||||
install_dir : includedir / incdir)
|
||||
|
||||
##########
|
||||
# CFLAGS #
|
||||
##########
|
||||
|
||||
#### warnings ####
|
||||
add_project_arguments(cc.get_supported_arguments('-Werror=declaration-after-statement'), language : 'c')
|
||||
|
||||
#### personality ####
|
||||
add_project_arguments(cc.get_supported_arguments('-fno-strict-aliasing'), language : 'c')
|
||||
if get_option('buildtype').contains('debug')
|
||||
add_project_arguments(cc.get_supported_arguments('-fno-omit-frame-pointer'), language : 'c')
|
||||
endif
|
||||
|
||||
if want_fuzzer
|
||||
if fuzzer_lib.startswith('-fsanitize=fuzzer')
|
||||
if not cc.has_argument('-fsanitize=fuzzer-no-link')
|
||||
error('compiler does not support -fsanitize=fuzzer-no-link, try clang?')
|
||||
endif
|
||||
add_project_arguments('-fsanitize=fuzzer-no-link', language : 'c')
|
||||
endif
|
||||
if fuzzer_link_language != 'c'
|
||||
add_languages(fuzzer_link_language)
|
||||
endif
|
||||
endif
|
||||
|
||||
##############
|
||||
# irssi-1.pc #
|
||||
##############
|
||||
|
||||
pc = import('pkgconfig')
|
||||
pc_requires = []
|
||||
if not glib_internal
|
||||
pc_requires += glib_dep
|
||||
endif
|
||||
pc.generate(filebase : 'irssi-1',
|
||||
name : 'Irssi',
|
||||
description : 'Irssi chat client',
|
||||
version : package_version,
|
||||
requires : pc_requires,
|
||||
variables : ['irssimoduledir=${libdir}' / incdir / 'modules'])
|
||||
|
||||
###########
|
||||
# irssi.1 #
|
||||
###########
|
||||
|
||||
install_man('docs/irssi.1')
|
||||
|
||||
###########
|
||||
# subdirs #
|
||||
###########
|
||||
|
||||
subdir('src')
|
||||
subdir('tests')
|
||||
subdir('docs')
|
||||
subdir('scripts')
|
||||
subdir('themes')
|
||||
# subdir('utils')
|
||||
|
||||
############################
|
||||
############################
|
||||
|
||||
message('*** Irssi configured ***')
|
||||
message('')
|
||||
message('Building text frontend ........... : ' + want_textui.to_string('yes', 'no'))
|
||||
message('Building irssi bot ............... : ' + want_bot.to_string('yes', 'no'))
|
||||
message('Building irssi proxy ............. : ' + want_proxy.to_string('yes', 'no'))
|
||||
if want_perl and not have_perl
|
||||
message('Building with Perl support ....... : NO!')
|
||||
message(' - Try: sudo apt-get install libperl-dev')
|
||||
message(' - Or: dnf install perl-devel')
|
||||
else
|
||||
message('Building with Perl support ....... : ' + have_perl.to_string('yes', 'no'))
|
||||
endif
|
||||
if have_perl
|
||||
message('Perl library directory ........... : ' + perl_use_lib)
|
||||
message(' ' + perl_library_dir)
|
||||
endif
|
||||
message('Install prefix ................... : ' + get_option('prefix'))
|
||||
message('')
|
||||
message('Building with Capsicum ........... : ' + have_capsicum.to_string('yes', 'no'))
|
||||
message('Building with utf8proc ........... : ' + have_libutf8proc.to_string('yes', 'no'))
|
||||
message('Building with OTR support ........ : ' + have_otr.to_string('yes', 'no'))
|
||||
message('')
|
||||
message('If there are any problems, read the INSTALL file.')
|
||||
message('Now type ninja -C ' + meson.current_build_dir() + ' to build Irssi')
|
||||
message('')
|
||||
|
||||
############################
|
||||
############################
|
16
meson_options.txt
Normal file
16
meson_options.txt
Normal file
@ -0,0 +1,16 @@
|
||||
option('without-textui', type : 'combo', description : 'Build without text frontend', choices : ['no', 'yes'])
|
||||
option('with-bot', type : 'combo', description : 'Build irssi-bot', choices : ['no', 'yes'])
|
||||
option('with-fuzzer', type : 'combo', description : 'Build irssi-fuzzer', choices : ['no', 'yes'])
|
||||
option('with-fuzzer-lib', type : 'string', description : 'Specify path to fuzzer library', value : '-fsanitize=fuzzer')
|
||||
option('fuzzer-link-language', type : 'string', description : 'The linker to use for the fuzz targets [c, cpp]', value : 'c')
|
||||
option('with-proxy', type : 'combo', description : 'Build irssi-proxy', choices : ['no', 'yes'])
|
||||
option('with-perl-lib', type : 'string', description : 'Specify where to install the Perl libraries for Irssi')
|
||||
option('with-perl', type : 'combo', description : 'Build with Perl support', choices : ['auto', 'yes', 'no'])
|
||||
option('with-otr', type : 'combo', description : 'Build with OTR support', choices : ['auto', 'yes', 'no'])
|
||||
option('disable-utf8proc', type : 'combo', description : 'Build without Julia\'s utf8proc', choices : ['auto', 'yes', 'no'])
|
||||
option('with-capsicum', type : 'combo', description : 'Build with Capsicum support', choices : ['auto', 'yes', 'no'])
|
||||
option('static-dependency', type : 'combo', description : 'Request static dependencies', choices : ['no', 'yes'])
|
||||
option('install-glib', type : 'combo', description : 'Download and install GLib for you', choices : ['no', 'yes', 'force'])
|
||||
option('docdir', type : 'string', description : 'Documentation directory')
|
||||
option('fhs-prefix', type : 'string', description : 'System prefix for Termux')
|
||||
option('PACKAGE_VERSION', type : 'string', description : 'Override PACKAGE_VERSION in tarballs')
|
16
redhat/.rpmmacros
Normal file
16
redhat/.rpmmacros
Normal file
@ -0,0 +1,16 @@
|
||||
%_topdir %(echo $HOME)/rpmbuild
|
||||
%_smp_mflags -j3
|
||||
#%__arch_install_post /usr/lib/rpm/check-rpaths /usr/lib/rpm/check-buildroot
|
||||
%dist .psychotic
|
||||
%_dist .psychotic
|
||||
%releasetagsuffix psychotic
|
||||
%_vendor psychotic
|
||||
%vendor psychotic
|
||||
%_host_vendor %{_vendor}
|
||||
%_packager Psychotic Build System <builder@psychotic.ninja>
|
||||
%packager Psychotic Build System <builder@psychotic.ninja>
|
||||
%_signature gpg
|
||||
%_gpg_name Psychotic Build System
|
||||
%_binary_filedigest_algorithm 1
|
||||
%_source_filedigest_algorithm 1
|
||||
%_binary_payload w9.gzdio
|
160
redhat/irssi.spec
Normal file
160
redhat/irssi.spec
Normal file
@ -0,0 +1,160 @@
|
||||
%define perl_vendorarch %(eval "`perl -V:installvendorarch`"; echo $installvendorarch)
|
||||
|
||||
Summary: Modular text mode IRC client with Perl scripting
|
||||
Name: irssi
|
||||
Version: 1.4.3
|
||||
Release: 0%{?dist}
|
||||
|
||||
License: GPLv2+
|
||||
Group: Applications/Communications
|
||||
URL: http://irssi.org/
|
||||
#Source0: http://irssi.org/files/irssi-%{version}.tar.gz
|
||||
Source0: https://github.com/irssi/irssi/releases/download/%{version}/irssi-%{version}.tar.gz
|
||||
Source1: irssi-config.h
|
||||
#Patch0: 00-freenode-to-libera.patch
|
||||
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-buildroot
|
||||
BuildRequires: ncurses-devel openssl-devel zlib-devel
|
||||
BuildRequires: pkgconfig glib2-devel perl-devel perl(ExtUtils::Embed)
|
||||
BuildRequires: autoconf automake libtool
|
||||
Requires: perl(:MODULE_COMPAT_%(eval "`%{__perl} -V:version`"; echo $version))
|
||||
|
||||
%package devel
|
||||
Summary: Development package for irssi
|
||||
Group: Development/Libraries
|
||||
Requires: %{name} = %{version}-%{release}
|
||||
|
||||
%description
|
||||
Irssi is a modular IRC client with Perl scripting. Only text-mode
|
||||
frontend is currently supported. The GTK/GNOME frontend is no longer
|
||||
being maintained.
|
||||
|
||||
%description devel
|
||||
This package contains headers needed to develop irssi plugins.
|
||||
|
||||
Irssi is a modular IRC client with Perl scripting. Only text-mode
|
||||
frontend is currently supported. The GTK/GNOME frontend is no longer
|
||||
being maintained.
|
||||
|
||||
|
||||
%prep
|
||||
%setup -q
|
||||
#%patch0 -p1
|
||||
|
||||
%build
|
||||
autoreconf -i
|
||||
# --with-bot \
|
||||
%configure --enable-ipv6 --with-textui \
|
||||
--with-proxy \
|
||||
--with-perl=yes \
|
||||
--with-perl-lib=vendor \
|
||||
--enable-true-color
|
||||
|
||||
make %{_smp_mflags} CFLAGS="$RPM_OPT_FLAGS -fno-strict-aliasing"
|
||||
mv irssi-config.h irssi-config-$(getconf LONG_BIT).h
|
||||
cp -p %{SOURCE1} irssi-config.h
|
||||
|
||||
|
||||
%install
|
||||
rm -rf $RPM_BUILD_ROOT
|
||||
%makeinstall PERL_INSTALL_ROOT=$RPM_BUILD_ROOT INSTALL="%{__install} -p"
|
||||
install -p irssi-config-$(getconf LONG_BIT).h $RPM_BUILD_ROOT%{_includedir}/%{name}/irssi-config-$(getconf LONG_BIT).h
|
||||
|
||||
rm -f $RPM_BUILD_ROOT%{_libdir}/%{name}/modules/lib*.*a
|
||||
rm -Rf $RPM_BUILD_ROOT/%{_docdir}/%{name}
|
||||
find $RPM_BUILD_ROOT%{perl_vendorarch} -type f -a -name '*.bs' -a -empty -exec rm -f {} ';'
|
||||
find $RPM_BUILD_ROOT%{perl_vendorarch} -type f -a -name .packlist -exec rm {} ';'
|
||||
chmod -R u+w $RPM_BUILD_ROOT%{perl_vendorarch}
|
||||
|
||||
|
||||
%clean
|
||||
rm -rf $RPM_BUILD_ROOT
|
||||
|
||||
|
||||
%files
|
||||
%defattr(-,root,root,-)
|
||||
%doc docs/*.txt docs/*.html AUTHORS COPYING NEWS README.md TODO
|
||||
%config(noreplace) %{_sysconfdir}/%{name}.conf
|
||||
%{_bindir}/%{name}
|
||||
#%{_bindir}/botti
|
||||
%{_datadir}/%{name}
|
||||
%{_libdir}/%{name}
|
||||
%{_libdir}/pkgconfig/irssi-1.pc
|
||||
%{_mandir}/man1/%{name}.1*
|
||||
%{perl_vendorarch}/Irssi*
|
||||
%{perl_vendorarch}/auto/Irssi
|
||||
|
||||
|
||||
%files devel
|
||||
%defattr(-,root,root,-)
|
||||
%{_includedir}/irssi/
|
||||
|
||||
|
||||
%changelog
|
||||
* Wed Nov 09 2022 Psychotic Build System <builder@psychotic.ninja> - 1.4.3-0
|
||||
- Upgrade to upstream 1.4.3
|
||||
|
||||
* Wed Jul 13 2022 Psychotic Build System <builder@psychotic.ninja> - 1.4.2-0
|
||||
- Update to upstreram 1.4.2
|
||||
|
||||
* Sat Jun 11 2022 Psychotic Build System <builder@psychotic.ninja> - 1.4.1-0
|
||||
- Upgrade to upstream 1.4.1
|
||||
|
||||
* Tue Jun 15 2021 Psychotic Build System <builder@psychotic.ninja> - 1.2.3-2
|
||||
- Change references of freenode to libera
|
||||
|
||||
* Fri Jun 04 2021 Psychotic Build System <builder@psychotic.ninja> - 1.2.3-1
|
||||
- Updated to upstream 1.2.3
|
||||
|
||||
* Fri Nov 01 2019 Psychotic Build System <builder@psychotic.ninja> - 1.2.2-1
|
||||
- Upgrade to upstream 1.2.2 which is stability and security update addressing
|
||||
CVE-2019-15717 (Use after free when receiving duplicate CAP)
|
||||
|
||||
* Mon Jul 01 2019 Psychotic Build System <builder@psychotic.ninja> - 1.2.1-1
|
||||
- Upgrade to upstream 1.2.1
|
||||
|
||||
* Mon Jul 01 2019 Psychotic Build System <builder@psychotic.ninja> - 1.1.3-1
|
||||
- Upgrade to upstream 1.1.3 which is a stability and security update addressing
|
||||
CVE-2019-13045 (use after free if SASL is enabled)
|
||||
|
||||
* Mon Jan 14 2019 Psychotic Build System <builder@psychotic.ninja> - 1.1.2-1
|
||||
- Upgrade to upstream 1.1.2 which is a stability and security update addressing
|
||||
CVE-2019-5882 (use-after-free).
|
||||
|
||||
* Fri Mar 09 2018 Psychotic Build System <builder@psychotic.ninja> - 1.1.1-2
|
||||
- Bump to upstream 1.1.1
|
||||
|
||||
* Fri Jan 19 2018 Psychotic Build System <builder@psychotic.ninja> - 1.1.0-2
|
||||
- Upgraded to upstream 1.1.0. Sourced from GhettoForge
|
||||
|
||||
* Tue Jan 16 2018 Bryan Seitz <seitz@ghettoforge.org> - 1.1.0-1
|
||||
- New upstream version 1.1.0
|
||||
|
||||
* Sat Jan 06 2018 Bryan Seitz <seitz@ghettoforge.org> - 1.0.6-1
|
||||
- New upstream version 1.0.6
|
||||
|
||||
* Mon Oct 23 2017 Bryan Seitz <seitz@ghettoforge.org> - 1.0.5-1
|
||||
- New upstream version 1.0.5
|
||||
|
||||
* Sat Jul 08 2017 Bryan Seitz <seitz@ghettoforge.org> - 1.0.4-1
|
||||
- New upstream version 1.0.4
|
||||
|
||||
* Sun Mar 19 2017 Psychotic Build System <builder@psychotic.ninja> - 1.0.2-1
|
||||
- Updated to upstream 1.0.2
|
||||
|
||||
* Fri Mar 17 2017 Psychotic Build System <builder@psychotic.ninja> - 1.0.1-2
|
||||
- Initial build for Psychotic Ninja; sourced from GhettoForge
|
||||
|
||||
* Mon Feb 06 2017 Bryan Seitz <seitz@ghettoforge.org> - 1.0.1-1
|
||||
- New upstream version 1.0.1
|
||||
|
||||
* Tue Jan 10 2017 Bryan Seitz <seitz@ghettoforge.org> - 1.0.0-1
|
||||
- New upstream version 1.0.0
|
||||
|
||||
* Fri Sep 23 2016 Bryan Seitz <seitz@ghettoforge.org> - 0.8.20-1
|
||||
- New upstream version 0.8.20
|
||||
|
||||
* Fri May 06 2016 Bryan Seitz <seitz@ghettoforge.org> - 0.8.19-1
|
||||
- New upstream version 0.8.19
|
||||
|
||||
* Mon May 11 2015 Bryan Seitz <seitz@ghettoforge.org> - 0.8.17-2
|
||||
- Import into GhettoForge
|
@ -1,17 +0,0 @@
|
||||
SUBDIRS = examples
|
||||
|
||||
scriptdir = $(datadir)/irssi/scripts
|
||||
|
||||
script_DATA = \
|
||||
autoop.pl \
|
||||
autorejoin.pl \
|
||||
buf.pl \
|
||||
dns.pl \
|
||||
kills.pl \
|
||||
mail.pl \
|
||||
mlock.pl \
|
||||
quitmsg.pl \
|
||||
scriptassist.pl \
|
||||
usercount.pl
|
||||
|
||||
EXTRA_DIST = $(script_DATA)
|
@ -1,8 +0,0 @@
|
||||
scriptdir = $(datadir)/irssi/scripts
|
||||
|
||||
script_DATA = \
|
||||
command.pl \
|
||||
msg-event.pl \
|
||||
redirect.pl
|
||||
|
||||
EXTRA_DIST = $(script_DATA)
|
14
scripts/meson.build
Normal file
14
scripts/meson.build
Normal file
@ -0,0 +1,14 @@
|
||||
install_data(
|
||||
files(
|
||||
'autoop.pl',
|
||||
'autorejoin.pl',
|
||||
'buf.pl',
|
||||
'dns.pl',
|
||||
'kills.pl',
|
||||
'mail.pl',
|
||||
'mlock.pl',
|
||||
'quitmsg.pl',
|
||||
'scriptassist.pl',
|
||||
'usercount.pl',
|
||||
),
|
||||
install_dir : scriptdir)
|
@ -6,36 +6,27 @@ use Irssi::Irc;
|
||||
use strict;
|
||||
use vars qw($VERSION %IRSSI);
|
||||
|
||||
$VERSION = "1.00";
|
||||
$VERSION = "1.01";
|
||||
%IRSSI = (
|
||||
authors => 'Timo Sirainen',
|
||||
name => 'quitmsg',
|
||||
description => 'Random quit messages',
|
||||
license => 'Public Domain',
|
||||
changed => 'Sun Mar 10 23:18 EET 2002'
|
||||
changed => 'Mon Jul 22 20:00 EET 2020'
|
||||
);
|
||||
|
||||
my $quitfile = glob "~/.irssi/irssi.quit";
|
||||
my $quitfile = Irssi::get_irssi_dir() . "/irssi.quit";
|
||||
|
||||
sub cmd_quit {
|
||||
my ($data, $server, $channel) = @_;
|
||||
return if ($data ne "");
|
||||
|
||||
open (my $fh, "<", $quitfile) || return;
|
||||
my @lines = <$fh>;
|
||||
|
||||
open (f, "<", $quitfile) || return;
|
||||
my $lines = 0; while(<f>) { $lines++; };
|
||||
|
||||
my $line = int(rand($lines))+1;
|
||||
|
||||
my $quitmsg;
|
||||
seek(f, 0, 0); $. = 0;
|
||||
while(<f>) {
|
||||
next if ($. != $line);
|
||||
|
||||
chomp;
|
||||
$quitmsg = $_;
|
||||
last;
|
||||
}
|
||||
close(f);
|
||||
my $quitmsg = $lines[int(rand(@lines))];
|
||||
chomp($quitmsg);
|
||||
close($fh);
|
||||
|
||||
foreach my $server (Irssi::servers) {
|
||||
$server->command("/disconnect ".$server->{tag}." $quitmsg");
|
||||
|
@ -5,30 +5,33 @@
|
||||
|
||||
use strict;
|
||||
|
||||
our $VERSION = '2003020806';
|
||||
our $VERSION = '2022053100';
|
||||
our %IRSSI = (
|
||||
authors => 'Stefan \'tommie\' Tomanek',
|
||||
contact => 'stefan@pico.ruhr.de',
|
||||
name => 'scriptassist',
|
||||
description => 'keeps your scripts on the cutting edge',
|
||||
license => 'GPLv2',
|
||||
url => 'http://irssi.org/scripts/',
|
||||
modules => 'Data::Dumper LWP::UserAgent (GnuPG)',
|
||||
url => 'https://scripts.irssi.org/',
|
||||
modules => 'CPAN::Meta::YAML LWP::Protocol::https (GnuPG)',
|
||||
commands => "scriptassist"
|
||||
);
|
||||
|
||||
our ($forked, %remote_db, $have_gpg, @complist);
|
||||
|
||||
use Irssi 20020324;
|
||||
use Data::Dumper;
|
||||
use CPAN::Meta::YAML;
|
||||
use LWP::UserAgent;
|
||||
use POSIX;
|
||||
use version;
|
||||
|
||||
# GnuPG is not always needed
|
||||
$have_gpg = 0;
|
||||
eval "use GnuPG qw(:algo :trust);";
|
||||
$have_gpg = 1 if not ($@);
|
||||
|
||||
my $irssi_version = qv('v'.Irssi::parse_special('$J') =~ s/[^.\d].*//r);
|
||||
|
||||
sub show_help {
|
||||
my $help = "scriptassist $VERSION
|
||||
/scriptassist check
|
||||
@ -39,15 +42,15 @@ sub show_help {
|
||||
Search the script database
|
||||
/scriptassist info <scripts>
|
||||
Display information about <scripts>
|
||||
".#/scriptassist ratings <scripts>
|
||||
# Retrieve the average ratings of the the scripts
|
||||
#/scriptassist top <num>
|
||||
# Retrieve the first <num> top rated scripts
|
||||
"/scriptassist new <num>
|
||||
/scriptassist ratings <scripts|all>
|
||||
Retrieve the average ratings of the the scripts
|
||||
/scriptassist top <num>
|
||||
Retrieve the first <num> top rated scripts
|
||||
/scriptassist new <num>
|
||||
Display the newest <num> scripts
|
||||
".#/scriptassist rate <script> <stars>
|
||||
# Rate the script with a number of stars ranging from 0-5
|
||||
"/scriptassist contact <script>
|
||||
/scriptassist rate <script>
|
||||
Rate the script if you like it
|
||||
/scriptassist contact <script>
|
||||
Write an email to the author of the script
|
||||
(Requires OpenURL)
|
||||
/scriptassist cpan <module>
|
||||
@ -95,6 +98,7 @@ sub call_openurl {
|
||||
$code->($url);
|
||||
} else {
|
||||
print CLIENTCRAP "%R>>%n Please install openurl.pl";
|
||||
print CLIENTCRAP "%R>>%n or open < $url > manually";
|
||||
}
|
||||
}
|
||||
|
||||
@ -170,14 +174,13 @@ sub bg_do {
|
||||
my $cmd = $items[1];
|
||||
$result{data}{unknown}{$cmd} = get_unknown($cmd, $xml);
|
||||
}
|
||||
my $dumper = Data::Dumper->new([\%result]);
|
||||
$dumper->Purity(1)->Deepcopy(1)->Indent(0);
|
||||
my $data = $dumper->Dump;
|
||||
my $yaml = CPAN::Meta::YAML->new(\%result);
|
||||
my $data = $yaml->write_string();
|
||||
print($wh $data);
|
||||
};
|
||||
if ($@) {
|
||||
print($wh Data::Dumper->new([+{data=>+{error=>$@}}])
|
||||
->Purity(1)->Deepcopy(1)->Indent(0)->Dump);
|
||||
print($wh CPAN::Meta::YAML->new(+{data=>+{error=>$@}})
|
||||
->write_string());
|
||||
}
|
||||
close($wh);
|
||||
POSIX::_exit(1);
|
||||
@ -189,7 +192,7 @@ sub get_unknown {
|
||||
foreach (keys %$db) {
|
||||
next unless defined $db->{$_}{commands};
|
||||
foreach my $item (split / /, $db->{$_}{commands}) {
|
||||
return { $_ => $db->{$_} } if ($item =~ /^$cmd$/i);
|
||||
return { $_ => +{%{$db->{$_}}} } if ($item =~ /^$cmd$/i);
|
||||
}
|
||||
}
|
||||
return undef;
|
||||
@ -265,47 +268,80 @@ sub script_info {
|
||||
$result{$sname}{modules}{$mod}{installed} = module_exist($mod);
|
||||
}
|
||||
}
|
||||
if (defined $xml->{$plname}{depends}) {
|
||||
my $depends = $xml->{$plname}{depends};
|
||||
foreach my $dep (split(/ /, $depends)) {
|
||||
$result{$sname}{depends}{$dep}{installed} = 1;
|
||||
}
|
||||
}
|
||||
# if (defined $xml->{$plname}{depends}) {
|
||||
# my $depends = $xml->{$plname}{depends};
|
||||
# foreach my $dep (split(/ /, $depends)) {
|
||||
# $result{$sname}{depends}{$dep}{installed} = 1; #(defined ${ 'Irssi::Script::'.$dep });
|
||||
# }
|
||||
# }
|
||||
}
|
||||
return \%result;
|
||||
}
|
||||
|
||||
sub get_rate_url {
|
||||
my ($src) = @_;
|
||||
my $ua = LWP::UserAgent->new(env_proxy=>1, keep_alive=>1, timeout=>30);
|
||||
$ua->agent('ScriptAssist/'.$VERSION);
|
||||
my $request = HTTP::Request->new('GET', $src);
|
||||
my $response = $ua->request($request);
|
||||
unless ($response->is_success) {
|
||||
my $error = join "\n", $response->status_line(), (grep / at .* line \d+/, split "\n", $response->content()), '';
|
||||
die("Fetching ratings location failed: $error");
|
||||
}
|
||||
my $votes_url;
|
||||
for my $tag ($response->content() =~ /<script([^>]*)>/g) {
|
||||
my $attr = " $tag ";
|
||||
($votes_url = $1) =~ s/\.\w+$/.yml/
|
||||
if $attr =~ /\sasync\s/ && $attr =~ m{\ssrc="(https?://.*?/votes\.\w+)"\s};
|
||||
}
|
||||
unless ($votes_url) {
|
||||
die("Fetching ratings failed: Could not find votes script\n");
|
||||
}
|
||||
$request = HTTP::Request->new('GET', $votes_url);
|
||||
$response = $ua->request($request);
|
||||
if (!$response->is_success) {
|
||||
my $error = join "\n", $response->status_line(), (grep / at .* line \d+/, split "\n", $response->content()), '';
|
||||
die("Fetching ratings failed: $error");
|
||||
}
|
||||
my $data = $response->content();
|
||||
utf8::decode($data);
|
||||
CPAN::Meta::YAML->read_string($data)->[0];
|
||||
}
|
||||
|
||||
sub rate_script {
|
||||
my ($script, $stars) = @_;
|
||||
my $ua = LWP::UserAgent->new(env_proxy=>1, keep_alive=>1, timeout=>30);
|
||||
$ua->agent('ScriptAssist/'.2003020803);
|
||||
my $request = HTTP::Request->new('GET', 'http://ratings.irssi.de/irssirate.pl?&stars='.$stars.'&mode=rate&script='.$script);
|
||||
my $response = $ua->request($request);
|
||||
unless ($response->is_success() && $response->content() =~ /You already rated this script/) {
|
||||
return 1;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
my $xml = get_scripts();
|
||||
my $votes = get_rate_url(map { $_->{source} } values %$xml);
|
||||
my ($sname, $plname, $pname) = get_names($script, $xml);
|
||||
die "Script $script not found\n" unless $votes->{$plname};
|
||||
return $votes->{$plname}{u}
|
||||
}
|
||||
|
||||
sub get_ratings {
|
||||
my ($scripts, $limit) = @_;
|
||||
my $ua = LWP::UserAgent->new(env_proxy=>1, keep_alive=>1, timeout=>30);
|
||||
$ua->agent('ScriptAssist/'.2003020803);
|
||||
my $script = join(',', @{$scripts});
|
||||
my $request = HTTP::Request->new('GET', 'http://ratings.irssi.de/irssirate.pl?script='.$script.'&sort=rating&limit='.$limit);
|
||||
my $response = $ua->request($request);
|
||||
my %result;
|
||||
if ($response->is_success()) {
|
||||
foreach (split /\n/, $response->content()) {
|
||||
if (/<tr><td><a href=".*?">(.*?)<\/a>/) {
|
||||
my $entry = $1;
|
||||
if (/"><\/td><td>([0-9.]+)<\/td><td>(.*?)<\/td><td>/) {
|
||||
$result{$entry} = [$1, $2];
|
||||
}
|
||||
}
|
||||
my $xml = get_scripts();
|
||||
my $votes = get_rate_url(map { $_->{source} } values %$xml);
|
||||
foreach (keys %{$votes}) {
|
||||
if ($xml->{$_}) {
|
||||
$xml->{$_}{votes} = $votes->{$_}{v};
|
||||
}
|
||||
}
|
||||
my %result;
|
||||
if (@{$scripts}) {
|
||||
foreach (@{$scripts}) {
|
||||
my ($sname, $plname, $pname) = get_names($_, $xml);
|
||||
next unless (defined $xml->{$plname} || ( exists $Irssi::Script::{$pname} && exists $Irssi::Script::{$pname}{IRSSI} ));
|
||||
$result{$plname} = [$xml->{$plname}{votes}];
|
||||
}
|
||||
} else {
|
||||
my @keys = sort { $xml->{$b}{votes} <=> $xml->{$a}{votes}
|
||||
|| $xml->{$b}{modified} cmp $xml->{$a}{modified} }
|
||||
grep { !$xml->{$_}{HIDDEN} && $xml->{$_}{votes} ne '' } keys %$xml;
|
||||
foreach (splice @keys, 0, $limit) {
|
||||
$result{$_} = [$xml->{$_}{votes}];
|
||||
}
|
||||
}
|
||||
die "No such script found\n" unless keys %result;
|
||||
return \%result;
|
||||
}
|
||||
|
||||
@ -313,7 +349,7 @@ sub get_new {
|
||||
my ($num) = @_;
|
||||
my $result;
|
||||
my $xml = get_scripts();
|
||||
foreach (sort {$xml->{$b}{last_modified} cmp $xml->{$a}{last_modified}} keys %$xml) {
|
||||
foreach (sort {$xml->{$b}{modified} cmp $xml->{$a}{modified}} keys %$xml) {
|
||||
my %entry = %{ $xml->{$_} };
|
||||
next if $entry{HIDDEN};
|
||||
$result->{$_} = \%entry;
|
||||
@ -427,8 +463,8 @@ sub pipe_input {
|
||||
print CLIENTCRAP "%R<<%n Something weird happend (no text)";
|
||||
return();
|
||||
}
|
||||
local our $VAR1;
|
||||
my $incoming = eval($text);
|
||||
utf8::decode($text);
|
||||
my $incoming = CPAN::Meta::YAML->read_string($text)->[0];
|
||||
if ($incoming->{db} && $incoming->{timestamp}) {
|
||||
$remote_db{db} = $incoming->{db};
|
||||
$remote_db{timestamp} = $incoming->{timestamp};
|
||||
@ -598,13 +634,8 @@ sub print_rate {
|
||||
my (%data) = @_;
|
||||
my $line;
|
||||
foreach my $script (sort keys(%data)) {
|
||||
if ($data{$script}) {
|
||||
$line .= "%go%n %9".$script."%9 has been rated";
|
||||
} else {
|
||||
$line .= "%ro%n %9".$script."%9 : Already rated this script";
|
||||
}
|
||||
call_openurl($data{$script});
|
||||
}
|
||||
print CLIENTCRAP draw_box('ScriptAssist', $line, 'rating', 1) ;
|
||||
}
|
||||
|
||||
sub print_ratings {
|
||||
@ -618,8 +649,7 @@ sub print_ratings {
|
||||
push @line, "%yo%n";
|
||||
}
|
||||
push @line, "%9".$script."%9";
|
||||
push @line, $data{$script}{rating};
|
||||
push @line, "[".$data{$script}{votes}." votes]";
|
||||
push @line, "[".(length $data{$script}{rating} ? $data{$script}{rating} : 'no')." votes]";
|
||||
push @table, \@line;
|
||||
}
|
||||
print CLIENTCRAP draw_box('ScriptAssist', array2table(@table), 'ratings', 1) ;
|
||||
@ -628,7 +658,7 @@ sub print_ratings {
|
||||
sub print_new {
|
||||
my ($list) = @_;
|
||||
my @table;
|
||||
foreach (sort {$list->{$b}{last_modified} cmp $list->{$a}{last_modified}} keys %$list) {
|
||||
foreach (sort {$list->{$b}{modified} cmp $list->{$a}{modified}} keys %$list) {
|
||||
my @line;
|
||||
my ($name) = get_names($_);
|
||||
if (get_local_version($name)) {
|
||||
@ -637,7 +667,7 @@ sub print_new {
|
||||
push @line, "%yo%n";
|
||||
}
|
||||
push @line, "%9".$name."%9";
|
||||
push @line, $list->{$_}{last_modified};
|
||||
push @line, $list->{$_}{modified};
|
||||
push @table, \@line;
|
||||
}
|
||||
print CLIENTCRAP draw_box('ScriptAssist', array2table(@table), 'new scripts', 1) ;
|
||||
@ -822,7 +852,7 @@ sub contact_author {
|
||||
|
||||
sub get_scripts {
|
||||
my $ua = LWP::UserAgent->new(env_proxy=>1, keep_alive=>1, timeout=>30);
|
||||
$ua->agent('ScriptAssist/'.2003020803);
|
||||
$ua->agent('ScriptAssist/'.$VERSION);
|
||||
$ua->env_proxy();
|
||||
my @mirrors = split(/ /, Irssi::settings_get_str('scriptassist_script_sources'));
|
||||
my %sites_db;
|
||||
@ -846,28 +876,32 @@ sub get_scripts {
|
||||
}
|
||||
$fetched = 1;
|
||||
my $data = $response->content();
|
||||
my ($src, $type);
|
||||
my $src = $site;
|
||||
my $type = '';
|
||||
if ($site =~ /(.*\/).+\.(.+)/) {
|
||||
$src = $1;
|
||||
$type = $2;
|
||||
}
|
||||
push @sources, $src;
|
||||
#my @header = ('name', 'contact', 'authors', 'description', 'version', 'modules', 'last_modified');
|
||||
#my @header = ('name', 'contact', 'authors', 'description', 'version', 'modules', 'modified');
|
||||
if ($type eq 'dmp') {
|
||||
no strict 'vars';
|
||||
my $new_db = eval "$data";
|
||||
foreach (keys %$new_db) {
|
||||
if (defined $sites_db{script}{$_}) {
|
||||
my $old = $sites_db{$_}{version};
|
||||
my $new = $new_db->{$_}{version};
|
||||
die("Support for $type script database has been removed. Please /set scriptassist_script_sources and change $type -> yml.\n");
|
||||
} elsif ($type eq 'yml') {
|
||||
utf8::decode($data);
|
||||
my $new_db = CPAN::Meta::YAML->read_string($data);
|
||||
foreach (@{$new_db->[0]}) {
|
||||
my $K = $_->{filename};
|
||||
if (defined $sites_db{script}{$K}) {
|
||||
my $old = $sites_db{$K}{version};
|
||||
my $new = $_->{version};
|
||||
next if (compare_versions($old, $new) eq 'newer');
|
||||
}
|
||||
#foreach my $key (@header) {
|
||||
foreach my $key (keys %{ $new_db->{$_} }) {
|
||||
next unless defined $new_db->{$_}{$key};
|
||||
$sites_db{$_}{$key} = $new_db->{$_}{$key};
|
||||
foreach my $key (keys %$_) {
|
||||
next unless defined $_->{$key};
|
||||
$sites_db{$K}{$key} = $_->{$key};
|
||||
}
|
||||
$sites_db{$_}{source} = $src;
|
||||
$sites_db{$K}{source} = $src;
|
||||
}
|
||||
} else {
|
||||
die("Unknown script database type ($type).\n");
|
||||
@ -1093,6 +1127,7 @@ sub missing_module {
|
||||
|
||||
sub cmd_scripassist {
|
||||
my ($arg, $server, $witem) = @_;
|
||||
utf8::decode($arg);
|
||||
my @args = split(/ /, $arg);
|
||||
if ($args[0] eq 'help' || $args[0] eq '-h') {
|
||||
show_help();
|
||||
@ -1112,9 +1147,9 @@ sub cmd_scripassist {
|
||||
} elsif ($args[0] eq 'ratings' && defined $args[1]) {
|
||||
shift @args;
|
||||
bg_do("ratings ".join(' ', @args));
|
||||
} elsif ($args[0] eq 'rate' && defined $args[1] && defined $args[2]) {
|
||||
} elsif ($args[0] eq 'rate' && defined $args[1]) {
|
||||
shift @args;
|
||||
bg_do("rate ".join(' ', @args)) if ($args[2] >= 0 && $args[2] < 6);
|
||||
bg_do("rate ".join(' ', @args));
|
||||
} elsif ($args[0] eq 'info' && defined $args[1]) {
|
||||
shift @args;
|
||||
bg_do("info ".join(' ', @args));
|
||||
@ -1155,6 +1190,7 @@ sub sig_command_script_load {
|
||||
sub sig_default_command {
|
||||
my ($cmd, $server) = @_;
|
||||
return unless Irssi::settings_get_bool("scriptassist_check_unknown_commands");
|
||||
return if ($cmd =~ /^\d+$/ && $irssi_version >= v1.2.0 && Irssi::settings_get_bool("window_number_commands"));
|
||||
bg_do('unknown '.$cmd);
|
||||
}
|
||||
|
||||
@ -1176,7 +1212,7 @@ sub sig_complete {
|
||||
}
|
||||
|
||||
|
||||
Irssi::settings_add_str($IRSSI{name}, 'scriptassist_script_sources', 'https://scripts.irssi.org/scripts.dmp');
|
||||
Irssi::settings_add_str($IRSSI{name}, 'scriptassist_script_sources', 'https://scripts.irssi.org/scripts.yml');
|
||||
Irssi::settings_add_bool($IRSSI{name}, 'scriptassist_cache_sources', 1);
|
||||
Irssi::settings_add_bool($IRSSI{name}, 'scriptassist_update_verbose', 1);
|
||||
Irssi::settings_add_bool($IRSSI{name}, 'scriptassist_check_verbose', 1);
|
||||
@ -1210,11 +1246,11 @@ foreach my $cmd ( ( 'check',
|
||||
'search',
|
||||
# '-h',
|
||||
'help',
|
||||
# 'ratings',
|
||||
# 'rate',
|
||||
'ratings',
|
||||
'rate',
|
||||
'info',
|
||||
# 'echo',
|
||||
# 'top',
|
||||
'top',
|
||||
'cpan',
|
||||
'autorun',
|
||||
'new' ) ) {
|
||||
|
@ -1,25 +0,0 @@
|
||||
if BUILD_TEXTUI
|
||||
TEXTUI=fe-text
|
||||
endif
|
||||
|
||||
if BUILD_IRSSIBOT
|
||||
BOTUI=fe-none
|
||||
endif
|
||||
|
||||
if BUILD_IRSSIFUZZER
|
||||
FUZZERUI=fe-fuzz
|
||||
endif
|
||||
|
||||
if HAVE_PERL
|
||||
PERLDIR=perl
|
||||
endif
|
||||
|
||||
if HAVE_OTR
|
||||
OTRDIR=otr
|
||||
endif
|
||||
|
||||
pkginc_srcdir=$(pkgincludedir)/src
|
||||
pkginc_src_HEADERS = \
|
||||
common.h
|
||||
|
||||
SUBDIRS = lib-config core irc fe-common $(PERLDIR) $(OTRDIR) $(TEXTUI) $(BOTUI) $(FUZZERUI)
|
36
src/common.h
36
src/common.h
@ -1,19 +1,17 @@
|
||||
#ifndef __COMMON_H
|
||||
#define __COMMON_H
|
||||
#ifndef IRSSI_COMMON_H
|
||||
#define IRSSI_COMMON_H
|
||||
|
||||
#define IRSSI_DIR_FULL "%s/.irssi" /* %s == g_get_home_dir() */
|
||||
|
||||
#define IRSSI_GLOBAL_CONFIG "irssi.conf" /* config file name in /etc/ */
|
||||
#define IRSSI_HOME_CONFIG "config" /* config file name in ~/.irssi/ */
|
||||
|
||||
#define IRSSI_ABI_VERSION 20
|
||||
#define IRSSI_ABI_VERSION 50
|
||||
|
||||
#define DEFAULT_SERVER_ADD_PORT 6667
|
||||
#define DEFAULT_SERVER_ADD_TLS_PORT 6697
|
||||
|
||||
#ifdef HAVE_CONFIG_H
|
||||
#include "irssi-config.h"
|
||||
#endif
|
||||
#include <irssi/irssi-config.h>
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stddef.h>
|
||||
@ -39,30 +37,20 @@
|
||||
#include <fcntl.h>
|
||||
|
||||
#include <glib.h>
|
||||
#ifdef HAVE_GMODULE
|
||||
# include <gmodule.h>
|
||||
#endif
|
||||
#include <gmodule.h>
|
||||
|
||||
#if defined (UOFF_T_INT)
|
||||
typedef unsigned int uoff_t;
|
||||
#elif defined (UOFF_T_LONG)
|
||||
typedef unsigned long uoff_t;
|
||||
#elif defined (UOFF_T_LONG_LONG)
|
||||
typedef unsigned long long uoff_t;
|
||||
#else
|
||||
# error uoff_t size not set
|
||||
#endif
|
||||
typedef guint64 uoff_t;
|
||||
#define PRIuUOFF_T G_GUINT64_FORMAT
|
||||
|
||||
/* input functions */
|
||||
#define G_INPUT_READ (1 << 0)
|
||||
#define G_INPUT_WRITE (1 << 1)
|
||||
#define I_INPUT_READ (1 << 0)
|
||||
#define I_INPUT_WRITE (1 << 1)
|
||||
|
||||
typedef void (*GInputFunction) (void *data, GIOChannel *source, int condition);
|
||||
|
||||
int g_input_add(GIOChannel *source, int condition,
|
||||
GInputFunction function, void *data);
|
||||
int g_input_add_full(GIOChannel *source, int priority, int condition,
|
||||
GInputFunction function, void *data);
|
||||
int i_input_add(GIOChannel *source, int condition, GInputFunction function, void *data);
|
||||
int i_input_add_full(GIOChannel *source, int priority, int condition, GInputFunction function,
|
||||
void *data);
|
||||
|
||||
/* return full path for ~/.irssi */
|
||||
const char *get_irssi_dir(void);
|
||||
|
@ -1,120 +0,0 @@
|
||||
noinst_LIBRARIES = libcore.a
|
||||
|
||||
AM_CPPFLAGS = \
|
||||
-I$(top_builddir) \
|
||||
-I$(top_srcdir)/src \
|
||||
-I$(top_srcdir)/src/core \
|
||||
$(GLIB_CFLAGS) \
|
||||
-DSYSCONFDIR=\""$(sysconfdir)"\" \
|
||||
-DMODULEDIR=\""$(libdir)/irssi/modules"\"
|
||||
|
||||
if USE_GREGEX
|
||||
regex_impl=iregex-gregex.c
|
||||
else
|
||||
regex_impl=iregex-regexh.c
|
||||
endif
|
||||
|
||||
libcore_a_SOURCES = \
|
||||
args.c \
|
||||
channels.c \
|
||||
channels-setup.c \
|
||||
commands.c \
|
||||
chat-commands.c \
|
||||
chat-protocols.c \
|
||||
chatnets.c \
|
||||
core.c \
|
||||
expandos.c \
|
||||
ignore.c \
|
||||
levels.c \
|
||||
line-split.c \
|
||||
log.c \
|
||||
log-away.c \
|
||||
masks.c \
|
||||
misc.c \
|
||||
modules.c \
|
||||
modules-load.c \
|
||||
net-disconnect.c \
|
||||
net-nonblock.c \
|
||||
net-sendbuffer.c \
|
||||
network.c \
|
||||
network-openssl.c \
|
||||
nicklist.c \
|
||||
nickmatch-cache.c \
|
||||
pidwait.c \
|
||||
queries.c \
|
||||
rawlog.c \
|
||||
recode.c \
|
||||
servers.c \
|
||||
servers-reconnect.c \
|
||||
servers-setup.c \
|
||||
session.c \
|
||||
settings.c \
|
||||
signals.c \
|
||||
special-vars.c \
|
||||
utf8.c \
|
||||
$(regex_impl) \
|
||||
wcwidth.c \
|
||||
wcwidth-wrapper.c \
|
||||
tls.c \
|
||||
write-buffer.c
|
||||
|
||||
if HAVE_CAPSICUM
|
||||
libcore_a_SOURCES += \
|
||||
capsicum.c
|
||||
endif
|
||||
|
||||
structure_headers = \
|
||||
channel-rec.h \
|
||||
channel-setup-rec.h \
|
||||
chatnet-rec.h \
|
||||
query-rec.h \
|
||||
server-rec.h \
|
||||
server-setup-rec.h \
|
||||
server-connect-rec.h \
|
||||
window-item-rec.h
|
||||
|
||||
pkginc_coredir=$(pkgincludedir)/src/core
|
||||
pkginc_core_HEADERS = \
|
||||
args.h \
|
||||
capsicum.h \
|
||||
channels.h \
|
||||
channels-setup.h \
|
||||
commands.h \
|
||||
chat-protocols.h \
|
||||
chatnets.h \
|
||||
core.h \
|
||||
expandos.h \
|
||||
ignore.h \
|
||||
levels.h \
|
||||
line-split.h \
|
||||
log.h \
|
||||
masks.h \
|
||||
misc.h \
|
||||
module.h \
|
||||
modules.h \
|
||||
modules-load.h \
|
||||
net-disconnect.h \
|
||||
net-nonblock.h \
|
||||
net-sendbuffer.h \
|
||||
network.h \
|
||||
network-openssl.h \
|
||||
nick-rec.h \
|
||||
nicklist.h \
|
||||
nickmatch-cache.h \
|
||||
pidwait.h \
|
||||
queries.h \
|
||||
rawlog.h \
|
||||
recode.h \
|
||||
servers.h \
|
||||
servers-reconnect.h \
|
||||
servers-setup.h \
|
||||
session.h \
|
||||
settings.h \
|
||||
signals.h \
|
||||
special-vars.h \
|
||||
utf8.h \
|
||||
iregex.h \
|
||||
window-item-def.h \
|
||||
tls.h \
|
||||
write-buffer.h \
|
||||
$(structure_headers)
|
@ -19,7 +19,7 @@
|
||||
*/
|
||||
|
||||
#include "module.h"
|
||||
#include "args.h"
|
||||
#include <irssi/src/core/args.h>
|
||||
|
||||
static GOptionContext *context = NULL;
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
#ifndef __ARGS_H
|
||||
#define __ARGS_H
|
||||
#ifndef IRSSI_CORE_ARGS_H
|
||||
#define IRSSI_CORE_ARGS_H
|
||||
|
||||
void args_register(GOptionEntry *options);
|
||||
void args_execute(int argc, char *argv[]);
|
||||
|
@ -23,14 +23,14 @@
|
||||
*/
|
||||
|
||||
#include "module.h"
|
||||
#include "capsicum.h"
|
||||
#include "commands.h"
|
||||
#include "log.h"
|
||||
#include "misc.h"
|
||||
#include "network.h"
|
||||
#include "network-openssl.h"
|
||||
#include "settings.h"
|
||||
#include "signals.h"
|
||||
#include <irssi/src/core/capsicum.h>
|
||||
#include <irssi/src/core/commands.h>
|
||||
#include <irssi/src/core/log.h>
|
||||
#include <irssi/src/core/misc.h>
|
||||
#include <irssi/src/core/network.h>
|
||||
#include <irssi/src/core/network-openssl.h>
|
||||
#include <irssi/src/core/settings.h>
|
||||
#include <irssi/src/core/signals.h>
|
||||
|
||||
#include <sys/param.h>
|
||||
#include <sys/capsicum.h>
|
||||
|
@ -1,5 +1,5 @@
|
||||
#ifndef __CAPSICUM_H
|
||||
#define __CAPSICUM_H
|
||||
#ifndef IRSSI_CORE_CAPSICUM_H
|
||||
#define IRSSI_CORE_CAPSICUM_H
|
||||
|
||||
gboolean capsicum_enabled(void);
|
||||
int capsicum_net_connect_ip(IPADDR *ip, int port, IPADDR *my_ip);
|
||||
@ -12,4 +12,4 @@ void capsicum_mkdir_with_parents_wrapper(const char *path, int mode);
|
||||
void capsicum_init(void);
|
||||
void capsicum_deinit(void);
|
||||
|
||||
#endif /* !__CAPSICUM_H */
|
||||
#endif /* !IRSSI_CORE_CAPSICUM_H */
|
||||
|
@ -1,6 +1,6 @@
|
||||
/* CHANNEL_REC definition, used for inheritance */
|
||||
|
||||
#include "window-item-rec.h"
|
||||
#include <irssi/src/core/window-item-rec.h>
|
||||
|
||||
char *topic;
|
||||
char *topic_by;
|
||||
|
@ -19,14 +19,14 @@
|
||||
*/
|
||||
|
||||
#include "module.h"
|
||||
#include "signals.h"
|
||||
#include "lib-config/iconfig.h"
|
||||
#include "settings.h"
|
||||
#include <irssi/src/core/signals.h>
|
||||
#include <irssi/src/lib-config/iconfig.h>
|
||||
#include <irssi/src/core/settings.h>
|
||||
|
||||
#include "chat-protocols.h"
|
||||
#include "chatnets.h"
|
||||
#include "servers-setup.h"
|
||||
#include "channels-setup.h"
|
||||
#include <irssi/src/core/chat-protocols.h>
|
||||
#include <irssi/src/core/chatnets.h>
|
||||
#include <irssi/src/core/servers-setup.h>
|
||||
#include <irssi/src/core/channels-setup.h>
|
||||
|
||||
GSList *setupchannels;
|
||||
|
||||
@ -34,6 +34,10 @@ static int compare_channel_setup (CONFIG_NODE *node, CHANNEL_SETUP_REC *channel)
|
||||
{
|
||||
char *name, *chatnet;
|
||||
|
||||
/* skip comment nodes */
|
||||
if (node->type == NODE_TYPE_COMMENT)
|
||||
return -1;
|
||||
|
||||
name = config_node_get_str(node, "name", NULL);
|
||||
chatnet = config_node_get_str(node, "chatnet", NULL);
|
||||
|
||||
@ -203,9 +207,18 @@ static void channels_read_config(void)
|
||||
/* Read channels */
|
||||
node = iconfig_node_traverse("channels", FALSE);
|
||||
if (node != NULL) {
|
||||
int i = 0;
|
||||
tmp = config_node_first(node->value);
|
||||
for (; tmp != NULL; tmp = config_node_next(tmp))
|
||||
channel_setup_read(tmp->data);
|
||||
for (; tmp != NULL; tmp = config_node_next(tmp), i++) {
|
||||
node = tmp->data;
|
||||
if (node->type != NODE_TYPE_BLOCK) {
|
||||
g_critical("Expected block node at `channels[%d]' was of %s type. "
|
||||
"Corrupt config?",
|
||||
i, node->type == NODE_TYPE_LIST ? "list" : "scalar");
|
||||
} else {
|
||||
channel_setup_read(node);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -214,8 +227,7 @@ void channels_setup_init(void)
|
||||
setupchannels = NULL;
|
||||
source_host_ok = FALSE;
|
||||
|
||||
signal_add("setup reread", (SIGNAL_FUNC) channels_read_config);
|
||||
signal_add("irssi init read settings", (SIGNAL_FUNC) channels_read_config);
|
||||
signal_add("setup reread channels", (SIGNAL_FUNC) channels_read_config);
|
||||
}
|
||||
|
||||
void channels_setup_deinit(void)
|
||||
@ -223,6 +235,5 @@ void channels_setup_deinit(void)
|
||||
while (setupchannels != NULL)
|
||||
channel_setup_destroy(setupchannels->data);
|
||||
|
||||
signal_remove("setup reread", (SIGNAL_FUNC) channels_read_config);
|
||||
signal_remove("irssi init read settings", (SIGNAL_FUNC) channels_read_config);
|
||||
signal_remove("setup reread channels", (SIGNAL_FUNC) channels_read_config);
|
||||
}
|
||||
|
@ -1,7 +1,7 @@
|
||||
#ifndef __CHANNELS_SETUP_H
|
||||
#define __CHANNELS_SETUP_H
|
||||
#ifndef IRSSI_CORE_CHANNELS_SETUP_H
|
||||
#define IRSSI_CORE_CHANNELS_SETUP_H
|
||||
|
||||
#include "modules.h"
|
||||
#include <irssi/src/core/modules.h>
|
||||
|
||||
#define CHANNEL_SETUP(server) \
|
||||
MODULE_CHECK_CAST(server, CHANNEL_SETUP_REC, type, "CHANNEL SETUP")
|
||||
@ -10,7 +10,7 @@
|
||||
(CHANNEL_SETUP(server) ? TRUE : FALSE)
|
||||
|
||||
struct _CHANNEL_SETUP_REC {
|
||||
#include "channel-setup-rec.h"
|
||||
#include <irssi/src/core/channel-setup-rec.h>
|
||||
};
|
||||
|
||||
extern GSList *setupchannels;
|
||||
|
@ -19,14 +19,14 @@
|
||||
*/
|
||||
|
||||
#include "module.h"
|
||||
#include "signals.h"
|
||||
#include "misc.h"
|
||||
#include "special-vars.h"
|
||||
#include <irssi/src/core/signals.h>
|
||||
#include <irssi/src/core/misc.h>
|
||||
#include <irssi/src/core/special-vars.h>
|
||||
|
||||
#include "servers.h"
|
||||
#include "channels.h"
|
||||
#include "channels-setup.h"
|
||||
#include "nicklist.h"
|
||||
#include <irssi/src/core/servers.h>
|
||||
#include <irssi/src/core/channels.h>
|
||||
#include <irssi/src/core/channels-setup.h>
|
||||
#include <irssi/src/core/nicklist.h>
|
||||
|
||||
GSList *channels; /* List of all channels */
|
||||
|
||||
@ -126,9 +126,8 @@ CHANNEL_REC *channel_find(SERVER_REC *server, const char *name)
|
||||
return channel_find_server(server, name);
|
||||
|
||||
/* find from any server */
|
||||
return gslist_foreach_find(servers,
|
||||
(FOREACH_FIND_FUNC) channel_find_server,
|
||||
(void *) name);
|
||||
return i_slist_foreach_find(servers, (FOREACH_FIND_FUNC) channel_find_server,
|
||||
(void *) name);
|
||||
}
|
||||
|
||||
void channel_change_name(CHANNEL_REC *channel, const char *name)
|
||||
@ -153,9 +152,8 @@ void channel_change_visible_name(CHANNEL_REC *channel, const char *name)
|
||||
|
||||
static CHANNEL_REC *channel_find_servers(GSList *servers, const char *name)
|
||||
{
|
||||
return gslist_foreach_find(servers,
|
||||
(FOREACH_FIND_FUNC) channel_find_server,
|
||||
(void *) name);
|
||||
return i_slist_foreach_find(servers, (FOREACH_FIND_FUNC) channel_find_server,
|
||||
(void *) name);
|
||||
}
|
||||
|
||||
static GSList *servers_find_chatnet_except(SERVER_REC *server)
|
||||
|
@ -1,7 +1,7 @@
|
||||
#ifndef __CHANNELS_H
|
||||
#define __CHANNELS_H
|
||||
#ifndef IRSSI_CORE_CHANNELS_H
|
||||
#define IRSSI_CORE_CHANNELS_H
|
||||
|
||||
#include "modules.h"
|
||||
#include <irssi/src/core/modules.h>
|
||||
|
||||
/* Returns CHANNEL_REC if it's channel, NULL if it isn't. */
|
||||
#define CHANNEL(channel) \
|
||||
@ -13,7 +13,7 @@
|
||||
|
||||
#define STRUCT_SERVER_REC SERVER_REC
|
||||
struct _CHANNEL_REC {
|
||||
#include "channel-rec.h"
|
||||
#include <irssi/src/core/channel-rec.h>
|
||||
};
|
||||
|
||||
extern GSList *channels;
|
||||
|
@ -19,20 +19,20 @@
|
||||
*/
|
||||
|
||||
#include "module.h"
|
||||
#include "network.h"
|
||||
#include "signals.h"
|
||||
#include "commands.h"
|
||||
#include "special-vars.h"
|
||||
#include "settings.h"
|
||||
#include <irssi/src/core/network.h>
|
||||
#include <irssi/src/core/signals.h>
|
||||
#include <irssi/src/core/commands.h>
|
||||
#include <irssi/src/core/special-vars.h>
|
||||
#include <irssi/src/core/settings.h>
|
||||
|
||||
#include "chat-protocols.h"
|
||||
#include "servers.h"
|
||||
#include "servers-setup.h"
|
||||
#include "servers-reconnect.h"
|
||||
#include "channels.h"
|
||||
#include "queries.h"
|
||||
#include "window-item-def.h"
|
||||
#include "rawlog.h"
|
||||
#include <irssi/src/core/chat-protocols.h>
|
||||
#include <irssi/src/core/servers.h>
|
||||
#include <irssi/src/core/servers-setup.h>
|
||||
#include <irssi/src/core/servers-reconnect.h>
|
||||
#include <irssi/src/core/channels.h>
|
||||
#include <irssi/src/core/queries.h>
|
||||
#include <irssi/src/core/window-item-def.h>
|
||||
#include <irssi/src/core/rawlog.h>
|
||||
|
||||
static SERVER_CONNECT_REC *get_server_connect(const char *data, int *plus_addr,
|
||||
char **rawlog_file)
|
||||
@ -40,7 +40,7 @@ static SERVER_CONNECT_REC *get_server_connect(const char *data, int *plus_addr,
|
||||
CHAT_PROTOCOL_REC *proto;
|
||||
SERVER_CONNECT_REC *conn;
|
||||
GHashTable *optlist;
|
||||
char *addr, *portstr, *password, *nick, *chatnet, *host, *tmp;
|
||||
char *addr, *portstr, *password, *nick, *chatnet, *host;
|
||||
void *free_arg;
|
||||
|
||||
g_return_val_if_fail(data != NULL, NULL);
|
||||
@ -71,8 +71,8 @@ static SERVER_CONNECT_REC *get_server_connect(const char *data, int *plus_addr,
|
||||
if (chatnet == NULL)
|
||||
chatnet = g_hash_table_lookup(optlist, "network");
|
||||
|
||||
conn = server_create_conn(proto != NULL ? proto->id : -1, addr,
|
||||
atoi(portstr), chatnet, password, nick);
|
||||
conn = server_create_conn_opt(proto != NULL ? proto->id : -1, addr, atoi(portstr), chatnet,
|
||||
password, nick, optlist);
|
||||
if (conn == NULL) {
|
||||
signal_emit("error command", 1,
|
||||
GINT_TO_POINTER(CMDERR_NO_SERVER_DEFINED));
|
||||
@ -94,46 +94,7 @@ static SERVER_CONNECT_REC *get_server_connect(const char *data, int *plus_addr,
|
||||
if (strchr(addr, '/') != NULL)
|
||||
conn->unix_socket = TRUE;
|
||||
|
||||
if (g_hash_table_lookup(optlist, "6") != NULL)
|
||||
conn->family = AF_INET6;
|
||||
else if (g_hash_table_lookup(optlist, "4") != NULL)
|
||||
conn->family = AF_INET;
|
||||
|
||||
if (g_hash_table_lookup(optlist, "tls") != NULL || g_hash_table_lookup(optlist, "ssl") != NULL)
|
||||
conn->use_tls = TRUE;
|
||||
if ((tmp = g_hash_table_lookup(optlist, "tls_cert")) != NULL || (tmp = g_hash_table_lookup(optlist, "ssl_cert")) != NULL)
|
||||
conn->tls_cert = g_strdup(tmp);
|
||||
if ((tmp = g_hash_table_lookup(optlist, "tls_pkey")) != NULL || (tmp = g_hash_table_lookup(optlist, "ssl_pkey")) != NULL)
|
||||
conn->tls_pkey = g_strdup(tmp);
|
||||
if ((tmp = g_hash_table_lookup(optlist, "tls_pass")) != NULL || (tmp = g_hash_table_lookup(optlist, "ssl_pass")) != NULL)
|
||||
conn->tls_pass = g_strdup(tmp);
|
||||
if (g_hash_table_lookup(optlist, "tls_verify") != NULL || g_hash_table_lookup(optlist, "ssl_verify") != NULL)
|
||||
conn->tls_verify = TRUE;
|
||||
if ((tmp = g_hash_table_lookup(optlist, "tls_cafile")) != NULL || (tmp = g_hash_table_lookup(optlist, "ssl_cafile")) != NULL)
|
||||
conn->tls_cafile = g_strdup(tmp);
|
||||
if ((tmp = g_hash_table_lookup(optlist, "tls_capath")) != NULL || (tmp = g_hash_table_lookup(optlist, "ssl_capath")) != NULL)
|
||||
conn->tls_capath = g_strdup(tmp);
|
||||
if ((tmp = g_hash_table_lookup(optlist, "tls_ciphers")) != NULL || (tmp = g_hash_table_lookup(optlist, "ssl_ciphers")) != NULL)
|
||||
conn->tls_ciphers = g_strdup(tmp);
|
||||
if ((tmp = g_hash_table_lookup(optlist, "tls_pinned_cert")) != NULL || (tmp = g_hash_table_lookup(optlist, "ssl_pinned_cert")) != NULL)
|
||||
conn->tls_pinned_cert = g_strdup(tmp);
|
||||
if ((tmp = g_hash_table_lookup(optlist, "tls_pinned_pubkey")) != NULL || (tmp = g_hash_table_lookup(optlist, "ssl_pinned_pubkey")) != NULL)
|
||||
conn->tls_pinned_pubkey = g_strdup(tmp);
|
||||
if ((conn->tls_capath != NULL && conn->tls_capath[0] != '\0')
|
||||
|| (conn->tls_cafile != NULL && conn->tls_cafile[0] != '\0'))
|
||||
conn->tls_verify = TRUE;
|
||||
if ((conn->tls_cert != NULL && conn->tls_cert[0] != '\0') || conn->tls_verify)
|
||||
conn->use_tls = TRUE;
|
||||
|
||||
if (g_hash_table_lookup(optlist, "!") != NULL)
|
||||
conn->no_autojoin_channels = TRUE;
|
||||
|
||||
if (g_hash_table_lookup(optlist, "noautosendcmd") != NULL)
|
||||
conn->no_autosendcmd = TRUE;
|
||||
|
||||
if (g_hash_table_lookup(optlist, "noproxy") != NULL)
|
||||
g_free_and_null(conn->proxy);
|
||||
|
||||
/* TLS options are handled in server_create_conn_opt ... -> server_setup_fill_optlist */
|
||||
|
||||
*rawlog_file = g_strdup(g_hash_table_lookup(optlist, "rawlog"));
|
||||
|
||||
@ -149,13 +110,13 @@ static SERVER_CONNECT_REC *get_server_connect(const char *data, int *plus_addr,
|
||||
return conn;
|
||||
}
|
||||
|
||||
/* SYNTAX: CONNECT [-4 | -6] [-tls] [-tls_cert <cert>] [-tls_pkey <pkey>] [-tls_pass <password>]
|
||||
/* SYNTAX: CONNECT [-4 | -6] [-tls_cert <cert>] [-tls_pkey <pkey>] [-tls_pass <password>]
|
||||
[-tls_verify] [-tls_cafile <cafile>] [-tls_capath <capath>]
|
||||
[-tls_ciphers <list>] [-tls_pinned_cert <fingerprint>] [-tls_pinned_pubkey <fingerprint>]
|
||||
[-!] [-noautosendcmd]
|
||||
[-noproxy] [-network <network>] [-host <hostname>]
|
||||
[-rawlog <file>]
|
||||
<address>|<chatnet> [<port> [<password> [<nick>]]] */
|
||||
[-tls_ciphers <list>] [-tls_pinned_cert <fingerprint>]
|
||||
[-tls_pinned_pubkey <fingerprint>] [-!] [-noautosendcmd] [-tls | -notls]
|
||||
[-nocap] [-starttls | -disallow_starttls] [-noproxy]
|
||||
[-network <network>] [-host <hostname>] [-rawlog <file>]
|
||||
<address>|<chatnet> [<port> [<password> [<nick>]]] */
|
||||
/* NOTE: -network replaces the old -ircnet flag. */
|
||||
static void cmd_connect(const char *data)
|
||||
{
|
||||
@ -250,14 +211,14 @@ static void cmd_server(const char *data, SERVER_REC *server, WI_ITEM_REC *item)
|
||||
command_runsub("server", data, server, item);
|
||||
}
|
||||
|
||||
/* SYNTAX: SERVER CONNECT [-4 | -6] [-tls] [-tls_cert <cert>] [-tls_pkey <pkey>]
|
||||
[-tls_pass <password>] [-tls_verify] [-tls_cafile <cafile>]
|
||||
[-tls_capath <capath>]
|
||||
[-tls_ciphers <list>] [-tls_pinned_cert <fingerprint>] [-tls_pinned_pubkey <fingerprint>]
|
||||
[-!] [-noautosendcmd]
|
||||
[-noproxy] [-network <network>] [-host <hostname>]
|
||||
[-rawlog <file>]
|
||||
[+]<address>|<chatnet> [<port> [<password> [<nick>]]] */
|
||||
/* SYNTAX: SERVER CONNECT [-4 | -6] [-tls] [-tls_cert <cert>] [-tls_pkey <pkey>]
|
||||
[-tls_pass <password>] [-tls_verify] [-tls_cafile <cafile>]
|
||||
[-tls_capath <capath>] [-tls_ciphers <list>]
|
||||
[-tls_pinned_cert <fingerprint>] [-tls_pinned_pubkey <fingerprint>]
|
||||
[-!] [-noautosendcmd] [-nocap]
|
||||
[-noproxy] [-network <network>] [-host <hostname>]
|
||||
[-rawlog <file>]
|
||||
[+]<address>|<chatnet> [<port> [<password> [<nick>]]] */
|
||||
/* NOTE: -network replaces the old -ircnet flag. */
|
||||
static void cmd_server_connect(const char *data, SERVER_REC *server)
|
||||
{
|
||||
@ -517,7 +478,12 @@ void chat_commands_init(void)
|
||||
|
||||
signal_add("server sendmsg", (SIGNAL_FUNC) sig_server_sendmsg);
|
||||
|
||||
command_set_options("connect", "4 6 !! -network ssl +ssl_cert +ssl_pkey +ssl_pass ssl_verify +ssl_cafile +ssl_capath +ssl_ciphers +ssl_pinned_cert +ssl_pinned_pubkey tls +tls_cert +tls_pkey +tls_pass tls_verify +tls_cafile +tls_capath +tls_ciphers +tls_pinned_cert +tls_pinned_pubkey +host noproxy -rawlog noautosendcmd");
|
||||
command_set_options(
|
||||
"connect",
|
||||
"4 6 !! -network ~ssl ~+ssl_cert ~+ssl_pkey ~+ssl_pass ~ssl_verify ~+ssl_cafile "
|
||||
"~+ssl_capath ~+ssl_ciphers ~+ssl_pinned_cert ~+ssl_pinned_pubkey tls notls +tls_cert "
|
||||
"+tls_pkey +tls_pass tls_verify notls_verify +tls_cafile +tls_capath +tls_ciphers "
|
||||
"+tls_pinned_cert +tls_pinned_pubkey +host noproxy -rawlog noautosendcmd");
|
||||
command_set_options("msg", "channel nick");
|
||||
}
|
||||
|
||||
|
@ -19,14 +19,14 @@
|
||||
*/
|
||||
|
||||
#include "module.h"
|
||||
#include "modules.h"
|
||||
#include "signals.h"
|
||||
#include "chat-protocols.h"
|
||||
#include <irssi/src/core/modules.h>
|
||||
#include <irssi/src/core/signals.h>
|
||||
#include <irssi/src/core/chat-protocols.h>
|
||||
|
||||
#include "chatnets.h"
|
||||
#include "servers.h"
|
||||
#include "servers-setup.h"
|
||||
#include "channels-setup.h"
|
||||
#include <irssi/src/core/chatnets.h>
|
||||
#include <irssi/src/core/servers.h>
|
||||
#include <irssi/src/core/servers-setup.h>
|
||||
#include <irssi/src/core/channels-setup.h>
|
||||
|
||||
GSList *chat_protocols;
|
||||
|
||||
@ -47,7 +47,7 @@ int chat_protocol_lookup(const char *name)
|
||||
g_return_val_if_fail(name != NULL, -1);
|
||||
|
||||
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)
|
||||
@ -99,6 +99,22 @@ CHAT_PROTOCOL_REC *chat_protocol_find_net(GHashTable *optlist)
|
||||
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. */
|
||||
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);
|
||||
|
||||
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) {
|
||||
newrec = g_new0(CHAT_PROTOCOL_REC, 1);
|
||||
chat_protocols = g_slist_append(chat_protocols, newrec);
|
||||
@ -131,23 +151,6 @@ CHAT_PROTOCOL_REC *chat_protocol_register(CHAT_PROTOCOL_REC *rec)
|
||||
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. */
|
||||
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);
|
||||
}
|
||||
|
||||
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
|
||||
specified but it isn't registered yet. */
|
||||
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_server_setup = create_server_setup;
|
||||
rec->create_channel_setup = create_channel_setup;
|
||||
/*
|
||||
rec->create_server_connect = create_server_connect;
|
||||
rec->destroy_server_connect = destroy_server_connect;
|
||||
*/
|
||||
|
||||
newrec = chat_protocol_register(rec);
|
||||
g_free(rec);
|
||||
|
@ -1,5 +1,5 @@
|
||||
#ifndef __CHAT_PROTOCOLS_H
|
||||
#define __CHAT_PROTOCOLS_H
|
||||
#ifndef IRSSI_CORE_CHAT_PROTOCOLS_H
|
||||
#define IRSSI_CORE_CHAT_PROTOCOLS_H
|
||||
|
||||
struct _CHAT_PROTOCOL_REC {
|
||||
int id;
|
||||
@ -35,6 +35,8 @@ void *chat_protocol_check_cast(void *object, int type_pos, const char *id);
|
||||
((object) == NULL ? chat_protocol_get_default() : \
|
||||
chat_protocol_find_id((object)->chat_type))
|
||||
|
||||
#define CHAT_PROTOCOL_NOT_INITIALIZED -2
|
||||
|
||||
/* Register new chat protocol. */
|
||||
CHAT_PROTOCOL_REC *chat_protocol_register(CHAT_PROTOCOL_REC *rec);
|
||||
|
||||
|
@ -19,17 +19,18 @@
|
||||
*/
|
||||
|
||||
#include "module.h"
|
||||
#include "network.h"
|
||||
#include "signals.h"
|
||||
#include "special-vars.h"
|
||||
#include "lib-config/iconfig.h"
|
||||
#include "settings.h"
|
||||
#include <irssi/src/core/network.h>
|
||||
#include <irssi/src/core/signals.h>
|
||||
#include <irssi/src/core/special-vars.h>
|
||||
#include <irssi/src/lib-config/iconfig.h>
|
||||
#include <irssi/src/core/settings.h>
|
||||
#include <irssi/src/core/misc.h>
|
||||
|
||||
#include "chat-protocols.h"
|
||||
#include "chatnets.h"
|
||||
#include "servers.h"
|
||||
#include <irssi/src/core/chat-protocols.h>
|
||||
#include <irssi/src/core/chatnets.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)
|
||||
{
|
||||
@ -60,8 +61,9 @@ static void chatnet_config_remove(CHATNET_REC *chatnet)
|
||||
void chatnet_create(CHATNET_REC *chatnet)
|
||||
{
|
||||
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)
|
||||
chatnets = g_slist_append(chatnets, chatnet);
|
||||
|
||||
@ -112,6 +114,21 @@ CHATNET_REC *chatnet_find(const char *name)
|
||||
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)
|
||||
{
|
||||
CHATNET_REC *rec;
|
||||
@ -136,14 +153,22 @@ static void chatnet_read(CONFIG_NODE *node)
|
||||
return;
|
||||
|
||||
type = config_node_get_str(node, "type", NULL);
|
||||
proto = type == NULL ? NULL : chat_protocol_find(type);
|
||||
if (proto == NULL) {
|
||||
proto = type == NULL ? chat_protocol_get_default() :
|
||||
chat_protocol_get_unknown(type);
|
||||
if (type == NULL) {
|
||||
proto = chat_protocol_get_default();
|
||||
} else {
|
||||
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);
|
||||
}
|
||||
|
||||
rec = proto->create_chatnet();
|
||||
rec->type = module_get_uniq_id("CHATNET", 0);
|
||||
@ -167,6 +192,12 @@ static void read_chatnets(void)
|
||||
while (chatnets != NULL)
|
||||
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);
|
||||
if (node != NULL) {
|
||||
tmp = config_node_first(node->value);
|
||||
@ -180,8 +211,7 @@ void chatnets_init(void)
|
||||
chatnets = NULL;
|
||||
|
||||
signal_add_first("event connected", (SIGNAL_FUNC) sig_connected);
|
||||
signal_add("setup reread", (SIGNAL_FUNC) read_chatnets);
|
||||
signal_add_first("irssi init read settings", (SIGNAL_FUNC) read_chatnets);
|
||||
signal_add("setup reread chatnets", (SIGNAL_FUNC) read_chatnets);
|
||||
}
|
||||
|
||||
void chatnets_deinit(void)
|
||||
@ -189,6 +219,5 @@ void chatnets_deinit(void)
|
||||
module_uniq_destroy("CHATNET");
|
||||
|
||||
signal_remove("event connected", (SIGNAL_FUNC) sig_connected);
|
||||
signal_remove("setup reread", (SIGNAL_FUNC) read_chatnets);
|
||||
signal_remove("irssi init read settings", (SIGNAL_FUNC) read_chatnets);
|
||||
signal_remove("setup reread chatnets", (SIGNAL_FUNC) read_chatnets);
|
||||
}
|
||||
|
@ -1,7 +1,7 @@
|
||||
#ifndef __CHATNETS_H
|
||||
#define __CHATNETS_H
|
||||
#ifndef IRSSI_CORE_CHATNETS_H
|
||||
#define IRSSI_CORE_CHATNETS_H
|
||||
|
||||
#include "modules.h"
|
||||
#include <irssi/src/core/modules.h>
|
||||
|
||||
/* Returns CHATNET_REC if it's chatnet, NULL if it isn't. */
|
||||
#define CHATNET(chatnet) \
|
||||
@ -11,7 +11,7 @@
|
||||
(CHATNET(chatnet) ? TRUE : FALSE)
|
||||
|
||||
struct _CHATNET_REC {
|
||||
#include "chatnet-rec.h"
|
||||
#include <irssi/src/core/chatnet-rec.h>
|
||||
};
|
||||
|
||||
extern GSList *chatnets; /* list of available chat networks */
|
||||
@ -25,6 +25,8 @@ void chatnet_destroy(CHATNET_REC *chatnet);
|
||||
|
||||
/* Find the chat network by 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_deinit(void);
|
||||
|
@ -19,17 +19,17 @@
|
||||
*/
|
||||
|
||||
#include "module.h"
|
||||
#include "signals.h"
|
||||
#include "commands.h"
|
||||
#include "misc.h"
|
||||
#include "special-vars.h"
|
||||
#include "window-item-def.h"
|
||||
#include <irssi/src/core/signals.h>
|
||||
#include <irssi/src/core/commands.h>
|
||||
#include <irssi/src/core/misc.h>
|
||||
#include <irssi/src/core/special-vars.h>
|
||||
#include <irssi/src/core/window-item-def.h>
|
||||
|
||||
#include "servers.h"
|
||||
#include "channels.h"
|
||||
#include <irssi/src/core/servers.h>
|
||||
#include <irssi/src/core/channels.h>
|
||||
|
||||
#include "lib-config/iconfig.h"
|
||||
#include "settings.h"
|
||||
#include <irssi/src/lib-config/iconfig.h>
|
||||
#include <irssi/src/core/settings.h>
|
||||
|
||||
GSList *commands;
|
||||
char *current_command;
|
||||
@ -339,11 +339,28 @@ void command_runsub(const char *cmd, const char *data,
|
||||
g_free(orig);
|
||||
}
|
||||
|
||||
static char *optname(char *option)
|
||||
{
|
||||
char *opt = option;
|
||||
if (*opt == '~')
|
||||
opt++;
|
||||
if (iscmdtype(*opt))
|
||||
opt++;
|
||||
return opt;
|
||||
}
|
||||
|
||||
static gboolean optflag(char *option, char *flag)
|
||||
{
|
||||
if (*option == '~')
|
||||
return optflag(option + 1, flag);
|
||||
|
||||
return (strchr(flag, *option) != NULL) || (!iscmdtype(*option) && strchr(flag, ' '));
|
||||
}
|
||||
|
||||
static GSList *optlist_find(GSList *optlist, const char *option)
|
||||
{
|
||||
while (optlist != NULL) {
|
||||
char *name = optlist->data;
|
||||
if (iscmdtype(*name)) name++;
|
||||
char *name = optname(optlist->data);
|
||||
|
||||
if (g_ascii_strcasecmp(name, option) == 0)
|
||||
return optlist;
|
||||
@ -369,7 +386,7 @@ int command_have_option(const char *cmd, const char *option)
|
||||
return FALSE;
|
||||
|
||||
for (tmp = rec->options; *tmp != NULL; tmp++) {
|
||||
char *name = iscmdtype(**tmp) ? (*tmp)+1 : *tmp;
|
||||
char *name = optname(*tmp);
|
||||
|
||||
if (g_ascii_strcasecmp(name, option) == 0)
|
||||
return TRUE;
|
||||
@ -399,7 +416,7 @@ static void command_calc_options(COMMAND_REC *rec, const char *options)
|
||||
|
||||
/* merge the options */
|
||||
for (tmp = optlist; *tmp != NULL; tmp++) {
|
||||
name = iscmdtype(**tmp) ? (*tmp)+1 : *tmp;
|
||||
name = optname(*tmp);
|
||||
|
||||
oldopt = optlist_find(list, name);
|
||||
if (oldopt != NULL) {
|
||||
@ -414,7 +431,7 @@ static void command_calc_options(COMMAND_REC *rec, const char *options)
|
||||
g_strfreev(optlist);
|
||||
|
||||
/* linked list -> string[] */
|
||||
str = gslist_to_string(list, " ");
|
||||
str = i_slist_to_string(list, " ");
|
||||
rec->options = g_strsplit(str, " ", -1);
|
||||
g_free(str);
|
||||
|
||||
@ -501,7 +518,7 @@ char *cmd_get_quoted_param(char **data)
|
||||
while (**data != '\0' && (**data != quote ||
|
||||
((*data)[1] != ' ' && (*data)[1] != '\0'))) {
|
||||
if (**data == '\\' && (*data)[1] != '\0')
|
||||
g_memmove(*data, (*data)+1, strlen(*data));
|
||||
memmove(*data, (*data)+1, strlen(*data));
|
||||
(*data)++;
|
||||
}
|
||||
|
||||
@ -529,7 +546,7 @@ static int option_find(char **array, const char *option)
|
||||
|
||||
found = -1; index = 0; multiple = FALSE;
|
||||
for (tmp = array; *tmp != NULL; tmp++, index++) {
|
||||
const char *text = *tmp + iscmdtype(**tmp);
|
||||
const char *text = optname(*tmp);
|
||||
|
||||
if (g_ascii_strncasecmp(text, option, len) == 0) {
|
||||
if (text[len] == '\0') {
|
||||
@ -568,9 +585,9 @@ static int get_cmd_options(char **data, int ignore_unknown,
|
||||
option = NULL; pos = -1;
|
||||
for (;;) {
|
||||
if (**data == '\0' || **data == '-') {
|
||||
if (option != NULL && *optlist[pos] == '+') {
|
||||
if (option != NULL && optflag(optlist[pos], "+")) {
|
||||
/* required argument missing! */
|
||||
*data = optlist[pos] + 1;
|
||||
*data = optname(optlist[pos]);
|
||||
return CMDERR_OPTION_ARG_MISSING;
|
||||
}
|
||||
}
|
||||
@ -621,14 +638,12 @@ static int get_cmd_options(char **data, int ignore_unknown,
|
||||
if (pos >= 0) {
|
||||
/* if we used a shortcut of parameter, put
|
||||
the whole parameter name in options table */
|
||||
option = optlist[pos] +
|
||||
iscmdtype(*optlist[pos]);
|
||||
option = optname(optlist[pos]);
|
||||
}
|
||||
if (options != NULL && pos != -3)
|
||||
g_hash_table_insert(options, option, "");
|
||||
|
||||
if (pos < 0 || !iscmdtype(*optlist[pos]) ||
|
||||
*optlist[pos] == '!')
|
||||
if (pos < 0 || optflag(optlist[pos], " !"))
|
||||
option = NULL;
|
||||
|
||||
while (**data == ' ') (*data)++;
|
||||
@ -638,7 +653,7 @@ static int get_cmd_options(char **data, int ignore_unknown,
|
||||
if (option == NULL)
|
||||
break;
|
||||
|
||||
if (*optlist[pos] == '@' && !is_numeric(*data, ' '))
|
||||
if (optflag(optlist[pos], "@") && !is_numeric(*data, ' '))
|
||||
break; /* expected a numeric argument */
|
||||
|
||||
/* save the argument */
|
||||
@ -725,8 +740,7 @@ int cmd_get_params(const char *data, gpointer *free_me, int count, ...)
|
||||
opthash = (GHashTable **) va_arg(args, GHashTable **);
|
||||
|
||||
rec->options = *opthash =
|
||||
g_hash_table_new((GHashFunc) g_istr_hash,
|
||||
(GCompareFunc) g_istr_equal);
|
||||
g_hash_table_new((GHashFunc) i_istr_hash, (GCompareFunc) i_istr_equal);
|
||||
|
||||
ignore_unknown = count & PARAM_FLAG_UNKNOWN_OPTIONS;
|
||||
error = get_cmd_options(&datad, ignore_unknown,
|
||||
@ -817,7 +831,7 @@ void commands_remove_module(const char *module)
|
||||
COMMAND_REC *rec = tmp->data;
|
||||
|
||||
next = tmp->next;
|
||||
modlist = gslist_find_string(rec->modules, module);
|
||||
modlist = i_slist_find_string(rec->modules, module);
|
||||
if (modlist != NULL)
|
||||
command_module_unbind_all(rec, modlist->data);
|
||||
}
|
||||
@ -851,8 +865,7 @@ static int cmd_protocol_match(COMMAND_REC *cmd, SERVER_REC *server)
|
||||
#define alias_runstack_pop(alias) \
|
||||
alias_runstack = g_slist_remove(alias_runstack, alias)
|
||||
|
||||
#define alias_runstack_find(alias) \
|
||||
(gslist_find_icase_string(alias_runstack, alias) != NULL)
|
||||
#define alias_runstack_find(alias) (i_slist_find_icase_string(alias_runstack, alias) != NULL)
|
||||
|
||||
static void parse_command(const char *command, int expand_aliases,
|
||||
SERVER_REC *server, void *item)
|
||||
|
@ -1,7 +1,7 @@
|
||||
#ifndef __COMMANDS_H
|
||||
#define __COMMANDS_H
|
||||
#ifndef IRSSI_CORE_COMMANDS_H
|
||||
#define IRSSI_CORE_COMMANDS_H
|
||||
|
||||
#include "signals.h"
|
||||
#include <irssi/src/core/signals.h>
|
||||
|
||||
typedef struct {
|
||||
SIGNAL_FUNC func;
|
||||
|
@ -21,33 +21,35 @@
|
||||
#include "module.h"
|
||||
#include <signal.h>
|
||||
|
||||
#include "args.h"
|
||||
#include "pidwait.h"
|
||||
#include "misc.h"
|
||||
#include <irssi/src/core/args.h>
|
||||
#include <irssi/src/core/pidwait.h>
|
||||
#include <irssi/src/core/misc.h>
|
||||
|
||||
#include "net-disconnect.h"
|
||||
#include "signals.h"
|
||||
#include "settings.h"
|
||||
#include "session.h"
|
||||
#include <irssi/src/core/net-disconnect.h>
|
||||
#include <irssi/src/core/signals.h>
|
||||
#include <irssi/src/core/settings.h>
|
||||
#include <irssi/src/core/session.h>
|
||||
#ifdef HAVE_CAPSICUM
|
||||
#include "capsicum.h"
|
||||
#include <irssi/src/core/capsicum.h>
|
||||
#endif
|
||||
|
||||
#include "chat-protocols.h"
|
||||
#include "servers.h"
|
||||
#include "chatnets.h"
|
||||
#include "commands.h"
|
||||
#include "expandos.h"
|
||||
#include "write-buffer.h"
|
||||
#include "log.h"
|
||||
#include "rawlog.h"
|
||||
#include "ignore.h"
|
||||
#include "recode.h"
|
||||
#include <irssi/src/core/chat-protocols.h>
|
||||
#include <irssi/src/core/chatnets.h>
|
||||
#include <irssi/src/core/commands.h>
|
||||
#include <irssi/src/core/expandos.h>
|
||||
#include <irssi/src/core/ignore.h>
|
||||
#include <irssi/src/core/log.h>
|
||||
#include <irssi/src/core/rawlog.h>
|
||||
#include <irssi/src/core/recode.h>
|
||||
#include <irssi/src/core/refstrings.h>
|
||||
#include <irssi/src/core/servers.h>
|
||||
#include <irssi/src/core/special-vars.h>
|
||||
#include <irssi/src/core/write-buffer.h>
|
||||
|
||||
#include "channels.h"
|
||||
#include "queries.h"
|
||||
#include "nicklist.h"
|
||||
#include "nickmatch-cache.h"
|
||||
#include <irssi/src/core/channels.h>
|
||||
#include <irssi/src/core/queries.h>
|
||||
#include <irssi/src/core/nicklist.h>
|
||||
#include <irssi/src/core/nickmatch-cache.h>
|
||||
|
||||
#ifdef HAVE_SYS_RESOURCE_H
|
||||
# include <sys/resource.h>
|
||||
@ -65,7 +67,8 @@ void wcwidth_wrapper_deinit(void);
|
||||
|
||||
int irssi_gui;
|
||||
int irssi_init_finished;
|
||||
int reload_config;
|
||||
int sighup_received;
|
||||
int sigterm_received;
|
||||
time_t client_start_time;
|
||||
|
||||
static char *irssi_dir, *irssi_config_file;
|
||||
@ -82,9 +85,14 @@ const char *get_irssi_config(void)
|
||||
return irssi_config_file;
|
||||
}
|
||||
|
||||
static void sig_reload_config(int signo)
|
||||
static void sig_hup(int signo)
|
||||
{
|
||||
reload_config = TRUE;
|
||||
sighup_received = TRUE;
|
||||
}
|
||||
|
||||
static void sig_term(int signo)
|
||||
{
|
||||
sigterm_received = TRUE;
|
||||
}
|
||||
|
||||
static void read_settings(void)
|
||||
@ -107,13 +115,19 @@ static void read_settings(void)
|
||||
sigemptyset (&act.sa_mask);
|
||||
act.sa_flags = 0;
|
||||
|
||||
/* reload config on SIGHUP */
|
||||
act.sa_handler = sig_reload_config;
|
||||
act.sa_handler = sig_hup;
|
||||
sigaction(SIGHUP, &act, NULL);
|
||||
|
||||
for (n = 0; n < sizeof(signals)/sizeof(signals[0]); n++) {
|
||||
act.sa_handler = find_substr(ignores, signames[n]) ?
|
||||
SIG_IGN : SIG_DFL;
|
||||
if (find_substr(ignores, signames[n])) {
|
||||
act.sa_handler = SIG_IGN;
|
||||
} else {
|
||||
/* set default handlers */
|
||||
if (signals[n] == SIGTERM)
|
||||
act.sa_handler = sig_term;
|
||||
else
|
||||
act.sa_handler = SIG_DFL;
|
||||
}
|
||||
sigaction(signals[n], &act, NULL);
|
||||
}
|
||||
|
||||
@ -222,6 +236,13 @@ static void sig_irssi_init_finished(void)
|
||||
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)
|
||||
{
|
||||
dialog_type_queue = NULL;
|
||||
@ -261,16 +282,23 @@ void core_init(void)
|
||||
nicklist_init();
|
||||
|
||||
chat_commands_init();
|
||||
i_refstr_init();
|
||||
special_vars_init();
|
||||
wcwidth_wrapper_init();
|
||||
|
||||
settings_add_str("misc", "ignore_signals", "");
|
||||
settings_add_bool("misc", "override_coredump_limit", FALSE);
|
||||
settings_add_bool("misc", "quit_on_hup", FALSE);
|
||||
settings_add_str("misc", "autoload_modules", "irc dcc flood notifylist perl otr");
|
||||
|
||||
#ifdef HAVE_SYS_RESOURCE_H
|
||||
getrlimit(RLIMIT_CORE, &orig_core_rlimit);
|
||||
#endif
|
||||
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);
|
||||
|
||||
settings_check();
|
||||
@ -283,9 +311,14 @@ void core_deinit(void)
|
||||
module_uniq_destroy("WINDOW ITEM TYPE");
|
||||
|
||||
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);
|
||||
|
||||
wcwidth_wrapper_deinit();
|
||||
special_vars_deinit();
|
||||
i_refstr_deinit();
|
||||
chat_commands_deinit();
|
||||
|
||||
nicklist_deinit();
|
||||
|
@ -1,7 +1,7 @@
|
||||
#ifndef __IRSSI_CORE_H
|
||||
#define __IRSSI_CORE_H
|
||||
#ifndef IRSSI_CORE_CORE_H
|
||||
#define IRSSI_CORE_CORE_H
|
||||
|
||||
#include "common.h"
|
||||
#include <irssi/src/common.h>
|
||||
|
||||
/* for determining what GUI is currently in use: */
|
||||
#define IRSSI_GUI_NONE 0
|
||||
@ -13,7 +13,8 @@
|
||||
|
||||
extern int irssi_gui;
|
||||
extern int irssi_init_finished; /* TRUE after "irssi init finished" signal is sent */
|
||||
extern int reload_config; /* TRUE after received SIGHUP. */
|
||||
extern int sighup_received; /* TRUE after received SIGHUP. */
|
||||
extern int sigterm_received; /* TRUE after received SIGTERM. */
|
||||
extern time_t client_start_time;
|
||||
|
||||
void core_preinit(const char *path);
|
||||
|
@ -18,20 +18,20 @@
|
||||
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*/
|
||||
|
||||
#include "core.h"
|
||||
#include <irssi/src/core/core.h>
|
||||
#include "module.h"
|
||||
#include "modules.h"
|
||||
#include "signals.h"
|
||||
#include "expandos.h"
|
||||
#include "settings.h"
|
||||
#include "commands.h"
|
||||
#include "misc.h"
|
||||
#include "irssi-version.h"
|
||||
#include <irssi/src/core/modules.h>
|
||||
#include <irssi/src/core/signals.h>
|
||||
#include <irssi/src/core/expandos.h>
|
||||
#include <irssi/src/core/settings.h>
|
||||
#include <irssi/src/core/commands.h>
|
||||
#include <irssi/src/core/misc.h>
|
||||
#include <irssi/irssi-version.h>
|
||||
|
||||
#include "servers.h"
|
||||
#include "channels.h"
|
||||
#include "queries.h"
|
||||
#include "window-item-def.h"
|
||||
#include <irssi/src/core/servers.h>
|
||||
#include <irssi/src/core/channels.h>
|
||||
#include <irssi/src/core/queries.h>
|
||||
#include <irssi/src/core/window-item-def.h>
|
||||
|
||||
#ifdef HAVE_SYS_UTSNAME_H
|
||||
# include <sys/utsname.h>
|
||||
@ -48,6 +48,8 @@ typedef struct {
|
||||
} EXPANDO_REC;
|
||||
|
||||
const char *current_expando = NULL;
|
||||
time_t reference_time = (time_t) -1;
|
||||
time_t current_time = (time_t)-1;
|
||||
|
||||
static int timer_tag;
|
||||
|
||||
@ -58,6 +60,7 @@ static char *last_privmsg_from, *last_public_from;
|
||||
static char *sysname, *sysrelease, *sysarch;
|
||||
|
||||
static char *timestamp_format;
|
||||
static char *timestamp_format_alt;
|
||||
static int timestamp_seconds;
|
||||
static time_t last_timestamp;
|
||||
|
||||
@ -440,12 +443,24 @@ static char *expando_time(SERVER_REC *server, void *item, int *free_ret)
|
||||
time_t now;
|
||||
struct tm *tm;
|
||||
char str[256];
|
||||
char *format;
|
||||
|
||||
now = time(NULL);
|
||||
now = current_time != (time_t) -1 ? current_time : time(NULL);
|
||||
tm = localtime(&now);
|
||||
format = timestamp_format;
|
||||
|
||||
if (strftime(str, sizeof(str), timestamp_format, tm) == 0)
|
||||
return "";
|
||||
if (reference_time != (time_t) -1) {
|
||||
time_t ref = reference_time;
|
||||
struct tm tm_ref;
|
||||
if (localtime_r(&ref, &tm_ref)) {
|
||||
if (tm_ref.tm_yday != tm->tm_yday || tm_ref.tm_year != tm->tm_year) {
|
||||
format = timestamp_format_alt;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (strftime(str, sizeof(str), format, tm) == 0)
|
||||
return "";
|
||||
|
||||
*free_ret = TRUE;
|
||||
return g_strdup(str);
|
||||
@ -575,7 +590,9 @@ static int sig_timer(void)
|
||||
static void read_settings(void)
|
||||
{
|
||||
g_free_not_null(timestamp_format);
|
||||
g_free_not_null(timestamp_format_alt);
|
||||
timestamp_format = g_strdup(settings_get_str("timestamp_format"));
|
||||
timestamp_format_alt = g_strdup(settings_get_str("timestamp_format_alt"));
|
||||
|
||||
timestamp_seconds =
|
||||
strstr(timestamp_format, "%r") != NULL ||
|
||||
@ -593,6 +610,7 @@ void expandos_init(void)
|
||||
#endif
|
||||
settings_add_str("misc", "STATUS_OPER", "*");
|
||||
settings_add_str("lookandfeel", "timestamp_format", "%H:%M");
|
||||
settings_add_str("lookandfeel", "timestamp_format_alt", "%a %e %b %H:%M");
|
||||
settings_add_bool("lookandfeel", "chanmode_expando_strip", FALSE);
|
||||
|
||||
last_sent_msg = NULL; last_sent_msg_body = NULL;
|
||||
@ -729,6 +747,7 @@ void expandos_deinit(void)
|
||||
g_free_not_null(sysrelease);
|
||||
g_free_not_null(sysarch);
|
||||
g_free_not_null(timestamp_format);
|
||||
g_free_not_null(timestamp_format_alt);
|
||||
|
||||
g_source_remove(timer_tag);
|
||||
signal_remove("message public", (SIGNAL_FUNC) sig_message_public);
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user