public static YDaisyChainProxy FindDaisyChain(string name) { // cases to handle: // name ="" no matching unknwn // name ="" unknown exists // name != "" no matching unknown // name !="" unknown exists YDaisyChain func = null; YDaisyChainProxy res = (YDaisyChainProxy)YFunctionProxy.FindSimilarUnknownFunction("YDaisyChainProxy"); if (name == "") { if (res != null) { return(res); } res = (YDaisyChainProxy)YFunctionProxy.FindSimilarKnownFunction("YDaisyChainProxy"); if (res != null) { return(res); } func = YDaisyChain.FirstDaisyChain(); if (func != null) { name = func.get_hardwareId(); if (func.get_userData() != null) { return((YDaisyChainProxy)func.get_userData()); } } } else { func = YDaisyChain.FindDaisyChain(name); if (func.get_userData() != null) { return((YDaisyChainProxy)func.get_userData()); } } if (res == null) { res = new YDaisyChainProxy(func, name); } if (func != null) { res.linkToHardware(name); if (func.isOnline()) { res.arrival(); } } return(res); }
/** * <summary> * Enumerates all functions of type DaisyChain available on the devices * currently reachable by the library, and returns their unique hardware ID. * <para> * Each of these IDs can be provided as argument to the method * <c>YDaisyChain.FindDaisyChain</c> to obtain an object that can control the * corresponding device. * </para> * </summary> * <returns> * an array of strings, each string containing the unique hardwareId * of a device function currently connected. * </returns> */ public static new string[] GetSimilarFunctions() { List <string> res = new List <string>(); YDaisyChain it = YDaisyChain.FirstDaisyChain(); while (it != null) { res.Add(it.get_hardwareId()); it = it.nextDaisyChain(); } return(res.ToArray()); }