mirror of
https://github.com/sys-fs/seddy
synced 2024-11-22 03:44:17 -05:00
Add seddy.py, LICENSE, and README
This commit is contained in:
parent
3113a4aac3
commit
b447e9fa78
27
LICENSE
Normal file
27
LICENSE
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
Copyright © 2016 Thomas Mannay
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without modification,
|
||||||
|
are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1. Redistributions of source code must retain the above copyright notice, this
|
||||||
|
list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation and/or
|
||||||
|
other materials provided with the distribution.
|
||||||
|
|
||||||
|
3. Neither the name of the copyright holder nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software without
|
||||||
|
specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||||
|
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||||
|
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
|
||||||
|
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
||||||
|
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
||||||
|
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
||||||
|
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
@ -1,2 +1,6 @@
|
|||||||
# seddy
|
# seddy
|
||||||
A sedbot written for tubes
|
seddy was written to make use of [tubes](https://github.com/sys-fs/tubes). Two
|
||||||
|
flags are supported: i and g. Due to using Python's re engine, whatever regex
|
||||||
|
syntax Python knows about should be understood by seddy.
|
||||||
|
|
||||||
|
This project depends on Python 3 and tubes.
|
||||||
|
112
seddy.py
Normal file
112
seddy.py
Normal file
@ -0,0 +1,112 @@
|
|||||||
|
#!/usr/bin/python3
|
||||||
|
# See the LICENSE file for licensing information
|
||||||
|
import re
|
||||||
|
|
||||||
|
nick = 'seddy'
|
||||||
|
server = 'chat.freenode.net'
|
||||||
|
channel = '#example'
|
||||||
|
gecos = 'A text processing bot'
|
||||||
|
|
||||||
|
receive = open('/tmp/' + server + '.in', 'r')
|
||||||
|
send = open('/tmp/' + server + '.out', 'w')
|
||||||
|
|
||||||
|
parse_msg = re.compile(' :(.*)')
|
||||||
|
parse_sed = re.compile('(?<!\\\\)/')
|
||||||
|
is_sed = re.compile('s/.*/.*')
|
||||||
|
|
||||||
|
class Queue:
|
||||||
|
size = 0
|
||||||
|
data = []
|
||||||
|
head = 0
|
||||||
|
tail = 0
|
||||||
|
count = 0
|
||||||
|
|
||||||
|
def __init__(self, size):
|
||||||
|
self.size = size
|
||||||
|
self.data = [None]*size
|
||||||
|
|
||||||
|
def enqueue(self, s):
|
||||||
|
if not self.full():
|
||||||
|
self.count += 1
|
||||||
|
self.data[self.tail] = s
|
||||||
|
self.tail = (self.tail + 1) % self.size
|
||||||
|
|
||||||
|
def dequeue(self):
|
||||||
|
if not self.empty():
|
||||||
|
self.count -= 1
|
||||||
|
s = self.data[self.head]
|
||||||
|
self.head = (self.head + 1) % self.size
|
||||||
|
return s
|
||||||
|
|
||||||
|
def full(self):
|
||||||
|
return self.size == self.count
|
||||||
|
|
||||||
|
def empty(self):
|
||||||
|
return self.head == self.count
|
||||||
|
|
||||||
|
def find(self, s):
|
||||||
|
i = self.tail-1
|
||||||
|
while True:
|
||||||
|
if i == -1:
|
||||||
|
i = self.size-1
|
||||||
|
if re.search(s, self.data[i]):
|
||||||
|
return self.data[i]
|
||||||
|
i -= 1
|
||||||
|
if i == self.tail-1:
|
||||||
|
return False
|
||||||
|
|
||||||
|
def seddy(sed, history):
|
||||||
|
regex = parse_sed.split(sed)
|
||||||
|
msg = history.find(regex[1])
|
||||||
|
f = 0
|
||||||
|
|
||||||
|
if msg == False:
|
||||||
|
return False
|
||||||
|
if 'i' in regex[3]:
|
||||||
|
f |= re.I
|
||||||
|
if "g" in regex[3]:
|
||||||
|
return re.sub(regex[1], regex[2], msg, flags=f)
|
||||||
|
else:
|
||||||
|
return re.sub(regex[1], regex[2], msg, 1)
|
||||||
|
|
||||||
|
def notice(msg):
|
||||||
|
send.write('NOTICE ' + channel + ' :' + msg + '\r\n')
|
||||||
|
send.flush()
|
||||||
|
|
||||||
|
def privmsg(msg):
|
||||||
|
send.write('PRIVMSG ' + channel + ' :' + msg + '\r\n')
|
||||||
|
send.flush()
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
history = Queue(48)
|
||||||
|
|
||||||
|
send.write('NICK ' + nick + '\r\n')
|
||||||
|
send.flush()
|
||||||
|
send.write('USER ' + nick + ' * 8 :' + gecos + '\r\n')
|
||||||
|
send.flush()
|
||||||
|
send.write('JOIN ' + channel + '\r\n')
|
||||||
|
send.flush()
|
||||||
|
|
||||||
|
for line in receive:
|
||||||
|
msg = parse_msg.search(line)
|
||||||
|
if msg is None:
|
||||||
|
continue
|
||||||
|
else:
|
||||||
|
msg = msg.group(1)
|
||||||
|
|
||||||
|
if history.full():
|
||||||
|
history.dequeue()
|
||||||
|
if 'PRIVMSG' in line and not is_sed.match(msg):
|
||||||
|
history.enqueue(msg)
|
||||||
|
|
||||||
|
if 'PING' in line:
|
||||||
|
send.write('PONG\r\n')
|
||||||
|
send.flush()
|
||||||
|
if '.bots' in msg or '.bot ' + nick in msg:
|
||||||
|
notice("I was written to correct your mistakes.")
|
||||||
|
if '.source ' + nick in msg:
|
||||||
|
notice('[Python] https://github.com/sys-fs/seddy')
|
||||||
|
elif is_sed.match(msg):
|
||||||
|
foo = seddy(msg, history)
|
||||||
|
if foo != False:
|
||||||
|
privmsg(re.sub('\\\\/', '/', foo))
|
Loading…
Reference in New Issue
Block a user