openehr 1.1.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.document +5 -0
- data/.rspec +2 -0
- data/.travis.yml +3 -0
- data/Gemfile +23 -0
- data/Guardfile +12 -0
- data/History.txt +36 -0
- data/PostInstall.txt +9 -0
- data/README.rdoc +82 -0
- data/Rakefile +44 -0
- data/VERSION +1 -0
- data/doc/openehr_terminology.xml +2700 -0
- data/lib/openehr.rb +11 -0
- data/lib/openehr/am.rb +8 -0
- data/lib/openehr/am/archetype.rb +133 -0
- data/lib/openehr/am/archetype/assertion.rb +190 -0
- data/lib/openehr/am/archetype/constraint_model.rb +328 -0
- data/lib/openehr/am/archetype/constraint_model/primitive.rb +327 -0
- data/lib/openehr/am/archetype/ontology.rb +126 -0
- data/lib/openehr/am/openehr_profile.rb +9 -0
- data/lib/openehr/am/openehr_profile/data_types.rb +13 -0
- data/lib/openehr/am/openehr_profile/data_types/basic.rb +114 -0
- data/lib/openehr/am/openehr_profile/data_types/quantity.rb +67 -0
- data/lib/openehr/am/openehr_profile/data_types/text.rb +22 -0
- data/lib/openehr/assumed_library_types.rb +691 -0
- data/lib/openehr/parser.rb +23 -0
- data/lib/openehr/parser/adl.rb +57 -0
- data/lib/openehr/parser/adl_grammar.tt +245 -0
- data/lib/openehr/parser/adl_parser.rb +52 -0
- data/lib/openehr/parser/cadl_grammar.tt +1527 -0
- data/lib/openehr/parser/cadl_node.rb +44 -0
- data/lib/openehr/parser/dadl.rb +13 -0
- data/lib/openehr/parser/dadl_grammar.tt +358 -0
- data/lib/openehr/parser/exception.rb +68 -0
- data/lib/openehr/parser/shared_token_grammar.tt +1229 -0
- data/lib/openehr/parser/validator.rb +19 -0
- data/lib/openehr/parser/xml_perser.rb +13 -0
- data/lib/openehr/rm.rb +15 -0
- data/lib/openehr/rm/common.rb +14 -0
- data/lib/openehr/rm/common/archetyped.rb +182 -0
- data/lib/openehr/rm/common/change_control.rb +332 -0
- data/lib/openehr/rm/common/directory.rb +29 -0
- data/lib/openehr/rm/common/generic.rb +216 -0
- data/lib/openehr/rm/common/resource.rb +154 -0
- data/lib/openehr/rm/composition.rb +103 -0
- data/lib/openehr/rm/composition/content.rb +22 -0
- data/lib/openehr/rm/composition/content/entry.rb +253 -0
- data/lib/openehr/rm/composition/content/navigation.rb +31 -0
- data/lib/openehr/rm/data_structures.rb +25 -0
- data/lib/openehr/rm/data_structures/history.rb +117 -0
- data/lib/openehr/rm/data_structures/item_structure.rb +218 -0
- data/lib/openehr/rm/data_structures/item_structure/representation.rb +63 -0
- data/lib/openehr/rm/data_types.rb +14 -0
- data/lib/openehr/rm/data_types/basic.rb +108 -0
- data/lib/openehr/rm/data_types/charset.lst +818 -0
- data/lib/openehr/rm/data_types/charset_extract.rb +24 -0
- data/lib/openehr/rm/data_types/encapsulated.rb +98 -0
- data/lib/openehr/rm/data_types/quantity.rb +402 -0
- data/lib/openehr/rm/data_types/quantity/date_time.rb +256 -0
- data/lib/openehr/rm/data_types/text.rb +169 -0
- data/lib/openehr/rm/data_types/time_specification.rb +75 -0
- data/lib/openehr/rm/data_types/uri.rb +83 -0
- data/lib/openehr/rm/demographic.rb +269 -0
- data/lib/openehr/rm/ehr.rb +162 -0
- data/lib/openehr/rm/integration.rb +27 -0
- data/lib/openehr/rm/security.rb +12 -0
- data/lib/openehr/rm/support.rb +14 -0
- data/lib/openehr/rm/support/definition.rb +15 -0
- data/lib/openehr/rm/support/identification.rb +412 -0
- data/lib/openehr/rm/support/measurement.rb +17 -0
- data/lib/openehr/rm/support/terminology.rb +135 -0
- data/lib/openehr/serializer.rb +272 -0
- data/lib/openehr/terminology.rb +7 -0
- data/lib/openehr/terminology/open_ehr_terminology.rb +41 -0
- data/lib/openehr/writer.rb +12 -0
- data/openehr.gemspec +472 -0
- data/spec/lib/openehr/am/archetype/archetype_spec.rb +103 -0
- data/spec/lib/openehr/am/archetype/assertion/assertion_spec.rb +60 -0
- data/spec/lib/openehr/am/archetype/assertion/assertion_variable_spec.rb +30 -0
- data/spec/lib/openehr/am/archetype/assertion/expr_binary_operator.rb +40 -0
- data/spec/lib/openehr/am/archetype/assertion/expr_item_spec.rb +28 -0
- data/spec/lib/openehr/am/archetype/assertion/expr_leaf_spec.rb +34 -0
- data/spec/lib/openehr/am/archetype/assertion/expr_operator_spec.rb +25 -0
- data/spec/lib/openehr/am/archetype/assertion/expr_unary_operator_spec.rb +26 -0
- data/spec/lib/openehr/am/archetype/assertion/operator_kind_spec.rb +114 -0
- data/spec/lib/openehr/am/archetype/constraint_model/archetype_constraint_spec.rb +56 -0
- data/spec/lib/openehr/am/archetype/constraint_model/archetype_internal_ref_spec.rb +36 -0
- data/spec/lib/openehr/am/archetype/constraint_model/archetype_slot_spec.rb +61 -0
- data/spec/lib/openehr/am/archetype/constraint_model/c_attribute_spec.rb +59 -0
- data/spec/lib/openehr/am/archetype/constraint_model/c_complex_object_spec.rb +39 -0
- data/spec/lib/openehr/am/archetype/constraint_model/c_defined_object_spec.rb +53 -0
- data/spec/lib/openehr/am/archetype/constraint_model/c_domain_type_spec.rb +25 -0
- data/spec/lib/openehr/am/archetype/constraint_model/c_multiple_attribute_spec.rb +23 -0
- data/spec/lib/openehr/am/archetype/constraint_model/c_object_spec.rb +61 -0
- data/spec/lib/openehr/am/archetype/constraint_model/c_primitive_object_spec.rb +33 -0
- data/spec/lib/openehr/am/archetype/constraint_model/c_reference_object_spec.rb +17 -0
- data/spec/lib/openehr/am/archetype/constraint_model/c_single_attribute_spec.rb +22 -0
- data/spec/lib/openehr/am/archetype/constraint_model/cardinality_spec.rb +68 -0
- data/spec/lib/openehr/am/archetype/constraint_model/constraint_ref_spec.rb +29 -0
- data/spec/lib/openehr/am/archetype/constraint_model/primitive/c_boolean_spec.rb +57 -0
- data/spec/lib/openehr/am/archetype/constraint_model/primitive/c_date_spec.rb +52 -0
- data/spec/lib/openehr/am/archetype/constraint_model/primitive/c_date_time_spec.rb +136 -0
- data/spec/lib/openehr/am/archetype/constraint_model/primitive/c_duration_spec.rb +41 -0
- data/spec/lib/openehr/am/archetype/constraint_model/primitive/c_integer_spec.rb +67 -0
- data/spec/lib/openehr/am/archetype/constraint_model/primitive/c_primitive_spec.rb +41 -0
- data/spec/lib/openehr/am/archetype/constraint_model/primitive/c_real_spec.rb +19 -0
- data/spec/lib/openehr/am/archetype/constraint_model/primitive/c_string_spec.rb +73 -0
- data/spec/lib/openehr/am/archetype/constraint_model/primitive/c_time_spec.rb +104 -0
- data/spec/lib/openehr/am/archetype/ontology/archetype_ontology_spec.rb +97 -0
- data/spec/lib/openehr/am/archetype/ontology/archetype_term_spec.rb +43 -0
- data/spec/lib/openehr/am/archetype/validity_kind_spec.rb +42 -0
- data/spec/lib/openehr/am/openehr_profile/data_types/basic/c_dv_state_spec.rb +34 -0
- data/spec/lib/openehr/am/openehr_profile/data_types/basic/non_terminal_state_spec.rb +36 -0
- data/spec/lib/openehr/am/openehr_profile/data_types/basic/state_machine_spec.rb +34 -0
- data/spec/lib/openehr/am/openehr_profile/data_types/basic/state_spec.rb +26 -0
- data/spec/lib/openehr/am/openehr_profile/data_types/basic/terminal_state_spec.rb +18 -0
- data/spec/lib/openehr/am/openehr_profile/data_types/basic/transition_spec.rb +62 -0
- data/spec/lib/openehr/am/openehr_profile/data_types/quantity/c_dv_ordinal_spec.rb +41 -0
- data/spec/lib/openehr/am/openehr_profile/data_types/quantity/c_dv_quantity_spec.rb +50 -0
- data/spec/lib/openehr/am/openehr_profile/data_types/quantity/c_quantity_item_spec.rb +46 -0
- data/spec/lib/openehr/am/openehr_profile/data_types/text/c_code_phrase_spec.rb +34 -0
- data/spec/lib/openehr/assumed_library_types/interval_spec.rb +145 -0
- data/spec/lib/openehr/assumed_library_types/iso8601_date_spec.rb +236 -0
- data/spec/lib/openehr/assumed_library_types/iso8601_date_time_spec.rb +47 -0
- data/spec/lib/openehr/assumed_library_types/iso8601_duration_spec.rb +150 -0
- data/spec/lib/openehr/assumed_library_types/iso8601_time_spec.rb +234 -0
- data/spec/lib/openehr/assumed_library_types/iso8601_timezone_spec.rb +57 -0
- data/spec/lib/openehr/assumed_library_types/time_definitions_spec.rb +136 -0
- data/spec/lib/openehr/assumed_library_types/timezone_spec.rb +42 -0
- data/spec/lib/openehr/parser/adl14/adl-test-ENTRY.assumed_types.v1.adl +88 -0
- data/spec/lib/openehr/parser/adl14/adl-test-ENTRY.basic_types.v1.adl +143 -0
- data/spec/lib/openehr/parser/adl14/adl-test-ENTRY.basic_types_fail.v1.adl +50 -0
- data/spec/lib/openehr/parser/adl14/adl-test-ENTRY.most_minimal.v1.adl +27 -0
- data/spec/lib/openehr/parser/adl14/adl-test-ENTRY.structure_test1.v1.adl +46 -0
- data/spec/lib/openehr/parser/adl14/adl-test-SOME_TYPE.generic_type_basic.draft.adl +56 -0
- data/spec/lib/openehr/parser/adl14/adl-test-SOME_TYPE.generic_type_use_node.draft.adl +63 -0
- data/spec/lib/openehr/parser/adl14/adl-test-car.paths.test.adl +80 -0
- data/spec/lib/openehr/parser/adl14/adl-test-car.use_node.test.adl +87 -0
- data/spec/lib/openehr/parser/adl14/adl-test-composition.dv_coded_text.test.adl +29 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.archetype_bindings.test.adl +47 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.archetype_desc_missing_purpose.test.adl +45 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.archetype_description.test.adl +61 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.archetype_description2.test.adl +45 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.archetype_identification.test.adl +26 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.archetype_internal_ref.test.adl +36 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.archetype_internal_ref2.test.adl +36 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.archetype_language.test.adl +47 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.archetype_language_no_accreditation.test.adl +38 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.archetype_language_order_of_translation_details.test.adl +40 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.archetype_ontology.test.adl +25 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.archetype_slot.test.adl +40 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.archetype_slot.test2.adl +37 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.archetype_uncommonkeys.test.adl +29 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.basic_types.test.adl +272 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.c_code_phrase.test.adl +77 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.c_dv_ordinal.test.adl +66 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.c_dv_quantity_empty.test.adl +46 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.c_dv_quantity_full.test.adl +64 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.c_dv_quantity_full2.test.adl +64 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.c_dv_quantity_full3.test.adl +64 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.c_dv_quantity_item_units_only.test.adl +55 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.c_dv_quantity_list.test.adl +58 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.c_dv_quantity_property.test.adl +47 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.c_dv_quantity_reversed.test.adl +59 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.constraint_binding.test.adl +37 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.constraint_ref.test.adl +43 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.datetime.test.adl +183 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.domain_types.test.adl +97 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.durations.test.adl +109 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.empty_other_contributors.test.adl +42 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.missing_language.test.adl +23 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.mixed_node_types.draft.adl +61 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.most_minimal.test.adl +23 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.multi_language.test.adl +52 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.special_string.test.adl +88 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.structure_test1.test.adl +45 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.structure_test2.test.adl +45 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.term_binding.test.adl +37 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.term_binding2.test.adl +32 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.testtranslations.test.adl +83 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.translations_author_language.test.adl +34 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.translations_language_author.test.adl +34 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.unicode_BOM_support.test.adl +41 -0
- data/spec/lib/openehr/parser/adl14/adl-test-entry.unicode_support.test.adl +41 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-ACTION.imaging.v1.adl +275 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-ACTION.referral.v1.adl +351 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-CLUSTER.auscultation-chest.v1.adl +765 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-CLUSTER.auscultation.v1.adl +48 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-CLUSTER.dimensions-circumference.v1.adl +134 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-CLUSTER.dimensions.v1.adl +241 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-CLUSTER.exam-abdomen.v1.adl +321 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-CLUSTER.exam-chest.v1.adl +379 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-CLUSTER.exam-fetus.v1.adl +577 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-CLUSTER.exam-generic-joint.v1.adl +146 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-CLUSTER.exam-generic-lymphnode.v1.adl +176 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-CLUSTER.exam-generic-mass.v1.adl +221 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-CLUSTER.exam-generic.v1.adl +139 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-CLUSTER.exam-nervous_system.v1.adl +116 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-CLUSTER.exam-uterine_cervix.v1.adl +420 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-CLUSTER.exam-uterus.v1.adl +293 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-COMPOSITION.discharge.v1draft.adl +53 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-COMPOSITION.encounter.v1draft.adl +45 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-EVALUATION.adverse.v1.adl +411 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-EVALUATION.columna_vertebral.v1.adl +85 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-INSTRUCTION.medication.v1.adl +88 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-INSTRUCTION.referral.v1.adl +84 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-ITEM_TREE.Laboratory_request.v1.adl +492 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-ITEM_TREE.follow_up.v1draft.adl +94 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-ITEM_TREE.imaging.v1.adl +127 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-ITEM_TREE.medication-formulation.v1.adl +457 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-ITEM_TREE.medication.v1.adl +869 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-ITEM_TREE.referral.v1.adl +494 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-OBSERVATION.apgar.v1.adl +545 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-OBSERVATION.blood_pressure.v1.adl +673 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-OBSERVATION.body_mass_index.v1.adl +166 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-OBSERVATION.lab_test.v1.adl +376 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-OBSERVATION.testassumedvalue.v1.adl +99 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-SECTION.findings.v1.adl +47 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-SECTION.reason_for_encounter.v1.adl +51 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-SECTION.summary.v1.adl +52 -0
- data/spec/lib/openehr/parser/adl14/openEHR-EHR-SECTION.vital_signs.v1.adl +54 -0
- data/spec/lib/openehr/parser/adl_archetype_internal_ref2_spec.rb +42 -0
- data/spec/lib/openehr/parser/adl_archetype_internal_ref_spec.rb +125 -0
- data/spec/lib/openehr/parser/adl_archetype_internal_ref_with_generics_spec.rb +258 -0
- data/spec/lib/openehr/parser/adl_archetype_ontology_binding_spec.rb +98 -0
- data/spec/lib/openehr/parser/adl_archetype_ontology_spec.rb +42 -0
- data/spec/lib/openehr/parser/adl_archetype_slot_cluster_spec.rb +101 -0
- data/spec/lib/openehr/parser/adl_archetype_slot_spec.rb +193 -0
- data/spec/lib/openehr/parser/adl_archetype_uncommon_term_keys_spec.rb +25 -0
- data/spec/lib/openehr/parser/adl_description_spec.rb +164 -0
- data/spec/lib/openehr/parser/adl_identification_spec.rb +18 -0
- data/spec/lib/openehr/parser/adl_language_no_accreditation_spec.rb +66 -0
- data/spec/lib/openehr/parser/adl_language_order_spec.rb +68 -0
- data/spec/lib/openehr/parser/adl_language_spec.rb +119 -0
- data/spec/lib/openehr/parser/adl_language_translation_author_language_spec.rb +50 -0
- data/spec/lib/openehr/parser/adl_language_translation_language_author_spec.rb +46 -0
- data/spec/lib/openehr/parser/adl_parser_spec.rb +347 -0
- data/spec/lib/openehr/parser/adl_path_spec.rb +176 -0
- data/spec/lib/openehr/parser/base_spec.rb +19 -0
- data/spec/lib/openehr/parser/basic_generic_type_spec.rb +18 -0
- data/spec/lib/openehr/parser/basic_type_spec.rb +2922 -0
- data/spec/lib/openehr/parser/c_dv_quantity_any_allowed_spec.rb +34 -0
- data/spec/lib/openehr/parser/c_dv_quantity_shared_example_for_lacked_items_spec.rb +36 -0
- data/spec/lib/openehr/parser/c_dv_quantity_shared_example_spec.rb +146 -0
- data/spec/lib/openehr/parser/cdv_ordinal_parse_spec.rb +231 -0
- data/spec/lib/openehr/parser/code_phrase_spec.rb +96 -0
- data/spec/lib/openehr/parser/constraint_binding_spec.rb +26 -0
- data/spec/lib/openehr/parser/constraint_ref_spec.rb +32 -0
- data/spec/lib/openehr/parser/date_time_spec.rb +1953 -0
- data/spec/lib/openehr/parser/duration_spec.rb +475 -0
- data/spec/lib/openehr/parser/dv_coded_text_parse_spec.rb +27 -0
- data/spec/lib/openehr/parser/empty_other_contributors_spec.rb +19 -0
- data/spec/lib/openehr/parser/lab_test_parser_spec.rb +14 -0
- data/spec/lib/openehr/parser/missing_language_spec.rb +20 -0
- data/spec/lib/openehr/parser/missing_purpose_spec.rb +23 -0
- data/spec/lib/openehr/parser/mixed_node_types_spec.rb +16 -0
- data/spec/lib/openehr/parser/most_minimal_adl_spec.rb +19 -0
- data/spec/lib/openehr/parser/multi_language_spec.rb +58 -0
- data/spec/lib/openehr/parser/parser_spec_helper.rb +7 -0
- data/spec/lib/openehr/parser/path_based_terminology_binding_spec.rb +30 -0
- data/spec/lib/openehr/parser/special_string_spec.rb +20 -0
- data/spec/lib/openehr/parser/structure_comment_spec.rb +21 -0
- data/spec/lib/openehr/parser/structure_nested_comments_spec.rb +22 -0
- data/spec/lib/openehr/parser/structure_spec.rb +202 -0
- data/spec/lib/openehr/parser/term_binding_spec.rb +54 -0
- data/spec/lib/openehr/parser/unicode_bom_spec.rb +17 -0
- data/spec/lib/openehr/parser/unicode_support_spec.rb +46 -0
- data/spec/lib/openehr/rm/common/archetyped/archetyped_spec.rb +50 -0
- data/spec/lib/openehr/rm/common/archetyped/feeder_audit_details_spec.rb +60 -0
- data/spec/lib/openehr/rm/common/archetyped/feeder_audit_spec.rb +51 -0
- data/spec/lib/openehr/rm/common/archetyped/link_spec.rb +42 -0
- data/spec/lib/openehr/rm/common/archetyped/locatable_spec.rb +89 -0
- data/spec/lib/openehr/rm/common/archetyped/pathable_spec.rb +42 -0
- data/spec/lib/openehr/rm/common/change_control/contribution_spec.rb +56 -0
- data/spec/lib/openehr/rm/common/change_control/imported_version_spec.rb +62 -0
- data/spec/lib/openehr/rm/common/change_control/original_version_spec.rb +71 -0
- data/spec/lib/openehr/rm/common/change_control/version_spec.rb +91 -0
- data/spec/lib/openehr/rm/common/change_control/versioned_object_spec.rb +284 -0
- data/spec/lib/openehr/rm/common/directory/folder_spec.rb +26 -0
- data/spec/lib/openehr/rm/common/generic/attestation_spec.rb +62 -0
- data/spec/lib/openehr/rm/common/generic/audit_details_spec.rb +51 -0
- data/spec/lib/openehr/rm/common/generic/participation_spec.rb +36 -0
- data/spec/lib/openehr/rm/common/generic/party_identified_spec.rb +64 -0
- data/spec/lib/openehr/rm/common/generic/party_proxy_spec.rb +18 -0
- data/spec/lib/openehr/rm/common/generic/party_related_spec.rb +24 -0
- data/spec/lib/openehr/rm/common/generic/revision_history_item_spec.rb +43 -0
- data/spec/lib/openehr/rm/common/generic/revision_history_spec.rb +45 -0
- data/spec/lib/openehr/rm/common/resource/authored_resource_spec.rb +68 -0
- data/spec/lib/openehr/rm/common/resource/resource_description_item_spec.rb +105 -0
- data/spec/lib/openehr/rm/common/resource/resource_description_spec.rb +74 -0
- data/spec/lib/openehr/rm/common/resource/translation_details_spec.rb +35 -0
- data/spec/lib/openehr/rm/composition/composition_spec.rb +92 -0
- data/spec/lib/openehr/rm/composition/content/content_item_spec.rb +14 -0
- data/spec/lib/openehr/rm/composition/content/entry/action_spec.rb +69 -0
- data/spec/lib/openehr/rm/composition/content/entry/activity_spec.rb +61 -0
- data/spec/lib/openehr/rm/composition/content/entry/admin_entry_spec.rb +38 -0
- data/spec/lib/openehr/rm/composition/content/entry/care_entry_spec.rb +37 -0
- data/spec/lib/openehr/rm/composition/content/entry/entry_spec.rb +98 -0
- data/spec/lib/openehr/rm/composition/content/entry/evaluation_spec.rb +37 -0
- data/spec/lib/openehr/rm/composition/content/entry/instruction_details_spec.rb +51 -0
- data/spec/lib/openehr/rm/composition/content/entry/instruction_spec.rb +62 -0
- data/spec/lib/openehr/rm/composition/content/entry/ism_transition_spec.rb +46 -0
- data/spec/lib/openehr/rm/composition/content/entry/observation_spec.rb +45 -0
- data/spec/lib/openehr/rm/composition/content/navigation/section_spec.rb +32 -0
- data/spec/lib/openehr/rm/composition/event_context_spec.rb +88 -0
- data/spec/lib/openehr/rm/data_structures/data_structure_spec.rb +21 -0
- data/spec/lib/openehr/rm/data_structures/history/event_spec.rb +44 -0
- data/spec/lib/openehr/rm/data_structures/history/history_spec.rb +67 -0
- data/spec/lib/openehr/rm/data_structures/history/interval_event_spec.rb +43 -0
- data/spec/lib/openehr/rm/data_structures/item_structure/item_list_spec.rb +53 -0
- data/spec/lib/openehr/rm/data_structures/item_structure/item_single_spec.rb +29 -0
- data/spec/lib/openehr/rm/data_structures/item_structure/item_table_spec.rb +147 -0
- data/spec/lib/openehr/rm/data_structures/item_structure/item_tree_spec.rb +48 -0
- data/spec/lib/openehr/rm/data_structures/item_structure/representation/cluster_spec.rb +26 -0
- data/spec/lib/openehr/rm/data_structures/item_structure/representation/element_spec.rb +22 -0
- data/spec/lib/openehr/rm/data_types/basic/data_value_spec.rb +17 -0
- data/spec/lib/openehr/rm/data_types/basic/dv_boolean_spec.rb +29 -0
- data/spec/lib/openehr/rm/data_types/basic/dv_identifier_spec.rb +108 -0
- data/spec/lib/openehr/rm/data_types/basic/dv_state_spec.rb +44 -0
- data/spec/lib/openehr/rm/data_types/encapsulated/dv_encapsulated_spec.rb +42 -0
- data/spec/lib/openehr/rm/data_types/encapsulated/dv_multimedia_spec.rb +79 -0
- data/spec/lib/openehr/rm/data_types/encapsulated/dv_parsable_spec.rb +34 -0
- data/spec/lib/openehr/rm/data_types/quantity/date_time/dv_date_spec.rb +64 -0
- data/spec/lib/openehr/rm/data_types/quantity/date_time/dv_date_time_spec.rb +26 -0
- data/spec/lib/openehr/rm/data_types/quantity/date_time/dv_duration_spec.rb +44 -0
- data/spec/lib/openehr/rm/data_types/quantity/date_time/dv_temporal_spec.rb +25 -0
- data/spec/lib/openehr/rm/data_types/quantity/date_time/dv_time_spec.rb +41 -0
- data/spec/lib/openehr/rm/data_types/quantity/dv_absolute_quantity_spec.rb +35 -0
- data/spec/lib/openehr/rm/data_types/quantity/dv_amount_spec.rb +105 -0
- data/spec/lib/openehr/rm/data_types/quantity/dv_count_spec.rb +12 -0
- data/spec/lib/openehr/rm/data_types/quantity/dv_interval_spec.rb +17 -0
- data/spec/lib/openehr/rm/data_types/quantity/dv_ordered_spec.rb +60 -0
- data/spec/lib/openehr/rm/data_types/quantity/dv_ordinal_spec.rb +74 -0
- data/spec/lib/openehr/rm/data_types/quantity/dv_proportion_spec.rb +162 -0
- data/spec/lib/openehr/rm/data_types/quantity/dv_quantified_spec.rb +36 -0
- data/spec/lib/openehr/rm/data_types/quantity/dv_quantity_spec.rb +78 -0
- data/spec/lib/openehr/rm/data_types/quantity/proportion_kind_spec.rb +24 -0
- data/spec/lib/openehr/rm/data_types/quantity/reference_range_spec.rb +43 -0
- data/spec/lib/openehr/rm/data_types/text/code_phrase_spec.rb +23 -0
- data/spec/lib/openehr/rm/data_types/text/dv_paragraph_spec.rb +13 -0
- data/spec/lib/openehr/rm/data_types/text/dv_text_spec.rb +79 -0
- data/spec/lib/openehr/rm/data_types/text/term_mapping_spec.rb +59 -0
- data/spec/lib/openehr/rm/data_types/uri/dv_ehr_uri_spec.rb +21 -0
- data/spec/lib/openehr/rm/data_types/uri/dv_uri_spec.rb +36 -0
- data/spec/lib/openehr/rm/demographic/actor_spec.rb +79 -0
- data/spec/lib/openehr/rm/demographic/address_spec.rb +33 -0
- data/spec/lib/openehr/rm/demographic/capability_spec.rb +37 -0
- data/spec/lib/openehr/rm/demographic/contact_spec.rb +45 -0
- data/spec/lib/openehr/rm/demographic/party_identity_spec.rb +32 -0
- data/spec/lib/openehr/rm/demographic/party_relationship_spec.rb +84 -0
- data/spec/lib/openehr/rm/demographic/party_spec.rb +131 -0
- data/spec/lib/openehr/rm/demographic/role_spec.rb +58 -0
- data/spec/lib/openehr/rm/ehr/ehr_access_spec.rb +33 -0
- data/spec/lib/openehr/rm/ehr/ehr_spec.rb +139 -0
- data/spec/lib/openehr/rm/ehr/ehr_status_spec.rb +52 -0
- data/spec/lib/openehr/rm/ehr/versioned_composition_spec.rb +33 -0
- data/spec/lib/openehr/rm/integration/generic_entry_spec.rb +31 -0
- data/spec/lib/openehr/rm/support/identification/access_group_ref_spec.rb +19 -0
- data/spec/lib/openehr/rm/support/identification/archetype_id_spec.rb +152 -0
- data/spec/lib/openehr/rm/support/identification/generic_id_spec.rb +33 -0
- data/spec/lib/openehr/rm/support/identification/hier_object_id_spec.rb +12 -0
- data/spec/lib/openehr/rm/support/identification/internet_id_spec.rb +12 -0
- data/spec/lib/openehr/rm/support/identification/iso_oid_spec.rb +12 -0
- data/spec/lib/openehr/rm/support/identification/locatable_ref_spec.rb +34 -0
- data/spec/lib/openehr/rm/support/identification/object_id_spec.rb +24 -0
- data/spec/lib/openehr/rm/support/identification/object_ref_spec.rb +33 -0
- data/spec/lib/openehr/rm/support/identification/object_version_id_spec.rb +59 -0
- data/spec/lib/openehr/rm/support/identification/party_ref_spec.rb +29 -0
- data/spec/lib/openehr/rm/support/identification/template_id_spec.rb +12 -0
- data/spec/lib/openehr/rm/support/identification/terminology_id_spec.rb +33 -0
- data/spec/lib/openehr/rm/support/identification/uid_based_id_spec.rb +50 -0
- data/spec/lib/openehr/rm/support/identification/uid_spec.rb +29 -0
- data/spec/lib/openehr/rm/support/identification/version_tree_id_spec.rb +104 -0
- data/spec/lib/openehr/rm/support/measurement_service_spec.rb +7 -0
- data/spec/lib/openehr/rm/support/terminology_service_spec.rb +24 -0
- data/spec/lib/openehr/serializer/adl-test-entry.most_minimal.test.adl +20 -0
- data/spec/lib/openehr/serializer/adl_serializer_spec.rb +47 -0
- data/spec/lib/openehr/serializer/openEHR-EHR-SECTION.test.v1.adl +38 -0
- data/spec/lib/openehr/serializer/openEHR-EHR-SECTION.test.v1.xml +58 -0
- data/spec/lib/openehr/serializer/sample_archetype_spec.rb +44 -0
- data/spec/lib/openehr/serializer/xml_serializer_spec.rb +49 -0
- data/spec/lib/openehr/terminology/open_ehr_terminology_spec.rb +40 -0
- data/spec/spec.opts +6 -0
- data/spec/spec_helper.rb +58 -0
- metadata +631 -0
@@ -0,0 +1,24 @@
|
|
1
|
+
#! /usr/bin/env ruby
|
2
|
+
# charactor sets extraction from download file from
|
3
|
+
# http://www.iana.org/assignments/character-sets
|
4
|
+
# as character-sets
|
5
|
+
|
6
|
+
class CharacterSets
|
7
|
+
def self.get_list
|
8
|
+
list = Array.new
|
9
|
+
open('character-sets') do |file|
|
10
|
+
while line = file.gets
|
11
|
+
if /^((Name:)|(Alias:)) (\S+)/ =~ line
|
12
|
+
list << $4 unless $4 == "None"
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
16
|
+
return list
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
open('charset.lst','w') do |f|
|
21
|
+
CharacterSets.get_list.each do |line|
|
22
|
+
f.puts(line)
|
23
|
+
end
|
24
|
+
end
|
@@ -0,0 +1,98 @@
|
|
1
|
+
# OpenEHR::RM::Data_Types::Encapsulated
|
2
|
+
# http://www.openehr.org/svn/specification/TAGS/Release-1.0.2/publishing/architecture/computable/UML/uml_start_view.html
|
3
|
+
# refs #51
|
4
|
+
require 'rubygems'
|
5
|
+
require 'locale/info'
|
6
|
+
|
7
|
+
module OpenEHR
|
8
|
+
module RM
|
9
|
+
module DataTypes
|
10
|
+
module Encapsulated
|
11
|
+
class DvEncapsulated < OpenEHR::RM::DataTypes::Basic::DataValue
|
12
|
+
attr_reader :language, :charset
|
13
|
+
|
14
|
+
def initialize(args = {})
|
15
|
+
super(args)
|
16
|
+
self.charset = args[:charset]
|
17
|
+
self.language = args[:language]
|
18
|
+
end
|
19
|
+
|
20
|
+
def size
|
21
|
+
@value.size
|
22
|
+
end
|
23
|
+
|
24
|
+
def language=(language)
|
25
|
+
if !language.nil? &&
|
26
|
+
!Locale::Info.language_code?(language.code_string)
|
27
|
+
raise ArgumentError, 'invalid language code'
|
28
|
+
end
|
29
|
+
@language = language
|
30
|
+
end
|
31
|
+
|
32
|
+
def charset=(charset)
|
33
|
+
if !charset.nil? && !charset_valid?(charset.code_string)
|
34
|
+
raise ArgumentError, 'invalid charset'
|
35
|
+
end
|
36
|
+
@charset = charset
|
37
|
+
end
|
38
|
+
|
39
|
+
private
|
40
|
+
|
41
|
+
def charset_valid?(charset)
|
42
|
+
result = false
|
43
|
+
open('lib/openehr/rm/data_types/charset.lst') do |file|
|
44
|
+
while line = file.gets
|
45
|
+
if charset == line.chomp
|
46
|
+
result = true
|
47
|
+
break
|
48
|
+
end
|
49
|
+
end
|
50
|
+
end
|
51
|
+
return result
|
52
|
+
end
|
53
|
+
end
|
54
|
+
|
55
|
+
# media type http://www.iana.org/assignments/media-types/text/
|
56
|
+
class DvMultimedia < DvEncapsulated
|
57
|
+
attr_reader :media_type
|
58
|
+
attr_accessor :uri, :data, :compression_algorithm,
|
59
|
+
:integrity_check, :integrity_check_algorithm, :alternate_text
|
60
|
+
|
61
|
+
def initialize(args = {})
|
62
|
+
super(args)
|
63
|
+
self.media_type = args[:media_type]
|
64
|
+
self.uri = args[:uri]
|
65
|
+
self.data = args[:data]
|
66
|
+
self.compression_algorithm = args[:compression_algorithm]
|
67
|
+
self.integrity_check = args[:integrity_check]
|
68
|
+
self.integrity_check_algorithm = args[:integrity_check_algorithm]
|
69
|
+
self.alternate_text = args[:alternate_text]
|
70
|
+
end
|
71
|
+
|
72
|
+
def media_type=(media_type)
|
73
|
+
if media_type.code_string.nil?
|
74
|
+
raise ArgumentError, 'media_type should not be nil'
|
75
|
+
end
|
76
|
+
@media_type = media_type
|
77
|
+
end
|
78
|
+
end
|
79
|
+
|
80
|
+
class DvParsable < DvEncapsulated
|
81
|
+
attr_reader :formalism
|
82
|
+
|
83
|
+
def initialize(args = {})
|
84
|
+
super(args)
|
85
|
+
self.formalism = args[:formalism]
|
86
|
+
end
|
87
|
+
|
88
|
+
def formalism=(formalism)
|
89
|
+
if formalism.nil? || formalism.empty?
|
90
|
+
raise ArgumentError, 'formalism is mandatory'
|
91
|
+
end
|
92
|
+
@formalism = formalism
|
93
|
+
end
|
94
|
+
end
|
95
|
+
end # of Encapsulated
|
96
|
+
end # of DataTypes
|
97
|
+
end # of RM
|
98
|
+
end # of OpenEHR
|
@@ -0,0 +1,402 @@
|
|
1
|
+
$:.unshift(File.dirname(__FILE__))
|
2
|
+
# This modules are implemented from the UML shown bellow
|
3
|
+
# http://www.openehr.org/uml/release-1.0.1/Browsable/_9_0_76d0249_1109599337877_94556_1510Report.html
|
4
|
+
# Ticket refs #50
|
5
|
+
|
6
|
+
require 'openehr/assumed_library_types'
|
7
|
+
|
8
|
+
module OpenEHR
|
9
|
+
module RM
|
10
|
+
module DataTypes
|
11
|
+
module Quantity
|
12
|
+
autoload :DateTime, 'quantity/date_time'
|
13
|
+
|
14
|
+
class DvOrdered < OpenEHR::RM::DataTypes::Basic::DataValue
|
15
|
+
include Comparable
|
16
|
+
attr_accessor :normal_range, :other_refference_ranges, :normal_status
|
17
|
+
|
18
|
+
def initialize(args = {})
|
19
|
+
super(args)
|
20
|
+
self.normal_range = args[:normal_range]
|
21
|
+
self.normal_status = args[:normal_status]
|
22
|
+
self.other_reference_ranges = args[:other_reference_ranges]
|
23
|
+
end
|
24
|
+
|
25
|
+
def is_normal?
|
26
|
+
if @normal_range.nil? and @normal_status.nil?
|
27
|
+
return false
|
28
|
+
elsif !@normal_range.nil?
|
29
|
+
return @normal_range.has(@value)
|
30
|
+
elsif !@normal_status.nil?
|
31
|
+
return @normal_status.code_string == 'N'
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
def is_simple?
|
36
|
+
return @other_reference_ranges.nil?
|
37
|
+
end
|
38
|
+
|
39
|
+
def <=>(other)
|
40
|
+
raise NotImplementedError, 'This method should be implemented'
|
41
|
+
end
|
42
|
+
|
43
|
+
def other_reference_ranges=(other_reference_ranges)
|
44
|
+
if !other_reference_ranges.nil? && other_reference_ranges.empty?
|
45
|
+
raise ArgumentError, "Other reference ranges validity error"
|
46
|
+
end
|
47
|
+
@other_reference_ranges = other_reference_ranges
|
48
|
+
end
|
49
|
+
|
50
|
+
def is_strictly_comparable_to?(others)
|
51
|
+
if others.instance_of? self.class
|
52
|
+
return true
|
53
|
+
else
|
54
|
+
return false
|
55
|
+
end
|
56
|
+
end
|
57
|
+
end
|
58
|
+
|
59
|
+
class DvInterval < OpenEHR::AssumedLibraryTypes::Interval
|
60
|
+
|
61
|
+
end
|
62
|
+
|
63
|
+
class DvQuantified < DvOrdered
|
64
|
+
attr_reader :magnitude, :magnitude_status
|
65
|
+
|
66
|
+
def initialize(args = {})
|
67
|
+
super(args)
|
68
|
+
self.magnitude = args[:magnitude]
|
69
|
+
self.magnitude_status = args[:magnitude_status]
|
70
|
+
end
|
71
|
+
|
72
|
+
def <=>(others)
|
73
|
+
self.magnitude <=> others.magnitude
|
74
|
+
end
|
75
|
+
|
76
|
+
def magnitude=(magnitude)
|
77
|
+
raise ArgumentError, 'magnitude should not be nil' if magnitude.nil?
|
78
|
+
@magnitude = magnitude
|
79
|
+
end
|
80
|
+
|
81
|
+
def magnitude_status=(magnitude_status)
|
82
|
+
if magnitude_status.nil?
|
83
|
+
@magnitude_status = '='
|
84
|
+
elsif DvQuantified.valid_magnitude_status?(magnitude_status)
|
85
|
+
@magnitude_status = magnitude_status
|
86
|
+
else
|
87
|
+
raise ArgumentError, 'magnitude_status invalid'
|
88
|
+
end
|
89
|
+
end
|
90
|
+
|
91
|
+
def accuracy_unknown?
|
92
|
+
return @accuracy.nil?
|
93
|
+
end
|
94
|
+
|
95
|
+
def self.valid_magnitude_status?(s)
|
96
|
+
if s == '=' || s == '>' || s == '<' || s == '<=' ||
|
97
|
+
s == '>=' || s == '~'
|
98
|
+
return true
|
99
|
+
else
|
100
|
+
return false
|
101
|
+
end
|
102
|
+
end
|
103
|
+
end
|
104
|
+
|
105
|
+
class DvOrdinal < DvOrdered
|
106
|
+
attr_reader :value, :symbol, :limits
|
107
|
+
|
108
|
+
def initialize(args = {})
|
109
|
+
super(args)
|
110
|
+
self.symbol = args[:symbol]
|
111
|
+
self.limits = args[:limits]
|
112
|
+
end
|
113
|
+
|
114
|
+
def value=(value)
|
115
|
+
raise ArgumentError, 'value should not be nil' if value.nil?
|
116
|
+
@value = value
|
117
|
+
end
|
118
|
+
|
119
|
+
def symbol=(symbol)
|
120
|
+
raise ArgumentError,'symbol should not be nil' if symbol.nil?
|
121
|
+
@symbol = symbol
|
122
|
+
end
|
123
|
+
|
124
|
+
def <=>(other)
|
125
|
+
@value <=> other.value
|
126
|
+
end
|
127
|
+
|
128
|
+
def limits=(limits)
|
129
|
+
unless limits.nil? or limits.meaning.value == 'limits'
|
130
|
+
raise ArgumentError, 'invalid limits'
|
131
|
+
else
|
132
|
+
@limits = limits
|
133
|
+
end
|
134
|
+
end
|
135
|
+
def is_strictly_comparable_to?(others)
|
136
|
+
unless super(others)
|
137
|
+
return false
|
138
|
+
end
|
139
|
+
unless others.symbol.defining_code.terminology_id.value ==
|
140
|
+
@symbol.defining_code.terminology_id.value
|
141
|
+
return false
|
142
|
+
else
|
143
|
+
return true
|
144
|
+
end
|
145
|
+
end
|
146
|
+
end
|
147
|
+
|
148
|
+
class DvAbsoluteQuantity < DvQuantified
|
149
|
+
attr_accessor :accuracy
|
150
|
+
|
151
|
+
def initialize(args = {})
|
152
|
+
super(args)
|
153
|
+
self.accuracy = args[:accuracy]
|
154
|
+
end
|
155
|
+
|
156
|
+
def add(a_diff)
|
157
|
+
type_check(a_diff)
|
158
|
+
return result_builder(self.class,
|
159
|
+
@magnitude+a_diff.magnitude)
|
160
|
+
end
|
161
|
+
|
162
|
+
def diff(other)
|
163
|
+
type_check(other)
|
164
|
+
return result_builder(self.class,
|
165
|
+
(@magnitude-other.magnitude).abs)
|
166
|
+
end
|
167
|
+
|
168
|
+
def subtract(a_diff)
|
169
|
+
type_check(a_diff)
|
170
|
+
return result_builder(self.class,
|
171
|
+
@magnitude-a_diff.magnitude)
|
172
|
+
end
|
173
|
+
private
|
174
|
+
def type_check(other)
|
175
|
+
unless self.is_strictly_comparable_to? other
|
176
|
+
raise ArgumentError, 'type mismatch'
|
177
|
+
end
|
178
|
+
end
|
179
|
+
|
180
|
+
def result_builder(klass, magnitude)
|
181
|
+
return klass.new(:magnitude => magnitude,
|
182
|
+
:magnitude_status => @magnitude_status,
|
183
|
+
:accuracy => @accuracy,
|
184
|
+
:accuracy_percent => @accuracy_percent,
|
185
|
+
:normal_range => @normal_range,
|
186
|
+
:normal_status => @normal_status,
|
187
|
+
:other_reference_ranges => @other_reference_ranges)
|
188
|
+
end
|
189
|
+
end
|
190
|
+
|
191
|
+
class DvAmount < DvQuantified
|
192
|
+
attr_reader :accuracy, :accuracy_percent
|
193
|
+
|
194
|
+
def initialize(args = {})
|
195
|
+
super(args)
|
196
|
+
unless args[:accuracy].nil?
|
197
|
+
set_accuracy(args[:accuracy], args[:accuracy_percent])
|
198
|
+
else
|
199
|
+
@accuracy, @accuracy_percent = nil, nil
|
200
|
+
end
|
201
|
+
end
|
202
|
+
|
203
|
+
def +(other)
|
204
|
+
unless self.is_strictly_comparable_to? other
|
205
|
+
raise ArgumentError, 'type mismatch'
|
206
|
+
end
|
207
|
+
result = self.dup
|
208
|
+
result.magnitude = @magnitude + other.magnitude
|
209
|
+
return result
|
210
|
+
end
|
211
|
+
|
212
|
+
def -(other)
|
213
|
+
other.magnitude = - other.magnitude
|
214
|
+
self+(other)
|
215
|
+
end
|
216
|
+
|
217
|
+
def set_accuracy(accuracy, accuracy_percent)
|
218
|
+
if accuracy_percent
|
219
|
+
raise ArgumentError, 'accuracy invalid' if accuracy < 0.0 || accuracy > 100.0
|
220
|
+
else
|
221
|
+
raise ArgumentError, 'accuracy invaild' if accuracy < 0.0 || accuracy > 1.0
|
222
|
+
end
|
223
|
+
@accuracy, @accuracy_percent = accuracy, accuracy_percent
|
224
|
+
end
|
225
|
+
|
226
|
+
def accuracy_is_percent?
|
227
|
+
return @accuracy_percent
|
228
|
+
end
|
229
|
+
end
|
230
|
+
|
231
|
+
class DvQuantity < DvAmount
|
232
|
+
attr_reader :units, :precision
|
233
|
+
|
234
|
+
def initialize(args = {})
|
235
|
+
super(args)
|
236
|
+
self.units = args[:units]
|
237
|
+
self.precision = args[:precision]
|
238
|
+
end
|
239
|
+
|
240
|
+
def units=(units)
|
241
|
+
raise ArgumentError, 'units should not be nil' if units.nil?
|
242
|
+
@units = units
|
243
|
+
end
|
244
|
+
|
245
|
+
def precision=(precision)
|
246
|
+
unless precision.nil? || precision >= -1
|
247
|
+
raise ArgumentError, 'precision invalid'
|
248
|
+
end
|
249
|
+
@precision = precision
|
250
|
+
end
|
251
|
+
|
252
|
+
def is_strictly_comparable_to?(others)
|
253
|
+
unless super(others)
|
254
|
+
return false
|
255
|
+
end
|
256
|
+
if others.units == @units
|
257
|
+
return true
|
258
|
+
else
|
259
|
+
return false
|
260
|
+
end
|
261
|
+
end
|
262
|
+
|
263
|
+
def is_integral?
|
264
|
+
if @precision.nil? || precision != 0
|
265
|
+
return false
|
266
|
+
else
|
267
|
+
return true
|
268
|
+
end
|
269
|
+
end
|
270
|
+
end
|
271
|
+
|
272
|
+
class DvCount < DvAmount
|
273
|
+
|
274
|
+
end
|
275
|
+
|
276
|
+
class ReferenceRange
|
277
|
+
attr_reader :meaning, :range
|
278
|
+
|
279
|
+
def initialize(args = {})
|
280
|
+
self.meaning = args[:meaning]
|
281
|
+
self.range = args[:range]
|
282
|
+
end
|
283
|
+
|
284
|
+
def meaning=(meaning)
|
285
|
+
if meaning.nil?
|
286
|
+
raise ArgumentError, 'meaning should not be nil'
|
287
|
+
end
|
288
|
+
@meaning = meaning
|
289
|
+
end
|
290
|
+
|
291
|
+
def range=(range)
|
292
|
+
if range.nil?
|
293
|
+
raise ArgumentError, 'range should not be nil'
|
294
|
+
end
|
295
|
+
@range = range
|
296
|
+
end
|
297
|
+
|
298
|
+
def is_in_range?(val)
|
299
|
+
return @range.has?(val)
|
300
|
+
end
|
301
|
+
end
|
302
|
+
|
303
|
+
module ProportionKind
|
304
|
+
PK_RATIO = 0
|
305
|
+
PK_UNITARY = 1
|
306
|
+
PK_PERCENT = 2
|
307
|
+
PK_FRACTION = 3
|
308
|
+
PK_INTEGER_FRACTION = 4
|
309
|
+
|
310
|
+
def ProportionKind.valid_proportion_kind?(kind)
|
311
|
+
return true if kind >= 0 && kind <= 4
|
312
|
+
return false
|
313
|
+
end
|
314
|
+
end # end of ProportionKind
|
315
|
+
|
316
|
+
class DvProportion < DvAmount
|
317
|
+
include ProportionKind
|
318
|
+
attr_reader :numerator, :denominator, :type, :precision
|
319
|
+
|
320
|
+
def initialize(args = {})
|
321
|
+
self.type = args[:type]
|
322
|
+
self.numerator = args[:numerator]
|
323
|
+
self.denominator = args[:denominator]
|
324
|
+
self.precision = args[:precision]
|
325
|
+
self.magnitude_status =args[:magnitude_status]
|
326
|
+
unless args[:accuracy].nil?
|
327
|
+
set_accuracy(args[:accuracy], args[:accuracy_percent])
|
328
|
+
else
|
329
|
+
@accuracy, @accuracy_percent = nil, nil
|
330
|
+
end
|
331
|
+
self.normal_range = args[:normal_range]
|
332
|
+
self.normal_status = args[:normal_status]
|
333
|
+
self.other_reference_ranges = args[:other_reference_ranges]
|
334
|
+
end
|
335
|
+
|
336
|
+
def numerator=(numerator)
|
337
|
+
raise ArgumentError, 'numerator should not be nil' if numerator.nil?
|
338
|
+
if (@type == PK_FRACTION || @type == PK_INTEGER_FRACTION) &&
|
339
|
+
!numerator.integer?
|
340
|
+
raise ArgumentError, 'numerator invalid for type'
|
341
|
+
end
|
342
|
+
@numerator = numerator
|
343
|
+
end
|
344
|
+
|
345
|
+
def denominator=(denominator)
|
346
|
+
case @type
|
347
|
+
when PK_UNITARY
|
348
|
+
unless denominator == 1
|
349
|
+
raise ArgumentError, 'Unitary denominator must be 1'
|
350
|
+
end
|
351
|
+
when PK_PERCENT
|
352
|
+
unless denominator == 100
|
353
|
+
raise ArgumentError, 'Percent denominator must be 100'
|
354
|
+
end
|
355
|
+
when PK_FRACTION, PK_INTEGER_FRACTION
|
356
|
+
unless denominator.integer? and @numerator.integer?
|
357
|
+
raise ArgumentError, 'Fraction numerator/denominator must be integer'
|
358
|
+
end
|
359
|
+
end
|
360
|
+
@denominator = denominator
|
361
|
+
end
|
362
|
+
|
363
|
+
def type=(type)
|
364
|
+
if ProportionKind.valid_proportion_kind?(type)
|
365
|
+
@type = type
|
366
|
+
else
|
367
|
+
raise ArgumentError, 'type invalid'
|
368
|
+
end
|
369
|
+
end
|
370
|
+
|
371
|
+
def magnitude
|
372
|
+
return numerator.to_f/denominator.to_f
|
373
|
+
end
|
374
|
+
|
375
|
+
def precision=(precision)
|
376
|
+
unless precision.nil?
|
377
|
+
if (self.is_integral? && precision !=0)
|
378
|
+
raise ArgumentError, 'precision invalid'
|
379
|
+
end
|
380
|
+
end
|
381
|
+
@precision = precision
|
382
|
+
end
|
383
|
+
|
384
|
+
def is_integral?
|
385
|
+
return denominator.integer? && numerator.integer?
|
386
|
+
end
|
387
|
+
|
388
|
+
def is_strictly_comparable_to?(other)
|
389
|
+
unless super(other)
|
390
|
+
return false
|
391
|
+
end
|
392
|
+
if other.type == @type
|
393
|
+
return true
|
394
|
+
else
|
395
|
+
return false
|
396
|
+
end
|
397
|
+
end
|
398
|
+
end # end of DvProportion
|
399
|
+
end # of Quantity
|
400
|
+
end # of Data_Types
|
401
|
+
end # of RM
|
402
|
+
end # of OpenEHR
|