Noob Question: Random Number Ambiguous reference

So I’ve been fiddling with trying to make a random number in JavaScript. Using this code:

import System;
var date = DateTime.Now;
var shadowPercent;

function Update () {
	shadowPercent = Random.Range(0,100);
	Debug.Log("shadowRange= " + shadowPercent);
}

Attaching that to an object works perfectly fine.

If I then try to use this same script in a different JavaScript file it gives me:

BCE0004: Ambiguous reference ‘Random’: System.Random, UnityEngine.Random.

using:

var shadowPercent;
function TimeIntensity(){
	var currentSeconds = date.TimeOfDay.Ticks / 10000000;
	
	if(currentSeconds >= 21600  currentSeconds <= 32400){
		GameLight.intensity = .02;
	}
	if(currentSeconds > 32400  currentSeconds <= 57600){
		GameLight.intensity = .4;
	}
	if(currentSeconds > 54000  currentSeconds <= 68400){
		GameLight.intensity = .2;
	}
}
function Update(){
	TimeIntensity();
	shadowPercent = Random.Range(0,100);
}

Can anyone tell me why it is giving me this error?

EDIT: It seems to be coming from import System. When I remove this it doesn’t give me the ambiguous name anymore.

Does anyone have any solutions on how to use both of them.

As you noted, when you import the System namespace, you are also in effect removing the need to specify the namespace when calling anything contained in the System namespace. I won’t go into the details as that can be confusing.

Since System has a class named Random and UnityEngine has a class named Random, the compiler cannot tell which one you want to use.

Normally without importing System, you would have to call System.Random(…) to gain access. Once you import System you can use its classes without the namespace prefix.

To tell the compiler which one you want to use, prefix it with the namespace name. So if you want to use Unity’s, call UnityEngine.Random(…), if you want .Net’s call System.Random(…).

-Jeremy

5 Likes

Jeremy, your explanation helped me, too. Thanks! :slight_smile:

I have a script where I load and save XML data and import System; is right in of course used. In my case, I bumped into the same error message when trying to use Resources.Load() later on in the code.