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 El Maxo · Mar 25, 2014 at 09:58 AM · javascripterrorcycle

Type could not be resolved because of a cycle.

Just added the bottom part of the code so I can check to see of a object is destroyed or not. but im getting this error :

Assets/Scripts/Mission.js(61,9): BCE0070: Definition of 'Mission.Check()' depends on 'Mission.Wait1()' whose type could not be resolved because of a cycle. Explicitly declare the type of either one to break the cycle.

Im not great at code so any help on where i went wrong would be good as I am learning.

 #pragma strict
  
 var enemyPrefabs : GameObject[]; // Array of different Enemies that are used.
 var spawnPoints : Transform[];  // Array of spawn points to be used.
 var Name1Choices : String[] = ["Bob", "Mary", "Maxo","Phil","Noobas","Hervard","Dan","Daniel","Johnathan"]; 
 var Name2Choices : String[] = ["Berry", "Richards", "Stephens"];
 var Backstory1Choices : String[] = ["Was"];
 var Backstory2Choices : String[] = ["a"];
 var Backstory3Choices : String[] = ["gent"];
 var Name1;
 var Name2;
 var Backstory1;
 var Backstory2;
 var Backstory3;
 var Nameone : GUIText;
  
 var mission : boolean = false;
 var money : float;
  
 function Start () 
 {
     MissionGen();
 }
  
 function MissionGen () 
 {
     if( !mission )
     {
        var pos :  Transform = spawnPoints[Random.Range(0, spawnPoints.length)];  // Randomize the spawnPoints to instantiate enemy at next.
        var obj : GameObject = enemyPrefabs[Random.Range(0, enemyPrefabs.length)];
        Instantiate(obj, pos.position, pos.rotation); 
  
            Name1 = Name1Choices[ Random.Range( 0, Name1Choices.length ) ]; //Randomly Generated Name
           Name2 = Name2Choices[ Random.Range( 0, Name2Choices.length ) ]; //Randomly Generated Name Part 2
            Backstory1 = Backstory1Choices[ Random.Range( 0, Backstory1Choices.length ) ]; //Randomly Generated BackStory Part 1
            Backstory2 = Backstory2Choices[ Random.Range( 0, Backstory2Choices.length ) ]; //Randomly Generated Backstroy Part 2
           Backstory3 = Backstory3Choices[ Random.Range( 0, Backstory3Choices.length ) ]; //Randomly Generated Backstory Part 3
            mission = true;
            Nameone.text = Name1;
            Wait1();
     }
     else
     {
        Invoke( "MissionGen", 1.0f );
     }
 }
  
 function Check () 
 {
     var BadGuyCheck : GameObject = GameObject.FindGameObjectWithTag( "BadGuy" );
     if ( BadGuyCheck == null )
     {
        mission = false;
        money += Random.Range(1000,10000);
        yield WaitForSeconds (1);
        Invoke( "MissionGen", 1.0f );
     }
     else
     {
         yield WaitForSeconds (1);
         Wait1 ();
     }
 }
 
 function Wait1 ()
 {
     yield WaitForSeconds (1);
     Check ();
 }
Comment
Add comment · Show 4
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 Destran · Mar 25, 2014 at 10:04 AM 0
Share

try doing

  function $$anonymous$$issionGen() : IEnumerator

But I'm fairly certain you could just take out your Wait1 function and replace this Part:

  mission = true;
         Nameone.text = Name1;
         Wait1();

with:

 mission = true;
 Nameone.text = Name1;
 yield WaitForSeconds (1);
 Check();
avatar image El Maxo · Mar 25, 2014 at 10:09 AM 0
Share

Hi thanks i have tried what you have said but I get a similar error, this time with the wait fuction :

Assets/Scripts/$$anonymous$$ission.js(69,9): BCE0070: Definition of '$$anonymous$$ission.Wait1()' depends on '$$anonymous$$ission.Check()' whose type could not be resolved because of a cycle. Explicitly declare the type of either one to break the cycle.

avatar image Destran · Mar 25, 2014 at 10:11 AM 0
Share

do function Wait1() : IEnumerator

avatar image Destran · Mar 25, 2014 at 10:11 AM 0
Share

but As I said, I'd recommend taking your Wait1() function out altogether

1 Reply

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

Answer by Bunny83 · Mar 25, 2014 at 10:40 AM

The way you use coroutines is very strange. You kind of build a recursive chain but since you have a yield in each one it's not a conceptional problem. However a coroutine is not a method, it's an object with it's own class type. The compiler just can't generate the code for both classes since they depend on each other. The actual type is not known until the class has been generated.

I would suggest something like this:

 function MissionGen ()
 {
     while(true)
     {
         var pos : Transform = spawnPoints[Random.Range(0, spawnPoints.length)]; 
         var obj : GameObject = enemyPrefabs[Random.Range(0, enemyPrefabs.length)];
         Instantiate(obj, pos.position, pos.rotation);
         Name1 = Name1Choices[ Random.Range( 0, Name1Choices.length ) ];
         Name2 = Name2Choices[ Random.Range( 0, Name2Choices.length ) ];
         Backstory1 = Backstory1Choices[ Random.Range( 0, Backstory1Choices.length ) ];
         Backstory2 = Backstory2Choices[ Random.Range( 0, Backstory2Choices.length ) ];
         Backstory3 = Backstory3Choices[ Random.Range( 0, Backstory3Choices.length ) ];
         mission = true;
         Nameone.text = Name1;
         yield WaitForSeconds (1);
         while (!Check())
         {
             yield WaitForSeconds (1);
         }
         yield WaitForSeconds (1);
     }
 }
  
 function Check()
 {
     var BadGuyCheck : GameObject = GameObject.FindGameObjectWithTag( "BadGuy" );
     if ( BadGuyCheck == null )
     {
         mission = false;
         money += Random.Range(1000,10000);
         return true;
     }
     return false;
 }


This does exactly the same but don't start new coroutines all the time.

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 El Maxo · Mar 25, 2014 at 10:57 AM 0
Share

Thank you both very helpfull

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

23 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

Related Questions

Exception error 1 Answer

Is not a Member of Collisions 2 Answers

My Javascript is not opening 0 Answers

The name 'Message' does not denote a valid type ('not found'). 1 Answer

When I kill one enemy, the rest disapear, but still shoot 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