Bugs/Threaded Tcl

From Eggdrop Wiki

Jump to: navigation, search
File:Ambox_deletion.png This page is deprecated as of Eggdrop 1.6.20. You should upgrade instead of applying the fixes below!


Some recent versions of Debian have begun shipping out with Tcl pre-compiled as threaded instead of non-threaded. The techno-babble: Up until now, eggdrop could not detect whether Tcl was compiled as threaded or not. For many years, the developers just assumed that Tcl was not threaded, as it was shipped this way with OS's nearly all the time. If eggdrop doesn't know Tcl is compiled with threads, when eggdrop tries to fork(), it hangs. Debian changed the way Tcl was compiled and distributed a while back, and as a result of not being able to detect that during the compile process, a few changes need to be made to the source to allow it to run again. Again, for the average user, what was just described won't make sense and doesn't need to, there is no advantage for eggdrop to run with threaded or non-threaded Tcl. Bottom line, if you want to fix it, try one of the solutions below.

Contents

Solution 1: Apply Tothwolf's Patch to your 1.6.19 source

Tothwolf's patch can be found here. Specific instructions on how to apply it are here.

  1. Apply this patch to the 1.6.19 source.
  2. ./configure
  3. make config
  4. make
  5. make install
  6. enjoy!

Solution 2: Edit config.h

./configure your bot. Open the config.h file in your editor.

Search for (around line 244)

/* Define for Tcl that has threads. */
/* #undef HAVE_TCL_THREADS */

and replace it with

/* Define for Tcl that has threads. */
 #define HAVE_TCL_THREADS 1

Carry on with your make config && make && make install.

Solution 3: Recompile Tcl

So, here's the deal. Eggdrop is supposed to be coded to handle Tcl threading. Either that code never worked, or it's now broken because of some change in Tcl internally. The solution? Compile and install Tcl with no threads, then recompile and reinstall your eggdrop.

Yeah, some of you will say 'Oh, ok, easy' and go and do it. The rest of you are probably saying 'Huh?'

These are some of the possible solutions to fix your problem:

If you don't have root access

If you have root access

Debian with Tcl 8.5, Ubuntu 8.04 with Tcl 8,5

  • Install the dependencies for developing debian packages using apt-get. There is a list of these dependencies on this page in section 1.1.
  • mkdir /root/tcl
  • cd /root/tcl
  • apt-get source tcl8.6
  • cd into the directory it creates (tcl8.6-8.6.4 currently)
  • cd debian
  • edit rules; remove the line " --enable-threads \" (currently line 52)
  • cd ..
  • dpkg-buildpackage -rfakeroot
  • Your .deb files are now being built.
  • cd ..
  • dpkg -i *.deb

Instead of doing that yourself, you could download the .deb files here: Debian and Ubuntu 8.04 and dpkg -i them yourself.

If you don't trust the files I've built, build them yourself, it shouldn't be that hard.

  • Note: The Ubuntu 8.04 tcl8.6 debian/rules file is borked. The quotes in lines 16, 21, and 23 need to be removed. Line 57 should be '$(MAKE) CFLAGS="$(CFLAGS)"'. The Ubuntu-MOTU group has been notified, and someone is filing a bug.

RHEL5/CentOS5 or Fedora Core 9 with Tcl 8.5

Instead of doing that yourself, you could download the RPMs here: RHEL5/CentOS5 or Fedora Core 9 and rpm -Uvh them yourself.

  • Note on FC9: I had to 'rm -rf /usr/lib/tcl8.5' after 'rpm -e tcl' before the new RPM would install.

If you don't trust the files I've built, build them yourself, it shouldn't be that hard.

Archlinux

cp -r /var/abs/extra/tcl .
cd tcl
nano PKGBUILD   (delete --enable-threads)
makepkg
pacman -U tcl-8.6.4-*-i686.pkg.tar.gz
Personal tools