mirror of
https://github.com/aljazceru/signal-cli-rest-api.git
synced 2025-12-20 08:04:28 +01:00
fixed bug in textstyleparser
* bold text wasn't correctly parsed see #382
This commit is contained in:
@@ -27,13 +27,14 @@ func ParseMarkdownMessage(message string) (string, []string) {
|
||||
state := None
|
||||
signalCliFormatStrings := []string{}
|
||||
fullString := ""
|
||||
lastChar := ""
|
||||
|
||||
runes := []rune(message) //turn string to slice
|
||||
|
||||
for i, v := range runes { //iterate through rune
|
||||
if v == '*' {
|
||||
if state == ItalicBegin {
|
||||
if i-1 == textFormatBegin {
|
||||
if lastChar == "*" {
|
||||
state = BoldBegin
|
||||
textFormat = Bold
|
||||
textFormatBegin = i - numOfAsterisks
|
||||
@@ -56,6 +57,7 @@ func ParseMarkdownMessage(message string) (string, []string) {
|
||||
textFormatLength += 1
|
||||
fullString += string(v)
|
||||
}
|
||||
lastChar = string(v)
|
||||
|
||||
if state == ItalicEnd || state == BoldEnd2 {
|
||||
signalCliFormatStrings = append(signalCliFormatStrings, strconv.Itoa(textFormatBegin)+":"+strconv.Itoa(textFormatLength)+":"+textFormat)
|
||||
|
||||
@@ -32,3 +32,9 @@ func TestBoldAndItalicMessage(t *testing.T) {
|
||||
expectMessageEqual(t, message, "This is a bold and italic message")
|
||||
expectFormatStringsEqual(t, signalCliFormatStrings, []string{"10:4:BOLD", "19:6:ITALIC"})
|
||||
}
|
||||
|
||||
func TestTwoBoldFormattedStrings(t *testing.T) {
|
||||
message, signalCliFormatStrings := ParseMarkdownMessage("This is a **bold** and another **bold** message")
|
||||
expectMessageEqual(t, message, "This is a bold and another bold message")
|
||||
expectFormatStringsEqual(t, signalCliFormatStrings, []string{"10:4:BOLD", "27:4:BOLD"})
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user