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,114 @@
|
|
1
|
+
module OpenEHR
|
2
|
+
module AM
|
3
|
+
module OpenEHRProfile
|
4
|
+
module DataTypes
|
5
|
+
module Basic
|
6
|
+
include OpenEHR::AM::Archetype::ConstraintModel
|
7
|
+
|
8
|
+
class CDvState < CDomainType
|
9
|
+
attr_reader :value
|
10
|
+
|
11
|
+
def initialize(args = { })
|
12
|
+
args[:rm_type_name] = 'DvState'
|
13
|
+
super
|
14
|
+
self.value = args[:value]
|
15
|
+
end
|
16
|
+
|
17
|
+
def value=(value)
|
18
|
+
raise ArgumentError, 'value is mandatory' if value.nil?
|
19
|
+
@value = value
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
23
|
+
class StateMachine
|
24
|
+
attr_reader :states
|
25
|
+
|
26
|
+
def initialize(args = { })
|
27
|
+
self.states = args[:states]
|
28
|
+
end
|
29
|
+
|
30
|
+
def states=(states)
|
31
|
+
if states.nil? or states.empty?
|
32
|
+
raise ArgumentError, 'states are mandatory'
|
33
|
+
end
|
34
|
+
@states = states
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
38
|
+
class State
|
39
|
+
attr_reader :name
|
40
|
+
|
41
|
+
def initialize(args = { })
|
42
|
+
self.name = args[:name]
|
43
|
+
end
|
44
|
+
|
45
|
+
def name=(name)
|
46
|
+
if name.nil? or name.empty?
|
47
|
+
raise ArgumentError, 'Invalid name'
|
48
|
+
end
|
49
|
+
@name = name
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
class TerminalState < State
|
54
|
+
|
55
|
+
end
|
56
|
+
|
57
|
+
class NonTerminalState < State
|
58
|
+
attr_reader :transitions
|
59
|
+
def initialize(args = { })
|
60
|
+
super
|
61
|
+
self.transitions = args[:transitions]
|
62
|
+
end
|
63
|
+
|
64
|
+
def transitions=(transitions)
|
65
|
+
if transitions.nil? or transitions.empty?
|
66
|
+
raise ArgumentError, 'transition should not be empty'
|
67
|
+
end
|
68
|
+
@transitions = transitions
|
69
|
+
end
|
70
|
+
end
|
71
|
+
|
72
|
+
class Transition
|
73
|
+
attr_reader :event, :action, :guard, :next_state
|
74
|
+
|
75
|
+
def initialize(args = { })
|
76
|
+
self.event = args[:event]
|
77
|
+
self.guard = args[:guard]
|
78
|
+
self.action = args[:action]
|
79
|
+
self.next_state = args[:next_state]
|
80
|
+
end
|
81
|
+
|
82
|
+
def event=(event)
|
83
|
+
if event.nil? or event.empty?
|
84
|
+
raise ArgumentError, 'event is mandatory'
|
85
|
+
end
|
86
|
+
@event = event
|
87
|
+
end
|
88
|
+
|
89
|
+
def guard=(guard)
|
90
|
+
if !guard.nil? && guard.empty?
|
91
|
+
raise ArgumentError, 'guard should not be empty'
|
92
|
+
end
|
93
|
+
@guard = guard
|
94
|
+
end
|
95
|
+
|
96
|
+
def action=(action)
|
97
|
+
if !action.nil? && action.empty?
|
98
|
+
raise ArgumentError, 'action should not be empty'
|
99
|
+
end
|
100
|
+
@action = action
|
101
|
+
end
|
102
|
+
|
103
|
+
def next_state=(next_state)
|
104
|
+
if next_state.nil?
|
105
|
+
raise ArgumentError, 'next state is mandatory'
|
106
|
+
end
|
107
|
+
@next_state = next_state
|
108
|
+
end
|
109
|
+
end
|
110
|
+
end
|
111
|
+
end # of DataTypes
|
112
|
+
end # of OpenEHR Profile
|
113
|
+
end # of AM
|
114
|
+
end # of OpenEHR
|
@@ -0,0 +1,67 @@
|
|
1
|
+
module OpenEHR
|
2
|
+
module AM
|
3
|
+
module OpenEHRProfile
|
4
|
+
module DataTypes
|
5
|
+
module Quantity
|
6
|
+
include OpenEHR::AM::Archetype::ConstraintModel
|
7
|
+
|
8
|
+
class CDvQuantity < CDomainType
|
9
|
+
attr_accessor :property, :list
|
10
|
+
|
11
|
+
def initialize(args = { })
|
12
|
+
super
|
13
|
+
self.property = args[:property]
|
14
|
+
self.list = args[:list]
|
15
|
+
end
|
16
|
+
|
17
|
+
def any_allowed?
|
18
|
+
if @property.nil? && @list.nil?
|
19
|
+
return true
|
20
|
+
else
|
21
|
+
return false
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
25
|
+
|
26
|
+
class CDvOrdinal < CDomainType
|
27
|
+
attr_accessor :list
|
28
|
+
def initialize(args = { })
|
29
|
+
super
|
30
|
+
self.list = args[:list]
|
31
|
+
end
|
32
|
+
|
33
|
+
def any_allowed?
|
34
|
+
@list.nil?
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
38
|
+
class CQuantityItem
|
39
|
+
attr_accessor :magnitude, :precision
|
40
|
+
attr_reader :units
|
41
|
+
|
42
|
+
def initialize(args = { })
|
43
|
+
self.magnitude = args[:magnitude]
|
44
|
+
self.precision = args[:precision]
|
45
|
+
self.units = args[:units]
|
46
|
+
end
|
47
|
+
|
48
|
+
def units=(units)
|
49
|
+
if units.nil? or units.empty?
|
50
|
+
raise ArgumentError, 'units are mandatory'
|
51
|
+
end
|
52
|
+
@units = units
|
53
|
+
end
|
54
|
+
|
55
|
+
def precision_unconstrained?
|
56
|
+
if @precision.upper == -1 && @precision.lower == -1
|
57
|
+
return true
|
58
|
+
else
|
59
|
+
return false
|
60
|
+
end
|
61
|
+
end
|
62
|
+
end
|
63
|
+
end
|
64
|
+
end # of DataTypes
|
65
|
+
end # of OpenEHRProfile
|
66
|
+
end # of AM
|
67
|
+
end # of OpenEHR
|
@@ -0,0 +1,22 @@
|
|
1
|
+
$:.unshift(File.dirname(__FILE__))
|
2
|
+
module OpenEHR
|
3
|
+
module AM
|
4
|
+
module OpenEHRProfile
|
5
|
+
module DataTypes
|
6
|
+
module Text
|
7
|
+
include OpenEHR::AM::Archetype::ConstraintModel
|
8
|
+
class CCodePhrase < CDomainType
|
9
|
+
attr_accessor :terminology_id, :code_list
|
10
|
+
|
11
|
+
def initialize(args = { })
|
12
|
+
super
|
13
|
+
self.terminology_id = args[:terminology_id]
|
14
|
+
self.code_list = args[:code_list]
|
15
|
+
self.assumed_value = args[:assumed_value]
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end # of Text
|
19
|
+
end # of Data_Types
|
20
|
+
end # of OpenEHR Profile
|
21
|
+
end # of AM
|
22
|
+
end # of OpenEHR
|
@@ -0,0 +1,691 @@
|
|
1
|
+
# This module is related to the ticket #36
|
2
|
+
require 'date'
|
3
|
+
require 'time'
|
4
|
+
|
5
|
+
module OpenEHR
|
6
|
+
module AssumedLibraryTypes
|
7
|
+
class Any < Object
|
8
|
+
|
9
|
+
end # of Any
|
10
|
+
|
11
|
+
class Interval < Any
|
12
|
+
attr_reader :lower, :upper
|
13
|
+
|
14
|
+
def initialize(args = {})
|
15
|
+
check_lower_upper(args[:lower], args[:upper])
|
16
|
+
self.lower_included = args[:lower_included]
|
17
|
+
self.upper_included = args[:upper_included]
|
18
|
+
end
|
19
|
+
|
20
|
+
def lower=(lower)
|
21
|
+
check_lower_upper(lower, @upper)
|
22
|
+
end
|
23
|
+
|
24
|
+
def upper=(upper)
|
25
|
+
check_lower_upper(@lower, upper)
|
26
|
+
end
|
27
|
+
|
28
|
+
def lower_included?
|
29
|
+
return @lower_included
|
30
|
+
end
|
31
|
+
|
32
|
+
def lower_included=(lower_included)
|
33
|
+
if (lower == nil) && (lower_included != nil)
|
34
|
+
raise ArgumentError, "lower is not set"
|
35
|
+
end
|
36
|
+
@lower_included = lower_included
|
37
|
+
end
|
38
|
+
|
39
|
+
def lower_unbounded?
|
40
|
+
return @lower.nil?
|
41
|
+
end
|
42
|
+
|
43
|
+
def upper_included?
|
44
|
+
return @upper_included
|
45
|
+
end
|
46
|
+
|
47
|
+
def upper_included=(upper_included)
|
48
|
+
if (@upper.nil?) && (upper_included != nil)
|
49
|
+
raise ArgumentError, "upper is not set"
|
50
|
+
end
|
51
|
+
@upper_included = upper_included
|
52
|
+
end
|
53
|
+
|
54
|
+
def upper_unbounded?
|
55
|
+
return @upper.nil?
|
56
|
+
end
|
57
|
+
|
58
|
+
def has?(value)
|
59
|
+
if ((@lower.nil?||@lower < value||((@lower_included == true) && (@lower == value)))&&
|
60
|
+
(@upper.nil?||value < @upper||((@upper_included == true) && (@upper == value))))
|
61
|
+
true
|
62
|
+
else
|
63
|
+
false
|
64
|
+
end
|
65
|
+
end
|
66
|
+
|
67
|
+
def ==(value)
|
68
|
+
return (@lower == value.lower) && (@upper == value.upper) &&
|
69
|
+
(@lower_included == value.lower_included?) &&
|
70
|
+
(@upper_included == value.upper_included?)
|
71
|
+
end
|
72
|
+
private
|
73
|
+
|
74
|
+
def check_lower_upper(lower, upper)
|
75
|
+
if lower.nil? && upper.nil?
|
76
|
+
raise ArgumentError, "Either lower or upper must be assigned"
|
77
|
+
end
|
78
|
+
unless (lower.nil? || upper.nil?)
|
79
|
+
if lower > upper
|
80
|
+
raise ArgumentError, "Upper must be larger than lower."
|
81
|
+
end
|
82
|
+
end
|
83
|
+
@lower = lower
|
84
|
+
@upper = upper
|
85
|
+
end
|
86
|
+
end # end of Interval
|
87
|
+
|
88
|
+
class Timezone
|
89
|
+
attr_reader :hour, :minute, :value
|
90
|
+
|
91
|
+
def initialize(value)
|
92
|
+
self.value = value
|
93
|
+
end
|
94
|
+
|
95
|
+
def value=(value)
|
96
|
+
unless value.nil?
|
97
|
+
if /((([+-](\d{2})):?(\d{2}))|Z)/ =~ value
|
98
|
+
@value = value
|
99
|
+
if $1 == 'Z'
|
100
|
+
@hour, @minute = 0,0
|
101
|
+
else
|
102
|
+
@hour = $3.to_i
|
103
|
+
@minute = $5.to_i
|
104
|
+
end
|
105
|
+
else
|
106
|
+
raise ArgumentError, "timezone invalid"
|
107
|
+
end
|
108
|
+
else
|
109
|
+
@value = nil
|
110
|
+
end
|
111
|
+
end
|
112
|
+
|
113
|
+
def sign
|
114
|
+
unless @hour
|
115
|
+
return nil
|
116
|
+
end
|
117
|
+
if @hour < 0
|
118
|
+
return -1
|
119
|
+
else
|
120
|
+
return +1
|
121
|
+
end
|
122
|
+
end
|
123
|
+
|
124
|
+
def to_s
|
125
|
+
return value
|
126
|
+
end
|
127
|
+
|
128
|
+
alias_method :as_string, :to_s
|
129
|
+
alias_method :hours, :hour
|
130
|
+
alias_method :minutes, :minute
|
131
|
+
end
|
132
|
+
|
133
|
+
module TimeDefinitions #< Any
|
134
|
+
DAYS_IN_LEAP_YEAR = 366
|
135
|
+
DAYS_IN_WEEK = 7
|
136
|
+
DAYS_IN_YEAR = 365
|
137
|
+
HOURS_IN_DAY = 24
|
138
|
+
MAX_DAYS_IN_MONTH = 31
|
139
|
+
MAX_DAYS_IN_YEAR = 366
|
140
|
+
MINUTES_IN_HOUR = 60
|
141
|
+
MONTH_IN_YEAR = 12
|
142
|
+
NOMINAL_DAYS_IN_MONTH = 30.42
|
143
|
+
NOMINAL_DAYS_IN_YEAR = 365.24
|
144
|
+
SECONDS_IN_MINUTE = 60
|
145
|
+
|
146
|
+
def self.valid_year?(year)
|
147
|
+
return !year.nil? && year >= 0
|
148
|
+
end
|
149
|
+
|
150
|
+
def self.valid_day?(y, m, d)
|
151
|
+
unless y.nil? || m.nil? || d.nil?
|
152
|
+
return Date.valid_date?(y,m,d)
|
153
|
+
end
|
154
|
+
if (y.nil?) || (m.nil? && !d.nil?)
|
155
|
+
return false
|
156
|
+
end
|
157
|
+
return self.valid_year?(y) && self.valid_month?(m)
|
158
|
+
end
|
159
|
+
|
160
|
+
def self.valid_hour?(h,m = nil, s = nil)
|
161
|
+
if h.nil?
|
162
|
+
return false
|
163
|
+
end
|
164
|
+
if !m.nil? and !valid_minute?(m)
|
165
|
+
return false
|
166
|
+
end
|
167
|
+
if !s.nil? and (!m.nil? and !valid_second?(s))
|
168
|
+
return false
|
169
|
+
end
|
170
|
+
(h >= 0 and h < HOURS_IN_DAY) or (h == HOURS_IN_DAY and m == 0 and s == 0)
|
171
|
+
end
|
172
|
+
|
173
|
+
def self.valid_minute?(mi)
|
174
|
+
mi >= 0 and mi < MINUTES_IN_HOUR
|
175
|
+
end
|
176
|
+
|
177
|
+
def self.valid_second?(s)
|
178
|
+
s >= 0 and s < SECONDS_IN_MINUTE
|
179
|
+
end
|
180
|
+
|
181
|
+
def self.valid_month?(mo)
|
182
|
+
mo >= 1 and mo <= MONTH_IN_YEAR
|
183
|
+
end
|
184
|
+
|
185
|
+
protected
|
186
|
+
def nilthenzero(value)
|
187
|
+
return value ? value : 0
|
188
|
+
end
|
189
|
+
|
190
|
+
end # end of TimeDefinitions
|
191
|
+
|
192
|
+
module ISO8601DateModule
|
193
|
+
include TimeDefinitions
|
194
|
+
attr_reader :year, :month, :day
|
195
|
+
|
196
|
+
def year=(year)
|
197
|
+
unless TimeDefinitions.valid_year?(year)
|
198
|
+
raise ArgumentError, "Year is not valid"
|
199
|
+
end
|
200
|
+
@year = year
|
201
|
+
end
|
202
|
+
|
203
|
+
def month=(month)
|
204
|
+
raise ArgumentError, "Month is not valid" unless month.nil? or TimeDefinitions.valid_month?(month)
|
205
|
+
@month = month
|
206
|
+
end
|
207
|
+
|
208
|
+
def day=(day)
|
209
|
+
|
210
|
+
raise ArgumentError, "Day is not valid" unless day.nil? or TimeDefinitions.valid_day?(@year, @month, day)
|
211
|
+
@day = day
|
212
|
+
end
|
213
|
+
|
214
|
+
def as_string
|
215
|
+
if (!@year.nil? and !@month.nil? and !@day.nil?)
|
216
|
+
Date.new(@year, @month, @day).to_s
|
217
|
+
elsif (!@year.nil? and !@month.nil? and @day.nil?)
|
218
|
+
Date.new(@year, @month).to_s[0,7]
|
219
|
+
elsif (!@year.nil? and @month.nil? and @day.nil?)
|
220
|
+
Date.new(@year).to_s[0,4]
|
221
|
+
end
|
222
|
+
end
|
223
|
+
|
224
|
+
def to_days
|
225
|
+
days = nilthenzero(@year)*TimeDefinitions::NOMINAL_DAYS_IN_YEAR +
|
226
|
+
nilthenzero(@month)*TimeDefinitions::NOMINAL_DAYS_IN_MONTH +
|
227
|
+
nilthenzero(@day)
|
228
|
+
return days
|
229
|
+
end
|
230
|
+
|
231
|
+
def month_unknown?
|
232
|
+
@month.nil?
|
233
|
+
end
|
234
|
+
|
235
|
+
def day_unknown?
|
236
|
+
@day.nil?
|
237
|
+
end
|
238
|
+
|
239
|
+
def is_extended?
|
240
|
+
true
|
241
|
+
end
|
242
|
+
|
243
|
+
def is_partial?
|
244
|
+
month_unknown? or day_unknown?
|
245
|
+
end
|
246
|
+
|
247
|
+
protected
|
248
|
+
def leapyear?(year)
|
249
|
+
case
|
250
|
+
when (year % 400) == 0 then true
|
251
|
+
when (year % 100) == 0 then false
|
252
|
+
else year % 4 == 0
|
253
|
+
end
|
254
|
+
end
|
255
|
+
end
|
256
|
+
|
257
|
+
class ISO8601Date
|
258
|
+
include ISO8601DateModule, Comparable
|
259
|
+
def initialize(string)
|
260
|
+
/(\d{4})(?:-(\d{2})(?:-(\d{2})?)?)?/ =~ string
|
261
|
+
if $1.nil?
|
262
|
+
raise ArgumentError, 'data invalid'
|
263
|
+
else
|
264
|
+
self.year = $1.to_i
|
265
|
+
end
|
266
|
+
if $2.nil?
|
267
|
+
self.month = nil
|
268
|
+
else
|
269
|
+
self.month = $2.to_i
|
270
|
+
end
|
271
|
+
if $3.nil?
|
272
|
+
self.day = nil
|
273
|
+
else
|
274
|
+
self.day = $3.to_i
|
275
|
+
end
|
276
|
+
end
|
277
|
+
|
278
|
+
def <=>(other)
|
279
|
+
self.to_days <=> other.to_days
|
280
|
+
end
|
281
|
+
|
282
|
+
def self.valid_iso8601_date?(string)
|
283
|
+
begin
|
284
|
+
Date.parse(string)
|
285
|
+
rescue
|
286
|
+
return false
|
287
|
+
end
|
288
|
+
true
|
289
|
+
end
|
290
|
+
end # end of ISO8601_DATE
|
291
|
+
|
292
|
+
module ISO8601TimeModule
|
293
|
+
include TimeDefinitions
|
294
|
+
attr_reader :hour, :minute, :second, :fractional_second
|
295
|
+
|
296
|
+
def hour=(hour)
|
297
|
+
unless TimeDefinitions.valid_hour?(hour, @minute, @second)
|
298
|
+
raise ArgumentError, "hour is not valid"
|
299
|
+
end
|
300
|
+
@hour = hour
|
301
|
+
end
|
302
|
+
|
303
|
+
def minute_unknown?
|
304
|
+
@minute.nil?
|
305
|
+
end
|
306
|
+
|
307
|
+
def minute=(minute)
|
308
|
+
raise ArgumentError, "minute is not valid" if !minute.nil? and !TimeDefinitions.valid_minute?(minute)
|
309
|
+
@minute = minute
|
310
|
+
end
|
311
|
+
|
312
|
+
def second_unknown?
|
313
|
+
@second.nil?
|
314
|
+
end
|
315
|
+
|
316
|
+
def second=(second)
|
317
|
+
raise ArgumentError, "minute not defined" if @minute.nil? and !second.nil?
|
318
|
+
raise ArgumentError, "second is not valid" if !second.nil? and !TimeDefinitions.valid_second?(second)
|
319
|
+
@second = second
|
320
|
+
end
|
321
|
+
|
322
|
+
def fractional_second=(fractional_second)
|
323
|
+
raise ArgumentError, "minute not defined" if minute_unknown? and !fractional_second.nil?
|
324
|
+
raise ArgumentError, "second not defined" if second_unknown? and !fractional_second.nil?
|
325
|
+
if !fractional_second.nil? &&
|
326
|
+
(fractional_second < 0.0 || fractional_second >= 1.0)
|
327
|
+
raise ArgumentError, 'fractional second should be between 0.0 - 1.0'
|
328
|
+
end
|
329
|
+
@fractional_second = fractional_second
|
330
|
+
end
|
331
|
+
|
332
|
+
def has_fractional_second?
|
333
|
+
return !@fractional_second.nil?
|
334
|
+
end
|
335
|
+
|
336
|
+
def timezone=(timezone)
|
337
|
+
unless timezone.nil? or timezone.empty?
|
338
|
+
@timezone = Timezone.new(timezone)
|
339
|
+
else
|
340
|
+
@timezone = nil
|
341
|
+
end
|
342
|
+
end
|
343
|
+
|
344
|
+
def timezone
|
345
|
+
@timezone.to_s
|
346
|
+
end
|
347
|
+
|
348
|
+
def is_decimal_sign_comma?
|
349
|
+
false
|
350
|
+
end
|
351
|
+
|
352
|
+
def is_extended?
|
353
|
+
true
|
354
|
+
end
|
355
|
+
|
356
|
+
def is_partial?
|
357
|
+
second_unknown? or minute_unknown?
|
358
|
+
end
|
359
|
+
|
360
|
+
def as_string
|
361
|
+
s = sprintf("%02d", @hour)
|
362
|
+
if !@minute.nil?
|
363
|
+
s += ":" + sprintf("%02d",@minute)
|
364
|
+
if !@second.nil?
|
365
|
+
s += ":" + sprintf("%02d", @second)
|
366
|
+
if !@fractional_second.nil?
|
367
|
+
s += "." + @fractional_second.to_s[2..-1]
|
368
|
+
if !@timezone.nil?
|
369
|
+
s += @timezone.to_s
|
370
|
+
end
|
371
|
+
end
|
372
|
+
end
|
373
|
+
end
|
374
|
+
return s
|
375
|
+
end
|
376
|
+
|
377
|
+
def to_second
|
378
|
+
second = (nilthenzero(@hour)*60 + nilthenzero(@minute))*60 +
|
379
|
+
nilthenzero(@second) +
|
380
|
+
nilthenzero(@fractional_second)
|
381
|
+
return second
|
382
|
+
end
|
383
|
+
end
|
384
|
+
|
385
|
+
class ISO8601Time
|
386
|
+
include ISO8601TimeModule, Comparable
|
387
|
+
def initialize(string)
|
388
|
+
/^(\d{2}):?(\d{2})?(:?)(\d{2})?((\.|,)(\d+))?(Z|([+-](\d{2}):?(\d{2})))?$/ =~ string
|
389
|
+
if $2.nil?
|
390
|
+
self.minute = nil
|
391
|
+
else
|
392
|
+
self.minute = $2.to_i
|
393
|
+
end
|
394
|
+
if $4.nil?
|
395
|
+
self.second = nil
|
396
|
+
else
|
397
|
+
self.second = $4.to_i
|
398
|
+
end
|
399
|
+
if $1.nil?
|
400
|
+
raise ArgumentError, 'data invalid'
|
401
|
+
else
|
402
|
+
self.hour = $1.to_i
|
403
|
+
end
|
404
|
+
if $7.nil?
|
405
|
+
self.fractional_second = nil
|
406
|
+
else
|
407
|
+
self.fractional_second = ("0." + $7).to_f
|
408
|
+
end
|
409
|
+
if $8.nil?
|
410
|
+
self.timezone = nil
|
411
|
+
else
|
412
|
+
self.timezone = $8
|
413
|
+
end
|
414
|
+
end
|
415
|
+
|
416
|
+
def <=>(other)
|
417
|
+
self.to_second <=> other.to_second
|
418
|
+
end
|
419
|
+
|
420
|
+
def self.valid_iso8601_time?(s)
|
421
|
+
if /^(\d{2}):?(\d{2})?(:?)(\d{2})?((\.|,)(\d+))?(Z|([+-](\d{2}):?(\d{2})))?$/ =~ s
|
422
|
+
# ISO 8601 regular expression by H. Yuki
|
423
|
+
# http://digit.que.ne.jp/work/wiki.cgi?Perl%E3%83%A1%E3%83%A2%2FW3C%E5%BD%A2%E5%BC%8F%E3%81%AE%E6%97%A5%E6%99%82%E3%81%AE%E8%A7%A3%E6%9E%90
|
424
|
+
# (\d{4})(?:-(\d{2})(?:-(\d{2})(?:T(\d{2}):(\d{2})(?::(\d{2})(?:\.(\d))?)?(Z|([+-]\d{2}):(\d{2}))?)?)?)?
|
425
|
+
hh = $1; mm = $2; ss = $4; msec = $7; tz = $8
|
426
|
+
if hh.to_i == HOURS_IN_DAY and (mm.nil? or mm.to_i == 0) and (ss.nil? or ss.to_i == 0) and (msec.nil? or msec.to_i==0)
|
427
|
+
return true
|
428
|
+
end
|
429
|
+
if hh.nil? or (hh.to_i < 0 or hh.to_i >= HOURS_IN_DAY)
|
430
|
+
return false
|
431
|
+
end
|
432
|
+
if !mm.nil?
|
433
|
+
if !TimeDefinitions.valid_minute?(mm.to_i)
|
434
|
+
return false
|
435
|
+
end
|
436
|
+
end
|
437
|
+
if !ss.nil?
|
438
|
+
if !TimeDefinitions.valid_second?(ss.to_i)
|
439
|
+
return false
|
440
|
+
end
|
441
|
+
end
|
442
|
+
unless tz.nil?
|
443
|
+
timezone = Timezone.new(tz)
|
444
|
+
if timezone.hour < 0 or timezone.hour >= HOURS_IN_DAY
|
445
|
+
return false
|
446
|
+
end
|
447
|
+
if timezone.minute < 0 or timezone.minute >= MINUTES_IN_HOUR
|
448
|
+
return false
|
449
|
+
end
|
450
|
+
return true
|
451
|
+
else
|
452
|
+
return false
|
453
|
+
end
|
454
|
+
end
|
455
|
+
end
|
456
|
+
end # end of ISO8601_TIME
|
457
|
+
|
458
|
+
module ISO8601DateTimeModule
|
459
|
+
include ISO8601DateModule, ISO8601TimeModule
|
460
|
+
|
461
|
+
def as_string
|
462
|
+
if (!@year.nil? and !@month.nil? and !@day.nil?)
|
463
|
+
s = Date.new(@year, @month, @day).to_s
|
464
|
+
elsif (!@year.nil? and !@month.nil? and @day.nil?)
|
465
|
+
return Date.new(@year, @month).to_s[0,7]
|
466
|
+
elsif (!@year.nil? and @month.nil? and @day.nil?)
|
467
|
+
return Date.new(@year).to_s[0,4]
|
468
|
+
end
|
469
|
+
unless hour.nil?
|
470
|
+
s += sprintf("T%02d", @hour)
|
471
|
+
unless @minute.nil?
|
472
|
+
s += ":" + sprintf("%02d",@minute)
|
473
|
+
unless @second.nil?
|
474
|
+
s += ":" + sprintf("%02d", @second)
|
475
|
+
unless @fractional_second.nil?
|
476
|
+
s += "." + @fractional_second.to_s[2..-1]
|
477
|
+
end
|
478
|
+
end
|
479
|
+
end
|
480
|
+
unless @timezone.nil?
|
481
|
+
s += @timezone.to_s
|
482
|
+
end
|
483
|
+
end
|
484
|
+
return s
|
485
|
+
end
|
486
|
+
end
|
487
|
+
|
488
|
+
class ISO8601DateTime
|
489
|
+
include ISO8601DateTimeModule
|
490
|
+
def initialize(string)
|
491
|
+
unless /(\d{4})(?:-(\d{2})(?:-(\d{2}))?)?T(\d{2})(?::(\d{2})(?::(\d{2})(?:(\.|,)(\d+))?)?(Z|([+-]\d{2}):?(\d{2}))?)?/ =~ string
|
492
|
+
raise ArgumentError, 'format invalid'
|
493
|
+
else
|
494
|
+
self.year = $1.to_i
|
495
|
+
end
|
496
|
+
if $2.nil?
|
497
|
+
self.month = nil
|
498
|
+
else
|
499
|
+
self.month = $2.to_i
|
500
|
+
end
|
501
|
+
if $3.nil?
|
502
|
+
self.day = nil
|
503
|
+
else
|
504
|
+
self.day = $3.to_i
|
505
|
+
end
|
506
|
+
if $5.nil?
|
507
|
+
self.minute = nil
|
508
|
+
else
|
509
|
+
self.minute = $5.to_i
|
510
|
+
end
|
511
|
+
if $6.nil?
|
512
|
+
self.second = nil
|
513
|
+
else
|
514
|
+
self.second = $6.to_i
|
515
|
+
end
|
516
|
+
if $4.nil?
|
517
|
+
self.hour = nil
|
518
|
+
else
|
519
|
+
self.hour = $4.to_i
|
520
|
+
end
|
521
|
+
if $8.nil? or $8.empty?
|
522
|
+
self.fractional_second = nil
|
523
|
+
else
|
524
|
+
self.fractional_second = ("0."+$8).to_f
|
525
|
+
end
|
526
|
+
if $9.nil?
|
527
|
+
self.timezone = nil
|
528
|
+
else
|
529
|
+
self.timezone = $9
|
530
|
+
end
|
531
|
+
end
|
532
|
+
|
533
|
+
def <=>(other)
|
534
|
+
self.magnitude <=> other.magnitude
|
535
|
+
end
|
536
|
+
|
537
|
+
protected
|
538
|
+
def magnitude
|
539
|
+
return self.to_days*HOURS_IN_DAY*MINUTES_IN_HOUR*SECONDS_IN_MINUTE +
|
540
|
+
self.to_second
|
541
|
+
end
|
542
|
+
end
|
543
|
+
|
544
|
+
class ISO8601Timezone
|
545
|
+
def initialize(string)
|
546
|
+
@timezone = Timezone.new(string)
|
547
|
+
end
|
548
|
+
|
549
|
+
def hour
|
550
|
+
return @timezone.hour
|
551
|
+
end
|
552
|
+
|
553
|
+
def minute
|
554
|
+
return @timezone.minute
|
555
|
+
end
|
556
|
+
|
557
|
+
def sign
|
558
|
+
if @timezone.hour < 0
|
559
|
+
return -1
|
560
|
+
else
|
561
|
+
return +1
|
562
|
+
end
|
563
|
+
end
|
564
|
+
|
565
|
+
def is_gmt?
|
566
|
+
return (@timezone.hour == 0 and @timezone.minute == 0)
|
567
|
+
end
|
568
|
+
|
569
|
+
def as_string
|
570
|
+
if @timezone.hour < 0
|
571
|
+
s = ''
|
572
|
+
else
|
573
|
+
s = '+'
|
574
|
+
end
|
575
|
+
sprintf("%s%02d%02d", s, @timezone.hour, @timezone.minute)
|
576
|
+
end
|
577
|
+
|
578
|
+
alias to_s as_string
|
579
|
+
alias gmt? is_gmt?
|
580
|
+
end # end of ISO8601Timezone
|
581
|
+
|
582
|
+
module ISO8601DurationModule
|
583
|
+
include TimeDefinitions
|
584
|
+
attr_reader :years, :months, :weeks, :days
|
585
|
+
attr_reader :hours, :minutes, :seconds, :fractional_second
|
586
|
+
|
587
|
+
def years=(years)
|
588
|
+
unless years.nil? || years >= 0
|
589
|
+
raise ArgumentError, 'years must be above zero'
|
590
|
+
end
|
591
|
+
@years = years
|
592
|
+
end
|
593
|
+
|
594
|
+
def months=(months)
|
595
|
+
unless months.nil? || months >= 0
|
596
|
+
raise ArgumentError, 'months must be above zero'
|
597
|
+
end
|
598
|
+
@months = months
|
599
|
+
end
|
600
|
+
|
601
|
+
def weeks=(weeks)
|
602
|
+
unless weeks.nil? || weeks >= 0
|
603
|
+
raise ArgumentError, 'weeks must be above zero'
|
604
|
+
end
|
605
|
+
@weeks = weeks
|
606
|
+
end
|
607
|
+
|
608
|
+
def days=(days)
|
609
|
+
unless days.nil? || days >= 0
|
610
|
+
raise ArgumentError, 'days must be above zero'
|
611
|
+
end
|
612
|
+
@days = days
|
613
|
+
end
|
614
|
+
|
615
|
+
def hours=(hours)
|
616
|
+
unless hours.nil? || hours >= 0
|
617
|
+
raise ArgumentError, 'hours must be above zero'
|
618
|
+
end
|
619
|
+
@hours = hours
|
620
|
+
end
|
621
|
+
|
622
|
+
def minutes=(minutes)
|
623
|
+
unless minutes.nil? || minutes >= 0
|
624
|
+
raise ArgumentError, 'minutes must be above zero'
|
625
|
+
end
|
626
|
+
@minutes = minutes
|
627
|
+
end
|
628
|
+
|
629
|
+
def seconds=(seconds)
|
630
|
+
unless seconds.nil? || seconds >= 0
|
631
|
+
raise ArgumentError, 'seconds must be above zero'
|
632
|
+
end
|
633
|
+
@seconds = seconds
|
634
|
+
end
|
635
|
+
|
636
|
+
def fractional_second=(fractional_second)
|
637
|
+
unless fractional_second.nil? || (fractional_second >= 0 && fractional_second < 1.0)
|
638
|
+
raise ArgumentError, 'fractional_second must be between 0.0 and 1.0'
|
639
|
+
end
|
640
|
+
@fractional_second = fractional_second
|
641
|
+
end
|
642
|
+
|
643
|
+
def as_string
|
644
|
+
str = 'P'
|
645
|
+
unless @years.nil?
|
646
|
+
str += @years.to_s + 'Y'
|
647
|
+
end
|
648
|
+
unless @months.nil?
|
649
|
+
str += @months.to_s + 'M'
|
650
|
+
end
|
651
|
+
unless @weeks.nil?
|
652
|
+
str += @weeks.to_s + 'W'
|
653
|
+
end
|
654
|
+
unless @days.nil?
|
655
|
+
str += @days.to_s + 'D'
|
656
|
+
end
|
657
|
+
unless @hours.nil?
|
658
|
+
str += 'T' + @hours.to_s + 'H'
|
659
|
+
unless @minutes.nil?
|
660
|
+
str += @minutes.to_s + 'M'
|
661
|
+
unless @seconds.nil?
|
662
|
+
str += @seconds.to_s
|
663
|
+
unless @fractional_second.nil?
|
664
|
+
str += @fractional_second.to_s[1 .. -1]
|
665
|
+
end
|
666
|
+
str += 'S'
|
667
|
+
end
|
668
|
+
end
|
669
|
+
end
|
670
|
+
return str
|
671
|
+
end
|
672
|
+
end
|
673
|
+
|
674
|
+
class ISO8601Duration
|
675
|
+
include ISO8601DurationModule
|
676
|
+
def initialize(str)
|
677
|
+
/^P((\d+)[Yy])?((\d+)[Mm])?((\d+)[Ww])?((\d)[dD])?(T((\d+)[Hh])?((\d+)[Mm])?((\d+)(\.\d+)?[Ss])?)?$/ =~ str
|
678
|
+
self.years = $2.to_i
|
679
|
+
self.months = $4.to_i
|
680
|
+
self.weeks = $6.to_i
|
681
|
+
self.days = $8.to_i
|
682
|
+
self.hours = $11.to_i
|
683
|
+
self.minutes = $13.to_i
|
684
|
+
self.seconds = $15.to_i
|
685
|
+
unless $16.nil?
|
686
|
+
self.fractional_second = $16.to_f
|
687
|
+
end
|
688
|
+
end
|
689
|
+
end # end of ISO8601Duration
|
690
|
+
end # end of Assumed_Types
|
691
|
+
end # end of OpenEHR
|