Welcome to the Treehouse Community

The Treehouse Community is a meeting place for developers, designers, and programmers of all backgrounds and skill levels to get support. Collaborate here on code errors or bugs that you need feedback on, or asking for an extra set of eyes on your latest project. Join thousands of Treehouse students and alumni in the community today. (Note: Only Treehouse students can comment or ask questions, but non-students are welcome to browse our conversations.)

Looking to learn something new?

Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and a supportive community. Start your free trial today.

Ruby Ruby Loops Ruby Loops The Ruby Loop

Using loop and break to complete a method

The repeat method should take a string, and print it a specified number of times. Use loop and break to complete the method. Be sure to do the following:

After printing the value of string, add 1 to the counter variable.

Use an if statement together with the break keyword to break out of the loop once counter is equal to times.

The error I get is 'unexpected keyword_end'

def repeat(string, times)
  fail "times must be 1 or more" if times < 1
  counter = 0
  loop do
    print string
    counter += 1
    if counter == times

2 Answers

Jennifer Nordell
Jennifer Nordell
Treehouse Teacher

Hi there Richard Wentford! You're super close here, and that's not exactly the error I get when I run your code. This is the error I receive:

Bummer: SyntaxError: f42c40ed-01a5-4c1f-b24b-fd11e17558e3.rb:15: syntax error, unexpected end-of-input, expecting keyword_end

It's expecting another end. There should be an "end" for your function, an "end" for your loop, and an "end" for your if statement making the total number of "end"s three. But you only have two. When I add an extra end to the bottom of your code, it passes with flying colors!

Hope this helps! :sparkles:

It was so simple! I love the people in these forums.