.github/workflows | ||
docs/v0.0.1 | ||
examples | ||
integration_test | ||
lib | ||
scripts | ||
spec | ||
.gitignore | ||
.rubocop.yml | ||
client_sample.rb | ||
Gemfile | ||
Rakefile | ||
README.md | ||
server_sample.rb | ||
teeworlds-client.gemspec |
teeworlds_network
A teeworlds 0.7 client & server library written in ruby
Sample
Here a simple sample usage of the library. Connecting a client to localhost on port 8303. Acting as a simple chat bot. Also properly disconnect when the program is killed gracefully.
For more sample usages checkout the examples/ folder.
require_relative 'lib/teeworlds_client'
client = TeeworldsClient.new(verbose: false)
client.on_chat do |msg|
# note use `next` instead of `return` in the block
next unless msg.message[0] == '!'
case msg.message[1..]
when 'ping' then client.send_chat('pong')
when 'whoami' then client.send_chat("You are: #{msg.author.name}")
when 'list' then client.send_chat(client.game_client.players.values.map(&:name).join(', '))
else client.send_chat('Unkown command! Commands: !ping, !whoami, !list')
end
end
# properly disconnect on ctrl+c
Signal.trap('INT') do
client.disconnect
end
# connect to localhost and block the current thread
client.connect('localhost', 8303, detach: false)
Documentation
Checkout docs/v0.0.1/READE.md for a full library documentation.