Skip to content
This repository has been archived by the owner on Nov 4, 2019. It is now read-only.

Commit

Permalink
Чтобы brackets-bot не ругался на грустные смайлы
Browse files Browse the repository at this point in the history
  • Loading branch information
akosourov committed Apr 22, 2017
1 parent 5629c33 commit 45c667f
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 0 deletions.
7 changes: 7 additions & 0 deletions brackets-bot/brackets.go
Expand Up @@ -2,6 +2,7 @@ package main

import (
"errors"
"strings"
)

var openingBrackets = [...]rune{'(', '[', '{', '<', '«'}
Expand All @@ -10,6 +11,8 @@ var closingBrackets = [...]rune{')', ']', '}', '>', '»'}
var inconsistentError = errors.New("Stack is inconsistent")
var emptyError = errors.New("Stack is empty")

var ignoredStrings = [...]string{":(", ":-("}

type bracketsStack []rune

func (a *bracketsStack) pop() (rune, error) {
Expand Down Expand Up @@ -65,6 +68,10 @@ func (a bracketsStack) getResult() []rune {
}

func processString(str string) (string, error) {
for _, x := range ignoredStrings {
str = strings.Replace(str, x, "", -1)
}

runes := []rune(str)
brackets_stack := bracketsStack{}
for _, s := range runes {
Expand Down
3 changes: 3 additions & 0 deletions brackets-bot/brackets_test.go
Expand Up @@ -11,6 +11,9 @@ func TestBracketsGood(t *testing.T) {
{"((()", "))"},
{"(([", "]))"},
{"()()()([{", "}])"},
{":(", ""},
{":-(", ""},
{"(:(()", ")"},
}
for _, c := range cases {
result, err := processString(c.in)
Expand Down

0 comments on commit 45c667f

Please sign in to comment.