README.markdown in blobject-0.3.7 vs README.markdown in blobject-0.4.0
- old
+ new
@@ -1,12 +1,52 @@
-data:image/s3,"s3://crabby-images/2cfbc/2cfbce95ac1ca257a249107ccd05de88b9146368" alt=""
-data:image/s3,"s3://crabby-images/c9d54/c9d543ccc121b4a3be452cdb698efbeca718a161" alt=""
+data:image/s3,"s3://crabby-images/2cfbc/2cfbce95ac1ca257a249107ccd05de88b9146368" alt=""
-Getting started: `http://sjltaylor.com/blobject'
+Rdocs: [http://sjltaylor.github.com/blobject](http://sjltaylor.github.com/blobject)
## About
+Consider the following json sample...
+
+ {
+ "device_id": 63354,
+ "channel_no": 6,
+ "interval_ms": 15000,
+ "readings": [
+ {
+ "value": 14232,
+ "time": 1339880802
+ },
+ {
+ "value": 14232,
+ "time": 1339880817
+ }
+ ],
+ "calibration": {
+ "staff": {
+ "name": {
+ "first": "Carl",
+ "middle_initial": "I",
+ "second": "Brator"
+ }
+ },
+ "last_calibration": "2010-06-16T22:06:42+01:00"
+ }
+ }
+
+Blobject let's you do this (complete code listing, no predefined data structures):
+
+
+ data = Blobject.from_json HTTParty.get('https://raw.github.com/sjltaylor/blobject/master/spec/sample_data/sample3.json')
+
+ full_name = "#{data.calibration.staff.name.first}#{data.calibration.staff.name.middle_initial}#{data.calibration.staff.name.second}".capitalize
+ => "Calibrator"
+
+ last_reading = data.readings.last.value if data.readings?
+ => 14232
+
+
+Blobject is convenient to creating json payloads too.
Blobjects are *freeform* which means you can do this...
data = Blobject.new
data.name = "Johnny"
@@ -66,11 +106,28 @@
You can work with JSON data using `Blobject.from_json` and `Blobject#to_json`, in Rails, you can use `Blobject#as_json` as you would with a hash.
You can work with YAML data using `Blobject.from_yaml` and `Blobject#to_yaml`.
+## Try it out...
+1. Install the gem (ruby 1.9.2+ required): `sh <(curl https://raw.github.com/sjltaylor/blobject/master/try_blobject.sh)`
+2. Load data from an api...
+ payload = Blobject.from_json HTTParty.get('https://raw.github.com/sjltaylor/blobject/master/spec/sample_data/sample3.json')
+3. Inspect it
+ payload.calibration.staff.name
+ => {:first=>"Carl", :middle_initial=>"I", :second=>"Brator"}
+4. Test for optional data members
+ payload.channel_no?
+ => true
+ payload.something_that_is_not_there?
+ => false
+5. Draw your own payload
+ mine = Blobject.new my: {data: 123}
+ mine.to_json
+ => "{\"my\":{\"data\":123}}"
+
## Used for Configuration
Consider a configuration object which contains credentials for a third-party api.
third_party_api:
@@ -102,11 +159,11 @@
"#{protocol}://#{hostname}#{path}"
end
end
-## Serializing & Deserializing
+## Serialization
Blobjects can be used to easily build complex payloads.
person = Blobject.new
@@ -207,5 +264,8 @@
THE SOFTWARE IS PROVIDED ‘AS IS’, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
Copyright (c) 2012 Sam Taylor. See LICENSE.txt for
further details.
+
+data:image/s3,"s3://crabby-images/c9d54/c9d543ccc121b4a3be452cdb698efbeca718a161" alt=""
+