Wayback Machinekoobas.hobune.stream
May JUN Jul
Previous capture 13 Next capture
2021 2022 2023
1 capture
13 Jun 22 - 13 Jun 22
sparklines
Close Help
  • Products
  • Solutions
  • Made with Unity
  • Learning
  • Support & Services
  • Community
  • Asset Store
  • Get Unity

UNITY ACCOUNT

You need a Unity Account to shop in the Online and Asset Stores, participate in the Unity Community and manage your license portfolio. Login Create account
  • Blog
  • Forums
  • Answers
  • Evangelists
  • User Groups
  • Beta Program
  • Advisory Panel

Navigation

  • Home
  • Products
  • Solutions
  • Made with Unity
  • Learning
  • Support & Services
  • Community
    • Blog
    • Forums
    • Answers
    • Evangelists
    • User Groups
    • Beta Program
    • Advisory Panel

Unity account

You need a Unity Account to shop in the Online and Asset Stores, participate in the Unity Community and manage your license portfolio. Login Create account

Language

  • Chinese
  • Spanish
  • Japanese
  • Korean
  • Portuguese
  • Ask a question
  • Spaces
    • Default
    • Help Room
    • META
    • Moderators
    • Topics
    • Questions
    • Users
    • Badges
  • Home /
avatar image
0
Question by matthew_gigante · Nov 09, 2020 at 10:05 PM · c#listswitchswitch-casecase

I would like some help refactoring my code, I am working with switch cases concering the delivery of food items in my game

