A collection of specialized parsers designed for handling composite measurements.
Harshal V. Ladhe, Master of Computer Science.
The composite_unit_measurements
gem offers versatile parsers for efficiently
parsing composite measurements. Leveraging the power of the [unit_measurements
]
(https://github.com/shivam091/unit_measurements) gem,
it enables smooth handling of composite measurements in various units.
- Ruby 3.2.2+ (Download Ruby)
To use composite_unit_measurements
in your Rails application, add the
following line to your Gemfile:
gem "composite_unit_measurements"
And then execute:
$ bundle install
Or otherwise simply install it yourself as:
$ gem install composite_unit_measurements
Each packaged parser includes the .parse
method to parse composite measurements.
You can use an appropriate parser to parse measurements and the final result of
parser is returned in the leftmost unit of your measurement.
The result of each parser method returns an instance of measurement on which we
can perform any functionality offered by unit_measurements
.
This gem internally uses unit_measurements
to perform conversions and arithmetic
operations. You can build supported composite measurements using any
unit alias.
Parsing length measurements:
CompositeUnitMeasurements::Length.parse("5 km 500 m") #=> 5.5 km
Parsing weight measurements:
CompositeUnitMeasurements::Weight.parse("4 kg 500 g") # 4.5 kg
Parsing time measurements:
CompositeUnitMeasurements::Time.parse("3 h 45 min") #=> 3.75 hr
Parsing volume measurements:
CompositeUnitMeasurements::Volume.parse("2 l 250 ml") #=> 2.25 l
Each parser can handle various numeric types, including scientific notation, rational numbers, and complex numbers.
CompositeUnitMeasurements::Length.parse("1+2i ft 12 in") #=> 2.0+2.0i ft
CompositeUnitMeasurements::Length.parse("1.5 ft 12e2 in") #=> 101.5 ft
CompositeUnitMeasurements::Length.parse("1 1/2 ft 1+2i in") #=> 1.5833333333333333+0.16666666666666669i ft
CompositeUnitMeasurements::Length.parse("2 ft 1+2i in") #=> 2.0833333333333335+0.16666666666666669i ft
CompositeUnitMeasurements::Length.parse("1e-2 ft 1+2i in") #=> 0.09333333333333334+0.16666666666666669i ft
The composite_unit_measurements
gem supports parsing various composite measurements,
including:
1. CompositeUnitMeasurements::Length
- metre-centimetre (6 m 50 cm)
- kilometre-metre (5 km 500 m)
- foot-inch (5 ft 6 in)
- mile-yard (20 mi 220 yd)
2. CompositeUnitMeasurements::Weight
- kilogramme-gramme (4 kg 500 g)
- pound-ounce (8 lb 12 oz)
- stone-pound (2 st 6 lb)
- tonne-kilogramme (1 t 500 kg)
3. CompositeUnitMeasurements::Time
- hour-minute (3 h 45 min)
- hour-minute-second-microsecond (12:60,3600:360000000)
- minute-second (10 min 90 s)
- week-day (8 wk 3 d)
- month-day (2 mo 60 d)
- second-millisecond (8 s 500 ms)
- year-month (3 yr 4 mo)
4. CompositeUnitMeasurements::Volume
- litre-millilitre (2 l 250 ml)
By default, composite_unit_measurements
includes all packaged parsers automatically
when required in your application. However, you can opt to use specific parsers as
needed:
require "composite_unit_measurements/base"
require "composite_unit_measurements/length"
require "composite_unit_measurements/weight"
Contributions to this project are welcomed! To contribute:
- Fork this repository
- Create a new branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am "Add some feature"
) - Push the changes to your branch (
git push origin my-new-feature
) - Create new Pull Request
Copyright 2023 Harshal V. LADHE, Released under the MIT License.