/// <summary> /// Converts the string representation of a bar/beat time span to its <see cref="BarBeatTimeSpan"/> /// equivalent. /// </summary> /// <param name="input">A string containing a time span to convert.</param> /// <returns>A <see cref="BarBeatTimeSpan"/> equivalent to the time span contained in /// <paramref name="input"/>.</returns> public static BarBeatTimeSpan Parse(string input) { BarBeatTimeSpan timeSpan; var parsingResult = BarBeatTimeSpanParser.TryParse(input, out timeSpan); if (parsingResult.Status == ParsingStatus.Parsed) { return(timeSpan); } throw parsingResult.Exception; }
/// <summary> /// Converts the string representation of a bar/beat time span to its <see cref="BarBeatTimeSpan"/> /// equivalent. A return value indicates whether the conversion succeeded. /// </summary> /// <param name="input">A string containing a time span to convert.</param> /// <param name="timeSpan">When this method returns, contains the <see cref="BarBeatTimeSpan"/> /// equivalent of the time span contained in <paramref name="input"/>, if the conversion succeeded, or /// null if the conversion failed. The conversion fails if the <paramref name="input"/> is null or /// <see cref="String.Empty"/>, is not of the correct format. This parameter is passed uninitialized; /// any value originally supplied in result will be overwritten.</param> /// <returns>true if <paramref name="input"/> was converted successfully; otherwise, false.</returns> public static bool TryParse(string input, out BarBeatTimeSpan timeSpan) { return(BarBeatTimeSpanParser.TryParse(input, out timeSpan).Status == ParsingStatus.Parsed); }