Currently, my following code checks against a list of strings that contain food names, my first case is for a Hot Dog. I would have to paste this same set of switch cases for each food type as the code is currently, and I feel like there is a better solution but cannot place my finger on it. Here is the code I currently have:

     //the food submitted will be checked against the customer's desired food item(s), and their dialogue will be updated if the correct item is delivered
     //note: additional pop up boxes might appear with seperate dialogue if the incorrect food is attempted to be delivered
     switch (FoodName)
     {
         case "Hot Dog":
             switch (customerRequestScript.amountToOrder)
             {
                 case 1:
                     if (customerRequestScript.FoodItem1 != "Hot Dog")
                     {
                         //Customer did not ask for a hot dog
                         Debug.Log("I did not ask for a hot dog! case1");
                         break;
                     }

                     if (customerRequestScript.FoodItem1 == "Hot Dog" && customerRequestScript.FoodItem1Delivered)
                     {
                         //customer already recieved their hotdog as the 1st food item
                         Debug.Log("I already recieved my 1st item hotdog case1");
                         break;
                     }

                     if (customerRequestScript.FoodItem1 == "Hot Dog" && customerRequestScript.FoodItem1Delivered == false)
                     {
                         customerRequestScript.FoodItem1Delivered = true;
                         //succesfully deliver hot dog to customer, now we update this in their request box with update dialog
                         Debug.Log("Thank you for my 1st item, hotdog! case1");
                         customerRequestScript.UpdateDialog();
                     }
                     break;

                 //NOTE TO SELF: most of the stuff below in case 2 needs to also be added in part to case 1, to catch different scenarios etc
                 case 2:
                     if (customerRequestScript.FoodItem1 != "Hot Dog" && customerRequestScript.FoodItem2 != "Hot Dog")
                     {
                         //Customer did not ask for a hot dog
                         Debug.Log("I did not ask for a hot dog! case2");
                         break;
                     }

                     //for when the hotdog is correctly submitted
                     if (customerRequestScript.FoodItem1 == "Hot Dog" && customerRequestScript.FoodItem1Delivered == false)
                     {

                         //break is placed inside the if in case the customer happens to order two hot dogs, we 
                         customerRequestScript.FoodItem1Delivered = true;
                         Debug.Log("Thank you for my 1st item, hotdog! case2");
                         //don't want one hot dog to end up counting as two
                         break;
                     }
                     //at this point, if the code hasn't broken out we check if the hot dog is the second food item
                     if (customerRequestScript.FoodItem2 == "Hot Dog" && customerRequestScript.FoodItem2Delivered == false)
                     {
                         //runs if hotdog is second item and the second item was not yet delivered to the customer
                         customerRequestScript.FoodItem2Delivered = true;
                         Debug.Log("Thank you for my 2nd item, hotdog! case2");
                         break;
                     }

                     //for when the customer already recieved their hotdog when it was the first food item
                     //Important to note that this code will never run before we check if either food item IS the correct item at the moment
                     if (customerRequestScript.FoodItem1 == "Hot Dog" && customerRequestScript.FoodItem1Delivered == true && customerRequestScript.FoodItem2 != "Hot Dog")
                     {
                         //customer already recieved their hotdog as the 1st food item
                         Debug.Log("I already recieved my 1st item hotdog case2");
                         break;
                     }
                     if (customerRequestScript.FoodItem2 == "Hot Dog" && customerRequestScript.FoodItem2Delivered == true && customerRequestScript.FoodItem1 != "Hot Dog")
                     {
                         //customer already recieved their hotdog as the 2nd food item
                         Debug.Log("I already recieved my 2nd item hotdog case2");
                         break;
                     }
                     if (customerRequestScript.FoodItem2 == "Hot Dog" && customerRequestScript.FoodItem2Delivered == true && customerRequestScript.FoodItem1 == "Hot Dog" && customerRequestScript.FoodItem1Delivered == true)
                     {
                         //customer already recieved their hotdog as the 2nd food item
                         Debug.Log("I already recieved my 1st and 2nd item hotdog case2");
                         break;
                     }
                     break;
             }
             break;
Comment
Add comment
10 |3000 characters needed characters left characters exceeded
▼
  • Viewable by all users
  • Viewable by moderators
  • Viewable by moderators and the original poster
  • Advanced visibility
Viewable by all users

1 Reply

· Add your reply
  • Sort: 
avatar image
0
Best Answer

Answer by oqopo · Nov 09, 2020 at 11:56 PM

I'm something of a beginner but I would at least consider using the string as a parameter in the method, if you can. Then you only need one switch case (and that could probs be simplified a fair bit, too).

 public void CheckFood(string foodName)
 {
     switch (customerRequestScript.amountToOrder)
     {
         case 1:
             if (customerRequestScript.FoodItem1 != foodName)
             {
                  Debug.Log($"I did not ask for a {foodName} case1");
                  break;
             }
             else if (customerRequestScript.FoodItem1 == foodName && customerRequestScript.FoodItem1Delivered)
             {
                  Debug.Log($"I already recieved my 1st item {foodName} case1");
                  break;
             }
 
             ...
Comment
Add comment · Show 1 · Share
10 |3000 characters needed characters left characters exceeded
▼
  • Viewable by all users
  • Viewable by moderators
  • Viewable by moderators and the original poster
  • Advanced visibility
Viewable by all users
avatar image matthew_gigante · Nov 12, 2020 at 08:54 PM 0
Share

Hey, my apologies for the late response but this is likely the best solution to lighten up the code that I have found in my searching (at least without heavily refactoring the workflow of my scripts). Pretty simple haha but I guess I overlooked it when initially throwing together the code, thanks!

Your answer

Hint: You can notify a user about this post by typing @username

Up to 2 attachments (including images) can be used with a maximum of 524.3 kB each and 1.0 MB total.

Follow this Question

Answers Answers and Comments

795 People are following this question.

avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image

Related Questions

Why would my switch's case be correct but the output is not? 2 Answers

What is a more efficient way to write this Switch Statement? 3 Answers

How to check if an enum’s case has changed 3 Answers

A node in a childnode? 1 Answer

What is wrong with my c# switch statement? 1 Answer


Enterprise
Social Q&A

Social
Subscribe on YouTube social-youtube Follow on LinkedIn social-linkedin Follow on Twitter social-twitter Follow on Facebook social-facebook Follow on Instagram social-instagram

Footer

  • Purchase
    • Products
    • Subscription
    • Asset Store
    • Unity Gear
    • Resellers
  • Education
    • Students
    • Educators
    • Certification
    • Learn
    • Center of Excellence
  • Download
    • Unity
    • Beta Program
  • Unity Labs
    • Labs
    • Publications
  • Resources
    • Learn platform
    • Community
    • Documentation
    • Unity QA
    • FAQ
    • Services Status
    • Connect
  • About Unity
    • About Us
    • Blog
    • Events
    • Careers
    • Contact
    • Press
    • Partners
    • Affiliates
    • Security
Copyright © 2020 Unity Technologies
  • Legal
  • Privacy Policy
  • Cookies
  • Do Not Sell My Personal Information
  • Cookies Settings
"Unity", Unity logos, and other Unity trademarks are trademarks or registered trademarks of Unity Technologies or its affiliates in the U.S. and elsewhere (more info here). Other names or brands are trademarks of their respective owners.
  • Anonymous
  • Sign in
  • Create
  • Ask a question
  • Spaces
  • Default
  • Help Room
  • META
  • Moderators
  • Explore
  • Topics
  • Questions
  • Users
  • Badges