2010-12-03 27 views
0

Je suis relativement nouveau à Ruby/Rails et ont foiré la structure d'une clause case/when ou peut-être je ne comprends pas les routes ...Erreur dans ma route Ruby code ... ou Rails?

Erreur dans le navigateur simplement: No route matches {:action=>"show", :controller=>"masters"}

mais clairement à la recherche à rake routes je vois:

master GET /masters/:id(.:format) {:action=>"show", :controller=>"masters"} 
breeder GET /breeders/:id(.:format) {:action=>"show", :controller=>"breeders"} 

et les deux (masters & breeders) les contrôleurs ont des méthodes de travail show ...

où est ma gaffe?

#app/controllers/dogs_controller.rb 
class DogsController < ApplicationController 

    def create 
    @parent = parent_object 
    @dog = @parent.dogs.create(params[:dog]) 
    puts parent_path 
    redirect_to parent_path(@parent) 
    end 

    def destroy 
    @parent = parent_object 
    @dog = @parent.dogs.find(params[:id]) 
    @dog.destroy 
    redirect_to parent_path(@parent) 
    end 

    private 

    def parent_object 
    case 
     when params[:master_id] then Master.find(params[:master_id]) && parent_path = master_path 
     when params[:breeder_id] then Breeder.find(params[:breeder_id]) && parent_path = breeder_path 
    end 
    end 
end 

Edit: Ajouté MastersController

#app/controllers/masters_controller.rb 
class MastersController < ApplicationController 
    respond_to :html, :json 

    def index 
     respond_with(@masters = Master.all) 
    end 

    def show 
     respond_with(@master = Master.find(params[:id])) 
    end 

    def new 
     respond_with(@master = Master.new) 
    end 

    def edit 
     respond_with(@master = Master.find(params[:id])) 
    end 

    def create 
     @master = Master.new(params[:master]) 
     flash[:notice] = 'Master was successfully created.' if @master.save 
     respond_with(@master) 
    end 

    def update 
     @master = Master.find(params[:id]) 
     flash[:notice] = 'Master has been updated.' if @master.update_attributes(params[:master]) 
     respond_with(@master) 
    end 

    def destroy 
     @master = Master.find(params[:id]) 
     flash[:notice] = 'Successfully deleted master.' if @master.destroy 
     respond_with(@master) 
    end 
end 
+1

Pouvez-vous montrer le MastersController? –

+0

ok. c'est plutôt cool, mais je l'ai ajouté. – Meltemi

+0

Veuillez expliquer les étapes exactes que vous prenez pour obtenir cette erreur. –

Répondre

1

Ha! Trouvé! Mes redirections étaient fausses ... aurait dû être redirect_to @parent au lieu d'essayer de construire quelques parent_path(@parent) comme j'étais ...

+1

Si vous avez trouvé la solution, n'hésitez pas à marquer votre réponse comme acceptée. Bon travail! –

+0

ya. ferait si je * pourrais *. SO ne me laissera pas accepter ma * propre * réponse pour deux (2) jours ... alors allez-y et faites votre propre réponse et * peut-être * je vais l'accepter si c'est plus intéressant que ce que j'ai eu .. . – Meltemi