forked from PsychoticNinja/irssi
Compare commits
5 Commits
master
...
orphaned/i
Author | SHA1 | Date | |
---|---|---|---|
|
7e57e3415a | ||
|
b68c81f767 | ||
|
e2dfd6d165 | ||
|
87542831fe | ||
|
3c351ba018 |
@ -1,38 +0,0 @@
|
||||
# IndentPPDirectives: AfterHash
|
||||
# SpaceInParentheses: false
|
||||
AlignAfterOpenBracket: Align
|
||||
AlignConsecutiveAssignments: false
|
||||
AlignConsecutiveDeclarations: false
|
||||
AlignOperands: true
|
||||
AlignTrailingComments: true
|
||||
AllowAllParametersOfDeclarationOnNextLine: true
|
||||
AllowShortBlocksOnASingleLine: false
|
||||
AllowShortCaseLabelsOnASingleLine: false
|
||||
AllowShortFunctionsOnASingleLine: Empty
|
||||
AllowShortIfStatementsOnASingleLine: false
|
||||
AllowShortLoopsOnASingleLine: false
|
||||
AlwaysBreakAfterReturnType: None
|
||||
AlwaysBreakBeforeMultilineStrings: false
|
||||
BinPackArguments: true
|
||||
BinPackParameters: true
|
||||
BreakBeforeBinaryOperators: None
|
||||
BreakBeforeBraces: Linux
|
||||
BreakBeforeTernaryOperators: false
|
||||
ColumnLimit: 100
|
||||
IndentCaseLabels: false
|
||||
IndentWidth: 8
|
||||
IndentWrappedFunctionNames: true
|
||||
KeepEmptyLinesAtTheStartOfBlocks: false
|
||||
Language: Cpp
|
||||
Cpp11BracedListStyle: false
|
||||
MaxEmptyLinesToKeep: 1
|
||||
PointerAlignment: Right
|
||||
SortIncludes: false
|
||||
SpaceAfterCStyleCast: true
|
||||
SpaceBeforeAssignmentOperators: true
|
||||
SpaceBeforeParens: ControlStatements
|
||||
SpaceInEmptyParentheses: false
|
||||
SpacesInCStyleCastParentheses: false
|
||||
SpacesInSquareBrackets: false
|
||||
TabWidth: 8
|
||||
UseTab: ForIndentation
|
3
.gitattributes
vendored
3
.gitattributes
vendored
@ -1,3 +0,0 @@
|
||||
# On Windows, some Git clients may normalize all text files' line-endings to
|
||||
# CRLF, which causes obscure errors when running shell scripts.
|
||||
*.sh eol=lf
|
127
.github/workflows/abicheck.yml
vendored
127
.github/workflows/abicheck.yml
vendored
@ -1,127 +0,0 @@
|
||||
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
101
.github/workflows/check.yml
vendored
@ -1,101 +0,0 @@
|
||||
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
51
.github/workflows/cifuzz.yml
vendored
@ -1,51 +0,0 @@
|
||||
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
29
.github/workflows/clangformat.yml
vendored
@ -1,29 +0,0 @@
|
||||
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
79
.github/workflows/termuxpkg.yml
vendored
@ -1,79 +0,0 @@
|
||||
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
20
.github/workflows/trigger-pages.yml
vendored
@ -1,20 +0,0 @@
|
||||
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'
|
||||
})
|
40
.gitignore
vendored
40
.gitignore
vendored
@ -11,6 +11,7 @@ config.status
|
||||
configure
|
||||
default-config.h
|
||||
default-theme.h
|
||||
faq.txt
|
||||
irssi-config
|
||||
irssi-config.h
|
||||
irssi-config.h.in
|
||||
@ -23,18 +24,16 @@ ltversion.m4
|
||||
lt~obsolete.m4
|
||||
pm_to_blib
|
||||
stamp-h1
|
||||
MYMETA.*
|
||||
|
||||
docs/help/Makefile.am
|
||||
docs/help/[a-z]*
|
||||
!docs/help/meson.build
|
||||
!docs/help/in
|
||||
docs/help/in/Makefile.am
|
||||
|
||||
src/fe-text/irssi
|
||||
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
|
||||
@ -46,35 +45,11 @@ src/perl/ui/*.c
|
||||
src/perl/*/MYMETA.*
|
||||
src/perl/*/Makefile.old
|
||||
|
||||
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
|
||||
/tests/fe-common/core/test-suite.log
|
||||
/tests/irc/core/core
|
||||
/tests/irc/core/test-channel-events
|
||||
/tests/irc/core/test-channel-events.log
|
||||
/tests/irc/core/test-channel-events.trs
|
||||
/tests/irc/core/test-irc
|
||||
/tests/irc/core/test-irc.log
|
||||
/tests/irc/core/test-irc.trs
|
||||
/tests/irc/core/test-suite.log
|
||||
/tests/irc/flood/test-796
|
||||
/tests/irc/flood/test-796.log
|
||||
/tests/irc/flood/test-796.trs
|
||||
/tests/irc/flood/test-suite.log
|
||||
|
||||
*.a
|
||||
*.bs
|
||||
*.la
|
||||
*.lo
|
||||
*.o
|
||||
*.swp
|
||||
*~
|
||||
|
||||
*.tar.bz2
|
||||
@ -82,10 +57,3 @@ src/fe-fuzz/oom-*
|
||||
|
||||
.deps
|
||||
.libs
|
||||
|
||||
Build
|
||||
subprojects/*
|
||||
!subprojects/*.wrap
|
||||
Irssi-Dist
|
||||
setup.cfg
|
||||
*.egg-info
|
||||
|
@ -1,13 +0,0 @@
|
||||
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
|
26
.travis.yml
Normal file
26
.travis.yml
Normal file
@ -0,0 +1,26 @@
|
||||
sudo: false
|
||||
language: perl
|
||||
perl:
|
||||
- "5.20-shrplib"
|
||||
- "5.18-shrplib"
|
||||
- "system-perl"
|
||||
env:
|
||||
- CC=clang
|
||||
- CC=gcc
|
||||
|
||||
addons:
|
||||
apt:
|
||||
packages:
|
||||
- libperl-dev
|
||||
- elinks
|
||||
|
||||
before_install:
|
||||
- perl -V
|
||||
|
||||
install: true
|
||||
|
||||
script:
|
||||
- ./autogen.sh --with-proxy --with-bot --with-perl=module --prefix=$HOME/irssi-build
|
||||
- cat config.log
|
||||
- make
|
||||
- make install
|
26
AUTHORS
26
AUTHORS
@ -11,9 +11,6 @@ Irssi staff (current maintainers) <staff@irssi.org>:
|
||||
Jilles Tjoelker (jilles)
|
||||
Alexander Færøy (ahf)
|
||||
Jase Thew (bazerka)
|
||||
dequis (dx)
|
||||
Ailin Nemui (Nei)
|
||||
Giuseppe (TheLemonMan, lemonboy)
|
||||
|
||||
Former developers:
|
||||
|
||||
@ -27,8 +24,6 @@ Large feature patches by:
|
||||
Heikki Orsila : DCC SEND queueing
|
||||
Mark Trumbull : DCC SERVER
|
||||
Francesco Fracassi : Passive DCC
|
||||
Uli Meis : OTR support
|
||||
David Goulet : OTR support
|
||||
|
||||
Other patches (grep for "patch" in ChangeLog) by:
|
||||
|
||||
@ -79,25 +74,10 @@ Other patches (grep for "patch" in ChangeLog) by:
|
||||
Jon Mayo
|
||||
Johan Kiviniemi
|
||||
JasonX
|
||||
Lukas Mai (mauke)
|
||||
Lukas Mai
|
||||
Ismael Luceno
|
||||
Thomas Karpiniec
|
||||
Svante Kvarnström
|
||||
Ailin Nemui (Nei)
|
||||
Tom Feist (shabble)
|
||||
Sebastian Thorarensen (Sebban)
|
||||
Hans Nielsen
|
||||
Jari Matilainen (vague)
|
||||
Thibault B (isundil)
|
||||
kyak
|
||||
Vesa Pirila (Lohhari)
|
||||
Haw Loeung
|
||||
François Revol (mmuman)
|
||||
blha303
|
||||
Guillaume Brogi (guiniol)
|
||||
Adam-
|
||||
Robert C Jensen
|
||||
Paul Johnson
|
||||
KindOne
|
||||
Fabian Kurz
|
||||
Todd Pratt
|
||||
xavierog
|
||||
Sebastian Thorarensen
|
||||
|
108
INSTALL
108
INSTALL
@ -2,64 +2,77 @@
|
||||
Irssi installation instructions
|
||||
-------------------------------
|
||||
|
||||
To compile Irssi you need:
|
||||
To compile irssi you need:
|
||||
|
||||
- meson-0.53 build system with ninja-1.8 or greater
|
||||
- glib-2.32 or greater
|
||||
- glib-2.6 or greater
|
||||
- pkg-config
|
||||
- openssl (for ssl support)
|
||||
- perl-5.6 or greater (for Perl support)
|
||||
- terminfo or ncurses (for text frontend)
|
||||
- perl-5.6 or greater (for perl support)
|
||||
|
||||
For most people, this should work just fine:
|
||||
|
||||
meson Build
|
||||
ninja -C Build
|
||||
./configure
|
||||
make
|
||||
su
|
||||
ninja -C Build install
|
||||
|
||||
meson options
|
||||
make install (not _really_ required except for perl support)
|
||||
|
||||
These options can be given to meson.
|
||||
|
||||
For a complete list of options, run
|
||||
meson configure
|
||||
configure options
|
||||
|
||||
--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
|
||||
|
||||
-Dwith-proxy=yes
|
||||
--with-proxy
|
||||
|
||||
Build the Irssi proxy (see startup-HOWTO).
|
||||
Build the irssi proxy (see startup-HOWTO).
|
||||
|
||||
-Dwith-perl=[yes|no]
|
||||
--disable-ipv6
|
||||
|
||||
Disable IPv6 support.
|
||||
|
||||
--disable-ssl
|
||||
|
||||
Disable SSL support.
|
||||
|
||||
--with-perl=[yes|no|module]
|
||||
|
||||
Enable Perl support
|
||||
yes enable builtin (default)
|
||||
no disable
|
||||
module enable as module
|
||||
|
||||
-Dwith-perl-lib=[site|vendor|DIR]
|
||||
--with-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
|
||||
|
||||
-Dwith-bot=yes
|
||||
--with-socks
|
||||
|
||||
Build with socks library
|
||||
|
||||
--with-bot
|
||||
|
||||
Build irssi-bot
|
||||
|
||||
-Dwithout-textui=yes
|
||||
--without-textui
|
||||
|
||||
Build without text frontend
|
||||
|
||||
If anything is in non-standard path, you can just give the paths in
|
||||
the -Dc_args and -Dc_link_args options variable, eg.:
|
||||
If ncurses is installed in a non-standard path you can specify it with
|
||||
--with-ncurses=/path. If anything else is in non-standard path, you can just
|
||||
give the paths in CPPFLAGS and LIBS environment variable, eg.:
|
||||
|
||||
meson Build -Dc_args='-I/opt/openssl/include' -Dc_link_args='-L/opt/openssl/lib'
|
||||
CPPFLAGS=-I/opt/openssl/include LDFLAGS=-L/opt/openssl/lib ./configure
|
||||
|
||||
Irssi doesn't really need curses anymore, by default it uses
|
||||
terminfo/termcap directly. The functions for using terminfo/termcap
|
||||
however are usually only in curses library, some systems use libtermcap
|
||||
as well. If you want to use only curses calls for some reason, use
|
||||
--without-terminfo.
|
||||
|
||||
|
||||
Perl problems
|
||||
@ -68,43 +81,46 @@ the -Dc_args and -Dc_link_args options 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.
|
||||
- If meson complains that it doesn't find some perl stuff, you're
|
||||
- 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
|
||||
probably missing libperl.so or libperl.a. In debian, you'll need to do
|
||||
apt-get install libperl-dev
|
||||
- For unprivileged home directory installations, using the local::lib CPAN
|
||||
module is recommended. Read its docs, bootstrap it if needed, ensure that
|
||||
the environment variables are set before running the configure script, and
|
||||
append "--with-perl-lib=site" to the configure parameters to use it.
|
||||
|
||||
You can verify that the perl module is loaded and working with "/LOAD"
|
||||
command. It should print something like:
|
||||
|
||||
Module Type Submodules
|
||||
...
|
||||
perl dynamic fe core
|
||||
perl static core fe
|
||||
|
||||
|
||||
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:
|
||||
|
||||
- TODO
|
||||
- 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
|
||||
|
35
MANIFEST.in
35
MANIFEST.in
@ -1,35 +0,0 @@
|
||||
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/*
|
38
Makefile.am
Normal file
38
Makefile.am
Normal file
@ -0,0 +1,38 @@
|
||||
ACLOCAL_AMFLAGS = -I m4 ${ACLOCAL_FLAGS}
|
||||
|
||||
# create default-config.h
|
||||
BUILT_SOURCES = default-config.h default-theme.h irssi-version.h
|
||||
|
||||
@MAINTAINER_MODE_TRUE@.PHONY: irssi-version.h
|
||||
|
||||
default-config.h: $(srcdir)/irssi.conf
|
||||
$(srcdir)/file2header.sh $(srcdir)/irssi.conf default_config > default-config.h
|
||||
|
||||
default-theme.h: $(srcdir)/default.theme
|
||||
$(srcdir)/file2header.sh $(srcdir)/default.theme default_theme > default-theme.h
|
||||
|
||||
irssi-version.h:
|
||||
VERSION="$(VERSION)" $(srcdir)/irssi-version.sh $(srcdir) | \
|
||||
cmp -s - $@ || VERSION="$(VERSION)" $(srcdir)/irssi-version.sh $(srcdir) >$@
|
||||
|
||||
SUBDIRS = src docs scripts
|
||||
|
||||
confdir = $(sysconfdir)
|
||||
conf_DATA = irssi.conf
|
||||
|
||||
themedir = $(datadir)/irssi/themes
|
||||
theme_DATA = default.theme colorless.theme
|
||||
|
||||
pkginclude_HEADERS = irssi-config.h irssi-version.h
|
||||
|
||||
EXTRA_DIST = \
|
||||
ChangeLog \
|
||||
autogen.sh \
|
||||
README.md \
|
||||
file2header.sh \
|
||||
$(conf_DATA) \
|
||||
$(theme_DATA) \
|
||||
irssi-config.in \
|
||||
irssi-icon.png \
|
||||
irssi-version.sh \
|
||||
syntax.pl
|
896
NEWS
896
NEWS
@ -1,897 +1,9 @@
|
||||
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
|
||||
mIRC colours (#1059)
|
||||
- Fix memory leak on malformed CAP requests (#1120)
|
||||
- Fix an erroneous free of SASL data. Credit to Oss-Fuzz (#1128,
|
||||
#1130)
|
||||
- Re-set the TLS flag when reconnecting (#1027, #1134)
|
||||
- Fix the scrollback getting stuck after /clear (#1115, #1136)
|
||||
- Fix the input of Ctrl+C as the first character (#1153, #1154)
|
||||
- Fix crash on quit during unloading of modules on certain
|
||||
platforms (#1167)
|
||||
- Fix Irssi freezing input after Ctrl+Space on GLib >2.62 (#1180,
|
||||
#1183)
|
||||
- Fix layout of IDCHANs. By Lauri Tirkkonen (#1197)
|
||||
- Fix crash when server got reconnected before it was properly
|
||||
connected (#1210, #1211)
|
||||
- Fix multiple identical active caps (#1249)
|
||||
- Minor help corrections (#1156, #1213, #1214, #1255)
|
||||
- Remove erroneous colour in the colorless theme. Reported and
|
||||
fixed by Nutchanon Wetchasit (#1220, #1221)
|
||||
- Fix invalid bounds calculation when editing the text
|
||||
entry. Found and fixed by Sergey Valentey (#1269)
|
||||
- Fix passing of negative size in buffer writes. Found and
|
||||
fixed by Sergey Valentey (#1270)
|
||||
- Fix Irssi freezing on slow hardware and fast DCC transfers (#159,
|
||||
#1271)
|
||||
- Fix compilation on Solaris (#1291)
|
||||
- Fix null pointer dereference when receiving broken JOIN
|
||||
record. Credit to Oss-Fuzz (#1292)
|
||||
- Fix crash on /connect to some sockets (#1239, #1298)
|
||||
- Fix Irssi rendering on Apple ARM. By Misty De Méo (#1267,
|
||||
#1268, #1290)
|
||||
- Fix crash on /lastlog with broken lines (#1281, #1299)
|
||||
- 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>
|
||||
- Fix a use after free issue when receiving IRCv3 CAP
|
||||
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>
|
||||
! Contains all changes from 1.1.3
|
||||
- Fix a test on big endian machines (#1014)
|
||||
- Fix the compile time conditionality of wcwidth
|
||||
implementation (#1019, gentoo#677804, #720)
|
||||
- Fix /save no longer working on old Solaris (pre
|
||||
POSIX.1-2008) (#1042, #1043)
|
||||
- Fix regression of #764 where display of 8-bit (legacy
|
||||
encoding) in the input prompt was broken (#1018,
|
||||
#1057). Initial patch by Артём Курашов
|
||||
|
||||
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>
|
||||
- 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>
|
||||
! Contains all changes from 1.1.2
|
||||
* Improved the /STATUSBAR commands (#858)
|
||||
* /SET no longer shows `=' between setting and value (#886)
|
||||
* /CUBES removed from default config (available as script)
|
||||
(#956)
|
||||
* /1 /2 /3 ... removed from default config (available as new
|
||||
setting window_number_commands) (#958)
|
||||
* Always redraw the screen on resize. By David Phillips (#896)
|
||||
* 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, #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)
|
||||
+ Added activity_hide_visible setting (#990)
|
||||
+ Allow hiding of lines through the /IGNORE system (#901,
|
||||
#900, #892, #890, #884, #937)
|
||||
+ Add window_default_hidelevel setting. By Doug Freed (#941)
|
||||
+ Add activity_hide_window_hidelevel setting, defaulting to ON
|
||||
(#938)
|
||||
+ Add autolog_only_saved_channels setting, to autolog only
|
||||
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)
|
||||
gui_input_clear_extents(pos, len)
|
||||
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)
|
||||
+ Continue using separators when addressing multiple nicks
|
||||
with tab completion. By Manish Goregaokar (#822)
|
||||
+ Bind Shift-tab by default. By Niklas Luokkala (#830, #829)
|
||||
+ Fuzzing more things (#913, #780, #813)
|
||||
- Disconnect SASL properly in case the SASL module got
|
||||
unloaded from server (#931, #629, #618, #616)
|
||||
- Fix backward completion jumping to the first instead of last
|
||||
word (#979)
|
||||
- Improve empty topic handling (#961, #905, #911, #897, #888)
|
||||
- Prevent config truncation when no space left. By dequis and
|
||||
Lukas Waymann (#922, #925, #910, #909, #906, #871, #817)
|
||||
- Also time-out servers in lookup phase (#866, #130)
|
||||
- Fix build with LibreSSL 2.7. By Dorian Harmans (#865)
|
||||
- Fix a crash when appending to a textbuffer without
|
||||
line. Reported by Jari Matilainen (#862)
|
||||
- Fix segfault on sending large messages (#803, #796, #802)
|
||||
- Fix segfault on invalid statusbar config (#993, #994)
|
||||
- Fix random memory writes on restoring queries of foreign
|
||||
protocols (#999, #1000)
|
||||
- Make default keybinds deletable (#859, #507)
|
||||
- Fix freeze when resizing Irssi very small (#946)
|
||||
- Compare channels case-insensitively, avoiding confusions
|
||||
with the config file (#857, #856)
|
||||
- Fix DCC GET on Android. By Martin Staron (#844)
|
||||
- Improve rawlog performance (#957)
|
||||
- Fix nick escaping erroneously escaping quotes (#978, #974,
|
||||
#709)
|
||||
- Protect against theme recursion, improve padding
|
||||
performance, limit alignment padding. Credit to Oss-Fuzz
|
||||
(#835, #851, #850, #846, #848)
|
||||
- Fix recursive loop in replaces (#833, GL#23)
|
||||
- Fix headers for compilation of C modules (#939)
|
||||
- Documentation. By Zero King (#814). (#852)
|
||||
- Sync NEWS, docs, scripts (#849, #855)
|
||||
- Build system (#868, #867, #985, #988)
|
||||
- Fix build on IBM i and AIX. By Calvin Buckley (#975)
|
||||
- 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>
|
||||
- Fix the resetting of window hiddenlevel (#861)
|
||||
- Fix clearing of hidelevel in layout (#951)
|
||||
- Fix accessing unallocated text when checking entry position
|
||||
(#928, #930)
|
||||
- Fix uninitialised memory on empty lines (#873, GL#31, #878,
|
||||
#877, #907, #914)
|
||||
- Fix use-after-free on expiration of hidden lines (#948)
|
||||
- Fix use-after-frees. By Maya Rashish (#919)
|
||||
- Fix out of bounds access in help display when window width
|
||||
is small (#949)
|
||||
- Fix paste_join_multiline (#970, #971)
|
||||
- Correctly check for errno when displaying SSL errors. By
|
||||
Janik Rabe (#895)
|
||||
- Fix wrong signal emission argument count (#965)
|
||||
- Documentation (#920). Sync NEWS, scripts (#849)
|
||||
- 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>
|
||||
! 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>
|
||||
- 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,
|
||||
#812, #819, #824, #832).
|
||||
- Fix use after free when SASL messages are received in
|
||||
unexpected order (GL#26, GL!33).
|
||||
- Fix null pointer dereference in the tab completion when an
|
||||
empty nick is joined (GL#24, GL!31).
|
||||
- Fix use after free when entering oper password (GL#22,
|
||||
GL!32).
|
||||
- Fix null pointer dereference when too many windows are
|
||||
opened (GL#27, #837).
|
||||
- Fix out of bounds access in theme strings when the last
|
||||
escape is incomplete. Credit to Oss-Fuzz (#842).
|
||||
- Fix out of bounds write when using negative counts on window
|
||||
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>
|
||||
! Warning. Irssi is broken and will crash with OpenSSL < 1.0.2
|
||||
due to openssl/openssl commit
|
||||
5b4b9ce976fce09a7a92e2f25b91a1635cb840fe
|
||||
* Colour is now re-set when reaching a comma, matching mIRC
|
||||
behaviour (#742, #740, #790)
|
||||
* Irssi now shows the initial nick and name on first start
|
||||
(#785, #786)
|
||||
* lynx is no longer required to run autogen.sh (#81, #781)
|
||||
* The command history no longer permits wrapping around (#686)
|
||||
* /foreach now correctly sends arguments as commands, stopping
|
||||
you from embarassing AMSGs (#659)
|
||||
* /server does not connect to servers anymore, use /server
|
||||
connect to change servers (#559, #649).
|
||||
* The net_ip_compare API function is now deprecated, and the
|
||||
previously deprecated net_connect has been removed. By Will
|
||||
Storey (#770).
|
||||
+ Add an option to ignore all channels or ignore all queries
|
||||
using /set activity_hide_targets. By Jari Matilainen (#612,
|
||||
#779)
|
||||
+ Add a startup warning if the TERM var is wrong inside
|
||||
tmux/screen (#726)
|
||||
+ Add option to hide certain levels from the textbuffer using
|
||||
/window hidelevel (#746, #808)
|
||||
+ Irssi now has its first unit test (for mode parsing). By
|
||||
Will Storey (#793)
|
||||
+ Added access to global command history when using window
|
||||
history, and a binding to erase entries from the command
|
||||
history (erase_history_entry) (#762)
|
||||
+ -alternate_nick is now available as a network specific
|
||||
property. By Paul Townsend (#120, #771)
|
||||
+ On FreeBSD, Irssi now supports Capsicum sandbox (/capsicum
|
||||
enter). By Edward Tomasz Napierala (#735, #755, #772)
|
||||
+ Filenames (directories) ending with a / now tab-complete
|
||||
(#741)
|
||||
+ UTF-8 should now work in regular expressions when using
|
||||
GRegex (the default) (#636, #653)
|
||||
+ Nicks are now properly escaped on completion. By Oscar
|
||||
Linderholm (#693, #709)
|
||||
+ /server add -port <num> now works. By Jari Matilainen (#703)
|
||||
+ Add a setting key_timeout to make key sequences
|
||||
automatically re-set when not finished (#644, #645)
|
||||
+ Warn users about expired client certificates, as servers may
|
||||
refuse them (#211, #627)
|
||||
+ Add a new net_start_ssl function for StartTLS. This is
|
||||
available from ABI 8 and can be used by protocol modules
|
||||
(#615, #622).
|
||||
+ The %# code is now stored in the textbuffer, so for example
|
||||
web scripts can make use of it (#626)
|
||||
+ Add new setting break_wide which can be used to enable
|
||||
breaking of wide characters (for east-asian
|
||||
users). Originally from FreeBSD ports. (#625)
|
||||
+ Add fuzzing code (#610, #620, #701, #713)
|
||||
- Netsplits show properly again (#812)
|
||||
- Do not error on blank lines when using /exec -o. By Fabian
|
||||
Kurz (FS#902, #805)
|
||||
- Detect used nickname as reported by server. By Alexandre
|
||||
Morignot (#219, #804)
|
||||
- Prevent use after free error during the execution of some
|
||||
commands. Found by Joseph Bisch. (GL#17, GL!24)
|
||||
- Fix MODE parameter parsing when colon was used at a place
|
||||
Irssi didn't expect (#601, #766)
|
||||
- Fixed code to compile with
|
||||
-Werror=declaration-after-statement (#795)
|
||||
- Clang-format is now supported for git-clang-format (#784)
|
||||
- Fix use after free when changing the network of
|
||||
hilights. Reported by Rui Mathias. (#787, #788)
|
||||
- Fix positioning error when tab-completing non-ascii
|
||||
strings. (#752, #754)
|
||||
- In-development issues (#750, #751)
|
||||
- Clarify Alis in /help list (#699, #712)
|
||||
- Improve /lastlog performance from O(N^2) to O(N) (#715)
|
||||
- Fix a segfault on "script destroyed" signal. By Stephen
|
||||
Oberholtzer (#660, #661).
|
||||
- Fix early ISON error (#596, #647)
|
||||
- Documentation improvements. By Paolo Martini (#639).
|
||||
By Tristan Pepin (#731). By Paul Townsend (#684, #736).
|
||||
By Will Storey (#777)
|
||||
- Minor cleanups (#590). By Edward Tomasz Napierala (#734,
|
||||
#738)
|
||||
- Fix space issue in glib-2.0.m4 (#621)
|
||||
|
||||
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.
|
||||
- Fix invalid memory access when reading hilight configuration
|
||||
(#787, #788).
|
||||
- Fix null pointer dereference when the channel topic is set
|
||||
without specifying a sender (GL#20, GL!25).
|
||||
- Fix return of random memory when using incomplete escape
|
||||
codes (GL#21, GL!26).
|
||||
- Fix heap buffer overflow when completing certain strings
|
||||
(GL#19, GL!27).
|
||||
- Fix return of random memory when using an incomplete
|
||||
variable argument (GL#18, GL!28).
|
||||
|
||||
v1.0.5 2017-10-23 The Irssi team <staff@irssi.org>
|
||||
- Fix missing -sasl_method '' in /NETWORK (#718, #719).
|
||||
- Fix incorrect restoration of term state when hitting SUSP
|
||||
inside screen (#737, #733).
|
||||
- Fix out of bounds read when compressing colour
|
||||
sequences. Found by Hanno Böck (GL#12, GL!18).
|
||||
- Fix use after free condition during a race condition when
|
||||
waiting on channel sync during a rejoin (GL#13, GL!19).
|
||||
- Fix null pointer dereference when parsing certain malformed
|
||||
CTCP DCC messages (GL#14, GL!20).
|
||||
- Fix crash due to null pointer dereference when failing to
|
||||
split messages due to overlong nick or target (GL#15, GL!21).
|
||||
- Fix out of bounds read when trying to skip a safe channel ID
|
||||
without verifying that the ID is long enough (GL#16, GL!22).
|
||||
- Fix return of random memory when inet_ntop failed (#769).
|
||||
- Minor statusbar help update. By Robert Bisewski (#758,
|
||||
#763).
|
||||
|
||||
v1.0.4 2017-07-07 The Irssi team <staff@irssi.org>
|
||||
- Fix null pointer dereference when parsing invalid timestamp (GL#10,
|
||||
GL!15). Reported by Brian 'geeknik' Carpenter.
|
||||
- Fix use-after-free condition when removing nicks from the internal
|
||||
nicklist (GL#11, GL!16). Reported by Brian 'geeknik' Carpenter.
|
||||
- Fix incorrect string comparison in DCC file names (#714).
|
||||
- Fix regression in Irssi 1.0.3 where it would claim "Invalid time '-1'"
|
||||
(#716, #722).
|
||||
- Fix a bug when using \n to separate lines with expand_escapes (#723).
|
||||
- Retain screen output on improper exit, to better see any error
|
||||
messages (#287, #721).
|
||||
- Minor help update (#729).
|
||||
|
||||
v1.0.3 2017-06-06 The Irssi team <staff@irssi.org>
|
||||
! Regression info in 1.0.3: #716 Warnings on start up: invalid time '-1'
|
||||
- Fix out of bounds read when scanning expandos (GL!11).
|
||||
- Fix invalid memory access with quoted filenames in DCC
|
||||
(GL#8, GL!12).
|
||||
- Fix null-pointer dereference on DCC without address (GL#9, GL!13).
|
||||
- Improve integer overflow handling. Originally reported by
|
||||
oss-fuzz#525 (#706).
|
||||
- Improve nicklist performance from O(N^2) to O(N) (#705).
|
||||
- Fix initial screen redraw delay. By Stephen Oberholtzer
|
||||
(#680, bdo#856201).
|
||||
- Fix incorrect reset of true colours when resetting background. (#711).
|
||||
- Fix missing -notls option in /SERVER. By Jari Matilainen (#117, #702).
|
||||
- Fix minor history glitch on overcounter (#462, #685).
|
||||
- Improved OpenSSL detection at compile time. By Rodrigo Rebello (#677).
|
||||
- Improved NetBSD Terminfo detection. By Maya Rashish (#694, #698).
|
||||
- Add missing syntax info for COMPLETION (#687, #688).
|
||||
- Minor typo correction in help. By Michael Hansen (#707).
|
||||
|
||||
v1.0.2 2017-03-10 The Irssi team <staff@irssi.org>
|
||||
! Warning. Irssi is broken on GLib 2.46 (bgo#755496)
|
||||
- Prevent some null-pointer crashes (GL!9).
|
||||
- Fix compilation with OpenSSL 1.1.0 (#628, #597).
|
||||
- Correct dereferencing of already freed server objects during
|
||||
output of netjoins. Found by APic (GL!10, GL#7).
|
||||
- Fix in command arg parser to detect missing arguments in tail place
|
||||
(#652, #651).
|
||||
- Fix regression that broke incoming DCC file transfers (#667, #656).
|
||||
- Fix issue with escaping \ in evaluated strings (#669, #520).
|
||||
|
||||
v1.0.1 2017-02-03 The Irssi team <staff@irssi.org>
|
||||
- Fix Perl compilation in object dir. By Martijn Dekker (#602, #623).
|
||||
- Disable EC cryptography on Solaris to fix build (#604, #598).
|
||||
- Fix incorrect HELP SERVER example (#606, #519).
|
||||
- Correct memory leak in /OP and /VOICE. By Tim Konick (#608).
|
||||
- Fix regression that broke second level completion (#613, #609).
|
||||
- Correct missing NULL termination in perl_parse. By Hanno Böck (#619).
|
||||
- Sync broken mail.pl script (#624, #607).
|
||||
- Prevent a memory leak during the processing of the SASL
|
||||
response (GL!8, GL#5)
|
||||
|
||||
v1.0.0 2017-01-03 The Irssi team <staff@irssi.org>
|
||||
* Removed --disable-ipv6 (#408).
|
||||
* /connect Network now aborts with an error if no servers have been
|
||||
added to that network (#443).
|
||||
* /dcc commands now use quotes around spaces consistently.
|
||||
* bell_beeps was removed (#524, #565).
|
||||
* Switch to GRegex instead of regex.h (#412).
|
||||
+ irssiproxy can now forward all tags through a single
|
||||
port. By Lukas Mai (mauke, #425).
|
||||
+ irssiproxy can also listen on unix sockets. By Lukas Mai (#427).
|
||||
+ send channel -botcmds immediately when no mask is specified (#175, #399).
|
||||
+ the kill buffer now remembers consecutive kills.
|
||||
New bindings were added: yank_next_cutbuffer and append_next_kill
|
||||
By Todd A. Pratt (#353, #414, #455)
|
||||
+ connections will avoid looking up IPv6 addresses if the machine does
|
||||
not have an IPv6 address assigned (exact behaviour is implementation
|
||||
defined, #410).
|
||||
+ Fix potential crash if scripts insert undef values into the completion
|
||||
list (#413).
|
||||
+ Paste warning is now also shown on pasting overlong
|
||||
lines. By Manish Goregaokar (#426).
|
||||
+ autolog_ignore_targets and activity_hide_targets learn a new syntax
|
||||
tag/* and * to ignore whole networks or everything.
|
||||
By Jari Matilainen (vague666, #437)
|
||||
+ /hilight got a -matchcase flag to hilight case
|
||||
sensitively. By Thibault B (isundil, #421, #476).
|
||||
+ Always build irssi with TLS support.
|
||||
+ Rename SSL to TLS in the code and add -tls_* versions of the -ssl_*
|
||||
options to /CONNECT and /SERVER, but make sure the -ssl_* options continue
|
||||
to work.
|
||||
+ Use TLS for Freenode, EFnet, EsperNet, OFTC, Rizon, and IRC6 in the default
|
||||
configuration.
|
||||
+ Display TLS connection information upon connect. You can disable this by
|
||||
setting tls_verbose_connect to FALSE.
|
||||
+ Add -tls_pinned_cert and -tls_pinned_pubkey for x509 and public key pinning.
|
||||
|
||||
The values needed for -tls_pinned_cert and -tls_pinned_pubkey is shown
|
||||
when connecting to a TLS enabled IRC server, but you can also find the
|
||||
values like this: Start by downloading the certificate from a given IRC
|
||||
server:
|
||||
|
||||
$ openssl s_client -connect irc.example.net:6697 < /dev/null 2>/dev/null | \
|
||||
openssl x509 > example.cert
|
||||
|
||||
Find the value for -tls_pinned_cert:
|
||||
|
||||
$ openssl x509 -in example.cert -fingerprint -sha256 -noout
|
||||
|
||||
Find the value for -tls_pinned_pubkey:
|
||||
|
||||
$ openssl x509 -in example.cert -pubkey -noout | \
|
||||
openssl pkey -pubin -outform der | \
|
||||
openssl dgst -sha256 -c | \
|
||||
tr a-z A-Z
|
||||
|
||||
+ Remove support for DANE validation of TLS certificates.
|
||||
|
||||
There wasn't enough support in the IRC community to push for this on the
|
||||
majority of bigger IRC networks. If you believe this should be
|
||||
reintroduced into irssi, then please come up with an implementation that
|
||||
does not rely on the libval library. It is causing a lot of troubles for
|
||||
our downstream maintainers.
|
||||
|
||||
+ /names and $[...] now uses utf8 string operations. By Xavier
|
||||
G. (#40, #411, #471, #480).
|
||||
+ New setting completion_nicks_match_case (#488).
|
||||
+ /channel /server /network now support modify subcommand. By
|
||||
Jari Matilainen (#338, #498).
|
||||
+ Irssi::signal_remove now works with coderefs. By Tom Feist (shabble, #512).
|
||||
+ /script reset got an -autorun switch (#540, #538).
|
||||
+ cap_toggle can now be called from Perl, and fields
|
||||
cap_active and cap_supported can be inspected (#542).
|
||||
+ Make it possible to disable empty line completion. By Lauri
|
||||
Tirkkonen (lotheac, #574).
|
||||
+ New option sasl_disconnect_on_failure to disconnect when
|
||||
SASL log-in failed (#514).
|
||||
- IP addresses are no longer stored when resolve_reverse_lookup is
|
||||
used.
|
||||
- Removed broken support for curses (#521).
|
||||
- Removed broken dummy mode (#526).
|
||||
- Fix terminal state after suspend (#450, #452).
|
||||
- Improve Perl library path detection (#479, #132).
|
||||
- Reconnect now works on unix connections (#493).
|
||||
- Fix completion warnings (#125, #496, FS#124).
|
||||
- Fix a crash in the --more-- item (#501).
|
||||
- Fix a display issue in /unignore (#517, bdo#577202).
|
||||
- Fix a crash in some netsplits (#529, #500).
|
||||
- Fix crashes with some invalid config (#550, #551, #563, #564, #587, #581, #570).
|
||||
- Add support for SASL Fragmentation. By Kenny Root (kruton, #506).
|
||||
- Improve netsplit dumping (#420, #465).
|
||||
- Improve responsibility under DCC I/O strain (#578, #159).
|
||||
- Fix query nick change on open (#580, #586).
|
||||
- Correct a few help texts.
|
||||
|
||||
v0.8.21 2017-01-03 The Irssi team <staff@irssi.org>
|
||||
- Correct a NULL pointer dereference in the nickcmp function found by
|
||||
Joseph Bisch (GL#1)
|
||||
- Correct an out of bounds read in certain incomplete control codes
|
||||
found by Joseph Bisch (GL#2)
|
||||
- Correct an out of bounds read in certain incomplete character
|
||||
sequences found by Hanno Böck and independently by J. Bisch (GL#3)
|
||||
- Correct an error when receiving invalid nick message (GL#4, #466)
|
||||
|
||||
v0.8.20 2016-09-16 The Irssi team <staff@irssi.org>
|
||||
- Correct the name of an emitted sasl signal (#484)
|
||||
- Correct the prototype for the 'message private' signal (#515)
|
||||
- Corrections in away and hilight help text (#477, #518)
|
||||
- /squery and /servlist commands have been restored (#461).
|
||||
- Where Irssi would previously only report "System error" on connect,
|
||||
it will now try harder to retrieve the system error message (#467).
|
||||
- Fixed issue with +channels not working properly (#533)
|
||||
- Fixed crash in optchan when item has no server (#485, bdo#826525)
|
||||
- Fixed random remote crash in the nicklist handling (#529)
|
||||
- Fixed remote crash due to incorrect bounds checking on
|
||||
formats, reported by Gabriel Campana and Adrien Guinet from
|
||||
Quarkslab.
|
||||
|
||||
v0.8.19 2016-03-23 The Irssi team <staff@irssi.org>
|
||||
! If your cursor keys stopped working, try this first: `/bind
|
||||
meta-O key meta2'
|
||||
- Fixed regression when joining and parting channels on IRCnet (#435)
|
||||
- Fixed SASL EXTERNAL. By Mantas Mikulėnas (grawity, #432)
|
||||
- Fixed regression when not using SASL (#438)
|
||||
- Fixed incorrect SSL disconnects when using SSL from modules/scripts.
|
||||
By Will Storey (horgh, #439)
|
||||
- Fixed regression where proxy_string could not be configured or
|
||||
certain file transfers could not be accepted (#445, #446)
|
||||
- Fixed storing layout of !channels (#183, #405)
|
||||
- Fixed restoration of bracketed paste mode on quit (#449, #457)
|
||||
- Make the usage of meta-O for cursor keys configurable with
|
||||
/set term_appkey_mode off
|
||||
(#430, #459)
|
||||
|
||||
v0.8.18 2016-02-13 The Irssi team <staff@irssi.org>
|
||||
* Modules will now require to define a
|
||||
|
||||
void MODULENAME ## _abicheck(int *version)
|
||||
|
||||
method to ensure that they are compiled against the correct Irssi
|
||||
version.
|
||||
* The signature of "message private" has been changed to
|
||||
|
||||
5: server, message, nick, address, target
|
||||
|
||||
in order to support "self messages". Module authors should
|
||||
implement this change if they are using this signal.
|
||||
* Removing networks will now remove all attached servers and channels
|
||||
(#45).
|
||||
* The proxy module now has an /irssiproxy command.
|
||||
* sb_search has been moved to scripts.irssi.org
|
||||
* WIN32 has been completely removed (it had not been working and is
|
||||
lacking a maintainer.)
|
||||
* Garbage Collection support has been removed. This will hardly have any
|
||||
v0.8.18-head 2014-XX-YY The Irssi team <staff@irssi.org>
|
||||
+ Garbage Collection support has been removed. This will hardly have any
|
||||
effect for anyone given that it has been unsupported for several years.
|
||||
+ CAP SASL PLAIN login is now supported natively.
|
||||
+ Paste bracket markers can be requested from terminal with
|
||||
|
||||
/set paste_use_bracketed_mode on
|
||||
|
||||
+ "Self messages" generated by some bouncers can now be received in the
|
||||
proper window.
|
||||
+ Try to split long lines on spaces to avoid words being splitted. Adds
|
||||
a new option: `split_line_on_space' which defaults to on.
|
||||
+ Add setting `hilight_nick_matches_everywhere' (#56).
|
||||
+ The config parser is more robust and prints out better diagnostics on
|
||||
incorrect config files.
|
||||
+ Ctrl+^ (FS#721) and Ctrl+J can now be bound.
|
||||
+ Command history can be cleared with /window history -clear
|
||||
+ /hilight -mask -line is now supported (FS#275).
|
||||
+ CHANTYPES are now supported.
|
||||
+ Improved reload speed of ignores.
|
||||
+ Add -date feature to /lastlog
|
||||
+ irssiproxy can be more easily enabled and disabled.
|
||||
+ Expando for hostname (FS#829).
|
||||
+ UNIX sockets can now also be specified in the config file.
|
||||
+ Disable SSLv3 due to the POODLE vulnerability.
|
||||
+ SSL ciphers can now be specified per server.
|
||||
+ Added SNI support for SSL.
|
||||
- /ignore now respects -pattern on merge (#78).
|
||||
- irssiproxy (BNC) module now uses correct line endings.
|
||||
- Fix missing lines on large pastes (FS#905).
|
||||
- Correctly preserve STATUSMSG prefixes (#291).
|
||||
- Fix infinite recursion in key bindings (FS#817).
|
||||
- Fix incomplete awaylog caused by buffering.
|
||||
- Fix calculation of UTF-8 string length display in some cases.
|
||||
- Fix some Perl warnings related to @ISA.
|
||||
- EXEC windowitems now get proper references on the Perl side.
|
||||
- Incremental help file improvements.
|
||||
- ANSI attributes are now properly reset.
|
||||
- Fixed regression where text would blink when terminal lacks color
|
||||
support.
|
||||
- Permit the usage of Freenode extban syntax in /ban (#150)
|
||||
- Fixed regression in scriptassist on unload of scripts.
|
||||
- Fixed regression in -actcolor %n
|
||||
+ Try to split long lines on spaces to avoid words being splitted. Adds
|
||||
a new option: 'split_line_on_space' which defaults to on.
|
||||
|
||||
v0.8.17 2014-10-11 The Irssi team <staff@irssi.org>
|
||||
+ Document that SSL connections aren't properly handled during /UPGRADE. See Github PR #39.
|
||||
|
137
README.md
137
README.md
@ -1,74 +1,109 @@
|
||||
# [Irssi](https://irssi.org)
|
||||
# Irssi
|
||||
|
||||

|
||||
[](https://travis-ci.org/irssi/irssi)
|
||||
|
||||
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),
|
||||
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. We have a working but currently unmaintained GTK2 frontend
|
||||
called xirssi. Irssi 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
|
||||
[PSYC](https://github.com/electric-blue/irssyc) and
|
||||
[Quassel](https://github.com/phhusson/quassel-irssi) protocol modules
|
||||
available.
|
||||
|
||||

|
||||
## Installation
|
||||
|
||||
## [Download information](https://irssi.org/download/)
|
||||
See the `INSTALL` file.
|
||||
|
||||
#### Development source installation
|
||||
## Features
|
||||
|
||||
[Ninja](https://ninja-build.org/) 1.8 and [Meson](https://mesonbuild.com/) 0.53
|
||||
So what's so great about Irssi? Here's a list of some features I can
|
||||
think of currently:
|
||||
|
||||
```
|
||||
git clone https://github.com/irssi/irssi
|
||||
cd irssi
|
||||
meson Build
|
||||
ninja -C Build && sudo ninja -C Build install
|
||||
```
|
||||
- **Optional automation** - There's lots of things Irssi does for you
|
||||
automatically that some people like and others just hate. Things like:
|
||||
nick completion, creating new window for newly joined channel, creating
|
||||
queries when msgs/notices are received or when you send a msg, closing
|
||||
queries when it's been idle for some time, etc.
|
||||
|
||||
#### Release source installation
|
||||
- **Multiserver friendy** - I think Irssi has clearly the best support
|
||||
for handling multiple server connections. You can have as many as you
|
||||
want in as many ircnets as you want. Having several connections in one
|
||||
server works too, for example when you hit the (ircnet's) 10
|
||||
channels/connection limit you can just create another connection and
|
||||
you hardly notice it. If connection to server is lost, Irssi tries to
|
||||
connect back until it's successful. Also channels you were joined
|
||||
before disconnection are restored, even if they're "temporarily
|
||||
unavailable" because of netsplits, Irssi keeps rejoining back to them.
|
||||
Also worth noticing - there's not that stupid "server is bound to this
|
||||
window, if this window gets closed the connection closes" thing that
|
||||
ircII based clients have.
|
||||
|
||||
* Download [release](https://github.com/irssi/irssi/releases)
|
||||
* Verify signature
|
||||
```
|
||||
tar xJf irssi-*.tar.xz
|
||||
cd irssi-*
|
||||
meson Build
|
||||
ninja -C Build && sudo ninja -C Build install
|
||||
```
|
||||
- **Channel automation** - You can specify what channels to join to
|
||||
immediately after connected to some server or IRC network. After joined
|
||||
to channel, Irssi can automatically request ops for you (or do
|
||||
anything, actually) from channel's bots.
|
||||
|
||||
### Requirements
|
||||
- **Window content saving** - Say /LAYOUT SAVE when you've put all the
|
||||
channels and queries to their correct place, and after restarting
|
||||
Irssi, the channels will be joined back into windows where they were
|
||||
saved.
|
||||
|
||||
- [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)
|
||||
- **Tab completing anything** - You can complete lots of things with tab:
|
||||
nicks, commands, command -options, file names, settings, text format
|
||||
names, channels and server names. There's also an excellent /msg
|
||||
completion that works transparently with multiple IRC networks.
|
||||
Completing channel nicks is also pretty intelligent, it first goes
|
||||
through the people who have talked to you recently, then the people who
|
||||
have talked to anyone recently and only then it fallbacks to rest of
|
||||
the nicks. You can also complete a set of words you've specified, for
|
||||
example homepage<tab> changes it to your actual home page URL.
|
||||
|
||||
#### See the [INSTALL](INSTALL) file for details
|
||||
- **Excellent logging** - You can log any way you want and as easily or
|
||||
hard as you want. With autologging Irssi logs everything to specified
|
||||
directory, one file per channel/nick. ircII style /WINDOW LOG ON is
|
||||
also supported. There's also the "hard way" of logging - /LOG command
|
||||
which lets you specify exactly what you wish to log and where. Log
|
||||
rotating is supported with all the different logging methods, you can
|
||||
specify how often you want it to rotate and what kind of time stamp to
|
||||
use.
|
||||
|
||||
## [Documentation](https://irssi.org/documentation/)
|
||||
- **Excellent ignoring** - You can most probably ignore anything any way
|
||||
you want. Nick masks, words, regular expressions. You can add
|
||||
exceptions to ignores. You can ignore other people's replies in
|
||||
channels to nicks you have ignored. You can also specify that the
|
||||
specific ignores work only in specific channel(s).
|
||||
|
||||
* [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
|
||||
- **Lastlog and scrollback handling** - /LASTLOG command has some new
|
||||
features: -new option checks only lines that came since you last did
|
||||
/LASTLOG command, -away option checks new lines since you last went
|
||||
away. Regular expression matches work also, of course. Going to some
|
||||
wanted place at scrollback has always been hard with non-GUI clients. A
|
||||
search command that jumps around in scrollback in GUI-style is still
|
||||
missing from Irssi, but there's something that's almost as good as it.
|
||||
/LASTLOG always shows timestamps when the line was printed, even if you
|
||||
didn't have timestamps on. Now doing /SB GOTO <timestamp> jumps
|
||||
directly to the position in scrollback you wanted. Great feature when
|
||||
you want to browse a bit of the discussion what happened when someone
|
||||
said your name (as seen in awaylog) or topic was changed (/last
|
||||
-topics)
|
||||
|
||||
## [Themes](https://irssi-import.github.io/themes/)
|
||||
## Files
|
||||
|
||||
## [Scripts](https://scripts.irssi.org/)
|
||||
- The `docs/` directory contains several documents:
|
||||
- `startup-HOWTO.txt` - new users should read this
|
||||
- `manual.txt` - manual I started writing but didn't get it very far :)
|
||||
- `perl.txt` - Perl scripting help
|
||||
- `formats.txt` - How to use colors, etc. with irssi
|
||||
- `faq.txt` - Frequently Asked Questions
|
||||
- `special_vars.txt` - some predefined $variables you can use with irssi
|
||||
|
||||
## [Modules](https://irssi.org/modules/)
|
||||
## Bugs / Suggestions
|
||||
|
||||
## [Security information](https://irssi.org/security/)
|
||||
See the `TODO` file, http://bugs.irssi.org and 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).
|
||||
|
||||
Please report security issues to staff@irssi.org. Thanks!
|
||||
|
||||
## [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).
|
||||
|
||||
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 irc.libera.chat.
|
||||
You can also contact the Irssi developers in #irssi on freenode.
|
||||
|
31
acconfig.h
Normal file
31
acconfig.h
Normal file
@ -0,0 +1,31 @@
|
||||
/* misc.. */
|
||||
#undef HAVE_IPV6
|
||||
#undef HAVE_SOCKS_H
|
||||
#undef HAVE_STATIC_PERL
|
||||
#undef HAVE_GMODULE
|
||||
|
||||
/* macros/curses checks */
|
||||
#undef HAS_CURSES
|
||||
#undef USE_SUNOS_CURSES
|
||||
#undef USE_BSD_CURSES
|
||||
#undef USE_SYSV_CURSES
|
||||
#undef USE_NCURSES
|
||||
#undef NO_COLOR_CURSES
|
||||
#undef SCO_FLAVOR
|
||||
|
||||
/* our own curses checks */
|
||||
#undef HAVE_NCURSES_USE_DEFAULT_COLORS
|
||||
#undef HAVE_CURSES_IDCOK
|
||||
#undef HAVE_CURSES_RESIZETERM
|
||||
#undef HAVE_CURSES_WRESIZE
|
||||
|
||||
/* terminfo/termcap */
|
||||
#undef HAVE_TERMINFO
|
||||
|
||||
/* What type should be used for uoff_t */
|
||||
#undef UOFF_T_INT
|
||||
#undef UOFF_T_LONG
|
||||
#undef UOFF_T_LONG_LONG
|
||||
|
||||
/* printf()-format for uoff_t, eg. "u" or "lu" or "llu" */
|
||||
#undef PRIuUOFF_T
|
67
autogen.sh
Executable file
67
autogen.sh
Executable file
@ -0,0 +1,67 @@
|
||||
#!/bin/sh
|
||||
# Run this to generate all the initial makefiles, etc.
|
||||
|
||||
PKG_NAME="Irssi"
|
||||
|
||||
srcdir=`dirname $0`
|
||||
test -z "$srcdir" && srcdir=.
|
||||
|
||||
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
|
||||
|
||||
# create help files
|
||||
echo "Creating help files..."
|
||||
perl syntax.pl
|
||||
|
||||
echo "Creating ChangeLog..."
|
||||
git log > $srcdir/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
|
||||
|
||||
# .html -> .txt with lynx or elinks
|
||||
echo "Documentation: html -> txt..."
|
||||
if type lynx >/dev/null 2>&1 ; then
|
||||
LC_ALL=C lynx -dump docs/faq.html|perl -pe 's/^ *//; if ($_ eq "\n" && $state eq "Q") { $_ = ""; } elsif (/^([QA]):/) { $state = $1 } elsif ($_ ne "\n") { $_ = " $_"; };' > docs/faq.txt
|
||||
elif type elinks >/dev/null 2>&1 ; then
|
||||
elinks -dump docs/faq.html|perl -pe 's/^ *//; if ($_ eq "\n" && $state eq "Q") { $_ = ""; } elsif (/^([QA]):/) { $state = $1 } elsif ($_ ne "\n") { $_ = " $_"; };' > docs/faq.txt
|
||||
elif type links >/dev/null 2>&1 ; then
|
||||
links -dump docs/faq.html|perl -pe 's/^ *//; if ($_ eq "\n" && $state eq "Q") { $_ = ""; } elsif (/^([QA]):/) { $state = $1 } elsif ($_ ne "\n") { $_ = " $_"; };' > docs/faq.txt
|
||||
else
|
||||
echo "**Error**: No lynx or elinks present"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
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 1
|
||||
|
||||
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
|
||||
|
||||
# make sure perl hashes have correct length
|
||||
find src/perl -name *.c -o -name *.xs | xargs grep -n hv_store | perl -ne 'if (/"(\w+)",\s*(\d+)/) { print unless $2 == length $1 }'
|
@ -251,7 +251,6 @@ abstracts = {
|
||||
# default background for all statusbars. You can also give
|
||||
# the default foreground color for statusbar items.
|
||||
sb_background = "%8";
|
||||
window_border = "%8";
|
||||
|
||||
# default backround for "default" statusbar group
|
||||
#sb_default_bg = "%8";
|
||||
@ -262,8 +261,8 @@ abstracts = {
|
||||
# background for topicbar (same default)
|
||||
#sb_topic_bg = "%8";
|
||||
|
||||
# text at the beginning of statusbars. "sb" already puts a space there,
|
||||
# so we don't use anything by default.
|
||||
# text at the beginning of statusbars. sb-item already puts
|
||||
# space there,so we don't use anything by default.
|
||||
sbstart = "";
|
||||
# text at the end of statusbars. Use space so that it's never
|
||||
# used for anything.
|
760
configure.ac
Normal file
760
configure.ac
Normal file
@ -0,0 +1,760 @@
|
||||
AC_INIT(irssi, 0.8.18-head)
|
||||
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])
|
||||
|
||||
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 regex.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(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(terminfo,
|
||||
[ --without-terminfo Use curses backend instead of terminfo],
|
||||
if test x$withval = xno; then
|
||||
want_terminfo=no
|
||||
else
|
||||
want_terminfo=yes
|
||||
fi,
|
||||
want_terminfo=yes)
|
||||
|
||||
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_library_dir="PERL_USE_LIB"
|
||||
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=[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" = xsite; then
|
||||
want_perl=yes
|
||||
perl_prefix_note=no
|
||||
PERL_MM_PARAMS=""
|
||||
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=`perl -e 'use Config; print $Config{prefix}'`"
|
||||
fi
|
||||
perl_library_dir="(vendor default - `$perlpath -e 'use Config; print $Config{archlib}'`)"
|
||||
else
|
||||
want_perl=yes
|
||||
perl_prefix_note=no
|
||||
PERL_MM_PARAMS="INSTALLDIRS=perl LIB=$withval"
|
||||
perl_library_dir="PERL_USE_LIB"
|
||||
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_ENABLE(ipv6,
|
||||
[ --disable-ipv6 Disable IPv6 support],
|
||||
if test x$enableval = xno; then
|
||||
want_ipv6=no
|
||||
else
|
||||
want_ipv6=yes
|
||||
fi,
|
||||
want_ipv6=yes)
|
||||
|
||||
AC_ARG_ENABLE(dane,
|
||||
[ --enable-dane Enable DANE support],
|
||||
if test x$enableval = xno ; then
|
||||
want_dane=no
|
||||
else
|
||||
want_dane=yes
|
||||
fi,
|
||||
want_dane=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)
|
||||
|
||||
dnl **
|
||||
dnl ** SSL Library checks (OpenSSL)
|
||||
dnl **
|
||||
|
||||
AC_ARG_ENABLE(ssl,
|
||||
[ --disable-ssl Disable Secure Sockets Layer support],,
|
||||
enable_ssl=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], [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.16.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"
|
||||
|
||||
have_openssl=no
|
||||
if test "$enable_ssl" = "yes"; then
|
||||
PKG_CHECK_MODULES(SSL, openssl, :, :)
|
||||
if test "$SSL_LIBS"; then
|
||||
CFLAGS="$CFLAGS $SSL_CFLAGS"
|
||||
have_openssl=yes
|
||||
else
|
||||
AC_CHECK_LIB(ssl, SSL_read, [
|
||||
AC_CHECK_HEADERS(openssl/ssl.h openssl/err.h, [
|
||||
SSL_LIBS="-lssl -lcrypto"
|
||||
have_openssl=yes
|
||||
])
|
||||
],, -lcrypto)
|
||||
fi
|
||||
if test "$have_openssl" = "yes"; then
|
||||
AC_DEFINE(HAVE_OPENSSL,, Build with OpenSSL support)
|
||||
LIBS="$LIBS $SSL_LIBS"
|
||||
fi
|
||||
fi
|
||||
|
||||
dnl **
|
||||
dnl ** curses checks
|
||||
dnl **
|
||||
|
||||
if test "x$want_textui" = "xyes"; then
|
||||
AC_CHECK_CURSES
|
||||
|
||||
TEXTUI_LIBS="$CURSES_LIBS"
|
||||
if test "x$has_curses" = "xtrue"; then
|
||||
old_libs=$LIBS
|
||||
LIBS="$LIBS $CURSES_LIBS"
|
||||
if test $want_terminfo = no; then
|
||||
AC_CHECK_FUNC(use_default_colors, AC_DEFINE(HAVE_NCURSES_USE_DEFAULT_COLORS))
|
||||
AC_CHECK_FUNC(idcok, AC_DEFINE(HAVE_CURSES_IDCOK))
|
||||
AC_CHECK_FUNC(resizeterm, AC_DEFINE(HAVE_CURSES_RESIZETERM))
|
||||
AC_CHECK_FUNC(wresize, AC_DEFINE(HAVE_CURSES_WRESIZE))
|
||||
fi
|
||||
AC_CHECK_FUNC(setupterm,, [
|
||||
want_termcap=yes
|
||||
])
|
||||
LIBS=$old_libs
|
||||
else
|
||||
AC_CHECK_LIB(tinfo, setupterm, [
|
||||
TEXTUI_LIBS="-ltinfo"
|
||||
want_terminfo=yes
|
||||
], AC_CHECK_LIB(termlib, tgetent, [
|
||||
TEXTUI_LIBS="-ltermlib"
|
||||
want_termcap=yes
|
||||
], AC_CHECK_LIB(termcap, tgetent, [
|
||||
TEXTUI_LIBS="-ltermcap"
|
||||
want_termcap=yes
|
||||
], [
|
||||
AC_ERROR(Terminfo/termcap not found - install libncurses-dev or ncurses-devel package)
|
||||
want_textui=no
|
||||
])))
|
||||
fi
|
||||
AC_SUBST(TEXTUI_LIBS)
|
||||
|
||||
if test "x$want_termcap" = "xyes"; then
|
||||
AC_CHECK_FUNC(tparm,, need_tparm=yes)
|
||||
else
|
||||
AC_DEFINE(HAVE_TERMINFO)
|
||||
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
|
||||
PERL_CFLAGS=`echo $PERL_CFLAGS | $perlpath -pe 's/^(.* )?-[^DUIfm][^ ]+/\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
|
||||
|
||||
# figure out the correct @INC path - we'll need to do this
|
||||
# through MakeMaker since it's difficult to get it right
|
||||
# otherwise.
|
||||
if test "x$perl_set_use_lib" = "xyes"; then
|
||||
perl -e 'use ExtUtils::MakeMaker; WriteMakefile("NAME" => "test", "MAKEFILE" => "Makefile.test");' $PERL_MM_PARAMS >/dev/null
|
||||
PERL_USE_LIB=`perl -e 'open(F, "Makefile.test"); while (<F>) { chomp; if (/^(\w+) = (.*$)/) { $keys{$1} = $2; } }; $key = $keys{INSTALLARCHLIB}; while ($key =~ /\\$\((\w+)\)/) { $value = $keys{$1}; $key =~ s/\\$\($1\)/$value/; }; print $key;'`
|
||||
rm -f Makefile.test
|
||||
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_PARAMS)
|
||||
AC_SUBST(PERL_STATIC_LIBS)
|
||||
fi
|
||||
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_IRSSIPROXY, test "$want_irssiproxy" = "yes")
|
||||
AM_CONDITIONAL(HAVE_PERL, test "$want_perl" != "no")
|
||||
AM_CONDITIONAL(NEED_TPARM, test "$need_tparm" = "yes")
|
||||
AM_CONDITIONAL(USE_CURSES, test "$want_terminfo" != "yes" -a "$want_termcap" != "yes")
|
||||
|
||||
# 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)
|
||||
|
||||
dnl **
|
||||
dnl ** IPv6 support
|
||||
dnl **
|
||||
|
||||
have_ipv6=no
|
||||
if test "x$want_ipv6" = "xyes"; then
|
||||
AC_MSG_CHECKING([for IPv6])
|
||||
AC_CACHE_VAL(irssi_cv_type_in6_addr,
|
||||
[AC_TRY_COMPILE([
|
||||
#include <sys/types.h>
|
||||
#include <sys/socket.h>
|
||||
#include <netinet/in.h>
|
||||
#include <netdb.h>
|
||||
#include <arpa/inet.h>],
|
||||
[struct in6_addr i = in6addr_any; return &i == &i;],
|
||||
have_ipv6=yes,
|
||||
)])
|
||||
if test $have_ipv6 = yes; then
|
||||
AC_DEFINE(HAVE_IPV6)
|
||||
fi
|
||||
AC_MSG_RESULT($have_ipv6)
|
||||
fi
|
||||
|
||||
have_dane=no
|
||||
if test "x$want_dane" = "xyes"; then
|
||||
AC_MSG_CHECKING([for DANE])
|
||||
AC_CHECK_LIB(val-threads, val_getdaneinfo,
|
||||
[
|
||||
LIBS="$LIBS -lval-threads -lsres"
|
||||
AC_DEFINE([HAVE_DANE], [], [DANE support])
|
||||
have_dane=yes
|
||||
], [], [-lssl -lcrypto -lsres -lpthread])
|
||||
|
||||
if test x$have_dane = "xyes" ; then
|
||||
if test x$have_openssl = "xno" ; then
|
||||
AC_ERROR([SSL is required to build Irssi with DANE support enabled.])
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
|
||||
if test "x$want_truecolor" = "xyes" -a "x$want_termcap" != "xyes" -a "x$want_terminfo" = "xyes" ; then
|
||||
AC_DEFINE([TERM_TRUECOLOR], [], [true color support in terminal])
|
||||
else
|
||||
want_truecolor=no
|
||||
fi
|
||||
|
||||
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-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
|
||||
scripts/Makefile
|
||||
scripts/examples/Makefile
|
||||
docs/Makefile
|
||||
docs/help/Makefile
|
||||
docs/help/in/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
|
||||
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
|
||||
|
||||
if test "x$want_textui" = "xno"; then
|
||||
text=no
|
||||
elif test "x$want_termcap" = "xyes"; then
|
||||
text="yes, using termcap"
|
||||
elif test "x$want_terminfo" = "xyes"; then
|
||||
text="yes, using terminfo"
|
||||
else
|
||||
text="yes, using curses"
|
||||
fi
|
||||
echo "Building text frontend ........... : $text"
|
||||
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
|
||||
if test "$perl_library_dir" = "PERL_USE_LIB"; then
|
||||
perl_library_dir=$PERL_USE_LIB
|
||||
fi
|
||||
if test -z "$perl_library_dir"; then
|
||||
perl_library_dir="(site default - `$perlpath -e 'use Config; print $Config{sitearch}'`)"
|
||||
fi
|
||||
echo "Perl library directory ........... : $perl_library_dir"
|
||||
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 IPv6 support ....... : $have_ipv6"
|
||||
echo "Building with SSL support ........ : $have_openssl"
|
||||
if test "x$have_openssl" = "xno" -a "x$enable_ssl" = "xyes"; then
|
||||
if test -f /etc/debian_version; then
|
||||
echo " - Try: sudo apt-get install libssl-dev"
|
||||
elif test -f /etc/redhat-release; then
|
||||
echo " - Try installing openssl-devel"
|
||||
else
|
||||
echo " - Try installing OpenSSL development headers"
|
||||
fi
|
||||
fi
|
||||
echo "Building with 64bit DCC support .. : $offt_64bit"
|
||||
echo "Building with DANE support ....... : $have_dane"
|
||||
echo "Building with true color support.. : $want_truecolor"
|
||||
|
||||
echo
|
||||
echo "If there are any problems, read the INSTALL file."
|
@ -202,7 +202,6 @@ abstracts = {
|
||||
# notices
|
||||
ownnotice = "[%r$0%K(%R$1-%K)]%n ";
|
||||
notice = "%K-%M$*%K-%n ";
|
||||
pubnotice = "%K-%M$0$1-%K-%n %|";
|
||||
pubnotice_channel = "%K:%m$*";
|
||||
pvtnotice_host = "%K(%m$*%K)";
|
||||
servernotice = "%g!$*%n ";
|
||||
@ -252,7 +251,6 @@ abstracts = {
|
||||
# default background for all statusbars. You can also give
|
||||
# the default foreground color for statusbar items.
|
||||
sb_background = "%4%w";
|
||||
window_border = "%4%w";
|
||||
|
||||
# default backround for "default" statusbar group
|
||||
#sb_default_bg = "%4";
|
||||
@ -263,8 +261,8 @@ abstracts = {
|
||||
# background for topicbar (same default)
|
||||
#sb_topic_bg = "%4";
|
||||
|
||||
# text at the beginning of statusbars. "sb" already puts a space there,
|
||||
# so we don't use anything by default.
|
||||
# text at the beginning of statusbars. sb-item already puts
|
||||
# space there,so we don't use anything by default.
|
||||
sbstart = "";
|
||||
# text at the end of statusbars. Use space so that it's never
|
||||
# used for anything.
|
17
docs/Makefile.am
Normal file
17
docs/Makefile.am
Normal file
@ -0,0 +1,17 @@
|
||||
man_MANS = \
|
||||
irssi.1
|
||||
|
||||
doc_DATA = \
|
||||
design.txt \
|
||||
formats.txt \
|
||||
manual.txt \
|
||||
faq.html \
|
||||
faq.txt \
|
||||
perl.txt \
|
||||
signals.txt \
|
||||
special_vars.txt \
|
||||
startup-HOWTO.html
|
||||
|
||||
EXTRA_DIST = $(doc_DATA) $(man_MANS)
|
||||
|
||||
SUBDIRS = help
|
@ -1,31 +0,0 @@
|
||||
Capsicum is a lightweight OS capability and sandbox framework provided
|
||||
by FreeBSD. When built with Capsicum support - which is the default under
|
||||
FreeBSD - Irssi can enter a Capsicum capability mode (a sandbox), greatly
|
||||
limiting possible consequences of a potential security hole in Irssi
|
||||
or the libraries it depends on.
|
||||
|
||||
To make Irssi enter capability mode on startup, add
|
||||
|
||||
capsicum = "yes";
|
||||
awaylog_file = "~/irclogs/away.log";
|
||||
|
||||
to your ~/.irssi/config and restart the client. Alternatively you can
|
||||
enter it "by hand", using the "/capsicum enter" command. From the security
|
||||
point of view it's strongly preferable to use the former method, to avoid
|
||||
establishing connections without the sandbox protection; the "/capsicum"
|
||||
command is only intended for experimentation, and in cases where you need
|
||||
to do something that's not possible in capability mode - run scripts,
|
||||
for example - before continuing.
|
||||
|
||||
There is no way to leave the capability mode, apart from exiting Irssi.
|
||||
When running in capability mode, there are certain restrictions - Irssi
|
||||
won't be able to access any files outside the directory pointed to by
|
||||
capsicum_irclogs_path (which defaults to ~/irclogs/). If you change
|
||||
the path when already in capability mode it won't be effective until
|
||||
you restart Irssi. Capability mode also makes it impossible to use
|
||||
the "/save" command.
|
||||
|
||||
Currently there is no way to use custom SSL certificates. As a workaround
|
||||
you can establish connections and enter the capability mode afterwards
|
||||
using the "/capsicum enter" command.
|
||||
|
165
docs/design.html
165
docs/design.html
@ -1,165 +0,0 @@
|
||||
<base href='https://irssi.org/documentation/design/'>
|
||||
<h1>Design</h1>
|
||||
<p>Irssi’s hierarchy is something like this:</p>
|
||||
|
||||
<pre class="repl" id="fig1"><code class="language-ascidia">
|
||||
sub1 sub2
|
||||
\ /
|
||||
xxx IRC COMMON ICQ yyy
|
||||
| | | | |
|
||||
'----+-----:-----+----+----'
|
||||
|
|
||||
GUI (gtk/gnome, qt/kde, text, none)
|
||||
|
|
||||
sub1 sub2 |
|
||||
\ / |
|
||||
xxx IRC | COMMON ICQ yyy
|
||||
'----+-----+-----+----+----'
|
||||
|
|
||||
COMMON UI
|
||||
|
|
||||
sub1 sub2 |
|
||||
\ / |
|
||||
xxx IRC | ICQ yyy
|
||||
| | | | |
|
||||
'----+-----+-----+----'
|
||||
|
|
||||
CORE
|
||||
/
|
||||
lib-config
|
||||
|
||||
</code></pre>
|
||||
|
||||
<p>(IRC, ICQ, xxx and yyy are chat protocols ..)</p>
|
||||
|
||||
<p>(sub1 and sub2 are submodules of IRC module, like DCC and flood protect)</p>
|
||||
|
||||
<p>Chat protocols and frontends are kept in separate modules. Common UI
|
||||
and GUI modules also have the common parts which don’t know anything
|
||||
about the chat protocols. This should allow implementing modules to
|
||||
whatever chat protocols and with whatever frontends easily.</p>
|
||||
|
||||
<h2 id="signals">Signals</h2>
|
||||
|
||||
<p>Communication between different modules are done with “signals”. They are
|
||||
not related to UNIX signals in any way, you could more like think of them
|
||||
as “events” - which might be a better name for them, but I don’t really
|
||||
want to change it anymore :)</p>
|
||||
|
||||
<p>So, you send signal with <code>signal_emit()</code> and it’s sent to all modules that
|
||||
have grabbed it by calling <code>signal_add()</code> in their init function. For
|
||||
example:</p>
|
||||
|
||||
<div><div><pre><code>signal_emit("mysignal", 1, "hello");
|
||||
</code></pre></div></div>
|
||||
|
||||
<p>Sends a “mysignal” function with one argument “hello” - before that, you
|
||||
should have grabbed the signal somewhere else with:</p>
|
||||
|
||||
<div><div><pre><code>static void sig_mysignal(const char *arg1)
|
||||
{
|
||||
/* arg1 contains "hello" */
|
||||
}
|
||||
|
||||
signal_add("mysignal", (SIGNAL_FUNC) sig_mysignal);
|
||||
</code></pre></div></div>
|
||||
|
||||
<p>There are three different <code>signal_add()</code> functions which you can use to
|
||||
specify if you want to grab the signal first, “normally” or last. You can
|
||||
also stop the signal from going any further.</p>
|
||||
|
||||
<p>Emitting signal with it’s name creates a small overhead since it has to
|
||||
look up the signal’s numeric ID first, after which it looks up the signal
|
||||
structure. This is done because if you call a signal <em>really</em> often,
|
||||
it’s faster to find it with it’s numeric ID instead of the string. You
|
||||
can use <code>signal_get_uniq_id()</code> macro to convert the signal name into ID -
|
||||
you’ll have to do this only once! - and use <code>signal_emit_id()</code> to emit the
|
||||
signal. Don’t bother to do this unless your signal is sent (or could be
|
||||
sent) several times in a second.</p>
|
||||
|
||||
<p>See <code>src/core/signals.h</code> for definition of the signal function, and
|
||||
signals.txt for a list of signals.</p>
|
||||
|
||||
<h2 id="lib-config">lib-config</h2>
|
||||
|
||||
<p>Irssi depends on this for reading and saving configuration.
|
||||
(created by me for irssi)</p>
|
||||
|
||||
<h2 id="core-module">CORE module</h2>
|
||||
|
||||
<p>Provides some functionality that all other modules can use:</p>
|
||||
<ul>
|
||||
<li>signal handling</li>
|
||||
<li>keeping list of settings</li>
|
||||
<li>keeping list of /commands</li>
|
||||
<li>keeping track of loaded modules</li>
|
||||
<li>networking functions (with nonblocking connects, IPv6 support)</li>
|
||||
<li>handles connecting to servers</li>
|
||||
<li>raw logging of server’s input/output data</li>
|
||||
<li>/EVAL support</li>
|
||||
<li>fgets() like function line_split() without any maximum line limits</li>
|
||||
<li>command line parameter handling</li>
|
||||
<li>miscellaneous useful little functions</li>
|
||||
<li>handles logging</li>
|
||||
</ul>
|
||||
|
||||
<h2 id="common-ui-module">COMMON UI module</h2>
|
||||
|
||||
<ul>
|
||||
<li>knows basics about windows and window items (=channels, queries, ..)</li>
|
||||
<li>printtext() - parsing texts and feeding it for GUI to print.</li>
|
||||
<li>themes</li>
|
||||
<li>translation tables</li>
|
||||
<li>text hilighting</li>
|
||||
<li>command history</li>
|
||||
<li>user interface (/commands) for CORE’s functionality</li>
|
||||
</ul>
|
||||
|
||||
<h2 id="gui-modules">GUI modules</h2>
|
||||
|
||||
<ul>
|
||||
<li>all the rest of the functionality needed for a working client.</li>
|
||||
</ul>
|
||||
|
||||
<h2 id="irc-module">IRC module</h2>
|
||||
|
||||
<ul>
|
||||
<li>CORE
|
||||
<ul>
|
||||
<li>IRC specific /commands</li>
|
||||
<li>flood protecting commands sent to server</li>
|
||||
<li>creating IRC masks based on nick/address for bans, ignores, etc.</li>
|
||||
<li>keeps list of channels, nicks, channel modes, bans, etc.</li>
|
||||
<li>keeps list of servers, server settings, irc networks,
|
||||
server reconnections and irc network splits</li>
|
||||
<li>redirection of commands’ replies</li>
|
||||
<li>lag detection</li>
|
||||
<li>ctcp support and flood protection</li>
|
||||
<li>Handles ignoring people</li>
|
||||
</ul>
|
||||
</li>
|
||||
<li>DCC
|
||||
<ul>
|
||||
<li>DCC chat, send and get</li>
|
||||
</ul>
|
||||
</li>
|
||||
<li>FLOOD
|
||||
<ul>
|
||||
<li>detects private or channel flooding and sends “flood” signal</li>
|
||||
<li>automatic ignoring when flooding</li>
|
||||
</ul>
|
||||
</li>
|
||||
<li>NOTIFYLIST
|
||||
<ul>
|
||||
<li>handles notifylist</li>
|
||||
</ul>
|
||||
</li>
|
||||
</ul>
|
||||
|
||||
<h2 id="irc-ui-module">IRC UI module</h2>
|
||||
|
||||
<ul>
|
||||
<li>placing channels and queries in windows</li>
|
||||
<li>nick completion</li>
|
||||
<li>printing infomation of some events</li>
|
||||
</ul>
|
231
docs/design.txt
231
docs/design.txt
@ -1,139 +1,150 @@
|
||||
Design
|
||||
|
||||
Irssi’s hierarchy is something like this:
|
||||
|
||||
sub1 sub2
|
||||
\ /
|
||||
xxx IRC COMMON ICQ yyy
|
||||
| | | | |
|
||||
'----+-----:-----+----+----'
|
||||
|
|
||||
GUI (gtk/gnome, qt/kde, text, none)
|
||||
|
|
||||
sub1 sub2 |
|
||||
\ / |
|
||||
xxx IRC | COMMON ICQ yyy
|
||||
'----+-----+-----+----+----'
|
||||
|
|
||||
COMMON UI
|
||||
|
|
||||
sub1 sub2 |
|
||||
\ / |
|
||||
xxx IRC | ICQ yyy
|
||||
| | | | |
|
||||
'----+-----+-----+----'
|
||||
|
|
||||
CORE
|
||||
/
|
||||
lib-config
|
||||
Irssi's hierarchy is something like this:
|
||||
|
||||
|
||||
(IRC, ICQ, xxx and yyy are chat protocols ..)
|
||||
sub1 sub2
|
||||
\ /
|
||||
xxx IRC COMMON ICQ yyy
|
||||
|____|___________|____|____|
|
||||
|
|
||||
GUI (gtk/gnome, qt/kde, text, none)
|
||||
|
|
||||
sub1 sub2 |
|
||||
\ / |
|
||||
xxx IRC | COMMON ICQ yyy
|
||||
|____|_____|_____|____|____|
|
||||
|
|
||||
COMMON UI
|
||||
|
|
||||
sub1 sub2 |
|
||||
\ / |
|
||||
xxx IRC | ICQ yyy
|
||||
|____|_____|_____|____|
|
||||
|
|
||||
CORE
|
||||
/
|
||||
lib-config
|
||||
|
||||
(sub1 and sub2 are submodules of IRC module, like DCC and flood protect)
|
||||
|
||||
Chat protocols and frontends are kept in separate modules. Common UI and GUI
|
||||
modules also have the common parts which don’t know anything about the chat
|
||||
protocols. This should allow implementing modules to whatever chat protocols
|
||||
and with whatever frontends easily.
|
||||
(IRC, ICQ, xxx and yyy are chat protocols ..)
|
||||
(sub1 and sub2 are submodules of IRC module, like DCC and flood protect)
|
||||
|
||||
Signals
|
||||
|
||||
Communication between different modules are done with “signals”. They are not
|
||||
related to UNIX signals in any way, you could more like think of them as
|
||||
“events” - which might be a better name for them, but I don’t really want to
|
||||
change it anymore :)
|
||||
Chat protocols and frontends are kept in separate modules. Common UI
|
||||
and GUI modules also have the common parts which don't know anything
|
||||
about the chat protocols. This should allow implementing modules to
|
||||
whatever chat protocols and with whatever frontends easily.
|
||||
|
||||
So, you send signal with signal_emit() and it’s sent to all modules that have
|
||||
grabbed it by calling signal_add() in their init function. For example:
|
||||
** Signals
|
||||
|
||||
signal_emit("mysignal", 1, "hello");
|
||||
Communication between different modules are done with "signals". They are
|
||||
not related to UNIX signals in any way, you could more like think of them
|
||||
as "events" - which might be a better name for them, but I don't really
|
||||
want to change it anymore :)
|
||||
|
||||
Sends a “mysignal” function with one argument “hello” - before that, you should
|
||||
have grabbed the signal somewhere else with:
|
||||
So, you send signal with signal_emit() and it's sent to all modules that
|
||||
have grabbed it by calling signal_add() in their init function. For
|
||||
example:
|
||||
|
||||
static void sig_mysignal(const char *arg1)
|
||||
{
|
||||
/* arg1 contains "hello" */
|
||||
}
|
||||
signal_emit("mysignal", 1, "hello");
|
||||
|
||||
signal_add("mysignal", (SIGNAL_FUNC) sig_mysignal);
|
||||
Sends a "mysignal" function with one argument "hello" - before that, you
|
||||
should have grabbed the signal somewhere else with:
|
||||
|
||||
There are three different signal_add() functions which you can use to specify
|
||||
if you want to grab the signal first, “normally” or last. You can also stop the
|
||||
signal from going any further.
|
||||
static void sig_mysignal(const char *arg1)
|
||||
{
|
||||
/* arg1 contains "hello" */
|
||||
}
|
||||
|
||||
Emitting signal with it’s name creates a small overhead since it has to look up
|
||||
the signal’s numeric ID first, after which it looks up the signal structure.
|
||||
This is done because if you call a signal really often, it’s faster to find it
|
||||
with it’s numeric ID instead of the string. You can use signal_get_uniq_id()
|
||||
macro to convert the signal name into ID - you’ll have to do this only once! -
|
||||
and use signal_emit_id() to emit the signal. Don’t bother to do this unless
|
||||
your signal is sent (or could be sent) several times in a second.
|
||||
signal_add("mysignal", (SIGNAL_FUNC) sig_mysignal);
|
||||
|
||||
See src/core/signals.h for definition of the signal function, and signals.txt
|
||||
for a list of signals.
|
||||
There are three different signal_add() functions which you can use to
|
||||
specify if you want to grab the signal first, "normally" or last. You can
|
||||
also stop the signal from going any further.
|
||||
|
||||
lib-config
|
||||
Emitting signal with it's name creates a small overhead since it has to
|
||||
look up the signal's numeric ID first, after which it looks up the signal
|
||||
structure. This is done because if you call a signal _really_ often,
|
||||
it's faster to find it with it's numeric ID instead of the string. You
|
||||
can use signal_get_uniq_id() macro to convert the signal name into ID -
|
||||
you'll have to do this only once! - and use signal_emit_id() to emit the
|
||||
signal. Don't bother to do this unless your signal is sent (or could be
|
||||
sent) several times in a second.
|
||||
|
||||
Irssi depends on this for reading and saving configuration. (created by me for
|
||||
irssi)
|
||||
See src/core/signals.h for definition of the signal function, and
|
||||
signals.txt for a list of signals.
|
||||
|
||||
CORE module
|
||||
|
||||
Provides some functionality that all other modules can use:
|
||||
** lib-config
|
||||
|
||||
• signal handling
|
||||
• keeping list of settings
|
||||
• keeping list of /commands
|
||||
• keeping track of loaded modules
|
||||
• networking functions (with nonblocking connects, IPv6 support)
|
||||
• handles connecting to servers
|
||||
• raw logging of server’s input/output data
|
||||
• /EVAL support
|
||||
• fgets() like function line_split() without any maximum line limits
|
||||
• command line parameter handling
|
||||
• miscellaneous useful little functions
|
||||
• handles logging
|
||||
Irssi depends on this for reading and saving configuration.
|
||||
(created by me for irssi)
|
||||
|
||||
COMMON UI module
|
||||
|
||||
• knows basics about windows and window items (=channels, queries, ..)
|
||||
• printtext() - parsing texts and feeding it for GUI to print.
|
||||
• themes
|
||||
• translation tables
|
||||
• text hilighting
|
||||
• command history
|
||||
• user interface (/commands) for CORE’s functionality
|
||||
** CORE module
|
||||
|
||||
GUI modules
|
||||
Provides some functionality that all other modules can use:
|
||||
- signal handling
|
||||
- keeping list of settings
|
||||
- keeping list of /commands
|
||||
- keeping track of loaded modules
|
||||
- networking functions (with nonblocking connects, IPv6 support)
|
||||
- handles connecting to servers
|
||||
- raw logging of server's input/output data
|
||||
- /EVAL support
|
||||
- fgets() like function line_split() without any maximum line limits
|
||||
- command line parameter handling
|
||||
- miscellaneous useful little functions
|
||||
- handles logging
|
||||
|
||||
• all the rest of the functionality needed for a working client.
|
||||
|
||||
IRC module
|
||||
** COMMON UI module
|
||||
|
||||
• CORE
|
||||
□ IRC specific /commands
|
||||
□ flood protecting commands sent to server
|
||||
□ creating IRC masks based on nick/address for bans, ignores, etc.
|
||||
□ keeps list of channels, nicks, channel modes, bans, etc.
|
||||
□ keeps list of servers, server settings, irc networks, server
|
||||
reconnections and irc network splits
|
||||
□ redirection of commands’ replies
|
||||
□ lag detection
|
||||
□ ctcp support and flood protection
|
||||
□ Handles ignoring people
|
||||
• DCC
|
||||
□ DCC chat, send and get
|
||||
• FLOOD
|
||||
□ detects private or channel flooding and sends “flood” signal
|
||||
□ automatic ignoring when flooding
|
||||
• NOTIFYLIST
|
||||
□ handles notifylist
|
||||
- knows basics about windows and window items (=channels, queries, ..)
|
||||
- printtext() - parsing texts and feeding it for GUI to print.
|
||||
- themes
|
||||
- translation tables
|
||||
- text hilighting
|
||||
- command history
|
||||
- user interface (/commands) for CORE's functionality
|
||||
|
||||
IRC UI module
|
||||
|
||||
• placing channels and queries in windows
|
||||
• nick completion
|
||||
• printing infomation of some events
|
||||
** GUI modules
|
||||
|
||||
- all the rest of the functionality needed for a working client.
|
||||
|
||||
|
||||
** IRC module
|
||||
|
||||
* CORE
|
||||
|
||||
- IRC specific /commands
|
||||
- flood protecting commands sent to server
|
||||
- creating IRC masks based on nick/address for bans, ignores, etc.
|
||||
- keeps list of channels, nicks, channel modes, bans, etc.
|
||||
- keeps list of servers, server settings, irc networks,
|
||||
server reconnections and irc network splits
|
||||
- redirection of commands' replies
|
||||
- lag detection
|
||||
- ctcp support and flood protection
|
||||
- Handles ignoring people
|
||||
|
||||
* DCC
|
||||
|
||||
- DCC chat, send and get
|
||||
|
||||
* FLOOD
|
||||
|
||||
- detects private or channel flooding and sends "flood" signal
|
||||
- automatic ignoring when flooding
|
||||
|
||||
* NOTIFYLIST
|
||||
|
||||
- handles notifylist
|
||||
|
||||
|
||||
** IRC UI module
|
||||
|
||||
- placing channels and queries in windows
|
||||
- nick completion
|
||||
- printing infomation of some events
|
||||
|
@ -1,47 +0,0 @@
|
||||
[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'
|
151
docs/faq.html
151
docs/faq.html
@ -1,81 +1,152 @@
|
||||
<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>
|
||||
<h2>FAQ</h2>
|
||||
|
||||
<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>Q: Why doesn't irssi display colors even when ircii etc. displays them?</h3>
|
||||
|
||||
<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>
|
||||
<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>
|
||||
|
||||
|
||||
<h3>Q: How do I easily write text to channel that starts with '/' character?</h3>
|
||||
|
||||
<p>A: <code>/ /text</code></p>
|
||||
|
||||
<h3 id="q-why-doesnt-irssi-update-my-realname-or-whatever-after-i-change-it-with-set-realname-and-reconnect-with-reconnect-or-server">Q: Why doesn’t irssi update my realname (or whatever) after I change it with <code>/SET realname</code> and reconnect with <code>/RECONNECT</code> or <code>/SERVER</code>?</h3>
|
||||
|
||||
<p>A: Irssi is trying to be too smart. This will be fixed in future, but for now you should use <code>/DISCONNECT</code> and <code>/CONNECT</code>.</p>
|
||||
<h3>Q: Why doesn't irssi update my realname (or whatever) after I change it
|
||||
with <code>/SET realname</code> and reconnect with <code>/RECONNECT</code>
|
||||
or <code>/SERVER</code>?</h3>
|
||||
|
||||
<h3 id="q-i-connected-to-some-server-which-isnt-responding-but-now-irssi-tries-to-connect-back-to-it-all-the-time-how-can-i-stop-it">Q: I connected to some server which isn’t responding but now irssi tries to connect back to it all the time! How can I stop it?</h3>
|
||||
<p>A: Irssi is trying to be too smart. This will be fixed in future, but for
|
||||
now you should use <code>/DISCONNECT</code> and <code>/CONNECT</code>.</p>
|
||||
|
||||
<p>A: Two ways. The “good way” to do it is with <code>/DISCONNECT</code>. Check the server tags first with <code>/SERVER</code> without giving it any parameters, reconnections are those that have tag starting with “recon” text. So most probably you’re going to do <code>/DISCONNECT recon-1</code>. The other way is to remove all the reconnections with <code>/RMRECONNS</code>, easier but may remove some connections you actually wanted to reconnect (if you used multiple servers..).</p>
|
||||
|
||||
<h3 id="q-how-do-i-add-seconds-to-timestamp">Q: How do I add seconds to timestamp?</h3>
|
||||
<h3>Q: I connected to some server which isn't responding but now irssi tries
|
||||
to connect back to it all the time! How can I stop it?</h3>
|
||||
|
||||
<p>A: <code>/FORMAT timestamp {timestamp %%H:%%M:%%S}</code> - and remember to add the trailing space :)</p>
|
||||
<p>A: Two ways. The "good way" to do it is with <code>/DISCONNECT</code>.
|
||||
Check the server tags first with <code>/SERVER</code> without giving it any
|
||||
parameters, reconnections are those that have tag starting with "recon"
|
||||
text. So most probably you're going to do <code>/DISCONNECT recon-1</code>.
|
||||
The other way is to remove all the reconnections with
|
||||
<code>/RMRECONNS</code>, easier but may remove some connections you actually
|
||||
wanted to reconnect (if you used multiple servers..).</p>
|
||||
|
||||
<h3 id="q-why-does-irssi-say-irssi-channel-not-fully-synchronized-yet-try-again-after-a-while-when-i-try-to-use-ban-etc">Q: Why does irssi say “Irssi: Channel not fully synchronized yet, try again after a while” when I try to use /BAN etc?</h3>
|
||||
|
||||
<p>A: Possibly a bug in irssi, or ircd you’re using does something that irssi didn’t really notice. The new code should make this happen far less often than before, but one known reason for this is when irssi doesn’t notice that you were unable to join some channel. Currently however I don’t know of any such events irssi doesn’t know about.</p>
|
||||
<h3>Q: How do I add seconds to timestamp?</h3>
|
||||
|
||||
<p>Anyway, if this does happen, do <code>/RAWLOG SAVE ~/rawlog</code> soon after joining to channel, and either try to figure out yourself why irssi didn’t get reply to WHO request, or open a Github issue with the full log included. Note that the rawlog is by default only 200 lines and it may not be enough to show all needed information, so you might want to do <code>/SET rawlog_lines 1000</code> or so.</p>
|
||||
<p>A: <code>/FORMAT timestamp {timestamp %%H:%%M:%%S}</code> - and remember
|
||||
to add the trailing space :)</p>
|
||||
|
||||
|
||||
<h3>Q: Why does irssi say "Irssi: Channel not fully synchronized yet, try
|
||||
again after a while" when I try to use /BAN etc?</h3>
|
||||
|
||||
<p>A: Possibly a bug in irssi, or ircd you're using does something that
|
||||
irssi didn't really notice. The new code should make this happen far less
|
||||
often than before, but one known reason for this is when irssi doesn't
|
||||
notice that you were unable to join some channel. Currently however I don't
|
||||
know of any such events irssi doesn't know about.</p>
|
||||
|
||||
<p>Anyway, if this does happen, do <code>/RAWLOG SAVE ~/rawlog</code> soon
|
||||
after joining to channel, and either try to figure out yourself why irssi
|
||||
didn't get reply to WHO request, or send the whole log to cras@irssi.org. Note
|
||||
that the rawlog is by default only 200 lines and it may not be enough to
|
||||
show all needed information, so you might want to do <code>/SET rawlog_lines
|
||||
1000</code> or so.</p>
|
||||
|
||||
<p><code>MODE +b</code> still works fine though.</p>
|
||||
|
||||
<h3 id="q-wheres-the-gui-version">Q: Where’s the GUI version?</h3>
|
||||
|
||||
<p>A: There was one on <a href="https://github.com/irssi-import/xirssi">irssi-import/xirssi</a> but it has not been maintained for a long time.</p>
|
||||
<h3>Q: Where's the GUI version?</h3>
|
||||
|
||||
<h3 id="q-how-do-i-autorejoin-channels-after-being-kicked">Q: How do I autorejoin channels after being kicked?</h3>
|
||||
<p>A: Read
|
||||
<a href="http://www.irssi.org/about">http://www.irssi.org/about</a></p>
|
||||
|
||||
<p>A: That’s evil and you shouldn’t do it. If you get kicked, you should stay out, at least until the channel forgot you existed :) Most channels I’ve joined just ban you if you autorejoin after kick. If you’re joined to channels who kick people for fun, try changing channels or something.</p>
|
||||
|
||||
<p>Anyway, if you REALLY want to do that, and you understand that you’re doing evilness, you can use the autorejoin.pl script that comes with irssi. You’ll still need to specify the channels you wish to rejoin with <code>/SET autorejoin_channels #chan1 #chan2 ...</code></p>
|
||||
<h3>Q: How do I autorejoin channels after being kicked?</h3>
|
||||
|
||||
<h3 id="q-how-do-i-announce-that-im-awayback-in-all-channels-ive-joined-or-how-do-i-change-my-nick-when-setting-myself-awayback">Q: How do I announce that I’m away/back in all channels I’ve joined? Or how do I change my nick when setting myself away/back?</h3>
|
||||
<p>A: That's evil and you shouldn't do it. If you get kicked, you should stay
|
||||
out, at least until the channel forgot you existed :) Most channels I've
|
||||
joined just ban you if you autorejoin after kick. If you're joined to
|
||||
channels who kick people for fun, try changing channels or something.</p>
|
||||
|
||||
<p>A: That’s even worse than autorejoin. Who could possibly care every time you come and go? Many channels will kick you for using this, and I for example have added several ignores so I’d never need to see these messages. Learn to use <code>/AWAY</code> command properly and tell its existence to people who don’t know about it. <code>/WII yournick</code> shows your away reason much better for people who actually want to know if you’re there or not.</p>
|
||||
<p>Anyway, if you REALLY want to do that, and you understand that you're doing
|
||||
evilness, you can use the autorejoin.pl script that comes with irssi. You'll
|
||||
still need to specify the channels you wish to rejoin with <code>/SET
|
||||
autorejoin_channels #chan1 #chan2 ...</code></p>
|
||||
|
||||
<h3 id="q-why-does-irssi-autojoin-on-invite-by-default">Q: Why does irssi autojoin on invite by default?</h3>
|
||||
|
||||
<p>A: The setting is /SET join_auto_chans_on_invite - it’s not the same as regular autojoin-on-invite, which irssi doesn’t even have. The only channels that are joined on invite, are the ones you’ve added to config with /CHANNEL ADD -auto. This is very useful with +i channels when you need to first send an invite request to bot, or if you get accidentally kicked from channel, the kicker can invite you back immediately.</p>
|
||||
<h3>Q: How do I announce that I'm away/back in all channels I've joined? Or
|
||||
how do I change my nick when setting myself away/back?</h3>
|
||||
|
||||
<p>I don’t see any bad side effects with this feature, so it’s ON by default. I guess someone could start kicking/inviting you all the time but server connection shouldn’t drop because of that, and you shouldn’t join channels whose operators are that evil.</p>
|
||||
<p>A: That's even worse than autorejoin. Who could possibly care every time
|
||||
you come and go? Many channels will kick you for using this, and I for example
|
||||
have added several ignores so I'd never need to see these messages. Learn to
|
||||
use <code>/AWAY</code> command properly and tell its existence to people
|
||||
who don't know about it. <code>/WII yournick</code> shows your away reason
|
||||
much better for people who actually want to know if you're there or not.</p>
|
||||
|
||||
<h3 id="q-how-to-make-utf-8-support-work-with-irssi">Q: How to make UTF-8 support work with irssi?</h3>
|
||||
|
||||
<p>A: Make sure your terminal supports UTF-8 (for example, <code>xterm -u8</code>). If you use screen, you may have to do <code>screen -U</code>. And in Irssi do <code>/SET term_charset utf-8</code>. (for 0.8.9 and older: <code>/SET term_type utf-8</code>)</p>
|
||||
<h3>Q: Why does irssi autojoin on invite by default?</h3>
|
||||
|
||||
<h3 id="q-will-there-be-detach-like-feature">Q: Will there be /DETACH-like feature?</h3>
|
||||
<p>A: The setting is /SET join_auto_chans_on_invite - it's not the same
|
||||
as regular autojoin-on-invite, which irssi doesn't even have. The only
|
||||
channels that are joined on invite, are the ones you've added to config
|
||||
with /CHANNEL ADD -auto. This is very useful with +i channels when you
|
||||
need to first send an invite request to bot, or if you get accidentally
|
||||
kicked from channel, the kicker can invite you back immediately.</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>
|
||||
<p>I don't see any bad side effects with this feature, so it's ON by
|
||||
default. I guess someone could start kicking/inviting you all the time
|
||||
but server connection shouldn't drop because of that, and you shouldn't
|
||||
join channels whose operators are that evil.</p>
|
||||
|
||||
<h3 id="q-how-do-i-run-scripts-automatically-at-startup">Q: How do I run scripts automatically at startup?</h3>
|
||||
|
||||
<p>A: Put them into <code>~/.irssi/scripts/autorun/</code> directory. Or better would be if you placed them in <code>~/.irssi/scripts/</code> and created symlinks to autorun directory (eg. <code>cd ~/.irssi/scripts/autorun/ ; ln -s ../script.pl .</code>)</p>
|
||||
<h3>Q: How to make UTF-8 support work with irssi?</h3>
|
||||
|
||||
<h3 id="q-how-do-i-execute-commands-automatically-at-startup">Q: How do I execute commands automatically at startup?</h3>
|
||||
<p>A: Make sure your terminal supports UTF-8 (for example, <code>xterm -u8</code>).
|
||||
If you use screen, you may have to do <code>screen -U</code>. And in Irssi do
|
||||
<code>/SET term_charset utf-8</code>. (for 0.8.9 and older: <code>/SET term_type utf-8</code>)</p>
|
||||
|
||||
<p>A: Put them into <code>~/.irssi/startup</code> file, each command on its own line. The preceding slash (/) is not necessary.</p>
|
||||
|
||||
<h3 id="q-how-do-i-easily-edit-existing-topic">Q: How do I easily edit existing topic?</h3>
|
||||
<h3>Q: Will there be /DETACH-like feature?</h3>
|
||||
|
||||
<p>A: <code>/TOPIC <tab></code></p>
|
||||
<p>A: Maybe. Detach code already is there, attach is just missing :) But I
|
||||
don't have much interest in coding it,
|
||||
<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>
|
||||
|
||||
<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="https://dgl.cx/irssi/hack-whois-in-current-window.pl">script</a>.</p>
|
||||
<h3>Q: How do I run scripts automatically at startup?</h3>
|
||||
|
||||
<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>
|
||||
<p>A: Put them into <code>~/.irssi/scripts/autorun/</code> directory. Or
|
||||
better would be if you placed them in <code>~/.irssi/scripts/</code> and
|
||||
created symlinks to autorun directory (eg. <code>cd
|
||||
~/.irssi/scripts/autorun/ ; ln -s ../script.pl .</code>)</p>
|
||||
|
||||
<p>A: Modify the window-line in statusbar section in config file to <code>window = "{sb $winref:$tag/$T{sbmode $M}}";</code></p>
|
||||
|
||||
<h3 id="q-how-to-pronounce-irssi">Q: How to pronounce Irssi?</h3>
|
||||
<h3>Q: How do I execute commands automatically at startup?</h3>
|
||||
|
||||
<p>A: Put them into <code>~/.irssi/startup</code> file, each command on its
|
||||
own line. The preceding slash (/) is not necessary.</p>
|
||||
|
||||
|
||||
<h3>Q: How do I easily edit existing topic?</h3>
|
||||
|
||||
<p>A: /TOPIC <tab></p>
|
||||
|
||||
<h3>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>
|
||||
|
||||
<h3>Q: How do I add the active network to the statusbar</h3>
|
||||
|
||||
<p>A: Modify the window-line in statusbar section in config file to
|
||||
<code>window = "{sb $winref:$tag/$T{sbmode $M}}";</code></p>
|
||||
|
||||
<p>A: Check <a href="/assets/irssi.wav">here</a></p>
|
124
docs/faq.txt
124
docs/faq.txt
@ -1,124 +0,0 @@
|
||||
Frequently Asked Questions
|
||||
|
||||
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-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
|
||||
|
||||
Q: Why doesn’t irssi update my realname (or whatever) after I change it with /
|
||||
SET realname and reconnect with /RECONNECT or /SERVER?
|
||||
A: Irssi is trying to be too smart. This will be fixed in future, but for now
|
||||
you should use /DISCONNECT and /CONNECT.
|
||||
|
||||
Q: I connected to some server which isn’t responding but now irssi tries to
|
||||
connect back to it all the time! How can I stop it?
|
||||
A: Two ways. The “good way” to do it is with /DISCONNECT. Check the server tags
|
||||
first with /SERVER without giving it any parameters, reconnections are those
|
||||
that have tag starting with “recon” text. So most probably you’re going to do /
|
||||
DISCONNECT recon-1. The other way is to remove all the reconnections with /
|
||||
RMRECONNS, easier but may remove some connections you actually wanted to
|
||||
reconnect (if you used multiple servers..).
|
||||
|
||||
Q: How do I add seconds to timestamp?
|
||||
A: /FORMAT timestamp {timestamp %%H:%%M:%%S} - and remember to add the trailing
|
||||
space :)
|
||||
|
||||
Q: Why does irssi say “Irssi: Channel not fully synchronized yet, try again
|
||||
after a while” when I try to use /BAN etc?
|
||||
A: Possibly a bug in irssi, or ircd you’re using does something that irssi
|
||||
didn’t really notice. The new code should make this happen far less often than
|
||||
before, but one known reason for this is when irssi doesn’t notice that you
|
||||
were unable to join some channel. Currently however I don’t know of any such
|
||||
events irssi doesn’t know about.
|
||||
|
||||
Anyway, if this does happen, do /RAWLOG SAVE ~/rawlog soon after joining to
|
||||
channel, and either try to figure out yourself why irssi didn’t get reply to
|
||||
WHO request, or open a Github issue with the full log included. Note that the
|
||||
rawlog is by default only 200 lines and it may not be enough to show all needed
|
||||
information, so you might want to do /SET rawlog_lines 1000 or so.
|
||||
|
||||
MODE +b still works fine though.
|
||||
|
||||
Q: Where’s the GUI version?
|
||||
A: There was one on [1]irssi-import/xirssi but it has not been maintained for a
|
||||
long time.
|
||||
|
||||
Q: How do I autorejoin channels after being kicked?
|
||||
A: That’s evil and you shouldn’t do it. If you get kicked, you should stay out,
|
||||
at least until the channel forgot you existed :) Most channels I’ve joined just
|
||||
ban you if you autorejoin after kick. If you’re joined to channels who kick
|
||||
people for fun, try changing channels or something.
|
||||
|
||||
Anyway, if you REALLY want to do that, and you understand that you’re doing
|
||||
evilness, you can use the autorejoin.pl script that comes with irssi. You’ll
|
||||
still need to specify the channels you wish to rejoin with /SET
|
||||
autorejoin_channels #chan1 #chan2 ...
|
||||
|
||||
Q: How do I announce that I’m away/back in all channels I’ve joined? Or how do
|
||||
I change my nick when setting myself away/back?
|
||||
A: That’s even worse than autorejoin. Who could possibly care every time you
|
||||
come and go? Many channels will kick you for using this, and I for example have
|
||||
added several ignores so I’d never need to see these messages. Learn to use /
|
||||
AWAY command properly and tell its existence to people who don’t know about it.
|
||||
/WII yournick shows your away reason much better for people who actually want
|
||||
to know if you’re there or not.
|
||||
|
||||
Q: Why does irssi autojoin on invite by default?
|
||||
A: The setting is /SET join_auto_chans_on_invite - it’s not the same as regular
|
||||
autojoin-on-invite, which irssi doesn’t even have. The only channels that are
|
||||
joined on invite, are the ones you’ve added to config with /CHANNEL ADD -auto.
|
||||
This is very useful with +i channels when you need to first send an invite
|
||||
request to bot, or if you get accidentally kicked from channel, the kicker can
|
||||
invite you back immediately.
|
||||
|
||||
I don’t see any bad side effects with this feature, so it’s ON by default. I
|
||||
guess someone could start kicking/inviting you all the time but server
|
||||
connection shouldn’t drop because of that, and you shouldn’t join channels
|
||||
whose operators are that evil.
|
||||
|
||||
Q: How to make UTF-8 support work with irssi?
|
||||
A: Make sure your terminal supports UTF-8 (for example, xterm -u8). If you use
|
||||
screen, you may have to do screen -U. And in Irssi do /SET term_charset utf-8.
|
||||
(for 0.8.9 and older: /SET term_type utf-8)
|
||||
|
||||
Q: Will there be /DETACH-like feature?
|
||||
A: [2]tmux, [3]screen and [4]dtach can be used to do it just fine.
|
||||
|
||||
Q: How do I run scripts automatically at startup?
|
||||
A: Put them into ~/.irssi/scripts/autorun/ directory. Or better would be if you
|
||||
placed them in ~/.irssi/scripts/ and created symlinks to autorun directory (eg.
|
||||
cd ~/.irssi/scripts/autorun/ ; ln -s ../script.pl .)
|
||||
|
||||
Q: How do I execute commands automatically at startup?
|
||||
A: Put them into ~/.irssi/startup file, each command on its own line. The
|
||||
preceding slash (/) is not necessary.
|
||||
|
||||
Q: How do I easily edit existing topic?
|
||||
A: /TOPIC <tab>
|
||||
|
||||
Q: How can I have /WHOIS replies to active window?
|
||||
A: You can disable the status window, or do /WINDOW LEVEL -CRAP in it which
|
||||
would also make several other messages show up in active window. You can also
|
||||
use a [5]script.
|
||||
|
||||
Q: How do I add the active network to the statusbar
|
||||
A: Modify the window-line in statusbar section in config file to window = "{sb
|
||||
$winref:$tag/$T{sbmode $M}}";
|
||||
|
||||
Q: How to pronounce Irssi?
|
||||
A: Check [6]here
|
||||
|
||||
|
||||
References:
|
||||
|
||||
[1] https://github.com/irssi-import/xirssi
|
||||
[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
|
12
docs/help/Makefile.am.gen
Normal file
12
docs/help/Makefile.am.gen
Normal file
@ -0,0 +1,12 @@
|
||||
# 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
|
5
docs/help/in/Makefile.am.gen
Normal file
5
docs/help/in/Makefile.am.gen
Normal file
@ -0,0 +1,5 @@
|
||||
# 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 irc.libera.chat
|
||||
/ADMIN orwell.freenode.net
|
||||
/ADMIN mike
|
||||
|
||||
%9See also:%9 INFO
|
||||
|
@ -8,8 +8,8 @@
|
||||
-one: Marks yourself as away on the active server.
|
||||
-all: Marks yourself as away on all the servers you are connected to.
|
||||
|
||||
Your away message; if no argument is given, your away status will be removed.
|
||||
|
||||
You away message; if no argument is given, your away status will be removed.
|
||||
|
||||
%9Description:%9
|
||||
|
||||
Marks yourself as 'away'; this method is used to inform people that you
|
||||
|
@ -6,8 +6,7 @@
|
||||
%9Parameters:%9
|
||||
|
||||
-list: Displays a list of all the bindable commands.
|
||||
-delete: Removes the binding.
|
||||
-reset: Reset a key to its default binding.
|
||||
-delete: Removes the binding,
|
||||
|
||||
A name of the binding and the command to perform; if no parameter is given,
|
||||
the list of bindings will be displayed.
|
||||
|
@ -5,22 +5,15 @@
|
||||
|
||||
%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.
|
||||
The file to display.
|
||||
|
||||
%9Description:%9
|
||||
|
||||
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.
|
||||
Displays the contents of the specified file into the active window.
|
||||
|
||||
%9Examples:%9
|
||||
|
||||
/CAT -window /etc/network/interfaces
|
||||
/CAT /etc/network/interfaces
|
||||
/CAT /home/mike/resume.txt
|
||||
/CAT contact_details.txt
|
||||
|
||||
|
@ -7,7 +7,6 @@
|
||||
|
||||
LIST: Displays the list of configured channels.
|
||||
ADD: Adds a channel to your configuration.
|
||||
MODIFY: Modifies a channel in your configuration.
|
||||
REMOVE: Removes a channel from your configuration.
|
||||
|
||||
-auto: Automatically join the channel.
|
||||
@ -33,12 +32,11 @@
|
||||
|
||||
/CHANNEL
|
||||
/CHANNEL LIST
|
||||
/CHANNEL ADD -auto #irssi liberachat
|
||||
/CHANNEL ADD -auto #irssi Freenode
|
||||
/CHANNEL ADD -auto #basementcat Quakenet secret_lair
|
||||
/CHANNEL ADD -auto -bots '*!@*.irssi.org *!bot@irssi.org' -botcmd 'msg $0 op WzerTrzq' #hideout liberachat
|
||||
/CHANNEL ADD -auto -bots '*!@*.irssi.org *!bot@irssi.org' -botcmd 'msg $0 op WzerTrzq' #hideout Freenode
|
||||
/CHANNEL ADD -auto -bots 'Q!TheQBot@CServe.quakenet.org' -botcmd '^MSG Q op #irssi' #irssi Quakenet
|
||||
/CHANNEL MODIFY -noauto #irssi liberachat
|
||||
/CHANNEL REMOVE #hideout liberachat
|
||||
/CHANNEL REMOVE #hideout Freenode
|
||||
|
||||
%9Special Example:%9
|
||||
|
||||
|
@ -12,8 +12,8 @@
|
||||
|
||||
%9Description:%9
|
||||
|
||||
Scrolls up the text in the window and fills the window with blank lines; you
|
||||
may want to use this to make new text start at the top of the window again.
|
||||
Clears the window of all text; you may use this to clear a windows that
|
||||
contains sensitive information or has rendered improperly.
|
||||
|
||||
%9See also:%9 REDRAW, SCROLLBACK CLEAR
|
||||
%9See also:%9 REDRAW
|
||||
|
||||
|
@ -5,25 +5,23 @@
|
||||
|
||||
%9Parameters:%9
|
||||
|
||||
-4: Connects using IPv4.
|
||||
-6: Connects using IPv6.
|
||||
-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.
|
||||
-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.
|
||||
-rawlog: Immediately open rawlog after connecting.
|
||||
-!: Doesn't autojoin channels.
|
||||
-noautosendcmd: Doesn't execute autosendcmd.
|
||||
-4: Connects using IPv4.
|
||||
-6: Connects using IPv6.
|
||||
-ssl: Connects using SSL encryption.
|
||||
-ssl_cert: The SSL client certificate file.
|
||||
-ssl_pkey: The SSL client private key, if not included in the
|
||||
certificate file.
|
||||
-ssl_pass: The password for the SSL client private key or certificate.
|
||||
-ssl_verify: Verifies the SSL certificate of the server.
|
||||
-ssl_cafile: The file with the list of CA certificates.
|
||||
-ssl_capath: The directory which contains the CA certificates.
|
||||
-ssl_ciphers: SSL cipher suite preference lists.
|
||||
-noproxy: Ignores the global proxy configuration.
|
||||
-network: The network this connection belongs to.
|
||||
-host: The hostname you would like to connect from.
|
||||
-rawlog: Immediately open rawlog after connecting.
|
||||
-!: Doesn't autojoin channels.
|
||||
-noautosendcmd: Doesn't execute autosendcmd.
|
||||
|
||||
A network or server to connect to; you can optionally specify a custom port,
|
||||
password and nickname.
|
||||
@ -35,9 +33,9 @@
|
||||
|
||||
%9Examples:%9
|
||||
|
||||
/CONNECT liberachat
|
||||
/CONNECT -6 liberachat
|
||||
/CONNECT -4 -! -host staff.irssi.org -network liberachat irc.libera.chat
|
||||
/CONNECT Freenode
|
||||
/CONNECT -6 Freenode
|
||||
/CONNECT -4 -! -host staff.irssi.org -network Freenode orwell.freenode.net
|
||||
/CONNECT irc.irssi.org 6667 WzerT8zq mike
|
||||
|
||||
%9See also:%9 DISCONNECT, RMRECONNS, SERVER
|
||||
|
@ -27,7 +27,7 @@
|
||||
and file transfers.
|
||||
|
||||
If you are behind NAT, or if the firewall is too restrictive, you might
|
||||
want to try if using the passive parameter resolves your connection
|
||||
want to try if using the passive parameter resolved your connection
|
||||
problem.
|
||||
|
||||
You can send files which contain special character or spaces by enclosing
|
||||
@ -36,10 +36,10 @@
|
||||
%9Examples:%9
|
||||
|
||||
/DCC CHAT mike
|
||||
/DCC GET bob "summer vacation.mkv"
|
||||
/DCC SEND sarah "summer vacation.mkv"
|
||||
/DCC CLOSE get mike
|
||||
/DCC CLOSE send bob "summer vacation.mkv"
|
||||
/DCC GET bob 'summer vacation.mkv'
|
||||
/DCC SEND sarah documents/resume.pdf
|
||||
/DCC CLOSE mike
|
||||
/DCC CLOSE bob 'summer vacation.mkv'
|
||||
|
||||
%9See also:%9 CD
|
||||
|
||||
|
@ -18,7 +18,7 @@
|
||||
|
||||
%9Examples:%9
|
||||
|
||||
/DISCONNECT liberachat I'm off for today, take care!
|
||||
/DISCONNECT Freenode I'm off for today, take care!
|
||||
/DISCONNECT * Vacation time :D
|
||||
/DISCONNECT
|
||||
|
||||
|
@ -5,6 +5,7 @@
|
||||
|
||||
%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.
|
||||
|
||||
@ -17,7 +18,7 @@
|
||||
%9Examples:%9
|
||||
|
||||
/ECHO 1 + 1 = 2 :D
|
||||
/ECHO Testing the ECHO command
|
||||
/ECHO -current Testing the ECHO command
|
||||
/ECHO -window #irssi Special variables such as ${N} will not be expanded.
|
||||
|
||||
%9See also:%9 CAT, EVAL, EXEC, LEVELS
|
||||
|
@ -10,23 +10,13 @@
|
||||
%9Description:%9
|
||||
|
||||
Evaluates the given commands and executes them; you can use internal
|
||||
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)
|
||||
`;' -> `\;'
|
||||
variables and separate multiple commands by using the ';' character.
|
||||
|
||||
%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
|
||||
|
@ -15,7 +15,7 @@
|
||||
|
||||
%9References:%9
|
||||
|
||||
https://irssi.org
|
||||
http://www.irssi.org
|
||||
https://github.com/irssi
|
||||
|
||||
%9See also:%9 DIE, KILL, OPER
|
||||
|
@ -20,7 +20,7 @@
|
||||
|
||||
%9References:%9
|
||||
|
||||
https://irssi.org
|
||||
http://www.irssi.org
|
||||
https://github.com/irssi
|
||||
|
||||
%9See also:%9 CONNECT, MSG, NETWORK, SERVER
|
||||
|
@ -10,9 +10,8 @@
|
||||
-line: Highlights the whole line.
|
||||
-mask: Highlights all messages from users matching the mask.
|
||||
-full: The text must match the full word.
|
||||
-matchcase: The text must match case.
|
||||
-regexp: The text is a regular expression.
|
||||
-color: The color to display the highlight in.
|
||||
-color: The color the 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.
|
||||
@ -32,7 +31,7 @@
|
||||
/HILIGHT
|
||||
/HILIGHT mike
|
||||
/HILIGHT -regexp mi+ke+
|
||||
/HILIGHT -mask -color %%G bob!*@*.irssi.org
|
||||
/HILIGHT -mask bob!*@*.irssi.org -color %%G
|
||||
/HILIGHT -full -color %%G -actcolor %%Y redbull
|
||||
|
||||
%9References:%9
|
||||
|
@ -14,8 +14,6 @@
|
||||
-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.
|
||||
@ -27,8 +25,6 @@
|
||||
The special level 'NO_ACT' can be used to ignore activity in the statusbar
|
||||
without actually ignoring the message; this behavior is somewhat special
|
||||
because it is allowed in addition to other ignores for the same target.
|
||||
The special level 'HIDDEN' can be used to hide matching messages that can
|
||||
later be revealed using /WINDOW HIDELEVEL -HIDDEN
|
||||
|
||||
%9Examples:%9
|
||||
|
||||
@ -39,15 +35,12 @@
|
||||
/IGNORE #irssi ALL -PUBLIC -ACTIONS
|
||||
/IGNORE -replies *!*@*.irssi.org ALL
|
||||
/IGNORE -regexp -pattern (away|gone|back|playing|returned) * ACTIONS
|
||||
/IGNORE -regexp -pattern (away|gone|back|playing|returned) #channel ACTIONS
|
||||
/IGNORE *zzz* NICKS
|
||||
/IGNORE *afk* NICKS
|
||||
/IGNORE *away* NICKS
|
||||
/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
|
||||
/IGNORE -regexp -pattern
|
||||
|
||||
%9See also:%9 ACCEPT, SILENCE, UNIGNORE
|
||||
|
||||
|
@ -15,7 +15,7 @@
|
||||
%9Examples:%9
|
||||
|
||||
/INFO
|
||||
/INFO irc.libera.chat
|
||||
/INFO orwell.freenode.net
|
||||
|
||||
%9See also:%9 ADMIN
|
||||
|
||||
|
@ -16,5 +16,5 @@
|
||||
/ISON mike
|
||||
/ISON sarah bob
|
||||
|
||||
%9See also:%9 NOTIFY, WHOWAS, WHOIS
|
||||
%9See also:%9 NOTIFY, WHOAS, WHOIS
|
||||
|
||||
|
@ -20,7 +20,7 @@
|
||||
/JOIN #irssi
|
||||
/JOIN #basementcat secret_lair
|
||||
/JOIN -invite
|
||||
/JOIN -liberachat #github,#libera,#irssi
|
||||
/JOIN -freenode #github,#freenode,#irssi
|
||||
|
||||
%9See also:%9 KICK, PART
|
||||
|
||||
|
@ -23,7 +23,7 @@
|
||||
%9Examples:%9
|
||||
|
||||
/KNOCK #irssi
|
||||
/KNOCK #libera
|
||||
/KNOCK #freenode
|
||||
/KNOCK #github
|
||||
|
||||
%9See also:%9 INVITE, JOIN
|
||||
|
@ -20,10 +20,9 @@
|
||||
MODES A channel mode is modified.
|
||||
MSGS Private messages.
|
||||
NICKS A nickname changes to another nickname.
|
||||
NOTICES Private notices.
|
||||
NOTICES Notices sent from a nickname.
|
||||
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,7 +32,6 @@
|
||||
|
||||
HILIGHT The text is highlighted.
|
||||
NEVER Never ignores or logs the message.
|
||||
HIDDEN Hides the message when window HIDELEVEL includes HIDDEN.
|
||||
NO_ACT Doesn't trigger any activity in the statusbar.
|
||||
NOHILIGHT The text is not highlighted.
|
||||
|
||||
|
@ -24,15 +24,11 @@
|
||||
|
||||
%9Remarks:%9
|
||||
|
||||
Not all networks support server-side filtering. Some provide a network
|
||||
service or service bot instead; on IRCnet, you may use the List service:
|
||||
Not all networks support server-side filtering and may provide a network
|
||||
service instead; on IRCnet, you may use the ALIS service:
|
||||
|
||||
/SQUERY Alis HELP
|
||||
/QUOTE SQUERY ALIS :HELP
|
||||
/MSG ALIS HELP
|
||||
|
||||
Other networks with service bots (like ChanServ) may also provide a list
|
||||
service bot (confirm with /WHOIS ALIS):
|
||||
|
||||
/MSG Alis HELP
|
||||
|
||||
%9See also:%9 STATS, SQUERY, WHOIS
|
||||
%9See also:%9 QUOTE, STATS, WHOIS
|
||||
|
||||
|
@ -33,10 +33,10 @@
|
||||
%9Examples:%9
|
||||
|
||||
/LOG OPEN -targets mike ~/irclogs/mike.log MSGS
|
||||
/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
|
||||
/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
|
||||
|
||||
/SET autolog ON
|
||||
|
||||
|
@ -1 +0,0 @@
|
||||
# don't forget to add new help files to ../meson.build
|
@ -15,7 +15,7 @@
|
||||
%9Examples:%9
|
||||
|
||||
/MOTD
|
||||
/MOTD irc.libera.chat
|
||||
/MOTD orwel.freenode.org
|
||||
/MOTD bob
|
||||
|
||||
%9See also:%9 ADMIN, INFO, LINKS, MAP
|
||||
|
@ -11,13 +11,8 @@
|
||||
|
||||
The target nickname or channel and the message to send.
|
||||
|
||||
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
|
||||
Use the wildcard character '*' if you want to use the active nickname or
|
||||
channel.
|
||||
|
||||
%9Description:%9
|
||||
|
||||
|
@ -21,7 +21,7 @@
|
||||
%9Examples:%9
|
||||
|
||||
/NAMES -ops
|
||||
/NAMES -voices #irssi,#libera
|
||||
/NAMES -voices #irssi,#freenode
|
||||
|
||||
%9See also:%9 JOIN, PART, WHO, WHOIS
|
||||
|
||||
|
@ -15,7 +15,7 @@
|
||||
%9Examples:%9
|
||||
|
||||
/NCTCP #irssi VERSION King of the Jungle v1.0
|
||||
/NCTCP bob,#libera USERINFO I am bob :p
|
||||
/NCTCP bob,#freenode USERINFO I am bob :p
|
||||
|
||||
%9See also:%9 CTCP
|
||||
|
||||
|
@ -7,19 +7,16 @@
|
||||
|
||||
LIST: Displays the list of configured networks.
|
||||
ADD: Adds a network to your configuration.
|
||||
MODIFY: Modifies a network in your configuration.
|
||||
REMOVE: Removes a network from your configuration.
|
||||
|
||||
-nick: Specifies the nickname to use.
|
||||
-alternate_nick Specifies the alternate nickname to use.
|
||||
-user: Specifies the user identity to use.
|
||||
-realname: Specifies the real name to use.
|
||||
-host: Specifies the hostname to use.
|
||||
-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.
|
||||
(Some characters need to be escaped - see /help eval)
|
||||
connecting.
|
||||
-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
|
||||
@ -38,7 +35,6 @@
|
||||
-sasl_mechanism Specifies the mechanism to use for the SASL authentication.
|
||||
At the moment irssi only supports the 'plain' and the
|
||||
'external' mechanisms.
|
||||
Use '' to disable the authentication.
|
||||
-sasl_username Specifies the username to use during the SASL authentication.
|
||||
-sasl_password Specifies the password to use during the SASL authentication.
|
||||
|
||||
@ -60,11 +56,10 @@
|
||||
%9Examples:%9
|
||||
|
||||
/NETWORK ADD -usermode +giw EFnet
|
||||
/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 -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 -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 liberachat
|
||||
/NETWORK REMOVE Freenode
|
||||
|
||||
%9See also:%9 CHANNEL, CONNECT, SERVER
|
||||
|
||||
|
@ -1,111 +0,0 @@
|
||||
|
||||
OTR %|[OPTION]
|
||||
|
||||
Command to control the OTR module. Without an option, /OTR INFO is printed.
|
||||
|
||||
This help contains three sections which are %9options, quickstart and files.%n
|
||||
|
||||
To add the OTR status bar (highly recommended):
|
||||
|
||||
%9/statusbar window add otr%n
|
||||
|
||||
%9Options:%n
|
||||
|
||||
AUTH <secret>
|
||||
Start or respond to an authentication process.
|
||||
|
||||
AUTHQ <question> <secret>
|
||||
Start a SMP authentication process.
|
||||
|
||||
Example: %9/otr authq "My question is" "this is the secret"%n
|
||||
|
||||
AUTHABORT
|
||||
Abort an ongoing authentication process.
|
||||
|
||||
CONTEXTS
|
||||
List known contexts which basically list the known fingerprints and their
|
||||
state.
|
||||
|
||||
DEBUG
|
||||
Turn on debugging.
|
||||
|
||||
DISTRUST <fingerprint>
|
||||
Distrust a specific fingerprint. This command can be done inside a private
|
||||
window for which the current fingerprint of the other person will be used
|
||||
or else set fp to a human readable OTR fingerprint available with the above
|
||||
contexts command.
|
||||
|
||||
Examples: %9/otr distrust 487FFADA 5073FEDD C5AB5C14 5BB6C1FF 6D40D48A%n
|
||||
|
||||
FINISH
|
||||
End the OTR session. This MUST be done inside a private conversation
|
||||
window.
|
||||
|
||||
FORGET <fingerprint>
|
||||
Forget a specific fingerprint (deleted from the known fingerprints). The
|
||||
behavior is the same as the distrust command explained above.
|
||||
|
||||
GENKEY <name>
|
||||
Generate OTR keys for a given account name. This is done automatically
|
||||
if someone tries to establish a secure session.
|
||||
|
||||
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
|
||||
caught.
|
||||
|
||||
HELP
|
||||
Print this help.
|
||||
|
||||
INFO
|
||||
Display the OTR fingerprint(s) of all your account(s).
|
||||
|
||||
INIT
|
||||
Initialize an OTR conversation within a private conversation window.
|
||||
|
||||
TRUST <fingerprint>
|
||||
Trust a specific fingerprint. The behavior is the same as the forget and
|
||||
distrust commands explained above.
|
||||
|
||||
VERSION
|
||||
Print the version of the OTR module.
|
||||
|
||||
%9Quickstart:%n
|
||||
|
||||
Start a private conversation with the person you want to initiate a secure
|
||||
session. Once in the private message window:
|
||||
|
||||
%9/otr init%n
|
||||
|
||||
Key generation should start if no key is found for your account name. Once the
|
||||
process is done, either type a message which should automatically start the
|
||||
session or redo the init command.
|
||||
|
||||
Time to authenticate the person. Either use a shared secret exchange through
|
||||
phone or GPG-signed email or use the socialist millionaire problem mechanism
|
||||
(SMP) which is basically to ask a question for which the answer can only be
|
||||
known by the other person.
|
||||
|
||||
%9/otr auth <shared-secret>%n OR %9/otr authq "A question" <shared-secret>%n
|
||||
|
||||
Or to respond to an authentication:
|
||||
|
||||
%9/otr auth <secret>%n
|
||||
|
||||
%9Files:%n
|
||||
|
||||
This otr modules creates a directory in %9$HOME/.irssi/otr%n and creates three
|
||||
files:
|
||||
|
||||
* %9otr.key%n
|
||||
Contains your OTR private key(s). NEVER shared this directory with someone
|
||||
else unless you know what you are doing.
|
||||
|
||||
* %9otr.fp%n
|
||||
The known fingerprints with their _trust_ status.
|
||||
|
||||
* %9otr.instag
|
||||
Instance tag of the libotr. This should NEVER be copied to an other
|
||||
computer. If unsure, just ignore this file.
|
||||
|
||||
For more information on OTR, see https://otr.cypherpunks.ca/
|
||||
|
@ -14,7 +14,7 @@
|
||||
%9Examples:%9
|
||||
|
||||
/PART #irssi
|
||||
/PART #libera,#irssi
|
||||
/PART #freenode,#irssi
|
||||
|
||||
%9See also:%9 JOIN, KICK
|
||||
|
||||
|
@ -17,8 +17,8 @@
|
||||
%9Examples:%9
|
||||
|
||||
/QUERY mike
|
||||
/QUERY -liberachat bob
|
||||
/QUERY -liberachat -window sarah
|
||||
/QUERY -freenode bob
|
||||
/QUERY -freenode -window sarah
|
||||
|
||||
%9See also:%9 MSG, UNQUERY, WINDOW
|
||||
|
||||
|
@ -22,7 +22,7 @@
|
||||
%9Examples:%9
|
||||
|
||||
/RECODE
|
||||
/RECODE ADD liberachat/mike utf-8
|
||||
/RECODE ADD Freenode/mike utf-8
|
||||
/RECODE ADD #korea euc-kr
|
||||
/RECODE REMOVE #korea
|
||||
|
||||
|
@ -15,7 +15,7 @@
|
||||
%9Examples:%9
|
||||
|
||||
/RECONNECT
|
||||
/RECONNECT liberachat
|
||||
/RECONNECT Freenode
|
||||
/RECONNECT EFnet BRB :)
|
||||
|
||||
%9See also:%9 CONNECT, DISCONNECT, NETWORK, RMRECONNS, SERVER
|
||||
|
@ -12,8 +12,6 @@
|
||||
RESET: Unloads all the scripts.
|
||||
-permanent: In combination with EXEC, the code will be loaded into the
|
||||
memory.
|
||||
-autorun: When passed to RESET the scripts in the autorun folder are
|
||||
reloaded.
|
||||
|
||||
If no argument is given, the list of active scripts will be displayed.
|
||||
|
||||
|
@ -5,72 +5,66 @@
|
||||
|
||||
%9Parameters:%9
|
||||
|
||||
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.
|
||||
REMOVE: Removes a server from your configuration.
|
||||
PURGE: Purges the commands queued to be sent to the server.
|
||||
LIST: Displays the list of servers you are connected to.
|
||||
CONNECT: Connects to the given server.
|
||||
ADD: Adds a server to your configuration.
|
||||
REMOVE: Removes a server from your configuration.
|
||||
PURGE: Purges the commands queued to be sent to the server.
|
||||
|
||||
-!: Doesn't autojoin the channels.
|
||||
-4: Connects using IPv4.
|
||||
-6: Connects using IPv6.
|
||||
-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 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
|
||||
milliseconds, that the client must wait before sending
|
||||
additional commands to the server.
|
||||
-cmdmax: Specifies the maximum number of commands to perform
|
||||
before starting the internal flood protection.
|
||||
-port: Specifies the port to connect to the server.
|
||||
-noproxy: Ignores the global proxy configuration.
|
||||
-rawlog: Immediately open rawlog after connecting.
|
||||
-noautosendcmd: Doesn't execute autosendcmd.
|
||||
-!: Doesn't autojoin the channels.
|
||||
-4: Connects using IPv4.
|
||||
-6: Connects using IPv6.
|
||||
-ssl: Connects using SSL encryption.
|
||||
-ssl_cert: The SSL client certificate file.
|
||||
-ssl_pkey: The SSL client private key, if not included in the
|
||||
certificate file.
|
||||
-ssl_pass: The password for the SSL client private key or certificate.
|
||||
-ssl_verify: Verifies the SSL certificate of the server.
|
||||
-ssl_cafile: The file with the list of CA certificates.
|
||||
-ssl_capath: The directory which contains the CA certificates.
|
||||
-ssl_ciphers: SSL cipher suite preference lists.
|
||||
-auto: Automatically connects to the server on startup.
|
||||
-noauto: Doesn't connect to the server on startup.
|
||||
-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
|
||||
milliseconds, that the client must wait before sending
|
||||
additional commands to the server.
|
||||
-cmdmax: Specifies the maximum number of commands to perform
|
||||
before starting the internal flood protection.
|
||||
-port: Specifies the port to connect to the server.
|
||||
-noproxy: Ignores the global proxy configuration.
|
||||
-rawlog: Immediately open rawlog after connecting.
|
||||
-noautosendcmd: Doesn't execute autosendcmd.
|
||||
|
||||
The server, port and network to add, modify or remove; if no argument is
|
||||
given, the list of servers you are connected to will be returned.
|
||||
|
||||
%9Description:%9
|
||||
|
||||
Displays, adds, modifies or removes the network configuration of IRC
|
||||
Displays, adds, modifies or removes the network configuration of IRC
|
||||
servers.
|
||||
|
||||
When using the ADD parameter on a server that already exists, the
|
||||
configuration will be merged with each other.
|
||||
|
||||
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
|
||||
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.
|
||||
|
||||
%9Examples:%9
|
||||
|
||||
/SERVER
|
||||
/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 chat.freenode.net
|
||||
/SERVER +chat.freenode.net
|
||||
/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 -port 6667 -4 -network Freenode -noproxy orwell.freenode.net
|
||||
/SERVER REMOVE orwell.freenode.net 6667 Freenode
|
||||
/SERVER PURGE
|
||||
/SERVER PURGE irc.libera.chat
|
||||
/SERVER PURGE orwell.freenode.net
|
||||
|
||||
%9See also:%9 CHANNEL, CONNECT, DISCONNECT, NETWORK, RECONNECT, RMRECONNS
|
||||
|
||||
|
@ -1,23 +0,0 @@
|
||||
|
||||
%9Syntax:%9
|
||||
|
||||
@SYNTAX:servlist@
|
||||
|
||||
%9Parameters:%9
|
||||
|
||||
<mask> limits the output to the services which names matches
|
||||
the mask.
|
||||
<type> limits the output to the services of the specified type.
|
||||
|
||||
%9Description:%9
|
||||
|
||||
List the network services currently present on the
|
||||
IRC network.
|
||||
|
||||
%9Examples:%9
|
||||
|
||||
/SERVLIST *@javairc.*
|
||||
/SERVLIST * 0xD000
|
||||
|
||||
%9See also:%9 SQUERY
|
||||
|
@ -7,7 +7,6 @@
|
||||
|
||||
-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
|
||||
@ -28,7 +27,6 @@
|
||||
/SET -clear nick
|
||||
/SET log_timestamp %%H:%%H:%%S
|
||||
/SET -default log_timestamp
|
||||
/SET -section lookandfeel
|
||||
/SET close
|
||||
|
||||
%9See also:%9 SAVE, TOGGLE
|
||||
|
@ -1,16 +0,0 @@
|
||||
|
||||
%9Syntax:%9
|
||||
|
||||
@SYNTAX:squery@
|
||||
|
||||
%9Parameters:%9
|
||||
|
||||
<service> - Service nickname or full hostmask of service to query.
|
||||
<message> - Message to send to the service.
|
||||
|
||||
%9Description:%9
|
||||
|
||||
/SQUERY sends a query to the specified service.
|
||||
|
||||
%9See also:%9 SERVLIST, LIST, MSG
|
||||
|
@ -5,58 +5,32 @@
|
||||
|
||||
%9Parameters:%9
|
||||
|
||||
ADD: Adds a statusbar to the list of statusbars.
|
||||
MODIFY: Modifies the configuration of a statusbar.
|
||||
ENABLE: Enables the statusbar.
|
||||
DISABLE: Disabled the statusbar.
|
||||
RESET: Restores the default statusbar configuration.
|
||||
ADDITEM: Adds an item to the specified statusbar. It can be set to
|
||||
appear before/after another item and left/right aligned
|
||||
to a specified position on the screen.
|
||||
MODIFYITEM: Changes an item position inside a bar.
|
||||
REMOVEITEM: Removes an item from the specified statusbar.
|
||||
INFO: List the current details and items of the specified
|
||||
statusbar.
|
||||
TYPE: Identifies the type of statusbar.
|
||||
PLACEMENT: Identifies the placement of the statusbar.
|
||||
POSITION: Identifies the position of the statusbar.
|
||||
VISIBLE: Identifies the visibility of the statusbar.
|
||||
ADD: Adds a statusbar into the configuration.
|
||||
REMOVE: Removes a statusbar from the configuration.
|
||||
|
||||
-disable: Removes a statusbar from the list.
|
||||
-type: Sets the type of statusbar, for each split window or only
|
||||
for the current root screen.
|
||||
-placement: Sets the placement of the statusbar, either at the top or
|
||||
the bottom of the screen.
|
||||
-position: Sets the position of the statusbar. Represented as a
|
||||
number, with 0 implying the first position.
|
||||
-visible: Sets the visibility of the statusbar or item. If set to
|
||||
always it is visible on all screens, otherwise if set to
|
||||
inactive or active then it is only visible on inactive
|
||||
or active screens, respectively.
|
||||
-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 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
|
||||
given, the entire list of statusbars will be displayed.
|
||||
The name of the statusbar; if no argument is given, the list of statusbars
|
||||
will be displayed.
|
||||
|
||||
%9Description:%9
|
||||
|
||||
Allows adjustment of the attributes and items of a statusbar, as well
|
||||
as where it is located and whether or not it is currently visible.
|
||||
Modified the attributes of the statusbar.
|
||||
|
||||
%9Examples:%9
|
||||
|
||||
/STATUSBAR
|
||||
/STATUSBAR INFO window
|
||||
/STATUSBAR REMOVEITEM time window
|
||||
/STATUSBAR ADDITEM time window
|
||||
/STATUSBAR RESET window
|
||||
/STATUSBAR MODIFY -disable topic
|
||||
/STATUSBAR MODIFY -nodisable topic
|
||||
|
||||
%9Remarks:%9
|
||||
|
||||
Statusbar syntax was changed in Irssi 1.2. The old syntax is still
|
||||
accepted for backward compatibility, but no longer documented.
|
||||
/STATUSBAR window
|
||||
/STATUSBAR window REMOVE time
|
||||
/STATUSBAR window ADD time
|
||||
/STATUSBAR window RESET
|
||||
/STATUSBAR topic DISABLE
|
||||
/STATUSBAR topic ENABLE
|
||||
|
||||
%9See also:%9 WINDOW
|
||||
|
||||
|
@ -33,22 +33,19 @@
|
||||
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 number of lines.
|
||||
SIZE: %|Set the current split window size to the specified numer 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 left.
|
||||
UP: %|Set the split window above the current one active. At the top, wraps to the bottom.
|
||||
DOWN: %|Set the split window below the current one active. At the bottom, wraps to the top.
|
||||
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.
|
||||
MOVE LEFT: %|Move the window to the numerically previous location inside the current sticky group.
|
||||
MOVE RIGHT: %|Move the window to the numerically next location inside the current sticky group.
|
||||
MOVE UP: %|Move the current window to the sticky group of the previous split window. If no sticky group remains, the split window collapses.
|
||||
MOVE DOWN: %|Move the current window to the sticky group of the next split window. If no sticky group remains, the split window collapses.
|
||||
|
||||
-right: %|Makes the command work on the width instead of height, or create the split window to the right instead of top.
|
||||
-directional: %|Set the split window in the given direction to the current one active, or move the current window to the sticky group of the split window in the given direction. (If no sticky group remains, the split window collapses.)
|
||||
MOVE UP: %|Move the current window to the sticky group of the split window above. If no sticky group remains, the split window collapses.
|
||||
MOVE DOWN: %|Move the current window to the sticky group of the split window below. If no sticky group remains, the split window collapses.
|
||||
|
||||
%|Add the required arguments for the given command. Without arguments, the details (size, immortality, levels, server, name and sticky group) of the currently active window are displayed. If used with a number as argument, same as WINDOW REFNUM.
|
||||
|
||||
|
@ -1,121 +0,0 @@
|
||||
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')
|
@ -51,6 +51,9 @@ use
|
||||
.I HOSTNAME
|
||||
for your irc session
|
||||
.TP
|
||||
.BI "\-d, \-\-dummy"
|
||||
use dummy terminal mode
|
||||
.TP
|
||||
.BI "\-v, \-\-version"
|
||||
display the version of Irssi
|
||||
.TP
|
||||
@ -59,7 +62,7 @@ show a help message
|
||||
.SH SEE ALSO
|
||||
.B Irssi
|
||||
has a solid amount of documentation available; check /HELP or look online
|
||||
at https://irssi.org
|
||||
at http://www.irssi.org
|
||||
.SH FILES
|
||||
.TP
|
||||
.I ~/.irssi/config
|
||||
|
@ -1,5 +1,5 @@
|
||||
|
||||
Irssi 0.8 documentation - https://irssi.org/
|
||||
Irssi 0.8 documentation - http://www.irssi.org/
|
||||
|
||||
Copyright(c) 2000 Timo Sirainen <cras@irssi.org>
|
||||
|
||||
@ -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" liberachat
|
||||
/NETWORK ADD -autosendcmd "/^msg NickServ identify secret" freenode
|
||||
|
||||
/NETWORK REMOVE <name>
|
||||
|
||||
@ -394,26 +394,10 @@
|
||||
|
||||
5.4 Server settings
|
||||
|
||||
/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>]
|
||||
/SERVER ADD [-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
|
||||
|
@ -1,18 +0,0 @@
|
||||
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')
|
@ -10,7 +10,7 @@ INSTALL file for information about perl problems.
|
||||
---------------
|
||||
|
||||
Scripts are run with /SCRIPT LOAD command, or the default /RUN alias.
|
||||
"/SCRIPT" shows list of running scripts, and /SCRIPT UNLOAD can unload
|
||||
"/SCRIPT" shows list of running script, and /SCRIPT UNLOAD can unload
|
||||
scripts.
|
||||
|
||||
Scripts should be placed to ~/.irssi/scripts/ or
|
||||
@ -178,9 +178,6 @@ 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
|
||||
@ -205,12 +202,6 @@ 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
|
||||
|
||||
@ -1201,9 +1192,4 @@ Client->{}
|
||||
Bugs and Limitations
|
||||
--------------------
|
||||
* Calling die in 'script error' handler causes segfault (#101)
|
||||
* Calling "script unload" from your own script causes segfault
|
||||
* Storing and later using any Irssi object may result in use-after-free related crash
|
||||
- Workaround: always acquire fresh objects
|
||||
* Calling $dcc->close from the "dcc created" signal will cause unstable behaviour and crashes (#386)
|
||||
- Workaround: use "dcc request" signal instead AND call
|
||||
&Irssi::signal_continue(@_); as the first thing
|
||||
|
@ -24,24 +24,12 @@ 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 liberachat=2779
|
||||
/SET irssiproxy_ports ircnet=2777 efnet=2778 freenode=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
|
||||
make it work properly.
|
||||
|
||||
The special network name "?" allows the client to select the network
|
||||
dynamically on connect:
|
||||
|
||||
/SET irssiproxy_ports ?=2777
|
||||
|
||||
Now the client can send <network>:<password> as the server password, e.g.
|
||||
|
||||
/CONNECT ... 2777 efnet:secret
|
||||
|
||||
to connect to efnet. If there is no irssiproxy_password set, you can
|
||||
omit the ":" and just send the network name as the password.
|
||||
|
||||
By default, the proxy binds to all available interfaces. To make it
|
||||
only listen on (for example) the loopback address:
|
||||
|
||||
|
@ -56,14 +56,15 @@ modules.c:
|
||||
"module error", int error, char *text, char *rootmodule, char *submodule
|
||||
|
||||
network-openssl.c:
|
||||
"tls handshake finished", SERVER_REC, TLS_REC
|
||||
"tlsa available", SERVER_REC
|
||||
"tlsa verification success", SERVER_REC
|
||||
"tlsa verification failed", SERVER_REC
|
||||
|
||||
nicklist.c:
|
||||
"nicklist new", CHANNEL_REC, NICK_REC
|
||||
"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
|
||||
|
||||
@ -133,10 +134,7 @@ irc-servers.c:
|
||||
irc-cap.c
|
||||
"server cap ack "<cmd>, SERVER_REC
|
||||
"server cap nak "<cmd>, SERVER_REC
|
||||
"server cap new "<cmd>, SERVER_REC
|
||||
"server cap delete "<cmd>, SERVER_REC
|
||||
"server cap end", SERVER_REC
|
||||
"server cap req", SERVER_REC, char *caps
|
||||
|
||||
sasl.c
|
||||
"server sasl failure", SERVER_REC, char *reason
|
||||
@ -145,13 +143,11 @@ 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
|
||||
@ -247,12 +243,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, TEXT_DEST_REC
|
||||
"gui print text finished", WINDOW_REC
|
||||
|
||||
* Provides signals:
|
||||
|
||||
completion.c:
|
||||
"complete word", GList * of char *s, WINDOW_REC, char *word, char *linestart, int *want_space
|
||||
"complete word", GList * of char*, WINDOW_REC, char *word, char *linestart, int *want_space
|
||||
|
||||
fe-common-core.c:
|
||||
"irssi init read settings"
|
||||
@ -264,21 +260,17 @@ fe-exec.c:
|
||||
|
||||
fe-messages.c:
|
||||
"message public", SERVER_REC, char *msg, char *nick, char *address, char *target
|
||||
"message private", SERVER_REC, char *msg, char *nick, char *address, char *target
|
||||
"message private", SERVER_REC, char *msg, char *nick, char *address
|
||||
"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, char *account, char *realname
|
||||
"message join", SERVER_REC, char *channel, char *nick, char *address
|
||||
"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
|
||||
@ -286,8 +278,6 @@ 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
|
||||
@ -295,7 +285,6 @@ themes.c:
|
||||
|
||||
window-activity.c:
|
||||
"window hilight", WINDOW_REC
|
||||
"window hilight check", TEXT_DEST_REC, char *msg, int *data_level, int *should_ignore
|
||||
"window dehilight", WINDOW_REC
|
||||
"window activity", WINDOW_REC, int old_level
|
||||
"window item hilight", WI_ITEM_REC
|
||||
@ -351,25 +340,15 @@ 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, TEXT_DEST_REC
|
||||
"gui print text after finished", WINDOW_REC, LINE_REC *line, LINE_REC *prev_line
|
||||
|
||||
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
|
||||
----
|
||||
|
||||
"script error", PERL_SCRIPT_REC, char *errormsg
|
||||
|
||||
OTR Core
|
||||
--------
|
||||
|
||||
otr.c:
|
||||
"otr event", SERVER_REC, char *nick, char *status
|
||||
|
@ -94,8 +94,6 @@ $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:
|
||||
|
||||
|
846
docs/startup-HOWTO-rus.html
Normal file
846
docs/startup-HOWTO-rus.html
Normal file
@ -0,0 +1,846 @@
|
||||
<h2>Startup HOWTO</h2>
|
||||
|
||||
<h3>Новичкам в Irssi (а не IRC ..)</h3>
|
||||
|
||||
<p>© 2000-2002 by Timo Sirainen, распространяется под лицензией
|
||||
<a href="http://www.gnu.org/licenses/fdl.html">GNU FDL</a> 1.1.<br/>
|
||||
На русский язык переведено NiXoiD'ом (#xakep @ irc.wenet.ru)
|
||||
</p>
|
||||
|
||||
|
||||
<p>Оглавление с некоторыми вопросами из FAQ, на которые дается ответ в параграфах:</p>
|
||||
|
||||
<ol>
|
||||
<li><a href="#c1">Для ленивых</a>
|
||||
<ul>
|
||||
<li>Управление окнами, аналогичное ircII</li>
|
||||
</ul></li>
|
||||
<li><a href="#c2">Основы пользовательского интерфейса</a>
|
||||
<ul>
|
||||
<li>Работа с "разделенными" окнами (я так перевёл "split windows")</li>
|
||||
<li>Как я могу легко переключаться между окнами?</li>
|
||||
<li>Но alt-1 и.т.д. не работает!</li>
|
||||
</ul></li>
|
||||
<li><a href="#c3">Автозаход на каналы и серверы</a>
|
||||
<ul>
|
||||
<li>Как автоматически подключаться к серверам при запуске?</li>
|
||||
<li>Как автоматически заходить на каналы?</li>
|
||||
<li>Как автоматически выполнять команды при подключении?</li>
|
||||
</ul></li>
|
||||
<li><a href="#c4">Настройка окон и автоматическое восстановление их при запуске</a></li>
|
||||
<li><a href="#c5">Окна status и msgs & уровни сообщений</a>
|
||||
<ul>
|
||||
<li>Я хочу чтобы ответ на /WHOIS выводился в текущее окно</li>
|
||||
<li>Я хочу чтобы все сообщения выводились в одном окне</li>
|
||||
</ul></li>
|
||||
<li><a href="#c6">Как в irssi работает многосерверная поддержка</a>
|
||||
<ul>
|
||||
<li>Я подключился к серверу, который не отвечает и теперь irssi пытается подключиться к нему снова и снова. Как мне остановить это??</li>
|
||||
<li>Я хочу отдельное окно статуса и сообщений для каждого сервера</li>
|
||||
</ul></li>
|
||||
<li><a href="#c7">Команда /LASTLOG и прокрутка окон</a>
|
||||
<ul>
|
||||
<li>Как сохранить весь текст из окна в файл?</li>
|
||||
</ul></li>
|
||||
<li><a href="#c8">Ведение логов</a></li>
|
||||
<li><a href="#c9">Изменение клавиатурных Сочетаний</a>
|
||||
<ul>
|
||||
<li>Как я могу заставить F1 делать что-то?</li>
|
||||
</ul></li>
|
||||
<li><a href="#c10">Прокси и боунсеры</a>
|
||||
<ul>
|
||||
<li>Что такое irssi-proxy?</li>
|
||||
</ul></li>
|
||||
<li><a href="#c11">Настройки Irssi</a></li>
|
||||
<li><a href="#c12">Статусбар</a>
|
||||
<ul>
|
||||
<li>Я загрузил скрипт для статусбара, но его нигде не видно!</li>
|
||||
</ul></li>
|
||||
</ol>
|
||||
|
||||
<h3><a id="c1">1. Для ленивых</a></h3>
|
||||
|
||||
<p>Несколько полезных настроек по умолчанию:</p>
|
||||
|
||||
<p>Если не работают цвета и вы не собираетесь использовать VT-несовместимый терминал, то просто введите:</p>
|
||||
|
||||
<pre>
|
||||
/SET term_force_colors ON
|
||||
</pre>
|
||||
|
||||
<p>Если вы хотите чтобы все сообщения выводились в одном окне:</p>
|
||||
|
||||
<pre>
|
||||
/SET autocreate_own_query OFF
|
||||
/SET autocreate_query_level DCCMSGS
|
||||
/SET use_status_window OFF
|
||||
/SET use_msgs_window ON
|
||||
</pre>
|
||||
|
||||
<p>Чтобы окна автоматически не закрывались когда вы покидаете канал(<code>/PART</code>)или приват
|
||||
(<code>/UNQUERY</code>):</p>
|
||||
|
||||
<pre>
|
||||
/SET autoclose_windows OFF
|
||||
/SET reuse_unused_windows ON
|
||||
</pre>
|
||||
|
||||
<p>Чтобы управление окнами в irssi было похоже на ircII введите эти команды:</p>
|
||||
|
||||
<pre>
|
||||
/SET autocreate_own_query OFF
|
||||
/SET autocreate_query_level NONE
|
||||
/SET use_status_window OFF
|
||||
/SET use_msgs_window OFF
|
||||
/SET reuse_unused_windows ON
|
||||
/SET windows_auto_renumber OFF
|
||||
|
||||
/SET autostick_split_windows OFF
|
||||
/SET autoclose_windows OFF
|
||||
/SET print_active_channel ON
|
||||
</pre>
|
||||
|
||||
<p>Вот пример добавления серверов:</p>
|
||||
|
||||
<p>(сеть OFTC, идентифицироваться через nickserv и ждать 2 секунды перед заходом на каналы)</p>
|
||||
|
||||
<pre>
|
||||
/IRCNET ADD -autosendcmd "/^msg nickserv identify pass;wait 2000" OFTC
|
||||
</pre>
|
||||
|
||||
<p>Теперь добавление нескольких серверов к разным сетям (IRC-сеть для них уже установлена),
|
||||
irc.kpnqwest.fi используется по дефолту для IRCNet но если он не доступен, то irssi будет пытаться подключиться к
|
||||
irc.funet.fi:</p>
|
||||
|
||||
<pre>
|
||||
/SERVER ADD -auto -ircnet ircnet irc.kpnqwest.fi 6667
|
||||
/SERVER ADD -ircnet ircnet irc.funet.fi 6667
|
||||
/SERVER ADD -auto -ircnet efnet efnet.cs.hut.fi 6667
|
||||
</pre>
|
||||
|
||||
<p>Автозаход на каналы при подключении к серверу и оп-запрос бота при заходе на efnet/#irssi:</p>
|
||||
|
||||
<pre>
|
||||
/CHANNEL ADD -auto #irssi ircnet
|
||||
/CHANNEL ADD -auto -bots *!*bot@host.org -botcmd "/^msg $0 op pass" #irssi efnet
|
||||
</pre>
|
||||
|
||||
Чтобы строки, содержащие Ваш ник подсвечивались:
|
||||
|
||||
<pre>
|
||||
/HILIGHT ваш_ник
|
||||
</pre>
|
||||
|
||||
<h3><a id="c2">2. Основы пользовательского интерфейса</a></h3>
|
||||
|
||||
<p>Для скроллинга содержимого окон используйте PgUp и PgDown. Если они не работают, используйте кнопки Meta-p и Meta-n.
|
||||
Чтобы перескочить в начало или конец буфера используйте команды <code>/SB HOME</code> и <code>/SB END</code>.</p>
|
||||
|
||||
<p>По умолчанию irssi использует для всего "скрытые окна". Скрытое окно создается каждый раз когда вы заходите(<code>/JOIN</code>) на канал или создаете приват(<code>/QUERY</code>)
|
||||
с кем-то. Есть несколько способов переключения между этими окнами:</p>
|
||||
|
||||
<pre>
|
||||
Meta-1, Meta-2, .. Meta-0 - Переключение между окнами 1-10
|
||||
Meta-q .. Meta-o - Переключение между окнами 11-19
|
||||
/WINDOW <номер> - Переключение на окно с заданным номером
|
||||
Ctrl-P, Ctrl-N - Переключение к предыдущему/следующему окну
|
||||
</pre>
|
||||
|
||||
<p>Простейший способ переключения - это Meta-номер. Что такое Meta?
|
||||
Для некоторых терминалов это ALT. Если у вас windows-совместимая клавиатура, то это так-же может быть левая кнопка windows. Если они не работают, то вам придется настроить некоторые X-ресурсы
|
||||
(это работает как в xterm так и в rxvt):</p>
|
||||
|
||||
<pre>
|
||||
XTerm*eightBitInput: false
|
||||
XTerm*metaSendsEscape: true
|
||||
</pre>
|
||||
|
||||
<p>В rxvt вы так-же можете указать какая кнопка соответствует кнопке meta, так что если вы хотите использовать Alt вместо Win допишите это в файл с ресурсами:</p>
|
||||
|
||||
<pre>
|
||||
rxvt*modifier: alt
|
||||
</pre>
|
||||
|
||||
<p>Вы так-же можете сделать это при помощи xmodmap:</p>
|
||||
|
||||
<pre>
|
||||
xmodmap -e "keysym Alt_L = Meta_L Alt_L"
|
||||
</pre>
|
||||
|
||||
<p>Так как-же установить эти X-ресурсы? Для Debian'а, это файл
|
||||
<code>/etc/X11/Xresources/xterm</code>, в который вы можете их засунуть и они будут автоматически читаться при старте иксов. Файлы <code>~/.Xresources</code> и
|
||||
<code>~/.Xdefaults</code> так-же должны работать. Если ничего из вышеперечисленного не работает, то просто скопируйте их в <code>~/.Xresources</code>
|
||||
и загрузите командой <code>xrdb -merge ~/.Xresources</code>.
|
||||
Изменения начинают действовать только в заново запущенном терминале.</p>
|
||||
|
||||
<p>Многие SSH клиенты под Windows так же не разрешают использовать кнопку ALT. Прекрасный клиент, который позволяет делать это - putty, вы можете скачать его с
|
||||
<a href="http://www.chiark.greenend.org.uk/~sgtatham/putty/">
|
||||
http://www.chiark.greenend.org.uk/~sgtatham/putty/</a>.</p>
|
||||
|
||||
<p>Так-же поддерживает разделение окон. Вот команды, которые позволяют это сделать:</p>
|
||||
|
||||
<pre>
|
||||
/WINDOW NEW - Создать новое разделенное окно
|
||||
/WINDOW NEW HIDE - Создать новое скрытое окно
|
||||
/WINDOW CLOSE - Закрыть разделенное или скрытое окно
|
||||
|
||||
/WINDOW HIDE [<number>|<name>] - Сделать разделенное окно скрытым
|
||||
/WINDOW SHOW <number>|<name> - Сделать скрытое окно разделенным
|
||||
|
||||
/WINDOW SHRINK [<lines>] - Уменьшить активное окно
|
||||
/WINDOW GROW [<lines>] - Увеличить активное окно
|
||||
/WINDOW BALANCE - Сбалансировать размеры всех разделенных окон
|
||||
</pre>
|
||||
|
||||
<p>По умолчанию Irssi использует "приклеивание окон". Это подразумевает, что окно, созданное внутри разделенного окна не может быть перемещено без некоторого гемора :). Например у вас может быть следующее расположение окон:</p>
|
||||
|
||||
<pre>
|
||||
Split window 1: win#1 - Status window, win#2 - Окно сообщений
|
||||
Split window 2: win#3 - ircnet/#channel1, win#4 - ircnet/#channel2
|
||||
Split window 3: win#5 - efnet/#channel1, win#6 - efnet/#channel2
|
||||
</pre>
|
||||
|
||||
<p>Когда вы в окне win#1 нажимаете ALT-6, irssi переключается на разделенное окно
|
||||
#3 и перемещает канал efnet/#channel2 в активное окно.</p>
|
||||
|
||||
<p>При "незакреплённом" варианте окна не имеют никакой связи с разделенными окнами
|
||||
и нажатие ALT-6 в окне win#1 перемещает окно win#6 в разделенное окно 1
|
||||
и делает его активным, исключение может быть когда окно win#6 уже видимо в каком-то другом
|
||||
разделенном окне, irssi просто переключается к этому разделенному окну. Такой метод переключения между окнами применяется в ircII и если он вам понравился то вы можете активизировать его при помощи команды</p>
|
||||
|
||||
<pre>
|
||||
/SET autostick_split_windows OFF
|
||||
</pre>
|
||||
|
||||
<p>Каждое окно внутри себя может содержать много каналов, приватов и других "вещей". Если вы вообще не любите окна, то вы можете отменить их командой</p>
|
||||
|
||||
<pre>
|
||||
/SET autocreate_windows OFF [format c: надёжнее ;) - прим. перев.]
|
||||
</pre>
|
||||
|
||||
<p>И если вы держите все каналы в одном окне, то вам наверное захочется чтобы имя канала выводилось в каждом сообщении:</p>
|
||||
|
||||
<pre>
|
||||
/SET print_active_channel ON
|
||||
</pre>
|
||||
|
||||
<p>Если вы хотите сгруппировать в какое-то окно только некоторые каналы или приваты, то используйте эти команды:</p>
|
||||
|
||||
<pre>
|
||||
/JOIN -window #channel
|
||||
/QUERY -window nick
|
||||
</pre>
|
||||
|
||||
<h3><a id="c3">3. Автозаход на каналы и серверы</a></h3>
|
||||
|
||||
<p>В Irssi многосерверная поддержка ИМХО очень хорошая :). Даже если вы хотите общаться только в одной сети, то очень удобно сгруппировать все серверы этой сети в одну группу т.к. это помогает в случае невозможности соединения с главным сервером и в некоторых других случаях :).
|
||||
Дополнительную информацию об эффективном использовании многосерверной поддержки смотрите в главе 6.</p>
|
||||
|
||||
<p>Для начала вам нужно установить свою IRC-сеть, для этого используйте команду <code>/IRCNET</code>,
|
||||
чтобы убедится, что она ещё не установлена. Если она не установлена, то введите <code>/IRCNET ADD
|
||||
имя_сети</code>. Если вы хотите, чтобы какие-то команды автоматически выполнялись при подключении к этой сети, то воспользуйтесь опцией <code>-autosendcmd</code>.
|
||||
Вот некоторые примеры:</p>
|
||||
|
||||
<pre>
|
||||
/IRCNET ADD -autosendcmd '^msg bot invite' ircnet
|
||||
/IRCNET ADD -autosendcmd "/^msg nickserv identify pass;wait 2000" OFTC
|
||||
</pre>
|
||||
|
||||
<p>После этого вы должны добавить к этой сети серверы. Например:</p>
|
||||
|
||||
<pre>
|
||||
/SERVER ADD -auto -ircnet ircnet irc.kpnqwest.fi 6667
|
||||
/SERVER ADD -auto -ircnet worknet irc.mycompany.com 6667 пароль
|
||||
</pre>
|
||||
|
||||
<p>Опция <code>-auto</code> указывает, что к этому серверу нужно автоматически подключаться при запуске.
|
||||
Вы не должны помечать другие серверы той-же сети опцией <code>-auto</code> - Irssi автоматически к ним подключится, если сервер помеченный <code>-auto</code> недоступен.</p>
|
||||
|
||||
<p>И наконец каналы:</p>
|
||||
|
||||
<pre>
|
||||
/CHANNEL ADD -auto -bots *!*bot@host.org -botcmd "/^msg $0 op pass" #irssi efnet
|
||||
/CHANNEL ADD -auto #secret ircnet password
|
||||
</pre>
|
||||
|
||||
<p>Опции <code>-bots</code> и <code>-botcmd</code> требуют небольшого пояснения.
|
||||
Они используются для того, чтобы автоматически давать команды боту при заходе на канал,
|
||||
обычно для автоматического получения опа. Вы можете задать много масок ботов при помощи опции
|
||||
<code>-bots</code>, разделенной пробелами (не забудьте взять эту строку в кавычек). Переменная $0 в опции
|
||||
<code>-botcmd</code> указывает на первого бота в списке найденных. Если вы не хотите использовать маски для ботов (например если бот всегда сидит под одним ником)
|
||||
вы можете указать только опцию <code>-botcmd</code> и команду.</p>
|
||||
|
||||
<h3><a id="c4">4. Настройка окон и автоматическое восстановление при запуске</a></h3>
|
||||
|
||||
<p>Для начала создайте нужные окна(подключитесь к нужным серверам, каналам и.т.д.).
|
||||
Для перемещения окон используйте следующие команды:</p>
|
||||
|
||||
<pre>
|
||||
/WINDOW MOVE LEFT/RIGHT/номер - переместить окно влево, вправо или на указанный номер
|
||||
/WINDOW ITEM MOVE <номер>|<имя> - переместить канал или приват в другое окно
|
||||
</pre>
|
||||
|
||||
<p>Когда всё выглядит так, как вы хотите, используйте команду <code>/LAYOUT SAVE</code>
|
||||
(и <code>/SAVE</code>, если не включено автосохранение) и когда вы в следующий раз запустите irssi, то он вспомнит позиции сохраненных окон.
|
||||
Это "запоминание" не означает, что использование команды <code>/LAYOUT SAVE</code> будет приводить к автоматическому подключению к серверам и заходу на каналы,
|
||||
для этого вы должны использовать команды <code>/SERVER ADD -auto</code> и <code>/CHANNEL ADD -auto</code>.</p>
|
||||
|
||||
<p>Чтобы изменить сохраненные настройки окон, расставьте их в нужные позиции и заново введите команду <code>/LAYOUT SAVE</code>.
|
||||
Чтобы обнулить настройки используйте команду <code>/LAYOUT RESET.</code></p>
|
||||
|
||||
|
||||
<h3><a id="c5">5. Окна status и msgs & уровни сообщений</a></h3>
|
||||
|
||||
<p>По умолчанию "дополнительные сообщения" выводятся в окно статуса. Под дополнительными подразумеваются сообщения, которые не принадлежат ни к одному каналу или привату(например ctcp-запросы).
|
||||
Некоторых людей они раздражают, так что если вы хотите их скрыть, то введите</p>
|
||||
|
||||
<pre>
|
||||
/SET use_status_window OFF
|
||||
</pre>
|
||||
|
||||
<p>Этот параметр заработает только после перезапуска irssi. Если вы хотите удалить их немедленно, то просто закройте окно(<code>/WINDOW CLOSE</code>).</p>
|
||||
|
||||
<p>Другое основное окно - это "окно сообщений", куда идут все сообщения привата.
|
||||
По умолчанию оно отключено и вместо этого для каждого привата создается новое окно. Чтобы все сообщения привата шли в одно окно используйте команду:</p>
|
||||
|
||||
<pre>
|
||||
/SET use_msgs_window ON
|
||||
/SET autocreate_query_level DCCMSGS (или если вы так-же не хотите
|
||||
создавать новые окна для DCC-чата напишите NONE)
|
||||
</pre>
|
||||
|
||||
<p>Этот параметр так-же не будет задействован до перезапуска irssi. Чтобы применить его немедленно введите:</p>
|
||||
|
||||
<pre>
|
||||
/WINDOW NEW HIDE - создать окно
|
||||
/WINDOW NAME (msgs) - переименовать его в "(msgs)"
|
||||
/WINDOW LEVEL MSGS - перенаправить все приватные сообщения в это окно
|
||||
/WINDOW MOVE 1 - сделать это окно первым в списке
|
||||
</pre>
|
||||
|
||||
<p>Учтите, что ни use_msgs_window, ни use_status_window не будут работать если использована команда <code>/LAYOUT SAVE</code>.</p>
|
||||
|
||||
<p>Теперь мы подошли к уровням сообщений.. Что это? Все сообщения, которые выводит irssi имеют один или больше
|
||||
"уровень сообщений". Вот основные уровни: PUBLIC - для сообщений на каналах,
|
||||
MSGS - для приватных сообщений и CRAP для остальных сообщений, которые нельзя классифицировать. Вы можете получить полный список уровней при помощи команды</p>
|
||||
|
||||
<pre>
|
||||
/HELP levels
|
||||
</pre>
|
||||
|
||||
<p>Окну статуса присвоен уровень <code>ALL -MSGS</code>, который подразумевает, что все сообщения,
|
||||
исключая приватные, для которых не назначено другое место идут в это окно. Благодаря опции <code>-MSGS</code> оно не конфликтует с окном сообщений.</p>
|
||||
|
||||
|
||||
<h3><a id="c6">6. Как в irssi работает многосерверная поддержка</a></h3>
|
||||
|
||||
<p>В ircII и некоторых других IRC-клиентах многосерверная поддержка реализована в виде помещения вкладки с сервером в список окон
|
||||
. В IRSSI НЕТ. Нет никакой связи между окном и сервером. Вы можете подключиться к десяти серверам одновременно и управлять ими всеми из одного окна, или заходить на каналы на каждом из них
|
||||
в одном окне, если вы действительно этого хотите. Как было сказано вы можете подключиться к новому серверу, не закрывая текущего соединения:</p>
|
||||
|
||||
<pre>
|
||||
/CONNECT irc.server.org
|
||||
</pre>
|
||||
|
||||
<p>Вместо команды <code>/SERVER</code>, которая закрывает существующее
|
||||
соединение. Чтобы посмотреть список осуществленных соединений используйте команду <code>/SERVER</code>
|
||||
без параметров. Вы увидите примерно следующее:</p>
|
||||
|
||||
<pre>
|
||||
-!- IRCNet: irc.song.fi:6667 (IRCNet)
|
||||
-!- OFTC: irc.oftc.net:6667 (OFTC)
|
||||
-!- RECON-1: 192.168.0.1:6667 () (02:59 left before reconnecting)
|
||||
</pre>
|
||||
|
||||
<p>Здесь видно, что мы подключены к сетям IRCNet и OFTC.
|
||||
Надпись IRCNet в начале является "меткой сервера" а
|
||||
(IRCnet) в конце показывает соответствующую IRC-сеть. Метка сервера соответствует уникальному имени, которое обычно совпадает с названием сети.
|
||||
Когда IRC-сеть не известна это какая-то часть имени сервера.
|
||||
Когда осуществлены несколько соединений с одной сетью или сервером, irssi
|
||||
добавляет цифру после метки, так что это может быть ircnet, ircnet2, ircnet3
|
||||
и.т.д.</p>
|
||||
|
||||
<p>Метка сервера, начинающаяся с <code>RECON-</code> обозначает переподключение.
|
||||
В вышеприведенном примере мы видим, что подключение к серверу 192.168.0.1 было неудачным и
|
||||
irssi попробует подключиться заново через 3 минуты.</p>
|
||||
|
||||
<p>Чтобы отключиться от сервера используйте следующие команды:</p>
|
||||
|
||||
<pre>
|
||||
/DISCONNECT ircnet - отключиться от сервера с меткой "ircnet"
|
||||
/DISCONNECT recon-1 - остановить попытки переподключения к серверу RECON-1
|
||||
/RMRECONNS - остановить все попытки переподключения
|
||||
|
||||
/RECONNECT recon-1 - немедленно попробовать переподключиться к RECON-1
|
||||
/RECONNECT ALL - немедленно попробовать переподключиться ко всем серверам
|
||||
в очереди на подключение
|
||||
</pre>
|
||||
|
||||
<p>Теперь, когда вы подключены ко всем серверам вы должны знать как указать какой из них вы хотите использовать.
|
||||
Единственный способ - это иметь пустое окно наподобе окна статуса. В нем вы можете выбрать какой сервер хотите сделать активным</p>
|
||||
|
||||
<pre>
|
||||
/WINDOW SERVER tag - сделать сервер с меткой "tag" активным
|
||||
Ctrl-X - Сделать следующий в списке сервер активным
|
||||
</pre>
|
||||
|
||||
<p>Когда сервер активный вы можете нормально его использовать. Когда вы подключены к нескольким серверам, irssi добавляет префикс [метка_сервера]
|
||||
ко всем сообщениям, не относящимся к каналу или привату так что вы можете знать с какого сервера оно пришло.</p>
|
||||
|
||||
<p>Некоторые команды так-же позволяют использовать опцию <code>-метка_сервера</code>
|
||||
чтобы указать для какого сервера вы хотите её использовать:</p>
|
||||
|
||||
<pre>
|
||||
/MSG -метка ник сообщение
|
||||
/JOIN -метка #канал
|
||||
/QUERY -метка ник
|
||||
</pre>
|
||||
|
||||
<p>Автодополнение команды <code>/MSG</code> так-же автоматически добавляет метку сервера
|
||||
когда ник не на активном сервере.</p>
|
||||
|
||||
<p>Окно сервера можно сделать закреплённым. Когда оно закреплено, то оно никогда автоматически не переключится на какое-то другое, и если произошло отключение от сервера,
|
||||
то оно не будет иметь активного сервера. Когда к серверу снова произведено подключение,
|
||||
то он автоматически становится активным в этом окне. Чтобы закрепить окно сервера используйте следующую команду:</p>
|
||||
|
||||
<pre>
|
||||
/WINDOW SERVER -sticky tag
|
||||
</pre>
|
||||
|
||||
<p>Это полезно если вы хотите иметь отдельные окна статуса и сообщений для каждого сервера. Вот как это можно сделать (повторите для каждого сервера):</p>
|
||||
|
||||
<pre>
|
||||
/WINDOW NEW HIDE
|
||||
/WINDOW NAME (status)
|
||||
/WINDOW LEVEL ALL -MSGS
|
||||
/WINDOW SERVER -sticky ircnet
|
||||
|
||||
/WINDOW NEW HIDE
|
||||
/WINDOW NAME (msgs)
|
||||
/WINDOW LEVEL MSGS
|
||||
/WINDOW SERVER -sticky ircnet
|
||||
</pre>
|
||||
|
||||
<h3><a id="c7">7. Команда /LASTLOG и прокрутка окон</a></h3>
|
||||
|
||||
<p>Команда <code>/LASTLOG</code> может быть использована для поиска текста в буфере окна. Вот простейшие примеры её использования:</p>
|
||||
|
||||
<pre>
|
||||
/LASTLOG слово - вывести все строки, содержащие "слово"
|
||||
/LASTLOG word 10 - вывести последние 10 строк, содержащих "word"
|
||||
/LASTLOG -topics - вывести все изменения топика
|
||||
</pre>
|
||||
|
||||
<p>Если результатом вывода должны стать более 1000 строк, то irssi предположит, что вы допустили ошибку и выведет их только с опцией <code>-force</code>.
|
||||
Чтобы сохранить содержимое буфера окна в файл, используйте следующую команду:</p>
|
||||
|
||||
<pre>
|
||||
/LASTLOG -file ~/irc.log
|
||||
</pre>
|
||||
|
||||
<p>При использовании опции <code>-file</code> опция <code>-force</code>
|
||||
не требуется. У команды <code>/LASTLOG</code> есть много других опций. Чтобы получить более подробную справку по ней используйте <code>/HELP lastlog</code>.</p>
|
||||
|
||||
<p>Когда вы нашли интересовавшие вас строки, вам скорее всего захочется посмотреть другие прилегающие к ним сообщения. В Irssi есть команда <code>/SCROLLBACK</code> (или
|
||||
её синоним - <code>/SB</code>) для перемещения по буферу окна.
|
||||
Команда <code>/LASTLOG</code> выводит оригинальное время сообщения
|
||||
и вы можете использовать команду <code>/SB GOTO чч:мм</code> чтобы "перепрыгнуть" к этому фрагменту дискуссии.
|
||||
Чтобы переместиться обратно вниз используйте команду <code>/SB
|
||||
END</code>.</p>
|
||||
|
||||
|
||||
<h3><a id="c8">8. Ведение логов</a></h3>
|
||||
|
||||
<p>Irssi может автоматически вести лог всех важных сообщений когда вы в эвее
|
||||
(<code>/AWAY причина</code>). когда вы вышли из эвея
|
||||
(ещё раз введите <code>/AWAY</code>), новые сообщения в эвей-логе выводятся на экран.
|
||||
Вы можете настроить его при помощи следующих команд:</p>
|
||||
|
||||
<pre>
|
||||
/SET awaylog_level MSGS HILIGHT - Выбирает какое сообщения надо записывать в лог
|
||||
/SET awaylog_file ~/.irssi/away.log - Выбирает файл для лога
|
||||
</pre>
|
||||
|
||||
<p>Простейший способ ведения логов при помощи Irssi - включение автолога.
|
||||
Irssi будет вести логи всех сообщений в заданный каталог.
|
||||
Вы можете включить его при помощи следующей команды:</p>
|
||||
|
||||
<pre>
|
||||
/SET autolog ON
|
||||
</pre>
|
||||
|
||||
<p>По умолчанию в логи записывается почти всё кроме уровней CTCPS или CRAP
|
||||
(<code>/WHOIS</code>-запросы и.т.д.). Вы можете задать уровни сообщений, которые надо писать в логи следующей командой:</p>
|
||||
|
||||
<pre>
|
||||
/SET autolog_level ALL -CRAP -CLIENTCRAP -CTCPS (this is the default)
|
||||
</pre>
|
||||
|
||||
<p>По умолчанию irssi пишет лог в ~/irclogs/<метка_сервера>/<цель>.log.
|
||||
Это настраивается следующей командой:</p>
|
||||
|
||||
<pre>
|
||||
/SET autolog_path ~/irclogs/$tag/$0.log (вариант "по умолчанию")
|
||||
</pre>
|
||||
|
||||
<p>Если заданный каталог не существует, то он автоматически создается. В переменной $0
|
||||
содержится цель(канал или ник). Вы можете настроить Irssi так, чтобы он автоматически добавлял дату/время к имени файла с логом.
|
||||
Вормат даты - "man strftime" :). Вот пример:</p>
|
||||
|
||||
<pre>
|
||||
/SET autolog_path ~/irclogs/%Y/$tag/$0.%m-%d.log
|
||||
</pre>
|
||||
|
||||
<p>Чтобы вести логи только по каким-то отдельным каналам или никам смотрите <code>/HELP
|
||||
log</code></p>
|
||||
|
||||
|
||||
<h3><a id="c9">9. Изменение клавиатурных сочетаний</a></h3>
|
||||
|
||||
<p>Вы можете изменить любое клавиатурное сочетание, о котором терминал даёт знать irssi.
|
||||
То есть irssi "видит" не все клавиатурные сочетания, например он не будет реагировать на
|
||||
shift-backspace если вы как-то не отредактируете соответствующие X-ресурсы.</p>
|
||||
|
||||
<p>Команда <code>/HELP bind</code> даёт намного больше информации о клавиатурных сочетаниях, чем приведено здесь.
|
||||
Обычно проблеммой является "забивание" каких-то не стандартных клавиш.
|
||||
Они немного различны для каждого терминала, так что вы должны будете узнать что именно даёт нажатие этой клавиши.
|
||||
Простейший путь узнать это - выполнить в консоли <code>cat</code> и посмотреть что будет выводится при нажатии этой клавиши.
|
||||
Вот пример нажатия клавиши F1:</p>
|
||||
|
||||
<pre>
|
||||
[cras@hurina] ~% cat
|
||||
^[OP
|
||||
</pre>
|
||||
|
||||
<p>Так что в irssi чтобы "забить" что-то на F1 вы должны будете использовать команду <code>/BIND ^[OP /ECHO нажата клавиша F1</code>.
|
||||
Если вы используете разные терминалы, которые по разному распознают нажатие одной и той-же клавиши, то вам лучше использовать что-то вроде этого:</p>
|
||||
|
||||
<pre>
|
||||
/BIND ^[OP key F1
|
||||
/BIND ^[11~ key F1
|
||||
/BIND F1 /ECHO нажата клавиша F1.
|
||||
</pre>
|
||||
|
||||
<h3><a id="c10">10. Прокси и боунсеры</a></h3>
|
||||
|
||||
<p>Irssi поддерживает подключение к IRC-серверам через прокси. Если вы всё правильно сделаете, то все подключения будут осуществляться через него и вам не надо будет вводить никаких дополнительных команд.</p>
|
||||
|
||||
<p>Вот пример: У вас есть боунсер, висящий на
|
||||
irc.bouncer.org 5000. Вы хотите использовать его для подключения к серверам irc.dal.net и irc.efnet.org. Для начала вы должны будете настроить боунсер:</p>
|
||||
|
||||
<pre>
|
||||
/SET use_proxy ON (включить использование прокси)
|
||||
/SET proxy_address irc.bouncer.org
|
||||
/SET proxy_port 5000
|
||||
|
||||
/SET proxy_password ВАШ_ПАРОЛЬ
|
||||
/SET -clear proxy_string
|
||||
/SET proxy_string_after conn %s %d
|
||||
</pre>
|
||||
|
||||
<p>Потом вам нужно будет добавить нужные серверы. Это делается точно так-же, как если бы вы хотели подключиться к ним напрямую:</p>
|
||||
|
||||
<pre>
|
||||
/SERVER ADD -auto -ircnet dalnet irc.dal.net
|
||||
/SERVER ADD -auto -ircnet efnet irc.efnet.org
|
||||
</pre>
|
||||
|
||||
<p>После того, как вы сделали вышеперечисленные настройки все соединения irssi будет производить через проксю.</p>
|
||||
|
||||
<p>Если вы не хотите использовать проксю для какого-то сервера, то при его добавлении укажите опцию
|
||||
<code>-noproxy</code>.</p>
|
||||
|
||||
<p><strong>Специфичные настройки для разных типов прокси:</strong></p>
|
||||
|
||||
<p>Обычные настройки:</p>
|
||||
|
||||
<pre>
|
||||
/SET use_proxy ON
|
||||
/SET proxy_address <Адрес прокси>
|
||||
/SET proxy_port <Порт>
|
||||
</pre>
|
||||
|
||||
<p><strong>HTTP proxy</strong></p>
|
||||
|
||||
<p>Используйте эти настройки для HTTP-прокси:</p>
|
||||
|
||||
<pre>
|
||||
/SET -clear proxy_password
|
||||
/EVAL SET proxy_string CONNECT %s:%d\n\n
|
||||
</pre>
|
||||
|
||||
<p><strong>BNC</strong></p>
|
||||
|
||||
<pre>
|
||||
/SET proxy_password ваш_пароль
|
||||
/SET -clear proxy_string
|
||||
/SET proxy_string_after conn %s %d
|
||||
</pre>
|
||||
|
||||
<p><strong>dircproxy</strong></p>
|
||||
|
||||
<p>dircproxy производит подключения к серверам по паролям. Так что если например вы хотите подключиться к серверу ircnet с паролем ircpass
|
||||
и к OFTC с паролем oftcpass, вы должны сделать примерно следующее:</p>
|
||||
|
||||
<pre>
|
||||
/SET -clear proxy_password
|
||||
/SET -clear proxy_string
|
||||
|
||||
/SERVER ADD -auto -ircnet ircnet fake.ircnet 6667 ircpass
|
||||
/SERVER ADD -auto -ircnet OFTC fake.oftc 6667 oftcpass
|
||||
</pre>
|
||||
|
||||
<p>Имя сервера и порт, которые вы вводите нигде не используются, так что вы можете писать сюда всё что угодно.</p>
|
||||
|
||||
<p><strong>psyBNC</strong></p>
|
||||
|
||||
<p>psyBNC имеет внутреннюю многосерверную поддержку.
|
||||
Это может доставлять небольшие неудобства и некоторые люди просто используют разные логины для подключения к нескольким серверам.
|
||||
Вы очень просто можете делать это средствами Irssi:</p>
|
||||
|
||||
<pre>
|
||||
/SET -clear proxy_password
|
||||
/SET -clear proxy_string
|
||||
|
||||
/IRCNET ADD -user ircnetuser ircnet
|
||||
/SERVER ADD -auto -ircnet ircnet fake.ircnet 6667 ircpass
|
||||
/IRCNET ADD -user oftcuser OFTC
|
||||
/SERVER ADD -auto -ircnet OFTC fake.oftc 6667 oftcpass
|
||||
</pre>
|
||||
|
||||
<p>Здесь при помощи команды <code>/IRCNET ADD</code> вы задаете имена пользователей
|
||||
и пароли при помощи <code>/SERVER ADD</code>.</p>
|
||||
|
||||
<p><strong>Irssi proxy</strong></p>
|
||||
|
||||
<p>Irssi включает свою собственную проксю, которую вы можете собрать при помощи опции configure
|
||||
<code>--with-proxy</code>. Чтобы её использовать вы должны оставлять irssi запущенным.</p>
|
||||
|
||||
<p>Irssi-прокся немного отличается от остальных прокси-серверов, нормальные прокси создают новые соединения с IRC-сервером когда вы хотите к нему подключиться, а
|
||||
<strong>irssi-прокся использует уже существующее соединение(я) для всех клиентов</strong>. Или ещё понятнее: <strong>Вы можете использовать только одно соединение с IRC-сервером для неограниченного числа клиентов</strong>.</p>
|
||||
|
||||
<p>Irssi-прокся может распределять несколько соединений с серверами на разные порты, например на 2777-ом порту у вас может быть соединение с ircnet, а на 2778 с efnet.</p>
|
||||
|
||||
<p>Использование на стороне прокси:</p>
|
||||
|
||||
<pre>
|
||||
/LOAD proxy
|
||||
/SET irssiproxy_password <пароль>
|
||||
/SET irssiproxy_ports <IRC_сеть>=<порт> ... (например ircnet=2777 efnet=2778)
|
||||
</pre>
|
||||
<p>Вы <strong>должны</strong> добавить все серверы, которые вы используете в списки серверов и сетей
|
||||
при помощи команд <code>/SERVER ADD</code> и
|
||||
<code>/IRCNET ADD</code>. ..разве что если вы хотите использовать только одно соединение, то вы можете указать:</p>
|
||||
|
||||
<pre>
|
||||
/SET irssiproxy_ports *=2777
|
||||
</pre>
|
||||
|
||||
<p>Использование на стороне клиента:</p>
|
||||
|
||||
<p>Просто подключитесь к проксе как к нормальному серверу с паролем, заданным командой <code>/SET irssiproxy_password</code>. Пример:</p>
|
||||
|
||||
<pre>
|
||||
/SERVER ADD -ircnet ircnet my.irssi-proxy.org 2777 secret
|
||||
/SERVER ADD -ircnet efnet my.irssi-proxy.org 2778 secret
|
||||
</pre>
|
||||
|
||||
<p>Irssi-прокся так-же нормально работает с другими irc-клиентами.</p>
|
||||
|
||||
<p><strong>SOCKS</strong></p>
|
||||
|
||||
Irssi может быть собран с поддержкой socks-прокси (опция configure <code>--with-socks</code>),
|
||||
но я на самом деле не знаю как оно работает. Настройки <code>/SET
|
||||
proxy</code> на эти прокси никак не действуют.
|
||||
|
||||
<p><strong>Другие прокси</strong></p>
|
||||
|
||||
<p>IRC-боунсеры обычно работают точно так-же как и IRC-серверы, но просят пароль. Вы можете дать им его при помощи следующей команды:</p>
|
||||
|
||||
<pre>
|
||||
/SET proxy_password <пароль>
|
||||
</pre>
|
||||
|
||||
<p>CONNECT-строки по умолчанию:</p>
|
||||
|
||||
<pre>
|
||||
/SET proxy_string CONNECT %s %d
|
||||
/SET proxy_string_after
|
||||
</pre>
|
||||
|
||||
<p>proxy_string отправляются перед командами NICK/USER, а
|
||||
proxy_string_after отправляется после них. %s and %d can be used with both
|
||||
of them.</p>
|
||||
|
||||
<h3><a id="c11">11. Настройки Irssi</a></h3>
|
||||
|
||||
<p>Вам могут не понравится настройки Irssi по умолчанию.
|
||||
Вот некоторые из них, которые вы скорее всего захотите изменить(в примерах приведены "умолчальные" значения):</p>
|
||||
|
||||
<p><strong>Окна приватов</strong></p>
|
||||
|
||||
<dl>
|
||||
<dt>/SET autocreate_own_query ON</dt>
|
||||
<dd>Автоматически создавать окно привата когда вы отправляете кому-то сообщение при помощи команды <code>/MSG</code>.</dd>
|
||||
|
||||
<dt>/SET autocreate_query_level MSGS</dt>
|
||||
<dd>При получении сообщений окно привата создается с этим уровнем сообщений. Сейчас работают только MSGS, DCCMSGS и NOTICES.
|
||||
Вы можете отменить это при помощи команды <code>/SET -clear autocreate_query_level</code>.</dd>
|
||||
|
||||
<dt>/SET autoclose_query 0</dt>
|
||||
<dd>Окна приватов могут быть автоматически закрыты после заданного "простоя". Активное окно и окна с непрочитанными сообщениями не закрываются. Значение задается в секундах.</dd>
|
||||
</dl>
|
||||
|
||||
<p><strong>Окна</strong></p>
|
||||
|
||||
<dl>
|
||||
<dt>/SET use_msgs_window OFF</dt>
|
||||
<dd>Создавать окно сообщений при запуске. Все приватные сообщения будут направляться в это окно.
|
||||
Это имеет смысл только если вы отменили автосоздание окон приватов.
|
||||
Это окно так-же может быть создано вручную при помощи команды /WINDOW LEVEL
|
||||
MSGS, /WINDOW NAME (msgs).</dd>
|
||||
|
||||
<dt>/SET use_status_window ON</dt>
|
||||
<dd>Создавать окно статуса при запуске. Все сообщения, которые больше некуда отправить идут сюда, включая /WHOIS и.т.д.
|
||||
Окно статуса тоже может быть создано вручную при помощи команд <code>/WINDOW LEVEL ALL -MSGS</code>,
|
||||
<code>/WINDOW NAME (status)</code>.</dd>
|
||||
|
||||
<dt>/SET autocreate_windows ON</dt>
|
||||
<dd>Если вы это отключите, то все сообщения будут помещаться в одно окно</dd>
|
||||
|
||||
<dt>/SET autoclose_windows ON</dt>
|
||||
<dd>Автозакрытие окон (например при выходе с каналов(<code>/PART</code>)).</dd>
|
||||
|
||||
<dt>/SET reuse_unused_windows OFF</dt>
|
||||
<dd>Когда ищется место для создания нового окна (канала или привата) Irssi
|
||||
сначала пытается использовать уже существующие пустые окна. Если эта опция включена, то всегда будут создаваться новые окна.
|
||||
Эта настройка игнорируется если autoclose_windows включен.</dd>
|
||||
|
||||
<dt>/SET window_auto_change OFF</dt>
|
||||
<dd>Автоматически переключаться в автоматически созданные окна.</dd>
|
||||
|
||||
<dt>/SET print_active_channel OFF</dt>
|
||||
<dd>Когда вы держите в одном окне больше чем один канал, Irssi выводит сообщения, приходящие на активный канал в форме <code><ник> текст</code>
|
||||
а те, что приходят на другие каналы так: <code><ник:канал> текст</code>. Если эта опция включена, то сообщения, приходящие на активный канал будут так-же выводиться во втором варианте.</dd>
|
||||
|
||||
<dt>/SET window_history OFF</dt>
|
||||
<dd>Хранить отдельную историю команд для каждого окна.</dd>
|
||||
</dl>
|
||||
|
||||
|
||||
<p><strong>Информация о пользователе</strong></p>
|
||||
|
||||
<dl>
|
||||
<dt>/SET nick</dt>
|
||||
<dd>Ваш ник</dd>
|
||||
|
||||
<dt>/SET alternate_nick</dt>
|
||||
<dd>Ваш альтернативный ник.</dd>
|
||||
|
||||
<dt>/SET user_name</dt>
|
||||
<dd>Ваше имя пользователя. Если у вас включен ident, то оно ничего не даёт.</dd>
|
||||
|
||||
<dt>/SET real_name</dt>
|
||||
<dd>Ваше настоящее имя.</dd>
|
||||
</dl>
|
||||
|
||||
|
||||
<p><strong>Информация о сервере</strong></p>
|
||||
|
||||
<dl>
|
||||
<dt>/SET skip_motd OFF</dt>
|
||||
<dd>Пропускать motd при подключении к серверу.</dd>
|
||||
|
||||
<dt>/SET server_reconnect_time 300</dt>
|
||||
<dd>Сколько секунд надо ждать перед повторной попыткой подключения к серверу.</dd>
|
||||
|
||||
<dt>/SET lag_max_before_disconnect 300</dt>
|
||||
<dd>При каком лаге(в секундах) надо отключаться от сервера и предпринимать попытку переподключения.</dd>
|
||||
</dl>
|
||||
|
||||
|
||||
<p><strong>Внешний вид</strong></p>
|
||||
|
||||
<dl>
|
||||
<dt>/SET timestamps ON</dt>
|
||||
<dd>Показывать время перед каждым сообщением.</dd>
|
||||
|
||||
<dt>/SET hide_text_style OFF</dt>
|
||||
<dd>Скрыть оформление текста(жирный шрифт, цвета и.т.д.).</dd>
|
||||
|
||||
<dt>/SET show_nickmode ON</dt>
|
||||
<dd>Показывать "режим ника" на каналах, например
|
||||
<code><@nick></code> у опов, <code><+nick></code> у войсов и.т.д.</dd>
|
||||
|
||||
<dt>/SET show_nickmode_empty ON</dt>
|
||||
<dd>Если у ника нет режима - выводить пробел на месте "символа режима".</dd>
|
||||
|
||||
<dt>/SET show_quit_once OFF</dt>
|
||||
<dd>Показывать quit-сообщение только в одном окне, если человек вышел с нескольких каналов, на которых вы сидите.</dd>
|
||||
|
||||
<dt>/SET lag_min_show 100</dt>
|
||||
<dd>Показывать в статус-баре лаг если он превышает заданное число юнитов. В одной секунде 100 юнитов.</dd>
|
||||
|
||||
<dt>/SET indent 10</dt>
|
||||
<dd>Если строка, которую надо вывести не вмещается в одну строку, то она разбивается и выводится на следующих строках. Этот параметр показывает сколько места надо отступить перед началом вывода текста на следующих строках.
|
||||
Это может быть переопределено в настройках форматирования текста при помощи формата <code>%|</code>.</dd>
|
||||
|
||||
<dt>/SET activity_hide_targets</dt>
|
||||
<dd>Если вы не хотите видеть активность на каких-то каналах или приватах, то перечислите их здесь. Например <code>#boringchannel =bot1
|
||||
=bot2</code>. Эта настройка игнорируется если встречается текст или сообщение, для которого вы настроили подсветку(highlight).</dd>
|
||||
</dl>
|
||||
|
||||
<p><strong>Автодополнение ников</strong></p>
|
||||
|
||||
<dl>
|
||||
<dt>/SET completion_auto OFF</dt>
|
||||
<dd>Автоматически дополнять ник если строка начинается с первых букв ника и "символа автодополнения".
|
||||
Лучше всего использовать автодополнение табом.</dd>
|
||||
|
||||
<dt>/SET completion_char :</dt>
|
||||
<dd>"Символ автодополнения".</dd>
|
||||
</dl>
|
||||
|
||||
<h3><a id="c12">12. Панель статуса</a></h3>
|
||||
|
||||
<p>Команда <code>/STATUSBAR</code> выводит список панелей статуса:</p>
|
||||
|
||||
<pre>
|
||||
Name Type Placement Position Visible
|
||||
window window bottom 0 always
|
||||
window_inact window bottom 1 inactive
|
||||
prompt root bottom 100 always
|
||||
topic root top 1 always
|
||||
</pre>
|
||||
|
||||
<p><code>/STATUSBAR <имя></code> выводит настройки панели статуса и её компоненты.
|
||||
<code>/STATUSBAR <имя> ENABLE|DISABLE</code>
|
||||
включает или отключает панель. <code>/STATUSBAR <имя> RESET</code>
|
||||
устанавливает для панели статуса настройки по умолчанию, или если она была создана вами, то удаляет её.</p>
|
||||
|
||||
<p>Панель может иметь два типа: windows и root - это подразумевает, что она может быть видна для всех окон или только для одного.
|
||||
Placement - это расположение панели: top - сверху, bottom - снизу.
|
||||
Position - это число, чем больше значение которого, тем ниже на экране располагается панель.
|
||||
Параметр Visible может принимать 3 значения: always, active и inactive. Режимы active/inactive полезны только для разделенных окон.
|
||||
Эти настройки могут быть изменены следующими командами:</p>
|
||||
|
||||
<pre>
|
||||
/STATUSBAR <имя> TYPE window|root
|
||||
/STATUSBAR <имя> PLACEMENT top|bottom
|
||||
/STATUSBAR <имя> POSITION <num>
|
||||
/STATUSBAR <имя> VISIBLE always|active|inactive
|
||||
</pre>
|
||||
|
||||
<p>Когда вы загружаете новые скрипты для панелей статуса вам скорее всего придется выбрать где вы хотите их расположить.
|
||||
Компоненты панелей могут быть изменены следующими командами:</p>
|
||||
|
||||
<pre>
|
||||
/STATUSBAR <имя> ADD [-before | -after <item>] [-priority #] [-alignment left|right] <компонента(item)>
|
||||
/STATUSBAR <имя> REMOVE <компонента(item)>
|
||||
</pre>
|
||||
|
||||
<p>Обычно для имя компоненты в скрипте для панели соответствует имени скрипта.
|
||||
Об этом должно быть написано в документации к скрипту. Так что чтобы добавить скрипт mail.pl
|
||||
перед списком активных окон (смотрите
|
||||
<code>/STATUSBAR</code>), введите эту команду: <code>/STATUSBAR window ADD -before
|
||||
act mail</code>.</p>
|
File diff suppressed because it is too large
Load Diff
@ -1,796 +0,0 @@
|
||||
Startup How-To
|
||||
|
||||
To new Irssi users (not to new IRC users ..)
|
||||
|
||||
Copyright (c) 2000-2002 by Timo Sirainen, release under [1]GNU FDL 1.1 license.
|
||||
|
||||
Index with some FAQ questions that are answered in the chapter:
|
||||
|
||||
1. First steps
|
||||
2. Basic user interface usage
|
||||
□ Split windows work in weird way
|
||||
□ How can I easily switch between windows?
|
||||
□ But alt-1 etc. don’t work!
|
||||
3. Server and channel automation
|
||||
□ How do I automatically connect to servers at startup?
|
||||
□ How do I automatically join to channels at startup?
|
||||
□ How do I automatically send commands to server at connect?
|
||||
4. Setting up windows and automatically restoring them at startup
|
||||
5. Status and msgs windows & message levels
|
||||
□ I want /WHOIS to print reply to current window
|
||||
□ I want all messages to go to one window, not create new windows
|
||||
6. How support for multiple servers works in irssi
|
||||
□ I connected to some server that doesn’t respond and now irssi keeps
|
||||
trying to reconnect to it again and again, how can I stop it??
|
||||
□ I want to have own status and/or msgs window for each servers
|
||||
7. /LASTLOG and jumping around in scrollback
|
||||
□ How can I save all texts in a window to file?
|
||||
8. Logging
|
||||
9. Changing keyboard bindings
|
||||
□ How do I make F1 key do something?
|
||||
10. Proxies and IRC bouncers
|
||||
11. Irssi’s settings
|
||||
□ For all the ircII people
|
||||
12. Statusbar
|
||||
□ I loaded a statusbar script but it’s not visible anywhere!
|
||||
|
||||
1. First steps
|
||||
|
||||
IRC Networks are made of servers, and servers have channels. The default config
|
||||
has a few predefined networks, to list them:
|
||||
|
||||
/NETWORK LIST
|
||||
|
||||
And to connect to one of those networks and join a channel:
|
||||
|
||||
/CONNECT liberachat
|
||||
/JOIN #irssi
|
||||
|
||||
To add more networks:
|
||||
|
||||
/NETWORK ADD ExampleNet
|
||||
|
||||
Then add some servers (with -auto to automatically connect):
|
||||
|
||||
/SERVER ADD -auto -network ExampleNet irc.example.net
|
||||
|
||||
Automatically join to channels after connected to server:
|
||||
|
||||
/CHANNEL ADD -auto #lounge ExampleNet
|
||||
|
||||
To modify existing networks (or servers, or channels) just ADD again using the
|
||||
same name as before. This configures a network to identify with nickserv and
|
||||
wait for 2 seconds before joining channels:
|
||||
|
||||
/NETWORK ADD -autosendcmd "/^msg nickserv ident pass;wait 2000" ExampleNet
|
||||
|
||||
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 liberachat
|
||||
|
||||
These commands have many more options, see their help for details:
|
||||
|
||||
/HELP NETWORK
|
||||
/HELP SERVER
|
||||
/HELP CHANNEL
|
||||
/HELP
|
||||
|
||||
If you want lines containing your nick to hilight:
|
||||
|
||||
/HILIGHT nick
|
||||
|
||||
Or, for irssi 0.8.18 or higher:
|
||||
|
||||
/SET hilight_nick_matches_everywhere ON
|
||||
|
||||
To get beeps on private messages or highlights:
|
||||
|
||||
/SET beep_msg_level MSGS HILIGHT DCCMSGS
|
||||
|
||||
No other irssi settings are needed (don’t enable bell_beeps), but there may be
|
||||
settings to change in your terminal multiplexer (screen/tmux), your terminal,
|
||||
or your desktop environment.
|
||||
|
||||
2. Basic user interface usage
|
||||
|
||||
Windows can be scrolled up/down with PgUp and PgDown keys. If they don’t work
|
||||
for you, use Meta-p and Meta-n keys. For jumping to beginning or end of the
|
||||
buffer, use /SB HOME and /SB END commands.
|
||||
|
||||
By default, irssi uses “hidden windows” for everything. Hidden windows are
|
||||
created every time you /JOIN a channel or /QUERY someone. There’s several ways
|
||||
you can change between these windows:
|
||||
|
||||
Meta-1, Meta-2, .. Meta-0 - Jump directly between windows 1-10
|
||||
Meta-q .. Meta-o - Jump directly between windows 11-19
|
||||
/WINDOW <number> - Jump to any window with specified number
|
||||
Ctrl-P, Ctrl-N - Jump to previous / next window
|
||||
|
||||
Clearly the easiest way is to use Meta-number keys. Meta usually means the ALT
|
||||
key, but if that doesn’t work, you can use ESC.
|
||||
|
||||
Mac OS X users with ALT key issues might prefer using [2]iTerm2 instead of the
|
||||
default terminal emulator.
|
||||
|
||||
Alt key as meta, for xterm/rxvt users
|
||||
|
||||
If you use xterm or rxvt, you may need to set a few X resources:
|
||||
|
||||
XTerm*eightBitInput: false
|
||||
XTerm*metaSendsEscape: true
|
||||
|
||||
With rxvt, you can also specify which key acts as Meta key. So if you want to
|
||||
use ALT instead of Windows key for it, use:
|
||||
|
||||
rxvt*modifier: alt
|
||||
|
||||
You could do this by changing the X key mappings:
|
||||
|
||||
xmodmap -e "keysym Alt_L = Meta_L Alt_L"
|
||||
|
||||
And how exactly do you set these X resources? For Debian, there’s /etc/X11/
|
||||
Xresources/xterm file where you can put them and it’s read automatically when X
|
||||
starts. ~/.Xresources and ~/.Xdefaults files might also work. If you can’t get
|
||||
anything else to work, just copy and paste those lines to ~/.Xresources and
|
||||
directly call xrdb -merge ~/.Xresources in some xterm. The resources affect
|
||||
only the new xterms you start, not existing ones.
|
||||
|
||||
Split windows and window items
|
||||
|
||||
Note: [3]this guide might be a better introduction to window splits
|
||||
|
||||
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:
|
||||
|
||||
/WINDOW NEW - Create new split window
|
||||
/WINDOW NEW HIDE - Create new hidden window
|
||||
/WINDOW CLOSE - Close split or hidden window
|
||||
|
||||
/WINDOW HIDE [<number>|<name>] - Make the split window hidden window
|
||||
/WINDOW SHOW <number>|<name> - Make the hidden window a split window
|
||||
|
||||
/WINDOW SHRINK [<lines>] - Shrink the split window
|
||||
/WINDOW GROW [<lines>] - Grow the split window
|
||||
/WINDOW BALANCE - Balance the sizes of all split windows
|
||||
|
||||
By default, irssi uses “sticky windowing” for split windows. This means that
|
||||
windows created inside one split window cannot be moved to another split window
|
||||
without some effort. For example you could have following window layout:
|
||||
|
||||
Split window 1: win#1 - Status window, win#2 - Messages window
|
||||
Split window 2: win#3 - IRCnet/#channel1, win#4 - IRCnet/#channel2
|
||||
Split window 3: win#5 - efnet/#channel1, win#6 - efnet/#channel2
|
||||
|
||||
When you are in win#1 and press ALT-6, irssi jumps to split window #3 and moves
|
||||
the efnet/#channel2 the active window.
|
||||
|
||||
With non-sticky windowing the windows don’t have any relationship with split
|
||||
windows, pressing ALT-6 in win#1 moves win#6 to split window 1 and sets it
|
||||
active, except if win#6 was already visible in some other split window irssi
|
||||
just changes to that split window. This it the way windows work with ircii, if
|
||||
you prefer it you can set it with
|
||||
|
||||
/SET autostick_split_windows OFF
|
||||
|
||||
Each window can have multiple channels, queries and other “window items” inside
|
||||
them. If you don’t like windows at all, you disable automatic creating of them
|
||||
with
|
||||
|
||||
/SET autocreate_windows OFF
|
||||
|
||||
And if you keep all channels in one window, you most probably want the channel
|
||||
name printed in each line:
|
||||
|
||||
/SET print_active_channel ON
|
||||
|
||||
If you want to group only some channels or queries in one window, use
|
||||
|
||||
/JOIN -window #channel
|
||||
/QUERY -window nick
|
||||
|
||||
3. Server and channel automation
|
||||
|
||||
Irssi’s multiple IRC network support is IMHO very good - at least compared to
|
||||
other clients :) Even if you’re only in one IRC network you should group all
|
||||
your servers to be in the same IRC network as this helps with reconnecting if
|
||||
your primary server breaks and is probably useful in some other ways too :) For
|
||||
information how to actually use irssi correctly with multiple servers see the
|
||||
chapter 6.
|
||||
|
||||
First you need to have your IRC network set, use /NETWORK command to see if
|
||||
it’s already there. If it isn’t, use /NETWORK ADD yournetwork. If you want to
|
||||
execute some commands automatically when you’re connected to some network, use
|
||||
-autosendcmd option. Here’s some examples:
|
||||
|
||||
/NETWORK ADD -autosendcmd '^msg bot invite' IRCnet
|
||||
/NETWORK ADD -autosendcmd "/^msg nickserv ident pass;wait 2000" OFTC
|
||||
|
||||
After that you need to add your servers. For example:
|
||||
|
||||
/SERVER ADD -auto -network IRCnet irc.kpnqwest.fi 6667
|
||||
/SERVER ADD -auto -network worknet irc.mycompany.com 6667 password
|
||||
|
||||
The -auto option specifies that this server is automatically connected at
|
||||
startup. You don’t need to make more than one server with -auto option to one
|
||||
IRC network, other servers are automatically connected in same network if the
|
||||
-auto server fails.
|
||||
|
||||
And finally channels:
|
||||
|
||||
/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
|
||||
used to send commands automatically to bot when channel is joined, usually to
|
||||
get ops automatically. You can specify multiple bot masks with -bots option
|
||||
separated with spaces (and remember to quote the string then). The $0 in
|
||||
-botcmd specifies the first found bot in the list. If you don’t need the bot
|
||||
masks (ie. the bot is always with the same nick, like chanserv) you can give
|
||||
only the -botcmd option and the command is always sent.
|
||||
|
||||
4. Setting up windows and automatically restoring them at startup
|
||||
|
||||
First connect to all the servers, join the channels and create the queries you
|
||||
want. If you want to move the windows or channels around use commands:
|
||||
|
||||
/WINDOW MOVE LEFT/RIGHT/number - move window elsewhere
|
||||
/WINDOW ITEM MOVE <number>|<name> - move channel/query to another window
|
||||
|
||||
When everything looks the way you like, use /LAYOUT SAVE command (and /SAVE, if
|
||||
you don’t have autosaving enabled) and when you start irssi next time, irssi
|
||||
remembers the positions of the channels, queries and everything. This
|
||||
“remembering” doesn’t mean that simply using /LAYOUT SAVE would automatically
|
||||
make irssi reconnect to all servers and join all channels, you’ll need the /
|
||||
SERVER ADD -auto and /CHANNEL ADD -auto commands to do that.
|
||||
|
||||
If you want to change the layout, you just rearrange the layout like you want
|
||||
it and use /LAYOUT SAVE again. If you want to remove the layout for some
|
||||
reason, use /LAYOUT RESET.
|
||||
|
||||
5. Status and msgs windows & message levels
|
||||
|
||||
By default, all the “extra messages” go to status window. This means pretty
|
||||
much all messages that don’t clearly belong to some channel or query. Some
|
||||
people like it, some don’t. If you want to remove it, use
|
||||
|
||||
/SET use_status_window OFF
|
||||
|
||||
This doesn’t have any effect until you restart irssi. If you want to remove it
|
||||
immediately, just /WINDOW CLOSE it.
|
||||
|
||||
Another common window is “messages window”, where all private messages go. By
|
||||
default it’s disabled and query windows are created instead. To make all
|
||||
private messages go to msgs window, say:
|
||||
|
||||
/SET use_msgs_window ON
|
||||
/SET autocreate_query_level DCCMSGS (or if you don't want queries to
|
||||
dcc chats either, say NONE)
|
||||
|
||||
use_msgs_window either doesn’t have any effect until restarting irssi. To
|
||||
create it immediately say:
|
||||
|
||||
/WINDOW NEW HIDE - create the window
|
||||
/WINDOW NAME (msgs) - name it to "(msgs)"
|
||||
/WINDOW LEVEL MSGS - make all private messages go to this window
|
||||
/WINDOW MOVE 1 - move it to first window
|
||||
|
||||
Note that neither use_msgs_window nor use_status_window have any effect at all
|
||||
if /LAYOUT SAVE has been used.
|
||||
|
||||
This brings us to message levels.. What are they? All messages that irssi
|
||||
prints have one or more “message levels”. Most common are PUBLIC for public
|
||||
messages in channels, MSGS for private messages and CRAP for all sorts of
|
||||
messages with no real classification. You can get a whole list of levels with
|
||||
|
||||
/HELP levels
|
||||
|
||||
Status window has message level ALL -MSGS, meaning that all messages, except
|
||||
private messages, without more specific place go to status window. The -MSGS is
|
||||
there so it doesn’t conflict with messages window.
|
||||
|
||||
6. How support for multiple servers works in irssi
|
||||
|
||||
ircii and several other clients support multiple servers by placing the
|
||||
connection into some window. IRSSI DOES NOT. There is no required relationship
|
||||
between window and server. You can connect to 10 servers and manage them all in
|
||||
just one window, or join channel in each one of them to one single window if
|
||||
you really want to. That being said, here’s how you do connect to new server
|
||||
without closing the old connection:
|
||||
|
||||
/CONNECT irc.server.org
|
||||
|
||||
Instead of the /SERVER which disconnects the existing connection. To see list
|
||||
of all active connections, use /SERVER without any parameters. You should see a
|
||||
list of something like:
|
||||
|
||||
-!- IRCNet: irc.song.fi:6667 (IRCNet)
|
||||
-!- OFTC: irc.oftc.net:6667 (OFTC)
|
||||
-!- RECON-1: 192.168.0.1:6667 () (02:59 left before reconnecting)
|
||||
|
||||
Here you see that we’re connected to IRCNet and OFTC networks. The IRCNet at
|
||||
the beginning is called the “server tag” while the (IRCnet) at the end shows
|
||||
the IRC network. Server tag specifies unique tag to refer to the server,
|
||||
usually it’s the same as the IRC network. When the IRC network isn’t known it’s
|
||||
some part of the server name. When there’s multiple connections to same IRC
|
||||
network or server, irssi adds a number after the tag so there could be network,
|
||||
network2, network3 etc.
|
||||
|
||||
Server tags beginning with RECON- mean server reconnections. Above we see that
|
||||
connection to server at 192.168.0.1 wasn’t successful and irssi will try to
|
||||
connect it again in 3 minutes.
|
||||
|
||||
To disconnect one of the servers, or to stop irssi from reconnecting, use
|
||||
|
||||
/DISCONNECT network - disconnect server with tag "network"
|
||||
/DISCONNECT recon-1 - stop trying to reconnect to RECON-1 server
|
||||
/RMRECONNS - stop all server reconnections
|
||||
|
||||
/RECONNECT recon-1 - immediately try reconnecting back to RECON-1
|
||||
/RECONNECT ALL - immediately try reconnecting back to all
|
||||
servers in reconnection queue
|
||||
|
||||
Now that you’re connected to all your servers, you’ll have to know how to
|
||||
specify which one of them you want to use. One way is to have an empty window,
|
||||
like status or msgs window. In it, you can specify which server to set active
|
||||
with
|
||||
|
||||
/WINDOW SERVER tag - set server "tag" active
|
||||
Ctrl-X - set the next server in list active
|
||||
|
||||
When the server is active, you can use it normally. When there’s multiple
|
||||
connected servers, irssi adds [servertag] prefix to all messages in non-channel
|
||||
/query messages so you’ll know where it came from.
|
||||
|
||||
Several commands also accept -servertag option to specify which server it
|
||||
should use:
|
||||
|
||||
/MSG -tag nick message
|
||||
/JOIN -tag #channel
|
||||
/QUERY -tag nick
|
||||
|
||||
/MSG tab completion also automatically adds the -tag option when nick isn’t in
|
||||
active server.
|
||||
|
||||
Window’s server can be made sticky. When sticky, it will never automatically
|
||||
change to anything else, and if server gets disconnected, the window won’t have
|
||||
any active server. When the server gets connected again, it is automatically
|
||||
set active in the window. To set the window’s server sticky use
|
||||
|
||||
/WINDOW SERVER -sticky tag
|
||||
|
||||
This is useful if you wish to have multiple status or msgs windows, one for
|
||||
each server. Here’s how to do them (repeat for each server)
|
||||
|
||||
/WINDOW NEW HIDE
|
||||
/WINDOW NAME (status)
|
||||
/WINDOW LEVEL ALL -MSGS
|
||||
/WINDOW SERVER -sticky network
|
||||
|
||||
/WINDOW NEW HIDE
|
||||
/WINDOW NAME (msgs)
|
||||
/WINDOW LEVEL MSGS
|
||||
/WINDOW SERVER -sticky network
|
||||
|
||||
7. /LASTLOG and jumping around in scrollback
|
||||
|
||||
/LASTLOG command can be used for searching texts in scrollback buffer. Simplest
|
||||
usages are
|
||||
|
||||
/LASTLOG word - print all lines with "word" in them
|
||||
/LASTLOG word 10 - print last 10 occurances of "word"
|
||||
/LASTLOG -topics - print all topic changes
|
||||
|
||||
If there’s more than 1000 lines to be printed, irssi thinks that you probably
|
||||
made some mistake and won’t print them without -force option. If you want to
|
||||
save the full lastlog to file, use
|
||||
|
||||
/LASTLOG -file ~/irc.log
|
||||
|
||||
With -file option you don’t need -force even if there’s more than 1000 lines. /
|
||||
LASTLOG has a lot of other options too, see /HELP lastlog for details.
|
||||
|
||||
Once you’ve found the lines you were interested in, you might want to check the
|
||||
discussion around them. Irssi has /SCROLLBACK (or alias /SB) command for
|
||||
jumping around in scrollback buffer. Since /LASTLOG prints the timestamp when
|
||||
the message was originally printed, you can use /SB GOTO hh:mm to jump directly
|
||||
there. To get back to the bottom of scrollback, use /SB END command.
|
||||
|
||||
8. Logging
|
||||
|
||||
Irssi can automatically log important messages when you’re set away (/AWAY
|
||||
reason). When you set yourself unaway (/AWAY), the new messages in away log are
|
||||
printed to screen. You can configure it with:
|
||||
|
||||
/SET awaylog_level MSGS HILIGHT - Specifies what messages to log
|
||||
/SET awaylog_file ~/.irssi/away.log - Specifies the file to use
|
||||
|
||||
Easiest way to start logging with Irssi is to use autologging. With it Irssi
|
||||
logs all channels and private messages to specified directory. You can turn it
|
||||
on with
|
||||
|
||||
/SET autolog ON
|
||||
|
||||
By default it logs pretty much everything execept CTCPS or CRAP (/WHOIS
|
||||
requests, etc). You can specify the logging level yourself with
|
||||
|
||||
/SET autolog_level ALL -CRAP -CLIENTCRAP -CTCPS (this is the default)
|
||||
|
||||
By default irssi logs to ~/irclogs/<servertag>/<target>.log. You can change
|
||||
this with
|
||||
|
||||
/SET autolog_path ~/irclogs/$tag/$0.log (this is the default)
|
||||
|
||||
The path is automatically created if it doesn’t exist. $0 specifies the target
|
||||
(channel/nick). You can make irssi automatically rotate the logs by adding date
|
||||
/time formats to the file name. The formats are in “man strftime” format. For
|
||||
example
|
||||
|
||||
/SET autolog_path ~/irclogs/%Y/$tag/$0.%m-%d.log
|
||||
|
||||
For logging only some specific channels or nicks, see /HELP log
|
||||
|
||||
9. Changing keyboard bindings
|
||||
|
||||
You can change any keyboard binding that terminal lets irssi know about. It
|
||||
doesn’t let irssi know everything, so for example shift-backspace can’t be
|
||||
bound unless you modify xterm resources somehow.
|
||||
|
||||
/HELP bind 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 cat. Here’s an example for pressing F1 key:
|
||||
|
||||
[cras@hurina] ~% cat
|
||||
^[OP
|
||||
|
||||
So in irssi you would use /BIND ^[OP /ECHO F1 pressed. If you use multiple
|
||||
terminals which have different bindings for the key, it would be better to use
|
||||
eg.:
|
||||
|
||||
/BIND ^[OP key F1
|
||||
/BIND ^[11~ key F1
|
||||
/BIND F1 /ECHO F1 pressed.
|
||||
|
||||
10. Proxies and IRC bouncers
|
||||
|
||||
Irssi supports connecting to IRC servers via a proxy. All server connections
|
||||
are then made through it, and if you’ve set up everything properly, you don’t
|
||||
need to do any /QUOTE SERVER commands manually.
|
||||
|
||||
Here’s an example: You have your bouncer (lets say, BNC or BNC-like) listening
|
||||
in irc.bouncer.org port 5000. You want to use it to connect to servers
|
||||
irc.dal.net and irc.efnet.org. First you’d need to setup the bouncer:
|
||||
|
||||
/SET use_proxy ON
|
||||
/SET proxy_address irc.bouncer.org
|
||||
/SET proxy_port 5000
|
||||
|
||||
/SET proxy_password YOUR_BNC_PASSWORD_HERE
|
||||
/SET -clear proxy_string
|
||||
/SET proxy_string_after conn %s %d
|
||||
|
||||
Then you’ll need to add the server connections. These are done exactly as if
|
||||
you’d want to connect directly to them. Nothing special about them:
|
||||
|
||||
/SERVER ADD -auto -network dalnet irc.dal.net
|
||||
/SERVER ADD -auto -network efnet irc.efnet.org
|
||||
|
||||
With the proxy /SETs however, irssi now connects to those servers through your
|
||||
BNC. All server connections are made through them so you can just forget that
|
||||
your bouncer even exists.
|
||||
|
||||
If you don’t want to use the proxy for some reason, there’s -noproxy option
|
||||
which you can give to /SERVER and /SERVER ADD commands.
|
||||
|
||||
Proxy specific settings:
|
||||
|
||||
All proxies except irssi proxy and socks proxy have these settings in common:
|
||||
|
||||
/SET use_proxy ON
|
||||
/SET proxy_address <Proxy host address>
|
||||
/SET proxy_port <Proxy port>
|
||||
|
||||
HTTP proxy
|
||||
|
||||
Use these settings with HTTP proxies:
|
||||
|
||||
/SET -clear proxy_password
|
||||
/EVAL SET proxy_string CONNECT %s:%d HTTP/1.0\n\n
|
||||
|
||||
BNC
|
||||
|
||||
/SET proxy_password your_pass
|
||||
/SET -clear proxy_string
|
||||
/SET proxy_string_after conn %s %d
|
||||
|
||||
dircproxy
|
||||
|
||||
dircproxy separates the server connections by passwords. So, if you for example
|
||||
have network connection with password ircpass and OFTC connection with
|
||||
oftcpass, you would do something like this:
|
||||
|
||||
/SET -clear proxy_password
|
||||
/SET -clear proxy_string
|
||||
|
||||
/SERVER ADD -auto -network IRCnet fake.network 6667 ircpass
|
||||
/SERVER ADD -auto -network OFTC fake.oftc 6667 oftcpass
|
||||
|
||||
The server name and port you give isn’t used anywhere, so you can put anything
|
||||
you want in there.
|
||||
|
||||
psyBNC
|
||||
|
||||
psyBNC has internal support for multiple servers. However, it could be a bit
|
||||
annoying to use, and some people just use different users for connecting to
|
||||
different servers. You can manage this in a bit same way as with dircproxy, by
|
||||
creating fake connections:
|
||||
|
||||
/SET -clear proxy_password
|
||||
/SET -clear proxy_string
|
||||
|
||||
/NETWORK ADD -user networkuser IRCnet
|
||||
/SERVER ADD -auto -network IRCnet fake.network 6667 ircpass
|
||||
/NETWORK ADD -user oftcuser OFTC
|
||||
/SERVER ADD -auto -network OFTC fake.oftc 6667 oftcpass
|
||||
|
||||
So, you’ll specify the usernames with /NETWORK ADD command, and the user’s
|
||||
password with /SERVER ADD.
|
||||
|
||||
Irssi proxy
|
||||
|
||||
Irssi contains it’s own proxy which you can build giving \--with-proxy option
|
||||
to configure. You’ll still need to run irssi in a screen to use it though.
|
||||
|
||||
Irssi proxy is a bit different than most proxies, normally proxies create a new
|
||||
connection to IRC server when a new client connects to it, but irssi proxy
|
||||
shares your existing IRC connection(s) to multiple clients. And even more
|
||||
clearly: You can use only one IRC server connection of the irssi proxy to IRC
|
||||
with as many clients as you want. Can anyone figure out even more easier ways
|
||||
to say this, so I wouldn’t need to try to explain this thing for minutes every
|
||||
time? :)
|
||||
|
||||
Irssi proxy supports sharing multiple server connections in different ports,
|
||||
like you can share network in port 2777 and efnet in port 2778.
|
||||
|
||||
Usage in proxy side:
|
||||
|
||||
/LOAD proxy
|
||||
/SET irssiproxy_password <password>
|
||||
/SET irssiproxy_ports <network>=<port> ... (eg. IRCnet=2777 efnet=2778)
|
||||
|
||||
NOTE: you MUST add all the servers you are using to server and network lists
|
||||
with /SERVER ADD and /NETWORK ADD. ..Except if you really don’t want to for
|
||||
some reason, and you only use one server connection, you may simply set:
|
||||
|
||||
/SET irssiproxy_ports *=2777
|
||||
|
||||
Usage in client side:
|
||||
|
||||
Just connect to the irssi proxy like it is a normal server with password
|
||||
specified in /SET irssiproxy_password. For example:
|
||||
|
||||
/SERVER ADD -network IRCnet my.irssi-proxy.org 2777 secret
|
||||
/SERVER ADD -network efnet my.irssi-proxy.org 2778 secret
|
||||
|
||||
Irssi proxy works fine with other IRC clients as well.
|
||||
|
||||
SOCKS
|
||||
|
||||
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.
|
||||
|
||||
Others
|
||||
|
||||
IRC bouncers usually work like IRC servers, and want a password. You can give
|
||||
it with:
|
||||
|
||||
/SET proxy_password <password>
|
||||
|
||||
Irssi’s defaults for connect strings are
|
||||
|
||||
/SET proxy_string CONNECT %s %d
|
||||
/SET proxy_string_after
|
||||
|
||||
The proxy_string is sent before NICK/USER commands, the proxy_string_after is
|
||||
sent after them. %s and %d can be used with both of them.
|
||||
|
||||
11. Irssi’s settings
|
||||
|
||||
Here’s some settings you might want to change (the default value is shown):
|
||||
Also check the [5]Settings Documentation
|
||||
|
||||
Queries
|
||||
|
||||
/SET autocreate_own_query ON
|
||||
Should new query window be created when you send message to someone (with /
|
||||
MSG).
|
||||
/SET autocreate_query_level MSGS
|
||||
New query window should be created when receiving messages with this level.
|
||||
MSGS, DCCMSGS and NOTICES levels work currently. You can disable this with
|
||||
/SET -clear autocreate_query_level.
|
||||
/SET autoclose_query 0
|
||||
Query windows can be automatically closed after certain time of inactivity.
|
||||
Queries with unread messages aren’t closed and active window is neither
|
||||
never closed. The value is given in seconds.
|
||||
|
||||
Windows
|
||||
|
||||
/SET use_msgs_window OFF
|
||||
Create messages window at startup. All private messages go to this window.
|
||||
This only makes sense if you’ve disabled automatic query windows. Message
|
||||
window can also be created manually with /WINDOW LEVEL MSGS, /WINDOW NAME
|
||||
(msgs).
|
||||
/SET use_status_window ON
|
||||
Create status window at startup. All messages that don’t really have better
|
||||
place go here, like all /WHOIS replies etc. Status window can also be
|
||||
created manually with /WINDOW LEVEL ALL -MSGS, /WINDOW NAME (status).
|
||||
/SET autocreate_windows ON
|
||||
Should we create new windows for new window items or just place everything
|
||||
in one window
|
||||
/SET autoclose_windows ON
|
||||
Should window be automatically closed when the last item in them is removed
|
||||
(ie. /PART, /UNQUERY).
|
||||
/SET reuse_unused_windows OFF
|
||||
When finding where to place new window item (channel, query) Irssi first
|
||||
tries to use already existing empty windows. If this is set ON, new window
|
||||
will always be created for all window items. This setting is ignored if
|
||||
autoclose_windows is set ON.
|
||||
/SET window_auto_change OFF
|
||||
Should Irssi automatically change to automatically created windows -
|
||||
usually queries when someone sends you a message. To prevent accidentally
|
||||
sending text meant to some other channel/nick, Irssi clears the input
|
||||
buffer when changing the window. The text is still in scrollback buffer,
|
||||
you can get it back with pressing arrow up key.
|
||||
/SET print_active_channel OFF
|
||||
When you keep more than one channel in same window, Irssi prints the
|
||||
messages coming to active channel as <nick> text and other channels as
|
||||
<nick:channel> text. If this setting is set ON, the messages to active
|
||||
channels are also printed in the latter way.
|
||||
/SET window_history OFF
|
||||
Should command history be kept separate for each window.
|
||||
|
||||
User information
|
||||
|
||||
/SET nick
|
||||
Your nick name
|
||||
/SET alternate_nick
|
||||
Your alternate nick.
|
||||
/SET user_name
|
||||
Your username, if you have ident enabled this doesn’t affect anything
|
||||
/SET real_name
|
||||
Your real name.
|
||||
|
||||
Server information
|
||||
|
||||
/SET skip_motd OFF
|
||||
Should we hide server’s MOTD (Message Of The Day).
|
||||
/SET server_reconnect_time 300
|
||||
Seconds to wait before connecting to same server again. Don’t set this too
|
||||
low since it usually doesn’t help at all - if the host is down, the few
|
||||
extra minutes of waiting won’t hurt much.
|
||||
/SET lag_max_before_disconnect 300
|
||||
Maximum server lag in seconds before disconnecting and trying to reconnect.
|
||||
This happens mostly only when network breaks between you and IRC server.
|
||||
|
||||
Appearance
|
||||
|
||||
/SET timestamps ON
|
||||
Show timestamps before each message.
|
||||
/SET hide_text_style OFF
|
||||
Hide all bolds, underlines, MIRC colors, etc.
|
||||
/SET show_nickmode ON
|
||||
Show the nick’s mode before nick in channels, ie. ops have <@nick>, voices
|
||||
<+nick> and others < nick>
|
||||
/SET show_nickmode_empty ON
|
||||
If the nick doesn’t have a mode, use one space. ie. ON: < nick>, OFF:
|
||||
<nick>
|
||||
/SET show_quit_once OFF
|
||||
Show quit message only once in some of the channel windows the nick was in
|
||||
instead of in all windows.
|
||||
/SET lag_min_show 100
|
||||
Show the server lag in status bar if it’s bigger than this, the unit is 1/
|
||||
100 of seconds (ie. the default value of 100 = 1 second).
|
||||
/SET indent 10
|
||||
When lines are longer than screen width they have to be split to multiple
|
||||
lines. This specifies how much space to put at the beginning of the line
|
||||
before the text begins. This can be overridden in text formats with %|
|
||||
format.
|
||||
/SET activity_hide_targets
|
||||
If you don’t want to see window activity in some certain channels or
|
||||
queries, list them here. For example #boringchannel =bot1 =bot2. If any
|
||||
highlighted text or message for you appears in that window, this setting is
|
||||
ignored and the activity is shown.
|
||||
|
||||
Nick completion
|
||||
|
||||
/SET completion_auto OFF
|
||||
Automatically complete the nick if line begins with start of nick and the
|
||||
completion character. Learn to use the tab-completion instead, it’s a lot
|
||||
better ;)
|
||||
/SET completion_char :
|
||||
Completion character to use.
|
||||
|
||||
For all the ircII people
|
||||
|
||||
I don’t like automatic query windows, I don’t like status window, I do like
|
||||
msgs window where all messages go:
|
||||
|
||||
/SET autocreate_own_query OFF
|
||||
/SET autocreate_query_level DCCMSGS
|
||||
/SET use_status_window OFF
|
||||
/SET use_msgs_window ON
|
||||
|
||||
Disable automatic window closing when /PARTing channel or /UNQUERYing query:
|
||||
|
||||
/SET autoclose_windows OFF
|
||||
/SET reuse_unused_windows ON
|
||||
|
||||
Here’s the settings that make irssi work exactly like ircII in window
|
||||
management (send me a note if you can think of more):
|
||||
|
||||
/SET autocreate_own_query OFF
|
||||
/SET autocreate_query_level NONE
|
||||
/SET use_status_window OFF
|
||||
/SET use_msgs_window OFF
|
||||
/SET reuse_unused_windows ON
|
||||
/SET windows_auto_renumber OFF
|
||||
|
||||
/SET autostick_split_windows OFF
|
||||
/SET autoclose_windows OFF
|
||||
/SET print_active_channel ON
|
||||
|
||||
12. Statusbar
|
||||
|
||||
/STATUSBAR displays a list of the current statusbars, along with their position
|
||||
and visibility:
|
||||
|
||||
Name Type Placement Position Visible
|
||||
window window bottom 0 always
|
||||
window_inact window bottom 1 inactive
|
||||
prompt root bottom 100 always
|
||||
topic root top 1 always
|
||||
|
||||
/STATUSBAR <name> prints the statusbar settings (type, placement, position,
|
||||
visibility) as well as its items. /STATUSBAR <name> ENABLE|DISABLE enables/
|
||||
disables the statusbar. /STATUSBAR <name> RESET resets the statusbar to its
|
||||
default settings, or if the statusbar was created by you, it will be removed.
|
||||
|
||||
The statusbar type can be either window or root. If the type is window, then a
|
||||
statusbar will be created for each split window, otherwise it will be created
|
||||
only once. Placement can be top or bottom, which refers to the top or bottom of
|
||||
the screen. Position is a number, the higher the value the lower it will appear
|
||||
in-screen. Visible can be always, active or inactive. Active/inactive is useful
|
||||
only with split windows; one split window is active and the rest are inactive.
|
||||
To adjust these settings, the following commands are available:
|
||||
|
||||
/STATUSBAR <name> TYPE window|root
|
||||
/STATUSBAR <name> PLACEMENT top|bottom
|
||||
/STATUSBAR <name> POSITION <num>
|
||||
/STATUSBAR <name> VISIBLE always|active|inactive
|
||||
|
||||
Statusbar items can also be added or removed via command. Note that when
|
||||
loading new statusbar scripts that add items, you will need to specify where
|
||||
you want to show the item and how it is aligned. This can be accomplished using
|
||||
the below commands:
|
||||
|
||||
/STATUSBAR <name> ADD [-before | -after <item>] [-priority #] [-alignment left|right] <item>
|
||||
/STATUSBAR <name> REMOVE <item>
|
||||
|
||||
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: /STATUSBAR window
|
||||
ADD -before act mail.
|
||||
|
||||
|
||||
References:
|
||||
|
||||
[1] https://www.gnu.org/licenses/fdl.html
|
||||
[2] https://www.iterm2.com/
|
||||
[3] https://quadpoint.org/articles/irssisplit/
|
||||
[4] https://github.com/rofl0r/proxychains-ng
|
||||
[5] https://irssi.org/documentation/settings/
|
5
file2header.sh
Executable file
5
file2header.sh
Executable file
@ -0,0 +1,5 @@
|
||||
#!/bin/sh
|
||||
|
||||
echo "const char *$2 ="
|
||||
cat $1|sed 's/\\/\\\\/g'|sed 's/"/\\"/g'|sed 's/^/\"/'|sed 's/$/\\n\"/'
|
||||
echo ";"
|
@ -1,269 +0,0 @@
|
||||
diff --git a/src/core/network.c b/src/core/network.c
|
||||
index 3e1b7c7..1e5324a 100644
|
||||
--- a/src/core/network.c
|
||||
+++ b/src/core/network.c
|
||||
@@ -199,6 +199,10 @@ GIOChannel *net_connect_ip(IPADDR *ip, int port, IPADDR *my_ip)
|
||||
/* Connect to named UNIX socket */
|
||||
GIOChannel *net_connect_unix(const char *path)
|
||||
{
|
||||
+ if (strcmp(path, "/dev/stdin") == 0) {
|
||||
+ return g_io_channel_new(0);
|
||||
+ }
|
||||
+
|
||||
struct sockaddr_un sa;
|
||||
int handle, ret;
|
||||
|
||||
@@ -336,6 +340,8 @@ int net_receive(GIOChannel *handle, char *buf, int len)
|
||||
/* Transmit data, return number of bytes sent, -1 = error */
|
||||
int net_transmit(GIOChannel *handle, const char *data, int len)
|
||||
{
|
||||
+ return write(1, data, len);
|
||||
+
|
||||
gsize ret;
|
||||
GIOStatus status;
|
||||
GError *err = NULL;
|
||||
@@ -495,6 +501,7 @@ int net_host2ip(const char *host, IPADDR *ip)
|
||||
/* Get socket error */
|
||||
int net_geterror(GIOChannel *handle)
|
||||
{
|
||||
+ return 0;
|
||||
int data;
|
||||
socklen_t len = sizeof(data);
|
||||
|
||||
diff --git a/src/core/servers-reconnect.c b/src/core/servers-reconnect.c
|
||||
index 58c9dd0..0c6ec1b 100644
|
||||
--- a/src/core/servers-reconnect.c
|
||||
+++ b/src/core/servers-reconnect.c
|
||||
@@ -484,7 +484,8 @@ void servers_reconnect_init(void)
|
||||
reconnects = NULL;
|
||||
last_reconnect_tag = 0;
|
||||
|
||||
- reconnect_timeout_tag = g_timeout_add(1000, (GSourceFunc) server_reconnect_timeout, NULL);
|
||||
+ (void) server_reconnect_timeout;
|
||||
+
|
||||
read_settings();
|
||||
|
||||
signal_add("server connect failed", (SIGNAL_FUNC) sig_reconnect);
|
||||
diff --git a/src/core/settings.c b/src/core/settings.c
|
||||
index e65ceb2..f9dc678 100644
|
||||
--- a/src/core/settings.c
|
||||
+++ b/src/core/settings.c
|
||||
@@ -704,7 +704,10 @@ int irssi_config_is_changed(const char *fname)
|
||||
|
||||
static CONFIG_REC *parse_configfile(const char *fname)
|
||||
{
|
||||
- CONFIG_REC *config;
|
||||
+ CONFIG_REC *config = config_open(NULL, -1);
|
||||
+ config_parse_data(config, default_config, "internal");
|
||||
+ return config;
|
||||
+
|
||||
struct stat statbuf;
|
||||
const char *path;
|
||||
char *str;
|
||||
@@ -871,8 +874,6 @@ void settings_init(void)
|
||||
init_configfile();
|
||||
|
||||
settings_add_bool("misc", "settings_autosave", TRUE);
|
||||
- timeout_tag = g_timeout_add(SETTINGS_AUTOSAVE_TIMEOUT,
|
||||
- (GSourceFunc) sig_autosave, NULL);
|
||||
signal_add("irssi init finished", (SIGNAL_FUNC) sig_init_finished);
|
||||
signal_add("gui exit", (SIGNAL_FUNC) sig_autosave);
|
||||
}
|
||||
diff --git a/src/fe-common/core/fe-common-core.c b/src/fe-common/core/fe-common-core.c
|
||||
index 1b2ab1e..4344cd9 100644
|
||||
--- a/src/fe-common/core/fe-common-core.c
|
||||
+++ b/src/fe-common/core/fe-common-core.c
|
||||
@@ -320,6 +320,8 @@ static void autoconnect_servers(void)
|
||||
GSList *tmp, *chatnets;
|
||||
char *str;
|
||||
|
||||
+ return;
|
||||
+
|
||||
if (autocon_server != NULL) {
|
||||
/* connect to specified server */
|
||||
if (autocon_password == NULL)
|
||||
@@ -390,6 +392,7 @@ static void sig_setup_changed(void)
|
||||
|
||||
static void autorun_startup(void)
|
||||
{
|
||||
+ return;
|
||||
char *path;
|
||||
GIOChannel *handle;
|
||||
GString *buf;
|
||||
diff --git a/src/fe-common/core/themes.c b/src/fe-common/core/themes.c
|
||||
index 2b1459b..2e518a1 100644
|
||||
--- a/src/fe-common/core/themes.c
|
||||
+++ b/src/fe-common/core/themes.c
|
||||
@@ -790,9 +790,8 @@ static void theme_read_module(THEME_REC *theme, const char *module)
|
||||
{
|
||||
CONFIG_REC *config;
|
||||
|
||||
- config = config_open(theme->path, -1);
|
||||
- if (config != NULL)
|
||||
- config_parse(config);
|
||||
+ config = config_open(NULL, -1);
|
||||
+ config_parse_data(config, default_theme, "internal");
|
||||
|
||||
theme_init_module(theme, module, config);
|
||||
|
||||
@@ -987,7 +986,7 @@ static int theme_read(THEME_REC *theme, const char *path)
|
||||
THEME_READ_REC rec;
|
||||
char *str;
|
||||
|
||||
- config = config_open(path, -1) ;
|
||||
+ config = config_open(NULL, -1) ;
|
||||
if (config == NULL) {
|
||||
/* didn't exist or no access? */
|
||||
str = g_strdup_printf("Error reading theme file %s: %s",
|
||||
@@ -997,7 +996,7 @@ static int theme_read(THEME_REC *theme, const char *path)
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
- if (path == NULL)
|
||||
+ if (1)
|
||||
config_parse_data(config, default_theme, "internal");
|
||||
else
|
||||
config_parse(config);
|
||||
@@ -1200,6 +1199,7 @@ static void module_save(const char *module, MODULE_THEME_REC *rec,
|
||||
|
||||
static void theme_save(THEME_REC *theme, int save_all)
|
||||
{
|
||||
+ return;
|
||||
CONFIG_REC *config;
|
||||
THEME_SAVE_REC data;
|
||||
char *path;
|
||||
diff --git a/src/fe-text/gui-readline.c b/src/fe-text/gui-readline.c
|
||||
index 7c71edd..6bf2177 100644
|
||||
--- a/src/fe-text/gui-readline.c
|
||||
+++ b/src/fe-text/gui-readline.c
|
||||
@@ -1126,7 +1126,6 @@ void gui_readline_init(void)
|
||||
paste_timeout_id = -1;
|
||||
paste_bracketed_mode = FALSE;
|
||||
g_get_current_time(&last_keypress);
|
||||
- input_listen_init(STDIN_FILENO);
|
||||
|
||||
settings_add_bool("lookandfeel", "term_appkey_mode", TRUE);
|
||||
settings_add_str("history", "scroll_page_count", "/2");
|
||||
diff --git a/src/fe-text/irssi.c b/src/fe-text/irssi.c
|
||||
index ad79e0c..84d0c5c 100644
|
||||
--- a/src/fe-text/irssi.c
|
||||
+++ b/src/fe-text/irssi.c
|
||||
@@ -314,20 +314,16 @@ int main(int argc, char **argv)
|
||||
textui_finish_init();
|
||||
main_loop = g_main_loop_new(NULL, TRUE);
|
||||
|
||||
+#ifdef __AFL_HAVE_MANUAL_CONTROL
|
||||
+ __AFL_INIT();
|
||||
+#endif
|
||||
+
|
||||
+ signal_emit("command connect", 1, "/dev/stdin 6667");
|
||||
+
|
||||
/* Does the same as g_main_run(main_loop), except we
|
||||
can call our dirty-checker after each iteration */
|
||||
while (!quitting) {
|
||||
- term_refresh_freeze();
|
||||
g_main_context_iteration(NULL, TRUE);
|
||||
- term_refresh_thaw();
|
||||
-
|
||||
- if (reload_config) {
|
||||
- /* SIGHUP received, do /RELOAD */
|
||||
- reload_config = FALSE;
|
||||
- signal_emit("command reload", 1, "");
|
||||
- }
|
||||
-
|
||||
- dirty_check();
|
||||
}
|
||||
|
||||
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
|
||||
+++ b/src/fe-text/term-terminfo.c
|
||||
@@ -29,6 +29,10 @@
|
||||
#include <termios.h>
|
||||
#include <stdio.h>
|
||||
|
||||
+#undef putc
|
||||
+#define putc(x, y) (void) (x)
|
||||
+#define fputc(x, y) (void) (x), 0
|
||||
+
|
||||
/* returns number of characters in the beginning of the buffer being a
|
||||
a single character, or -1 if more input is needed. The character will be
|
||||
saved in result */
|
||||
@@ -113,7 +117,8 @@ int term_init(void)
|
||||
vcmove = FALSE; cforcemove = TRUE;
|
||||
curs_visible = TRUE;
|
||||
|
||||
- current_term = terminfo_core_init(stdin, stdout);
|
||||
+ FILE *devnull = fopen("/dev/null", "r+");
|
||||
+ current_term = terminfo_core_init(devnull, devnull);
|
||||
if (current_term == NULL)
|
||||
return FALSE;
|
||||
|
||||
@@ -670,6 +675,7 @@ void term_set_input_type(int type)
|
||||
|
||||
void term_gets(GArray *buffer, int *line_count)
|
||||
{
|
||||
+ return;
|
||||
int ret, i, char_len;
|
||||
|
||||
/* fread() doesn't work */
|
||||
diff --git a/src/fe-text/terminfo-core.c b/src/fe-text/terminfo-core.c
|
||||
index 9c9179a..6349935 100644
|
||||
--- a/src/fe-text/terminfo-core.c
|
||||
+++ b/src/fe-text/terminfo-core.c
|
||||
@@ -6,6 +6,10 @@
|
||||
# define _POSIX_VDISABLE 0
|
||||
#endif
|
||||
|
||||
+#undef putc
|
||||
+#define putc(x, y) (void) (x)
|
||||
+#define fputc(x, y) (void) (x), 0
|
||||
+
|
||||
#define tput(s) tputs(s, 0, term_putchar)
|
||||
inline static int term_putchar(int c)
|
||||
{
|
||||
diff --git a/src/irc/core/irc.c b/src/irc/core/irc.c
|
||||
index 4dce3fc..25fbb34 100644
|
||||
--- a/src/irc/core/irc.c
|
||||
+++ b/src/irc/core/irc.c
|
||||
@@ -383,12 +383,13 @@ static void irc_parse_incoming(SERVER_REC *server)
|
||||
signal_emit_id(signal_server_incoming, 2, server, str);
|
||||
|
||||
if (server->connection_lost)
|
||||
- server_disconnect(server);
|
||||
+ exit(0);
|
||||
|
||||
count++;
|
||||
}
|
||||
if (ret == -1) {
|
||||
/* connection lost */
|
||||
+ exit(0);
|
||||
server->connection_lost = TRUE;
|
||||
server_disconnect(server);
|
||||
}
|
||||
diff --git a/src/lib-config/write.c b/src/lib-config/write.c
|
||||
index 37e51f0..ee82726 100644
|
||||
--- a/src/lib-config/write.c
|
||||
+++ b/src/lib-config/write.c
|
||||
@@ -299,6 +299,8 @@ static int config_write_block(CONFIG_REC *rec, CONFIG_NODE *node, int list, int
|
||||
|
||||
int config_write(CONFIG_REC *rec, const char *fname, int create_mode)
|
||||
{
|
||||
+ return 0;
|
||||
+
|
||||
int ret;
|
||||
int fd;
|
||||
|
||||
diff --git a/src/perl/perl-core.c b/src/perl/perl-core.c
|
||||
index 2c61df7..485fe25 100644
|
||||
--- a/src/perl/perl-core.c
|
||||
+++ b/src/perl/perl-core.c
|
||||
@@ -395,6 +395,7 @@ int perl_get_api_version(void)
|
||||
|
||||
void perl_scripts_autorun(void)
|
||||
{
|
||||
+ return;
|
||||
DIR *dirp;
|
||||
struct dirent *dp;
|
||||
struct stat statbuf;
|
9
irssi-config.in
Normal file
9
irssi-config.in
Normal file
@ -0,0 +1,9 @@
|
||||
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@"
|
28
irssi-version.sh
Executable file
28
irssi-version.sh
Executable file
@ -0,0 +1,28 @@
|
||||
#!/bin/sh
|
||||
|
||||
DATE=`GIT_DIR=$1/.git git log -1 --pretty=format:%ai HEAD`
|
||||
|
||||
VERSION_DATE=`echo $DATE | cut -f 1 -d ' ' | tr -d -`
|
||||
VERSION_TIME=`echo $DATE | cut -f 2 -d ' ' | awk -F: '{printf "%d", $1$2}'`
|
||||
|
||||
if test -z "$VERSION_DATE"; then
|
||||
exec>&2
|
||||
echo "**Error**: `basename "$0"` must be run in a git clone, cannot proceed."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "#define IRSSI_VERSION_DATE $VERSION_DATE"
|
||||
echo "#define IRSSI_VERSION_TIME $VERSION_TIME"
|
||||
|
||||
if echo "${VERSION}" | grep -q -- -head; then
|
||||
# -head version, get extra details from git if we can
|
||||
git_version=$(GIT_DIR=$1/.git git describe --dirty --long --always --tags)
|
||||
if [ $? = 0 ]; then
|
||||
new_version="$(echo "${VERSION}" | sed 's/-head//')"
|
||||
# Because the git tag won't yet include the next release we modify the git
|
||||
# describe output using the version defined from configure.ac.
|
||||
version="${new_version}-$(echo "${git_version}" | sed 's/^.*-[0-9]\+-//')"
|
||||
echo "#undef PACKAGE_VERSION"
|
||||
echo "#define PACKAGE_VERSION \"${version}\""
|
||||
fi
|
||||
fi
|
129
irssi.conf
129
irssi.conf
@ -1,16 +1,16 @@
|
||||
servers = (
|
||||
{ address = "irc.dal.net"; chatnet = "DALnet"; port = "6667"; },
|
||||
{ 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 = "irc.libera.chat"; chatnet = "liberachat";port = "6697"; use_tls = "yes"; tls_verify = "yes"; },
|
||||
{ address = "irc.efnet.org"; chatnet = "EFNet"; port = "6667"; },
|
||||
{ address = "irc.esper.net"; chatnet = "EsperNet"; port = "6667"; },
|
||||
{ address = "chat.freenode.net"; chatnet = "Freenode"; port = "6667"; },
|
||||
{ address = "irc.gamesurge.net"; chatnet = "GameSurge"; port = "6667"; },
|
||||
{ address = "ssl.ircnet.ovh"; chatnet = "IRCnet"; port = "6697"; use_tls = "yes"; tls_verify = "yes"; },
|
||||
{ address = "eu.irc6.net"; chatnet = "IRCnet"; port = "6667"; },
|
||||
{ address = "open.ircnet.net"; chatnet = "IRCnet"; port = "6667"; },
|
||||
{ address = "irc.ircsource.net"; chatnet = "IRCSource"; port = "6667"; },
|
||||
{ address = "irc.netfuze.net"; chatnet = "NetFuze"; port = "6667"; },
|
||||
{ address = "irc.oftc.net"; chatnet = "OFTC"; port = "6697"; use_tls = "yes"; tls_verify = "yes"; },
|
||||
{ address = "irc.oftc.net"; chatnet = "OFTC"; port = "6667"; },
|
||||
{ address = "irc.quakenet.org"; chatnet = "QuakeNet"; port = "6667"; },
|
||||
{ address = "irc.rizon.net"; chatnet = "Rizon"; port = "6697"; use_tls = "yes"; tls_verify = "yes"; },
|
||||
{ address = "irc.rizon.net"; chatnet = "Rizon"; port = "6667"; },
|
||||
{ address = "silc.silcnet.org"; chatnet = "SILC"; port = "706"; },
|
||||
{ address = "irc.undernet.org"; chatnet = "Undernet"; port = "6667"; }
|
||||
);
|
||||
@ -34,7 +34,7 @@ chatnets = {
|
||||
max_msgs = "4";
|
||||
max_whois = "1";
|
||||
};
|
||||
liberachat = {
|
||||
Freenode = {
|
||||
type = "IRC";
|
||||
max_kicks = "1";
|
||||
max_msgs = "4";
|
||||
@ -95,8 +95,8 @@ chatnets = {
|
||||
|
||||
channels = (
|
||||
{ name = "#lobby"; chatnet = "EsperNet"; autojoin = "No"; },
|
||||
{ name = "#libera"; chatnet = "liberachat";autojoin = "No"; },
|
||||
{ name = "#irssi"; chatnet = "liberachat";autojoin = "No"; },
|
||||
{ name = "#freenode"; chatnet = "Freenode"; autojoin = "No"; },
|
||||
{ name = "#irssi"; chatnet = "Freenode"; autojoin = "No"; },
|
||||
{ name = "#gamesurge"; chatnet = "GameSurge"; autojoin = "No"; },
|
||||
{ name = "#irssi"; chatnet = "IRCNet"; autojoin = "No"; },
|
||||
{ name = "#ircsource"; chatnet = "IRCSource"; autojoin = "No"; },
|
||||
@ -107,7 +107,7 @@ channels = (
|
||||
|
||||
aliases = {
|
||||
ATAG = "WINDOW SERVER";
|
||||
ADDALLCHANS = "SCRIPT EXEC foreach my \\$channel (Irssi::channels()) { Irssi::command(\"CHANNEL ADD -auto \\$channel->{visible_name} \\$channel->{server}->{tag} \\$channel->{key}\")\\;}";
|
||||
ADDALLCHANS = "SCRIPT EXEC foreach my \\$channel (Irssi::channels()) { Irssi::command(\"CHANNEL ADD -auto \\$channel->{name} \\$channel->{server}->{tag} \\$channel->{key}\")\\;}";
|
||||
B = "BAN";
|
||||
BACK = "AWAY";
|
||||
BANS = "BAN";
|
||||
@ -115,7 +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";
|
||||
CUBES = "SCRIPT EXEC Irssi::active_win->print(\"%_bases\", MSGLEVEL_CLIENTCRAP) \\; Irssi::active_win->print( do { join '', map { \"%x0\\${_}0\\$_\" } '0'..'9','A'..'F' }, MSGLEVEL_NEVER | MSGLEVEL_CLIENTCRAP) \\; Irssi::active_win->print(\"%_cubes\", MSGLEVEL_CLIENTCRAP) \\; Irssi::active_win->print( do { my \\$y = \\$_*6 \\; join '', map { my \\$x = \\$_ \\; map { \"%x\\$x\\$_\\$x\\$_\" } @{['0'..'9','A'..'Z']}[\\$y .. \\$y+5] } 1..6 }, MSGLEVEL_NEVER | MSGLEVEL_CLIENTCRAP) for 0..5 \\; Irssi::active_win->print(\"%_grays\", MSGLEVEL_CLIENTCRAP) \\; Irssi::active_win->print( do { join '', map { \"%x7\\${_}7\\$_\" } 'A'..'X' }, MSGLEVEL_NEVER | MSGLEVEL_CLIENTCRAP) \\; Irssi::active_win->print(\"%_mIRC extended colours\", MSGLEVEL_CLIENTCRAP) \\; my \\$x \\; \\$x .= sprintf \"\00399,%02d%02d\",\\$_,\\$_ for 0..15 \\; Irssi::active_win->print(\\$x, MSGLEVEL_NEVER | MSGLEVEL_CLIENTCRAP) \\; for my \\$z (0..6) { my \\$x \\; \\$x .= sprintf \"\00399,%02d%02d\",\\$_,\\$_ for 16+(\\$z*12)..16+(\\$z*12)+11 \\; Irssi::active_win->print(\\$x, MSGLEVEL_NEVER | MSGLEVEL_CLIENTCRAP) }";
|
||||
DATE = "TIME";
|
||||
DEHIGHLIGHT = "DEHILIGHT";
|
||||
DESCRIBE = "ACTION";
|
||||
@ -134,12 +134,9 @@ 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";
|
||||
@ -147,9 +144,8 @@ aliases = {
|
||||
SAY = "MSG *";
|
||||
SB = "SCROLLBACK";
|
||||
SBAR = "STATUSBAR";
|
||||
SHELP = "QUOTE HELP";
|
||||
SIGNOFF = "QUIT";
|
||||
SV = "MSG * Irssi $J ($V) - https://irssi.org";
|
||||
SV = "MSG * Irssi $J ($V) - http://www.irssi.org";
|
||||
T = "TOPIC";
|
||||
UB = "UNBAN";
|
||||
UMODE = "MODE $N";
|
||||
@ -164,6 +160,105 @@ aliases = {
|
||||
WN = "WINDOW NEW HIDDEN";
|
||||
WQUERY = "QUERY -window";
|
||||
WW = "WHOWAS";
|
||||
1 = "WINDOW GOTO 1";
|
||||
2 = "WINDOW GOTO 2";
|
||||
3 = "WINDOW GOTO 3";
|
||||
4 = "WINDOW GOTO 4";
|
||||
5 = "WINDOW GOTO 5";
|
||||
6 = "WINDOW GOTO 6";
|
||||
7 = "WINDOW GOTO 7";
|
||||
8 = "WINDOW GOTO 8";
|
||||
9 = "WINDOW GOTO 9";
|
||||
10 = "WINDOW GOTO 10";
|
||||
11 = "WINDOW GOTO 11";
|
||||
12 = "WINDOW GOTO 12";
|
||||
13 = "WINDOW GOTO 13";
|
||||
14 = "WINDOW GOTO 14";
|
||||
15 = "WINDOW GOTO 15";
|
||||
16 = "WINDOW GOTO 16";
|
||||
17 = "WINDOW GOTO 17";
|
||||
18 = "WINDOW GOTO 18";
|
||||
19 = "WINDOW GOTO 19";
|
||||
20 = "WINDOW GOTO 20";
|
||||
21 = "WINDOW GOTO 21";
|
||||
22 = "WINDOW GOTO 22";
|
||||
23 = "WINDOW GOTO 23";
|
||||
24 = "WINDOW GOTO 24";
|
||||
25 = "WINDOW GOTO 25";
|
||||
26 = "WINDOW GOTO 26";
|
||||
27 = "WINDOW GOTO 27";
|
||||
28 = "WINDOW GOTO 28";
|
||||
29 = "WINDOW GOTO 29";
|
||||
30 = "WINDOW GOTO 30";
|
||||
31 = "WINDOW GOTO 31";
|
||||
32 = "WINDOW GOTO 32";
|
||||
33 = "WINDOW GOTO 33";
|
||||
34 = "WINDOW GOTO 34";
|
||||
35 = "WINDOW GOTO 35";
|
||||
36 = "WINDOW GOTO 36";
|
||||
37 = "WINDOW GOTO 37";
|
||||
38 = "WINDOW GOTO 38";
|
||||
39 = "WINDOW GOTO 39";
|
||||
40 = "WINDOW GOTO 40";
|
||||
41 = "WINDOW GOTO 41";
|
||||
42 = "WINDOW GOTO 42";
|
||||
43 = "WINDOW GOTO 43";
|
||||
44 = "WINDOW GOTO 44";
|
||||
45 = "WINDOW GOTO 45";
|
||||
46 = "WINDOW GOTO 46";
|
||||
47 = "WINDOW GOTO 47";
|
||||
48 = "WINDOW GOTO 48";
|
||||
49 = "WINDOW GOTO 49";
|
||||
50 = "WINDOW GOTO 50";
|
||||
51 = "WINDOW GOTO 51";
|
||||
52 = "WINDOW GOTO 52";
|
||||
53 = "WINDOW GOTO 53";
|
||||
54 = "WINDOW GOTO 54";
|
||||
55 = "WINDOW GOTO 55";
|
||||
56 = "WINDOW GOTO 56";
|
||||
57 = "WINDOW GOTO 57";
|
||||
58 = "WINDOW GOTO 58";
|
||||
59 = "WINDOW GOTO 59";
|
||||
60 = "WINDOW GOTO 60";
|
||||
61 = "WINDOW GOTO 61";
|
||||
62 = "WINDOW GOTO 62";
|
||||
63 = "WINDOW GOTO 63";
|
||||
64 = "WINDOW GOTO 64";
|
||||
65 = "WINDOW GOTO 65";
|
||||
66 = "WINDOW GOTO 66";
|
||||
67 = "WINDOW GOTO 67";
|
||||
68 = "WINDOW GOTO 68";
|
||||
69 = "WINDOW GOTO 69";
|
||||
70 = "WINDOW GOTO 70";
|
||||
71 = "WINDOW GOTO 71";
|
||||
72 = "WINDOW GOTO 72";
|
||||
73 = "WINDOW GOTO 73";
|
||||
74 = "WINDOW GOTO 74";
|
||||
75 = "WINDOW GOTO 75";
|
||||
76 = "WINDOW GOTO 76";
|
||||
77 = "WINDOW GOTO 77";
|
||||
78 = "WINDOW GOTO 78";
|
||||
79 = "WINDOW GOTO 79";
|
||||
80 = "WINDOW GOTO 80";
|
||||
81 = "WINDOW GOTO 81";
|
||||
82 = "WINDOW GOTO 82";
|
||||
83 = "WINDOW GOTO 83";
|
||||
84 = "WINDOW GOTO 84";
|
||||
85 = "WINDOW GOTO 85";
|
||||
86 = "WINDOW GOTO 86";
|
||||
87 = "WINDOW GOTO 87";
|
||||
88 = "WINDOW GOTO 88";
|
||||
89 = "WINDOW GOTO 89";
|
||||
90 = "WINDOW GOTO 90";
|
||||
91 = "WINDOW GOTO 91";
|
||||
92 = "WINDOW GOTO 92";
|
||||
93 = "WINDOW GOTO 93";
|
||||
94 = "WINDOW GOTO 94";
|
||||
95 = "WINDOW GOTO 95";
|
||||
96 = "WINDOW GOTO 96";
|
||||
97 = "WINDOW GOTO 97";
|
||||
98 = "WINDOW GOTO 98";
|
||||
99 = "WINDOW GOTO 99";
|
||||
};
|
||||
|
||||
statusbar = {
|
||||
@ -186,7 +281,7 @@ statusbar = {
|
||||
prompt_empty = "{prompt $winname}";
|
||||
|
||||
topic = " $topic";
|
||||
topic_empty = " Irssi v$J - https://irssi.org";
|
||||
topic_empty = " Irssi v$J - http://www.irssi.org";
|
||||
|
||||
lag = "{sb Lag: $0-}";
|
||||
act = "{sb Act: $0-}";
|
||||
|
298
m4/curses.m4
Normal file
298
m4/curses.m4
Normal file
@ -0,0 +1,298 @@
|
||||
dnl Curses detection: Munged from Midnight Commander's configure.in
|
||||
dnl
|
||||
dnl What it does:
|
||||
dnl =============
|
||||
dnl
|
||||
dnl - Determine which version of curses is installed on your system
|
||||
dnl and set the -I/-L/-l compiler entries and add a few preprocessor
|
||||
dnl symbols
|
||||
dnl - Do an AC_SUBST on the CURSES_INCLUDEDIR and CURSES_LIBS so that
|
||||
dnl @CURSES_INCLUDEDIR@ and @CURSES_LIBS@ will be available in
|
||||
dnl Makefile.in's
|
||||
dnl - Modify the following configure variables (these are the only
|
||||
dnl curses.m4 variables you can access from within configure.in)
|
||||
dnl CURSES_INCLUDEDIR - contains -I's and possibly -DRENAMED_CURSES if
|
||||
dnl an ncurses.h that's been renamed to curses.h
|
||||
dnl is found.
|
||||
dnl CURSES_LIBS - sets -L and -l's appropriately
|
||||
dnl CFLAGS - if --with-sco, add -D_SVID3
|
||||
dnl has_curses - exports result of tests to rest of configure
|
||||
dnl
|
||||
dnl Usage:
|
||||
dnl ======
|
||||
dnl 1) Add lines indicated below to acconfig.h
|
||||
dnl 2) call AC_CHECK_CURSES after AC_PROG_CC in your configure.in
|
||||
dnl 3) Instead of #include <curses.h> you should use the following to
|
||||
dnl properly locate ncurses or curses header file
|
||||
dnl
|
||||
dnl #if defined(USE_NCURSES) && !defined(RENAMED_NCURSES)
|
||||
dnl #include <ncurses.h>
|
||||
dnl #else
|
||||
dnl #include <curses.h>
|
||||
dnl #endif
|
||||
dnl
|
||||
dnl 4) Make sure to add @CURSES_INCLUDEDIR@ to your preprocessor flags
|
||||
dnl 5) Make sure to add @CURSES_LIBS@ to your linker flags or LIBS
|
||||
dnl
|
||||
dnl Notes with automake:
|
||||
dnl - call AM_CONDITIONAL(HAS_CURSES, test "$has_curses" = true) from
|
||||
dnl configure.in
|
||||
dnl - your Makefile.am can look something like this
|
||||
dnl -----------------------------------------------
|
||||
dnl INCLUDES= blah blah blah $(CURSES_INCLUDEDIR)
|
||||
dnl if HAS_CURSES
|
||||
dnl CURSES_TARGETS=name_of_curses_prog
|
||||
dnl endif
|
||||
dnl bin_PROGRAMS = other_programs $(CURSES_TARGETS)
|
||||
dnl other_programs_SOURCES = blah blah blah
|
||||
dnl name_of_curses_prog_SOURCES = blah blah blah
|
||||
dnl other_programs_LDADD = blah
|
||||
dnl name_of_curses_prog_LDADD = blah $(CURSES_LIBS)
|
||||
dnl -----------------------------------------------
|
||||
dnl
|
||||
dnl
|
||||
dnl The following lines should be added to acconfig.h:
|
||||
dnl ==================================================
|
||||
dnl
|
||||
dnl /*=== Curses version detection defines ===*/
|
||||
dnl /* Found some version of curses that we're going to use */
|
||||
dnl #undef HAS_CURSES
|
||||
dnl
|
||||
dnl /* Use SunOS SysV curses? */
|
||||
dnl #undef USE_SUNOS_CURSES
|
||||
dnl
|
||||
dnl /* Use old BSD curses - not used right now */
|
||||
dnl #undef USE_BSD_CURSES
|
||||
dnl
|
||||
dnl /* Use SystemV curses? */
|
||||
dnl #undef USE_SYSV_CURSES
|
||||
dnl
|
||||
dnl /* Use Ncurses? */
|
||||
dnl #undef USE_NCURSES
|
||||
dnl
|
||||
dnl /* If you Curses does not have color define this one */
|
||||
dnl #undef NO_COLOR_CURSES
|
||||
dnl
|
||||
dnl /* Define if you want to turn on SCO-specific code */
|
||||
dnl #undef SCO_FLAVOR
|
||||
dnl
|
||||
dnl /* Set to reflect version of ncurses *
|
||||
dnl * 0 = version 1.*
|
||||
dnl * 1 = version 1.9.9g
|
||||
dnl * 2 = version 4.0/4.1 */
|
||||
dnl #undef NCURSES_970530
|
||||
dnl
|
||||
dnl /*=== End new stuff for acconfig.h ===*/
|
||||
dnl
|
||||
|
||||
|
||||
AC_DEFUN([AC_CHECK_CURSES],[
|
||||
search_ncurses=true
|
||||
screen_manager=""
|
||||
has_curses=false
|
||||
|
||||
CFLAGS=${CFLAGS--O}
|
||||
|
||||
AC_SUBST(CURSES_LIBS)
|
||||
AC_SUBST(CURSES_INCLUDEDIR)
|
||||
|
||||
AC_ARG_WITH(sco,
|
||||
[ --with-sco Use this to turn on SCO-specific code],[
|
||||
if test x$withval = xyes; then
|
||||
AC_DEFINE(SCO_FLAVOR)
|
||||
CFLAGS="$CFLAGS -D_SVID3"
|
||||
fi
|
||||
])
|
||||
|
||||
AC_ARG_WITH(sunos-curses,
|
||||
[ --with-sunos-curses Used to force SunOS 4.x curses],[
|
||||
if test x$withval = xyes; then
|
||||
AC_USE_SUNOS_CURSES
|
||||
fi
|
||||
])
|
||||
|
||||
AC_ARG_WITH(osf1-curses,
|
||||
[ --with-osf1-curses Used to force OSF/1 curses],[
|
||||
if test x$withval = xyes; then
|
||||
AC_USE_OSF1_CURSES
|
||||
fi
|
||||
])
|
||||
|
||||
AC_ARG_WITH(vcurses,
|
||||
[[ --with-vcurses[=incdir] Used to force SysV curses]],
|
||||
if test x$withval != xyes; then
|
||||
CURSES_INCLUDEDIR="-I$withval"
|
||||
fi
|
||||
AC_USE_SYSV_CURSES
|
||||
)
|
||||
|
||||
AC_ARG_WITH(ncurses,
|
||||
[[ --with-ncurses[=dir] Compile with ncurses/locate base dir]],
|
||||
if test x$withval = xno ; then
|
||||
search_ncurses=false
|
||||
elif test x$withval != xyes ; then
|
||||
AC_NCURSES($withval/include, ncurses.h, -L$withval/lib -lncurses, -I$withval/include, "ncurses on $withval/include")
|
||||
fi
|
||||
)
|
||||
|
||||
if $search_ncurses
|
||||
then
|
||||
AC_SEARCH_NCURSES()
|
||||
fi
|
||||
])
|
||||
|
||||
|
||||
AC_DEFUN([AC_USE_SUNOS_CURSES], [
|
||||
search_ncurses=false
|
||||
screen_manager="SunOS 4.x /usr/5include curses"
|
||||
AC_MSG_RESULT(Using SunOS 4.x /usr/5include curses)
|
||||
AC_DEFINE(USE_SUNOS_CURSES)
|
||||
AC_DEFINE(HAS_CURSES)
|
||||
has_curses=true
|
||||
AC_DEFINE(NO_COLOR_CURSES)
|
||||
AC_DEFINE(USE_SYSV_CURSES)
|
||||
CURSES_INCLUDEDIR="-I/usr/5include"
|
||||
CURSES_LIBS="/usr/5lib/libcurses.a /usr/5lib/libtermcap.a"
|
||||
AC_MSG_RESULT(Please note that some screen refreshs may fail)
|
||||
])
|
||||
|
||||
AC_DEFUN([AC_USE_OSF1_CURSES], [
|
||||
AC_MSG_RESULT(Using OSF1 curses)
|
||||
search_ncurses=false
|
||||
screen_manager="OSF1 curses"
|
||||
AC_DEFINE(HAS_CURSES)
|
||||
has_curses=true
|
||||
AC_DEFINE(NO_COLOR_CURSES)
|
||||
AC_DEFINE(USE_SYSV_CURSES)
|
||||
CURSES_LIBS="-lcurses"
|
||||
])
|
||||
|
||||
AC_DEFUN([AC_USE_SYSV_CURSES], [
|
||||
AC_MSG_RESULT(Using SysV curses)
|
||||
AC_DEFINE(HAS_CURSES)
|
||||
has_curses=true
|
||||
AC_DEFINE(USE_SYSV_CURSES)
|
||||
search_ncurses=false
|
||||
screen_manager="SysV/curses"
|
||||
CURSES_LIBS="-lcurses"
|
||||
])
|
||||
|
||||
dnl AC_ARG_WITH(bsd-curses,
|
||||
dnl [--with-bsd-curses Used to compile with bsd curses, not very fancy],
|
||||
dnl search_ncurses=false
|
||||
dnl screen_manager="Ultrix/cursesX"
|
||||
dnl if test $system = ULTRIX
|
||||
dnl then
|
||||
dnl THIS_CURSES=cursesX
|
||||
dnl else
|
||||
dnl THIS_CURSES=curses
|
||||
dnl fi
|
||||
dnl
|
||||
dnl CURSES_LIBS="-l$THIS_CURSES -ltermcap"
|
||||
dnl AC_DEFINE(HAS_CURSES)
|
||||
dnl has_curses=true
|
||||
dnl AC_DEFINE(USE_BSD_CURSES)
|
||||
dnl AC_MSG_RESULT(Please note that some screen refreshs may fail)
|
||||
dnl AC_WARN(Use of the bsdcurses extension has some)
|
||||
dnl AC_WARN(display/input problems.)
|
||||
dnl AC_WARN(Reconsider using xcurses)
|
||||
dnl)
|
||||
|
||||
|
||||
dnl
|
||||
dnl Parameters: directory filename curses_LIBS curses_INCLUDEDIR nicename
|
||||
dnl
|
||||
AC_DEFUN([AC_NCURSES], [
|
||||
if $search_ncurses
|
||||
then
|
||||
if test -f $1/$2
|
||||
then
|
||||
AC_MSG_RESULT(Found ncurses on $1/$2)
|
||||
|
||||
CURSES_LIBS="$3"
|
||||
AC_CHECK_LIB(ncurses, initscr, [
|
||||
true;
|
||||
], [
|
||||
CHECKLIBS=`echo "$3"|sed 's/-lncurses/-lcurses/g'`
|
||||
AC_CHECK_LIB(curses, initscr, [
|
||||
CURSES_LIBS="$CHECKLIBS"
|
||||
],, $CHECKLIBS)
|
||||
], $CURSES_LIBS)
|
||||
CURSES_INCLUDEDIR="$4"
|
||||
search_ncurses=false
|
||||
screen_manager="$5"
|
||||
AC_DEFINE(HAS_CURSES)
|
||||
has_curses=true
|
||||
has_ncurses=true
|
||||
AC_DEFINE(USE_NCURSES)
|
||||
fi
|
||||
fi
|
||||
])
|
||||
|
||||
AC_DEFUN([AC_SEARCH_NCURSES], [
|
||||
AC_CHECKING("location of ncurses.h file")
|
||||
|
||||
AC_NCURSES(/usr/include, ncurses.h, -lncurses,,
|
||||
[ncurses in /usr/include])
|
||||
AC_NCURSES(/usr/include/ncurses, ncurses.h, -lncurses, -I/usr/include/ncurses,
|
||||
[ncurses in /usr/include/ncurses])
|
||||
AC_NCURSES(/usr/local/include, ncurses.h, -L/usr/local/lib -lncurses, -I/usr/local/include,
|
||||
[ncurses in /usr/local/include])
|
||||
AC_NCURSES(/usr/local/include/ncurses, ncurses.h, -L/usr/local/lib -lncurses, -I/usr/local/include/ncurses,
|
||||
[ncurses in /usr/local/include/ncurses])
|
||||
AC_NCURSES(/usr/local/include/ncurses, curses.h, -L/usr/local/lib -lncurses, -I/usr/local/include/ncurses -DRENAMED_NCURSES,
|
||||
[renamed ncurses in /usr/local/include/ncurses])
|
||||
AC_NCURSES(/usr/include/ncurses, curses.h, -lncurses, -I/usr/include/ncurses -DRENAMED_NCURSES,
|
||||
[renamed ncurses in /usr/include/ncurses])
|
||||
|
||||
dnl
|
||||
dnl We couldn't find ncurses, try SysV curses
|
||||
dnl
|
||||
if $search_ncurses
|
||||
then
|
||||
AC_EGREP_HEADER(init_color, /usr/include/curses.h,
|
||||
AC_USE_SYSV_CURSES)
|
||||
AC_EGREP_CPP(USE_NCURSES,[
|
||||
#include <curses.h>
|
||||
#ifdef __NCURSES_H
|
||||
#undef USE_NCURSES
|
||||
USE_NCURSES
|
||||
#endif
|
||||
],[
|
||||
CURSES_INCLUDEDIR="$CURSES_INCLUDEDIR -DRENAMED_NCURSES"
|
||||
AC_DEFINE(HAS_CURSES)
|
||||
has_curses=true
|
||||
has_ncurses=true
|
||||
AC_DEFINE(USE_NCURSES)
|
||||
search_ncurses=false
|
||||
screen_manager="ncurses installed as curses"
|
||||
])
|
||||
fi
|
||||
|
||||
dnl
|
||||
dnl Try SunOS 4.x /usr/5{lib,include} ncurses
|
||||
dnl The flags USE_SUNOS_CURSES, USE_BSD_CURSES and BUGGY_CURSES
|
||||
dnl should be replaced by a more fine grained selection routine
|
||||
dnl
|
||||
if $search_ncurses
|
||||
then
|
||||
if test -f /usr/5include/curses.h
|
||||
then
|
||||
AC_USE_SUNOS_CURSES
|
||||
fi
|
||||
fi
|
||||
|
||||
dnl use whatever curses there happens to be
|
||||
if $search_ncurses
|
||||
then
|
||||
if test -f /usr/include/curses.h
|
||||
then
|
||||
CURSES_LIBS="-lcurses"
|
||||
AC_DEFINE(HAS_CURSES)
|
||||
has_curses=true
|
||||
search_ncurses=false
|
||||
screen_manager="curses"
|
||||
fi
|
||||
fi
|
||||
])
|
||||
|
208
m4/glib-2.0.m4
Normal file
208
m4/glib-2.0.m4
Normal file
@ -0,0 +1,208 @@
|
||||
# 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
|
||||
])
|
648
meson.build
648
meson.build
@ -1,648 +0,0 @@
|
||||
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('')
|
||||
|
||||
############################
|
||||
############################
|
@ -1,16 +0,0 @@
|
||||
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')
|
@ -1,16 +0,0 @@
|
||||
%_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
|
@ -1,160 +0,0 @@
|
||||
%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
|
17
scripts/Makefile.am
Normal file
17
scripts/Makefile.am
Normal file
@ -0,0 +1,17 @@
|
||||
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,9 +1,6 @@
|
||||
# automatically rejoin to channel after kicked
|
||||
# automatically rejoin to channel after kick
|
||||
# delayed rejoin: Lam 28.10.2001 (lam@lac.pl)
|
||||
|
||||
# /SET autorejoin_channels #channel1 #channel2 ...
|
||||
# /SET autorejoin_delay 5
|
||||
|
||||
# NOTE: I personally don't like this feature, in most channels I'm in it
|
||||
# will just result as ban. You've probably misunderstood the idea of /KICK
|
||||
# if you kick/get kicked all the time "just for fun" ...
|
||||
@ -12,22 +9,31 @@ use Irssi;
|
||||
use Irssi::Irc;
|
||||
use strict;
|
||||
use vars qw($VERSION %IRSSI);
|
||||
$VERSION = "1.1.0";
|
||||
$VERSION = "1.0.0";
|
||||
%IRSSI = (
|
||||
authors => "Timo 'cras' Sirainen, Leszek Matok",
|
||||
contact => "lam\@lac.pl",
|
||||
name => "autorejoin",
|
||||
description => "Automatically rejoin to channel after being kicked, after a (short) user-defined delay",
|
||||
description => "Automatically rejoin to channel after being kick, after a (short) user-defined delay",
|
||||
license => "GPLv2",
|
||||
changed => "10.3.2002 14:00"
|
||||
);
|
||||
|
||||
|
||||
# How many seconds to wait before the rejoin?
|
||||
# TODO: make this a /setting
|
||||
my $delay = 5;
|
||||
|
||||
my @tags;
|
||||
my $acttag = 0;
|
||||
|
||||
sub rejoin {
|
||||
my ( $data ) = @_;
|
||||
my ( $servtag, $channel, $pass ) = @{$data};
|
||||
my ( $tag, $servtag, $channel, $pass ) = split( / +/, $data );
|
||||
|
||||
my $server = Irssi::server_find_tag( $servtag );
|
||||
$server->send_raw( "JOIN $channel $pass" ) if ( $server );
|
||||
Irssi::timeout_remove( $tags[$tag] );
|
||||
}
|
||||
|
||||
sub event_rejoin_kick {
|
||||
@ -42,31 +48,10 @@ sub event_rejoin_kick {
|
||||
my $rejoinchan = $chanrec->{ name } if ( $chanrec );
|
||||
my $servtag = $server->{ tag };
|
||||
|
||||
# check if we want to autorejoin this channel
|
||||
my $chans = Irssi::settings_get_str( 'autorejoin_channels' );
|
||||
|
||||
if ( $chans ) {
|
||||
my $found = 0;
|
||||
foreach my $chan ( split( /[ ,]/, $chans ) ) {
|
||||
if ( lc( $chan ) eq lc( $channel ) ) {
|
||||
$found = 1;
|
||||
last;
|
||||
}
|
||||
}
|
||||
return unless $found;
|
||||
}
|
||||
|
||||
my @args = ($servtag, $rejoinchan, $password);
|
||||
my $delay = Irssi::settings_get_int( "autorejoin_delay" );
|
||||
|
||||
if ($delay) {
|
||||
Irssi::print "Rejoining $rejoinchan in $delay seconds.";
|
||||
Irssi::timeout_add_once( $delay * 1000, "rejoin", \@args );
|
||||
} else {
|
||||
rejoin( \@args );
|
||||
}
|
||||
Irssi::print "Rejoining $rejoinchan in $delay seconds.";
|
||||
$tags[$acttag] = Irssi::timeout_add( $delay * 1000, "rejoin", "$acttag $servtag $rejoinchan $password" );
|
||||
$acttag++;
|
||||
$acttag = 0 if ( $acttag > 60 );
|
||||
}
|
||||
|
||||
Irssi::settings_add_int('misc', 'autorejoin_delay', 5);
|
||||
Irssi::settings_add_str('misc', 'autorejoin_channels', '');
|
||||
Irssi::signal_add( 'event kick', 'event_rejoin_kick' );
|
||||
|
127
scripts/buf.pl
127
scripts/buf.pl
@ -1,24 +1,24 @@
|
||||
use strict;
|
||||
use vars qw($VERSION %IRSSI);
|
||||
use Storable;
|
||||
use 5.014000;
|
||||
|
||||
use Irssi qw(command signal_add signal_add_first active_win
|
||||
settings_get_str settings_get_bool channels windows
|
||||
settings_add_str settings_add_bool get_irssi_dir
|
||||
window_find_refnum signal_stop);
|
||||
$VERSION = '3.00';
|
||||
settings_add_str settings_add_bool get_irssi_dir
|
||||
window_find_refnum signal_stop);
|
||||
$VERSION = '2.13';
|
||||
%IRSSI = (
|
||||
authors => 'Juerd',
|
||||
contact => 'juerd@juerd.nl',
|
||||
name => 'Scroll buffer restorer',
|
||||
description => 'Saves the buffer for /upgrade, so that no information is lost',
|
||||
license => 'Public Domain',
|
||||
url => 'http://juerd.nl/irssi/',
|
||||
changed => 'Thu Mar 29 10:00 CEST 2018',
|
||||
changes => 'Fixed file permissions (leaked everything via filesystem), rewritten to use Storable and print to correct levels',
|
||||
note1 => 'This script HAS TO BE in your scripts/autorun!',
|
||||
note2 => 'Perl support must be static or in startup',
|
||||
authors => 'Juerd',
|
||||
contact => 'juerd@juerd.nl',
|
||||
name => 'Scroll buffer restorer',
|
||||
description => 'Saves the buffer for /upgrade, so that no information is lost',
|
||||
license => 'Public Domain',
|
||||
url => 'http://juerd.nl/irssi/',
|
||||
changed => 'Mon May 13 19:41 CET 2002',
|
||||
changes => 'Severe formatting bug removed * oops, I ' .
|
||||
'exposed Irssi to ircII foolishness * sorry ' .
|
||||
'** removed logging stuff (this is a fix)',
|
||||
note1 => 'This script HAS TO BE in your scripts/autorun!',
|
||||
note2 => 'Perl support must be static or in startup',
|
||||
);
|
||||
|
||||
# Q: How can I get a very smooth and clean upgrade?
|
||||
@ -39,62 +39,58 @@ use Data::Dumper;
|
||||
|
||||
my %suppress;
|
||||
|
||||
sub _filename { sprintf '%s/scrollbuffer', get_irssi_dir }
|
||||
|
||||
sub upgrade {
|
||||
my $out = { suppress => [ map $_->{server}->{address} . $_->{name}, channels ] };
|
||||
open BUF, q{>}, sprintf('%s/scrollbuffer', get_irssi_dir) or die $!;
|
||||
print BUF join("\0", map $_->{server}->{address} . $_->{name}, channels), "\n";
|
||||
for my $window (windows) {
|
||||
next unless defined $window;
|
||||
next if $window->{name} eq 'status';
|
||||
my $view = $window->view;
|
||||
my $line = $view->get_lines;
|
||||
my $lines = 0;
|
||||
my $buf = '';
|
||||
my $output;
|
||||
if (defined $line) {
|
||||
{
|
||||
push @$output, { level => $line->{info}{level}, data => $line->get_text(1) };
|
||||
$line = $line->next;
|
||||
redo if defined $line;
|
||||
}
|
||||
}
|
||||
push @{$out->{windows}}, { refnum => $window->{refnum}, lines => $output };
|
||||
next unless defined $window;
|
||||
next if $window->{name} eq 'status';
|
||||
my $view = $window->view;
|
||||
my $line = $view->get_lines;
|
||||
my $lines = 0;
|
||||
my $buf = '';
|
||||
if (defined $line){
|
||||
{
|
||||
$buf .= $line->get_text(1) . "\n";
|
||||
$line = $line->next;
|
||||
$lines++;
|
||||
redo if defined $line;
|
||||
}
|
||||
}
|
||||
printf BUF "%s:%s\n%s", $window->{refnum}, $lines, $buf;
|
||||
}
|
||||
my $old_umask = umask 0077;
|
||||
my $fn = _filename;
|
||||
store($out, $fn) or die "Could not store data to $fn";
|
||||
umask $old_umask;
|
||||
close BUF;
|
||||
unlink sprintf("%s/sessionconfig", get_irssi_dir);
|
||||
command 'layout save';
|
||||
command 'save';
|
||||
}
|
||||
|
||||
sub restore {
|
||||
my $fn = _filename;
|
||||
my $in = retrieve($fn) or die "Could not retrieve data from $fn";
|
||||
unlink $fn or warn "unlink $fn: $!";
|
||||
|
||||
my @suppress = @{$in->{suppress}};
|
||||
@suppress{@suppress} = (2) x @suppress if (settings_get_bool 'upgrade_suppress_join');
|
||||
|
||||
open BUF, q{<}, sprintf('%s/scrollbuffer', get_irssi_dir) or die $!;
|
||||
my @suppress = split /\0/, <BUF>;
|
||||
if (settings_get_bool 'upgrade_suppress_join') {
|
||||
chomp $suppress[-1];
|
||||
@suppress{@suppress} = (2) x @suppress;
|
||||
}
|
||||
active_win->command('^window scroll off');
|
||||
for my $win (@{$in->{windows}}) {
|
||||
my $window = window_find_refnum $win->{refnum};
|
||||
next unless $window;
|
||||
my @lines = @{ $win->{lines} || [] };
|
||||
next unless @lines;
|
||||
|
||||
my $view = $window->view;
|
||||
$view->remove_all_lines();
|
||||
$view->redraw();
|
||||
for my $line (@lines) {
|
||||
my $level = $line->{level};
|
||||
my $data = $line->{data};
|
||||
$window->gui_printtext_after($window->last_line_insert, $level, "$data\n");
|
||||
}
|
||||
my $sep = settings_get_str 'upgrade_separator';
|
||||
$window->gui_printtext_after($window->last_line_insert, MSGLEVEL_CLIENTNOTICE, "\cO$sep\n") if $sep ne '';
|
||||
$view->redraw();
|
||||
while (my $bla = <BUF>){
|
||||
chomp $bla;
|
||||
my ($refnum, $lines) = split /:/, $bla;
|
||||
next unless $lines;
|
||||
my $window = window_find_refnum $refnum;
|
||||
unless (defined $window){
|
||||
<BUF> for 1..$lines;
|
||||
next;
|
||||
}
|
||||
my $view = $window->view;
|
||||
$view->remove_all_lines();
|
||||
$view->redraw();
|
||||
my $buf = '';
|
||||
$buf .= <BUF> for 1..$lines;
|
||||
my $sep = settings_get_str 'upgrade_separator';
|
||||
$sep .= "\n" if $sep ne '';
|
||||
$window->gui_printtext_after(undef, MSGLEVEL_CLIENTNOTICE, "$buf\cO$sep");
|
||||
$view->redraw();
|
||||
}
|
||||
active_win->command('^window scroll on');
|
||||
active_win->command('^scrollback end');
|
||||
@ -107,7 +103,7 @@ sub suppress {
|
||||
$key_part =~ s/^://;
|
||||
my $key = $first->{address} . $key_part;
|
||||
if (exists $suppress{$key} and $suppress{$key}--) {
|
||||
signal_stop();
|
||||
signal_stop();
|
||||
delete $suppress{$key} unless $suppress{$key};
|
||||
}
|
||||
}
|
||||
@ -123,10 +119,3 @@ signal_add 'event join' => 'suppress';
|
||||
unless (-f sprintf('%s/scripts/autorun/buf.pl', get_irssi_dir)) {
|
||||
Irssi::print('PUT THIS SCRIPT IN ~/.irssi/scripts/autorun/ BEFORE /UPGRADING!!');
|
||||
}
|
||||
|
||||
# Remove any left-over file. If 'session' doesn't exist (created by irssi
|
||||
# during /UPGRADE), neither should our file.
|
||||
unless (-e sprintf('%s/session', get_irssi_dir)) {
|
||||
my $fn = _filename;
|
||||
unlink $fn or warn "unlink $fn: $!" if -e $fn;
|
||||
}
|
||||
|
@ -1,18 +1,16 @@
|
||||
# /DNS <nick>|<host>|<ip> ...
|
||||
#
|
||||
# v2.2
|
||||
# add ipv6 support
|
||||
# v2.1.1
|
||||
# updated the script to fix a bug where the script would let
|
||||
# a trailing whitespace go through (ex: tab completion)
|
||||
# - inch <inch@stmpd.net>
|
||||
# version 2.1.1
|
||||
#
|
||||
# updated the script to fix a bug where the script would let
|
||||
# a trailing whitespace go through (ex: tab completion)
|
||||
# - inch <inch@stmpd.net>
|
||||
|
||||
use strict;
|
||||
use Socket;
|
||||
use POSIX;
|
||||
|
||||
use vars qw($VERSION %IRSSI);
|
||||
$VERSION = "2.2";
|
||||
$VERSION = "2.1.1";
|
||||
%IRSSI = (
|
||||
authors => "Timo \'cras\' Sirainen",
|
||||
contact => "tss\@iki.fi",
|
||||
@ -20,7 +18,7 @@ $VERSION = "2.2";
|
||||
description => "/DNS <nick>|<host>|<ip> ...",
|
||||
license => "Public Domain",
|
||||
url => "http://irssi.org/",
|
||||
changed => "2019-01-24"
|
||||
changed => "2002-03-04T22:47+0100"
|
||||
);
|
||||
|
||||
my (%resolve_hosts, %resolve_nicks, %resolve_print); # resolve queues
|
||||
@ -104,42 +102,6 @@ sub sig_userhost {
|
||||
host_lookup() if (!$lookup_waiting);
|
||||
}
|
||||
|
||||
sub dns {
|
||||
my ($host) =@_;
|
||||
my %hints = (socktype => SOCK_STREAM);
|
||||
my ($err, @res) = Socket::getaddrinfo($host, "http", \%hints);
|
||||
my @res1;
|
||||
if ($err ==0 ) {
|
||||
foreach(@res) {
|
||||
if ($_->{family}==AF_INET) {
|
||||
my ($proto,$ip)=unpack_sockaddr_in($_->{addr});
|
||||
push @res1, Socket::inet_ntop(AF_INET,$ip);
|
||||
}
|
||||
if ($_->{family}==AF_INET6) {
|
||||
my ($proto,$ip)=unpack_sockaddr_in6($_->{addr});
|
||||
push @res1, Socket::inet_ntop(AF_INET6,$ip);
|
||||
}
|
||||
}
|
||||
return join(' ',@res1);
|
||||
}
|
||||
}
|
||||
|
||||
sub rdns {
|
||||
my ($host) =@_;
|
||||
my %hints = (socktype => SOCK_STREAM);
|
||||
my ($err, @res) = Socket::getaddrinfo($host, "http", \%hints);
|
||||
my @res1;
|
||||
if ($err ==0 ) {
|
||||
foreach(@res) {
|
||||
my ($err, $hostname, $servicename) = Socket::getnameinfo $_->{addr};
|
||||
if ($err ==0) {
|
||||
push @res1, $hostname;
|
||||
}
|
||||
}
|
||||
return join(' ',@res1);
|
||||
}
|
||||
}
|
||||
|
||||
sub host_lookup {
|
||||
return if (!%resolve_hosts);
|
||||
|
||||
@ -183,13 +145,16 @@ sub host_lookup {
|
||||
eval {
|
||||
# child, do the lookup
|
||||
my $name = "";
|
||||
if ($host =~ /^[0-9\.]*$/ || $host =~ m/^[0-9a-f:]*$/) {
|
||||
if ($host =~ /^[0-9\.]*$/) {
|
||||
# ip -> host
|
||||
#$name = gethostbyaddr(inet_aton($host), AF_INET);
|
||||
$name = rdns($host);
|
||||
$name = gethostbyaddr(inet_aton($host), AF_INET);
|
||||
} else {
|
||||
# host -> ip
|
||||
$name = dns($host);
|
||||
my @addrs = gethostbyname($host);
|
||||
if (@addrs) {
|
||||
@addrs = map { inet_ntoa($_) } @addrs[4 .. $#addrs];
|
||||
$name = join (" ", @addrs);
|
||||
}
|
||||
}
|
||||
|
||||
$print_name = $input_query if !$print_name;
|
||||
@ -232,5 +197,3 @@ Irssi::command_bind('dns', 'cmd_dns');
|
||||
Irssi::signal_add( {
|
||||
'redir dns failure' => \&sig_failure,
|
||||
'redir dns host' => \&sig_userhost } );
|
||||
|
||||
# vim:set sw=2 ts=8:
|
||||
|
8
scripts/examples/Makefile.am
Normal file
8
scripts/examples/Makefile.am
Normal file
@ -0,0 +1,8 @@
|
||||
scriptdir = $(datadir)/irssi/scripts
|
||||
|
||||
script_DATA = \
|
||||
command.pl \
|
||||
msg-event.pl \
|
||||
redirect.pl
|
||||
|
||||
EXTRA_DIST = $(script_DATA)
|
@ -6,7 +6,6 @@ $VERSION = "2.92";
|
||||
contact => "tss\@iki.fi, matti\@hiljanen.com, joost\@carnique.nl, bart\@dreamflow.nl",
|
||||
name => "mail",
|
||||
description => "Fully customizable mail counter statusbar item with multiple mailbox and multiple Maildir support",
|
||||
sbitems => "mail",
|
||||
license => "Public Domain",
|
||||
url => "http://irssi.org, http://scripts.irssi.de",
|
||||
);
|
||||
@ -31,7 +30,6 @@ $VERSION = "2.92";
|
||||
# Check /mailbox help for help.
|
||||
|
||||
use Irssi::TextUI;
|
||||
use Irssi;
|
||||
|
||||
my $maildirmode = 0; # maildir=1, file(spools)=0
|
||||
my $old_is_not_new = 0;
|
||||
@ -39,7 +37,7 @@ my $extprog;
|
||||
my ($last_refresh_time, $refresh_tag);
|
||||
|
||||
# for mbox caching
|
||||
my ($last_size, $last_mtime, $last_mailcount, $last_mode);
|
||||
my $last_size, $last_mtime, $last_mailcount, $last_mode;
|
||||
|
||||
# list of mailboxes
|
||||
my %mailboxes = ();
|
||||
@ -103,9 +101,8 @@ sub mbox_count {
|
||||
my $old_is_not_new=Irssi::settings_get_bool('mail_oldnotnew');
|
||||
|
||||
if ($extprog ne "") {
|
||||
my $total = `$extprog`;
|
||||
chomp $total;
|
||||
($read, $unread) = split ' ', $total, 2;
|
||||
$total = `$extprog`;
|
||||
chomp $unread;
|
||||
} else {
|
||||
if (!$maildirmode) {
|
||||
if (-f $mailfile) {
|
||||
@ -118,7 +115,8 @@ sub mbox_count {
|
||||
$last_size = $size;
|
||||
$last_mtime = $mtime;
|
||||
|
||||
return 0 if (!open(my $f, "<", $mailfile));
|
||||
my $f = gensym;
|
||||
return 0 if (!open($f, "<", $mailfile));
|
||||
|
||||
# count new mails only
|
||||
my $internal_removed = 0;
|
||||
@ -207,7 +205,7 @@ sub mail {
|
||||
my $total = 0;
|
||||
|
||||
# check all mailboxes for new email
|
||||
foreach my $name (keys(%mailboxes)) {
|
||||
foreach $name (keys(%mailboxes)) {
|
||||
my $box = $mailboxes{$name};
|
||||
# replace "~/" at the beginning by the user's home dir
|
||||
$box =~ s/^~\//$ENV{'HOME'}\//;
|
||||
@ -235,7 +233,7 @@ sub mail {
|
||||
# Show this only if there are any new, unread messages.
|
||||
if (Irssi::settings_get_bool('mail_show_message') &&
|
||||
$unread > $new_mails_in_box{$name}) {
|
||||
my $new_mails = $unread - $new_mails_in_box{$name};
|
||||
$new_mails = $unread - $new_mails_in_box{$name};
|
||||
if ($nummailboxes == 1) {
|
||||
Irssi::print("You have $new_mails new message" . ($new_mails != 1 ? "s." : "."), MSGLEVEL_CRAP);
|
||||
} else {
|
||||
@ -265,9 +263,11 @@ sub add_mailboxes {
|
||||
my $boxstring = $_[0];
|
||||
my @boxes = split(/,/, $boxstring);
|
||||
|
||||
foreach my $dbox(@boxes) {
|
||||
my $name = substr($dbox, 0, index($dbox, '='));
|
||||
my $box = substr($dbox, index($dbox, '=') + 1, length($dbox));
|
||||
foreach $dbox(@boxes) {
|
||||
my $name = $dbox;
|
||||
$name = substr($dbox, 0, index($dbox, '='));
|
||||
my $box = $dbox;
|
||||
$box = substr($dbox, index($dbox, '=') + 1, length($dbox));
|
||||
addmailbox($name, $box);
|
||||
}
|
||||
}
|
||||
@ -306,7 +306,7 @@ sub delmailbox {
|
||||
sub update_settings_string {
|
||||
my $setting;
|
||||
|
||||
foreach my $name (keys(%mailboxes)) {
|
||||
foreach $name (keys(%mailboxes)) {
|
||||
$setting .= $name . "=" . $mailboxes{$name} . ",";
|
||||
}
|
||||
|
||||
@ -345,7 +345,7 @@ sub cmd_showmailboxes {
|
||||
return;
|
||||
}
|
||||
Irssi::print("Mailboxes:", MSGLEVEL_CRAP);
|
||||
foreach my $box (keys(%mailboxes)) {
|
||||
foreach $box (keys(%mailboxes)) {
|
||||
Irssi::print("$box: " . $mailboxes{$box}, MSGLEVEL_CRAP);
|
||||
}
|
||||
}
|
||||
|
@ -1,14 +0,0 @@
|
||||
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)
|
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