mirror of
https://github.com/house-of-vanity/desubot.git
synced 2025-10-24 18:29:08 +00:00
Update /code feature.
This commit is contained in:
@@ -30,7 +30,8 @@ subprocess = "0.2.6"
|
|||||||
serde_json = "1.0"
|
serde_json = "1.0"
|
||||||
markov = "1.1.0"
|
markov = "1.1.0"
|
||||||
rand = "0.7.3"
|
rand = "0.7.3"
|
||||||
mystem = "0.2.1"
|
mystem = "^0.2"
|
||||||
|
#mystem = { path = "../mystem-rs" }
|
||||||
async-trait = "0.1.42"
|
async-trait = "0.1.42"
|
||||||
sqlparser = "0.7.0"
|
sqlparser = "0.7.0"
|
||||||
|
|
||||||
|
@@ -17,11 +17,11 @@ use sqlparser::ast::Statement;
|
|||||||
use sqlparser::dialect::GenericDialect;
|
use sqlparser::dialect::GenericDialect;
|
||||||
use sqlparser::parser::Parser;
|
use sqlparser::parser::Parser;
|
||||||
use syntect::easy::HighlightLines;
|
use syntect::easy::HighlightLines;
|
||||||
|
use syntect::highlighting::Theme;
|
||||||
use syntect::parsing::SyntaxReference;
|
use syntect::parsing::SyntaxReference;
|
||||||
use syntect::util::LinesWithEndings;
|
use syntect::util::LinesWithEndings;
|
||||||
use telegram_bot::prelude::*;
|
use telegram_bot::prelude::*;
|
||||||
use telegram_bot::{Api, Message, ParseMode};
|
use telegram_bot::{Api, Message, ParseMode};
|
||||||
use syntect::highlighting::Theme;
|
|
||||||
|
|
||||||
pub struct Here {
|
pub struct Here {
|
||||||
pub data: String,
|
pub data: String,
|
||||||
@@ -551,7 +551,12 @@ impl Execute for Code {
|
|||||||
unimplemented!()
|
unimplemented!()
|
||||||
}
|
}
|
||||||
async fn exec_with_result(&self, api: &Api, message: &Message) -> Result<String, Error> {
|
async fn exec_with_result(&self, api: &Api, message: &Message) -> Result<String, Error> {
|
||||||
let mut lines: Vec<String> = self.data.trim().split("\n").map(|s| s.to_string()).collect();
|
let mut lines: Vec<String> = self
|
||||||
|
.data
|
||||||
|
.trim()
|
||||||
|
.split("\n")
|
||||||
|
.map(|s| s.to_string())
|
||||||
|
.collect();
|
||||||
if lines.len() >= 81 {
|
if lines.len() >= 81 {
|
||||||
return Err(CodeHighlightningError);
|
return Err(CodeHighlightningError);
|
||||||
}
|
}
|
||||||
@@ -593,7 +598,6 @@ impl Execute for Code {
|
|||||||
.map(|s| s.unwrap())
|
.map(|s| s.unwrap())
|
||||||
.collect();
|
.collect();
|
||||||
|
|
||||||
|
|
||||||
let theme = if theme.len() != 1 {
|
let theme = if theme.len() != 1 {
|
||||||
ts.themes.get("Dracula").unwrap()
|
ts.themes.get("Dracula").unwrap()
|
||||||
} else {
|
} else {
|
||||||
@@ -606,6 +610,7 @@ impl Execute for Code {
|
|||||||
.collect::<Vec<_>>();
|
.collect::<Vec<_>>();
|
||||||
let formatter = silicon::formatter::ImageFormatterBuilder::<String>::new()
|
let formatter = silicon::formatter::ImageFormatterBuilder::<String>::new()
|
||||||
.window_controls(false)
|
.window_controls(false)
|
||||||
|
.line_offset(1)
|
||||||
.round_corner(false);
|
.round_corner(false);
|
||||||
let mut formatter = formatter.build().unwrap();
|
let mut formatter = formatter.build().unwrap();
|
||||||
let image = formatter.format(&highlight, &theme);
|
let image = formatter.format(&highlight, &theme);
|
||||||
|
@@ -3,6 +3,8 @@ use crate::utils;
|
|||||||
use rusqlite::{named_params, params, Connection, Error, Result};
|
use rusqlite::{named_params, params, Connection, Error, Result};
|
||||||
use std::time::SystemTime;
|
use std::time::SystemTime;
|
||||||
use telegram_bot::*;
|
use telegram_bot::*;
|
||||||
|
use std::time::Duration;
|
||||||
|
use std::thread;
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub struct Conf {
|
pub struct Conf {
|
||||||
|
@@ -4,8 +4,10 @@ use crate::db;
|
|||||||
use crate::errors;
|
use crate::errors;
|
||||||
use crate::utils;
|
use crate::utils;
|
||||||
use mystem::MyStem;
|
use mystem::MyStem;
|
||||||
|
use std::time::Duration;
|
||||||
use telegram_bot::*;
|
use telegram_bot::*;
|
||||||
|
use tokio::sync::oneshot;
|
||||||
|
use tokio::time::timeout;
|
||||||
|
|
||||||
include!("../assets/help_text.rs");
|
include!("../assets/help_text.rs");
|
||||||
|
|
||||||
@@ -25,13 +27,12 @@ pub async fn handler(
|
|||||||
title,
|
title,
|
||||||
&message.from.id,
|
&message.from.id,
|
||||||
&message.from.first_name,
|
&message.from.first_name,
|
||||||
{if data.len() <= 200 {data} else {&data[..200]}}.replace("\n", " ")
|
data.replace("\n", " ")
|
||||||
);
|
);
|
||||||
|
|
||||||
let cleaned_message = data.replace(&format!("@{}", me.clone().username.unwrap()), "");
|
let cleaned_message = data.replace(&format!("@{}", me.clone().username.unwrap()), "");
|
||||||
match cleaned_message.as_str() {
|
match cleaned_message.as_str() {
|
||||||
s if s.to_string().starts_with("/code") => {
|
s if s.to_string().starts_with("/code") => {
|
||||||
|
|
||||||
match {
|
match {
|
||||||
Code {
|
Code {
|
||||||
data: s.replace("/code", ""),
|
data: s.replace("/code", ""),
|
||||||
@@ -120,7 +121,9 @@ pub async fn handler(
|
|||||||
.exec_mystem(&api, &message, mystem)
|
.exec_mystem(&api, &message, mystem)
|
||||||
.await?
|
.await?
|
||||||
}
|
}
|
||||||
_ => db::add_sentence(&message, mystem).await?,
|
_ => {
|
||||||
|
db::add_sentence(&message, mystem).await?
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
MessageKind::Photo { ref caption, .. } => {
|
MessageKind::Photo { ref caption, .. } => {
|
||||||
|
Reference in New Issue
Block a user