summaryrefslogtreecommitdiff
path: root/bin/rbot
diff options
context:
space:
mode:
authorGiuseppe Bilotta <giuseppe.bilotta@gmail.com>2007-02-20 23:02:35 +0000
committerGiuseppe Bilotta <giuseppe.bilotta@gmail.com>2007-02-20 23:02:35 +0000
commit397b61df257f72a8ce90792985f76497ba735da4 (patch)
tree7b8321eab08498376d537178ebe7ed57dfc23713 /bin/rbot
parent1572836f8c2888742b4f65da7dc6f66735f94bc1 (diff)
Use ASCII KCODE to prevent problems like missing characters or matching failures when clients send messages in something else than UTF-8
Diffstat (limited to 'bin/rbot')
-rwxr-xr-xbin/rbot11
1 files changed, 10 insertions, 1 deletions
diff --git a/bin/rbot b/bin/rbot
index 5872e3e1..b7a6207f 100755
--- a/bin/rbot
+++ b/bin/rbot
@@ -21,7 +21,16 @@
# IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
# CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
-$KCODE = 'u'
+# Most of the string processing across rbot is done against IRC messages, which
+# do not have a well-defined encoding. Although many clients are now using
+# UTF-8, there is no guarantee that an arbitrary string received from IRC will
+# be UTF-8 encoded. We have to force ASCII (byte-wise/charset agnostic)
+# matching because otherwise some strings can give problems: in particular, for
+# example, the bytesequence "\340\350\354\362\371" (that is the aeiou vowels,
+# each with a grave accent) will cause the string to be considered up to the
+# "\354" (i with grave accent) only: so either the rest of the message is
+# ignored, or the matching fails.
+$KCODE = 'a'
$VERBOSE=true