matteo-the-prestige
simsim discord bot
blaseball, blaseball, is back! in an unofficial capacity. this project is completely unaffiliated with the game band.
we have custom players (generated by onomancer), custom teams, custom leagues (that last one is coming soon™), all set up in discord and watchable at https://simsim.sibr.dev!
if you would like to add matteo to your server to be able to set up teams and games, you can do so with this link: https://discord.com/api/oauth2/authorize?client_id=789956166796574740&permissions=388160&scope=bot
accepting pull requests, check the issues for to-dos.
commands: (everything here is case sensitive, and can be prefixed with either m; or m!)
team commands:
creation and deletion:
- m;saveteam
- saves a team to the database allowing it to be used for games. use this command at the top of a list with each of these in a new line after:
- the team's name.
- the team's icon and slogan, generally this is an emoji followed by a space, followed by a short slogan.
- a blank line.
- the batters' names in the order you want them to appear in your lineup, each on its own line. lineups can contain any number of batters between 1 and 12.
- a blank line.
- the pitchers' names in the order you want them to appear in your rotation. rotations can contain any number of pitchers between 1 and 8.
 
- if you did everything correctly you'll get a team embed with a prompt to confirm. hit the 👍 and your team will be saved!
 
- saves a team to the database allowing it to be used for games. use this command at the top of a list with each of these in a new line after:
- m;deleteteam [teamname] (requires team ownership)
- allows you to delete the team with the provided name. you'll get an embed with a confirmation to prevent accidental deletions. hit the 👍 and your team will be deleted.
 
- m;import
- imports an onomancer collection as a new team. you can use the new onomancer simsim setting to ensure compatibility. similarly to saveteam, you'll get a team embed with a prompt to confirm, hit the 👍 and your team will be saved!
 
editing (all of these commands require ownership of the team used):
- m;addplayer batter/pitcher [team name] [player name]
- adds a new player to the end of your team, either in the lineup or the rotation depending on which version you use. use addplayer batter or addplayer pitcher at the top of a list with each of these in a new line after: -the name of the team you want to add the player to. -the name of the player you want to add to the team.
 
- m;moveplayer [team name] [player name] [new lineup/rotation position number]
- changes the position of a player within your lineup or rotation. if you want to instead move a player from your rotation to your lineup or vice versa, use m;swapsection instead. use this command at the top of a list with each of these in a new line after:
- the name of the team you want to move the player on.
- the name of the player you want to move.
- the position you want to move them too, indexed with 1 being the first position of the lineup or rotation. all players below the specified position in the lineup or rotation will be pushed down.
 
 
- changes the position of a player within your lineup or rotation. if you want to instead move a player from your rotation to your lineup or vice versa, use m;swapsection instead. use this command at the top of a list with each of these in a new line after:
- m;swapsection [team name] [player name]
- swaps a player from your lineup to the end of your rotation or your rotation to the end of your lineup. use this command at the top of a list followed by each of these in a new line after:
- the name of the team you want to swap the player on.
- the name of the player you want to swap.
 
 
- swaps a player from your lineup to the end of your rotation or your rotation to the end of your lineup. use this command at the top of a list followed by each of these in a new line after:
- m;removeplayer [team name] [player name]
- removes a player from your lineup or rotation. if there are multiple copies of the same player on a team this will only delete the first one. use this command at the top of a list with each of these in a new line after:
- the name of the team you want to remove the player from.
- the name of the player you want to remove.
 
 
- removes a player from your lineup or rotation. if there are multiple copies of the same player on a team this will only delete the first one. use this command at the top of a list with each of these in a new line after:
viewing and searching:
- m;showteam [name]
- shows the lineup, rotation, and slogan of any saved team in a discord embed with primary stat star ratings for all of the players. this command has fuzzy search so you don't need to type the full name of the team as long as you give enough to identify the team you're looking for.
 
- m;searchteams [searchterm]
- shows a paginated list of all teams whose names contain the given search term.
 
- m;showallteams
- shows a paginated list of all teams available for games which can be scrolled through.
 
player commands:
- m;showplayer [name]
- displays any name's stars, there's a limit of 70 characters. that should be plenty. note: if you want to lookup a lot of different players you can do it on onomancer instead of spamming this command a bunch and clogging up discord: https://onomancer.sibr.dev/reflect
 
- m;idolize [name]
- records any name as your idol, mostly for fun.
 
- m;showidol
- displays your idol's name and stars.
 
game commands:
- m;startgame --day # or -d #
- starts a game with premade teams made using saveteam. provides a link to the website where you can watch the game.
- the --day/-d is optional, if used it'll force the game to use the #th spot in each team's rotations. if this number is larger than the number of pitchers in one or both of the teams' rotations it'll wrap around. if it is not used pitchers will be chosen randomly from the teams' rotations.
- use this command at the top of a list with each of these in a new line after:
- the away team's name.
- the home team's name.
- optionally, the number of innings, which must be greater than 2 and less than 31. if not included it will default to 9.
 
- this command has fuzzy search so you don't need to type the full name of the team as long as you give enough to identify the team you're looking for.
 
- m;randomgame
- starts a 9-inning game between 2 entirely random teams. embrace chaos!
 
- m;starttournament --rounddelay #
- starts a randomly seeded tournament with up to 64 provided teams, automatically adding byes as nescesary. all rounds are best of 5 until the finals which is best of 7. all series have a 5 minute break between games.
- the --rounddelay is optional, if used, # must be between 1 and 120 and it'll set the delay between rounds to be # minutes. if not included it will default to 10.
- use this command at the top of a list with each of these in a new line after:
- the name of the tournament.
- the name of each participating team on its own line.
 
 
other commands:
- m;help [command]
- shows instructions for a given command. if no command is provided, it will instead provide a list of all of the commands that instructions can be provided for.
 
- m;credit
- shows artist credit for matteo's avatar.
 
- m;roman [number]
- converts any natural number less than 4,000,000 into roman numerals, this one is just for fun.
 
patreon!
these folks are helping me a ton via patreon, and i cannot possibly thank them enough:
- Ale Humano
- Chris Denmark
- Astrid Bek
- Kameleon
Description
				
					Languages
				
				
								
								
									Python
								
								96.4%
							
						
							
								
								
									C
								
								2.5%
							
						
							
								
								
									Cython
								
								0.5%
							
						
							
								
								
									TypeScript
								
								0.3%
							
						
							
								
								
									PowerShell
								
								0.2%
							
						
							
								
								
									Other
								
								0.1%