Browse Source

new funcs to render unicode emojis and resolve emoji aliases

pull/34/head
David Haukeness 5 years ago
parent
commit
bd02981b52
No known key found for this signature in database
GPG Key ID: A7F1091956853EF9
  1. 31
      emojiMap.go

31
emojiMap.go

@ -1,7 +1,10 @@
package main package main
import ( import (
"fmt"
"regexp"
"strconv" "strconv"
"strings"
) )
var UNICODE_EMOJI_SUPPORT bool = false var UNICODE_EMOJI_SUPPORT bool = false
@ -13,6 +16,34 @@ type emojiData struct {
Alias []string Alias []string
} }
func emojiUnicodeConvert(s string) string {
pStr := strings.Fields(s)
reeMatch := regexp.MustCompile(`:\w+:`)
for i, word := range pStr {
if matched := reeMatch.MatchString(word); matched {
// renders a unicode emoji instead of the name
if temp, ok := emojiMap[word]; ok {
pStr[i] = renderUnicodeEmoji(temp)
}
}
}
return strings.Join(pStr, " ")
}
func resolveRootEmojis(s string) string {
pStr := strings.Fields(s)
reMatch := regexp.MustCompile(`:\w+:`)
for i, word := range pStr {
if matched := reMatch.MatchString(word); matched {
// resolves the real emoji in case they typed an alias
if temp, ok := emojiMap[word]; ok {
pStr[i] = temp.Name
}
}
}
return strings.Join(pStr, " ")
}
func renderUnicodeEmoji(data emojiData) (string, error) { func renderUnicodeEmoji(data emojiData) (string, error) {
emj, err := strconv.ParseInt(data.Unicode, 16, 32) emj, err := strconv.ParseInt(data.Unicode, 16, 32)
if err != nil { if err != nil {

Loading…
Cancel
Save