Welcome to the Treehouse Community
Want to collaborate on code errors? Have bugs you need feedback on? Looking for an extra set of eyes on your latest project? Get support with fellow developers, designers, and programmers of all backgrounds and skill levels here with the Treehouse Community! While you're at it, check out some resources Treehouse students have shared here.
Looking to learn something new?
Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and join thousands of Treehouse students and alumni in the community today.
Start your free trialDavid Curtis
11,301 PointsTodoList method contains? not working
I already found a solution here that worked so I could pass the question; however, I was wondering why my solution (code attached) didn't work.
Thanks
class TodoList
attr_reader :name, :todo_items
def initialize(name)
@name = name
@todo_items = []
end
def add_item(name)
todo_items.push(TodoItem.new(name))
end
def contains?(name)
if @todo_items.find_index(name) =! nil
return true
else
return false
end
end
def find_index(name)
index = 0
found = false
todo_items.each do |item|
found = true if item.name == name
break if found
index += 1
end
if found
return index
else
return nil
end
end
end
1 Answer
Jeff Jacobson-Swartfager
15,419 PointsIt is because of your if condition:
if @todo_items.find_index(name) =! nil
There's a couple things about this line:
- Evaluating against not
nil
is unnecessary here. If.find_index(name)
doesn't return true, theelse
block will run. - Instead of running
.find_index(name)
on@todo_items
, you want to run it onself
. This is because.find_index
already iterates over thetodo_items
array. By calling it on@todo_items
, the.find_index
method looks for atodo_items
array to iterate over within@todo_items
(which doesn't exist).
So, if you change the line to this, it will pass:
if self.find_index(name)
The complete method will be:
def contains?(name)
if self.find_index(name)
return true
else
return false
end
end
David Curtis
11,301 PointsDavid Curtis
11,301 Pointsthank you!
Jeff Jacobson-Swartfager
15,419 PointsJeff Jacobson-Swartfager
15,419 PointsNo problem!