I am writing a library for our company's product that will take any kind of architectural dimension that our users are already familiar with as input for a function that converts from a string to a double. Here is the list of input types that we would like to be valid.
Input
| Meaning | Output
(Inches represented by a double)
12.5'
| 12 Feet and six inches | 150.0
11"
| 11 Inches | 11.0
3/16"
| 3 sixteenths of an Inch | 0.1875
spaces may or may not be used between the feet and inches and the inches and sixteenths
11' 11"
| 11 Feet and 11 Inches | 143.0
11'11"
| 11 Feet and 11 Inches | 143.0
Dashes may or may not be used between feet and inches or between inches and sixteenths or both
12'-11"
| 12 Feet and 11 Inches | 155.0
12' 11 3/16"
| 12 Feet and 11 Inches and 3 sixteenths | 155.1875
12' 11-1/2"
| 12 Feet and 11 Inches and 8 sixteenths | 155.5
Any number of spaces may be used between the feet and inches and the inches and sixteenths
12' 11 1/2"
| 12 Feet and 11 Inches and 8 sixteenths | 155.5
An alternate simpler format is also available
121103
| 12 Feet and 11 Inches and 3 sixteenths | 155.1875
Negatives are also possible in every format
-121103
| 12 Feet and 11 Inches and 3 sixteenths | -155.1875
-11'11"
| 11 Feet and 11 Inches | -143.0
We are currently using an extremely complicated set of branching logic to try and determine what format the input is trying to emulate... And it doesn't work in all cases.
Is there some possible combination of LINQ and Regular Expressions and witchcraft that we can use to determine how to parse the string?
Also note that we really want to avoid giving a simple combobox on the form to select the input format type from.