minor refactoring; update README example to actual fizz-buzz

This commit is contained in:
2018-03-05 08:19:27 +01:00
parent 3a2468dc83
commit b5b284b8c8
3 changed files with 9 additions and 8 deletions

View File

@@ -16,12 +16,13 @@ func (in *inputs) generateFizzbuzz() []string {
return out
}
for j := 1; j <= in.limit; j++ {
multipleOf1, multipleOf2 := isAMultiple(j, in.int1), isAMultiple(j, in.int2)
switch {
case isAMultiple(j, in.int1) && isAMultiple(j, in.int2):
case multipleOf1 && multipleOf2:
out = append(out, in.string1+in.string2)
case isAMultiple(j, in.int1):
case multipleOf1:
out = append(out, in.string1)
case isAMultiple(j, in.int2):
case multipleOf2:
out = append(out, in.string2)
default:
out = append(out, fmt.Sprint(j))

View File

@@ -32,15 +32,15 @@ func (s *Server) handleFizzBuzz(w http.ResponseWriter, r *http.Request) {
in.string2 = r.URL.Query().Get("string2")
var err error
if in.int1, err = parseInt(r.URL, "int1"); err != nil {
if in.int1, err = parseIntFromURL(r.URL, "int1"); err != nil {
http.Error(w, err.Error(), http.StatusBadRequest)
return
}
if in.int2, err = parseInt(r.URL, "int2"); err != nil {
if in.int2, err = parseIntFromURL(r.URL, "int2"); err != nil {
http.Error(w, err.Error(), http.StatusBadRequest)
return
}
if in.limit, err = parseInt(r.URL, "limit"); err != nil {
if in.limit, err = parseIntFromURL(r.URL, "limit"); err != nil {
http.Error(w, err.Error(), http.StatusBadRequest)
return
}
@@ -51,7 +51,7 @@ func (s *Server) handleFizzBuzz(w http.ResponseWriter, r *http.Request) {
}
}
func parseInt(url *url.URL, paramName string) (int, error) {
func parseIntFromURL(url *url.URL, paramName string) (int, error) {
if param := url.Query().Get(paramName); param != "" {
intParam, err := strconv.Atoi(param)
if err != nil {