/** * <summary> * Retrieves a servo for a given identifier. * <para> * The identifier can be specified using several formats: * </para> * <para> * </para> * <para> * - FunctionLogicalName * </para> * <para> * - ModuleSerialNumber.FunctionIdentifier * </para> * <para> * - ModuleSerialNumber.FunctionLogicalName * </para> * <para> * - ModuleLogicalName.FunctionIdentifier * </para> * <para> * - ModuleLogicalName.FunctionLogicalName * </para> * <para> * </para> * <para> * This function does not require that the servo is online at the time * it is invoked. The returned object is nevertheless valid. * Use the method <c>YServo.isOnline()</c> to test if the servo is * indeed online at a given time. In case of ambiguity when looking for * a servo by logical name, no error is notified: the first instance * found is returned. The search is performed first by hardware name, * then by logical name. * </para> * </summary> * <param name="func"> * a string that uniquely characterizes the servo * </param> * <returns> * a <c>YServo</c> object allowing you to drive the servo. * </returns> */ public static YServo FindServo(string func) { YServo obj; obj = (YServo)YFunction._FindFromCache("Servo", func); if (obj == null) { obj = new YServo(func); YFunction._AddToCache("Servo", func, obj); } return(obj); }
/** * <summary> * Retrieves a servo for a given identifier. * <para> * The identifier can be specified using several formats: * </para> * <para> * </para> * <para> * - FunctionLogicalName * </para> * <para> * - ModuleSerialNumber.FunctionIdentifier * </para> * <para> * - ModuleSerialNumber.FunctionLogicalName * </para> * <para> * - ModuleLogicalName.FunctionIdentifier * </para> * <para> * - ModuleLogicalName.FunctionLogicalName * </para> * <para> * </para> * <para> * This function does not require that the servo is online at the time * it is invoked. The returned object is nevertheless valid. * Use the method <c>YServo.isOnline()</c> to test if the servo is * indeed online at a given time. In case of ambiguity when looking for * a servo by logical name, no error is notified: the first instance * found is returned. The search is performed first by hardware name, * then by logical name. * </para> * </summary> * <param name="func"> * a string that uniquely characterizes the servo * </param> * <returns> * a <c>YServo</c> object allowing you to drive the servo. * </returns> */ public static YServo FindServo(string func) { YServo obj; obj = (YServo)YFunction._FindFromCache("Servo", func); if (obj == null) { obj = new YServo(func); YFunction._AddToCache("Servo", func, obj); } return obj; }