compact_real_string Subroutine

private subroutine compact_real_string(str)

Compact a string representing a real number, so that the same value is displayed with fewer characters.

See also

Arguments

Type IntentOptional Attributes Name
character(kind=CK, len=*), intent(inout) :: str

string representation of a real number.


Called by

proc~~compact_real_string~~CalledByGraph proc~compact_real_string json_string_utilities::compact_real_string proc~real_to_string json_string_utilities::real_to_string proc~real_to_string->proc~compact_real_string proc~json_get_string json_value_module::json_core%json_get_string proc~json_get_string->proc~real_to_string proc~json_value_print json_value_module::json_core%json_value_print proc~json_value_print->proc~real_to_string proc~json_value_print->proc~json_value_print proc~json_is_vector json_value_module::json_core%json_is_vector proc~json_value_print->proc~json_is_vector none~get json_value_module::json_core%get none~get->proc~json_get_string proc~json_get_alloc_string_vec json_value_module::json_core%json_get_alloc_string_vec none~get->proc~json_get_alloc_string_vec proc~json_get_alloc_string_vec_by_path json_value_module::json_core%json_get_alloc_string_vec_by_path none~get->proc~json_get_alloc_string_vec_by_path proc~json_get_array_by_path json_value_module::json_core%json_get_array_by_path none~get->proc~json_get_array_by_path proc~json_get_integer_by_path json_value_module::json_core%json_get_integer_by_path none~get->proc~json_get_integer_by_path proc~json_get_integer_vec json_value_module::json_core%json_get_integer_vec none~get->proc~json_get_integer_vec proc~json_get_integer_vec_by_path json_value_module::json_core%json_get_integer_vec_by_path none~get->proc~json_get_integer_vec_by_path proc~json_get_logical_by_path json_value_module::json_core%json_get_logical_by_path none~get->proc~json_get_logical_by_path proc~json_get_logical_vec json_value_module::json_core%json_get_logical_vec none~get->proc~json_get_logical_vec proc~json_get_logical_vec_by_path json_value_module::json_core%json_get_logical_vec_by_path none~get->proc~json_get_logical_vec_by_path proc~json_get_real32 json_value_module::json_core%json_get_real32 none~get->proc~json_get_real32 proc~json_get_real32_by_path json_value_module::json_core%json_get_real32_by_path none~get->proc~json_get_real32_by_path proc~json_get_real32_vec json_value_module::json_core%json_get_real32_vec none~get->proc~json_get_real32_vec proc~json_get_real32_vec_by_path json_value_module::json_core%json_get_real32_vec_by_path none~get->proc~json_get_real32_vec_by_path proc~json_get_real_by_path json_value_module::json_core%json_get_real_by_path none~get->proc~json_get_real_by_path proc~json_get_real_vec json_value_module::json_core%json_get_real_vec none~get->proc~json_get_real_vec proc~json_get_real_vec_by_path json_value_module::json_core%json_get_real_vec_by_path none~get->proc~json_get_real_vec_by_path proc~json_get_string_by_path json_value_module::json_core%json_get_string_by_path none~get->proc~json_get_string_by_path proc~json_get_string_vec json_value_module::json_core%json_get_string_vec none~get->proc~json_get_string_vec proc~json_get_string_vec_by_path json_value_module::json_core%json_get_string_vec_by_path none~get->proc~json_get_string_vec_by_path proc~wrap_json_get_alloc_string_vec_by_path json_value_module::json_core%wrap_json_get_alloc_string_vec_by_path none~get->proc~wrap_json_get_alloc_string_vec_by_path proc~wrap_json_get_array_by_path json_value_module::json_core%wrap_json_get_array_by_path none~get->proc~wrap_json_get_array_by_path proc~wrap_json_get_by_path json_value_module::json_core%wrap_json_get_by_path none~get->proc~wrap_json_get_by_path proc~wrap_json_get_integer_by_path json_value_module::json_core%wrap_json_get_integer_by_path none~get->proc~wrap_json_get_integer_by_path proc~wrap_json_get_integer_vec_by_path json_value_module::json_core%wrap_json_get_integer_vec_by_path none~get->proc~wrap_json_get_integer_vec_by_path proc~wrap_json_get_logical_by_path json_value_module::json_core%wrap_json_get_logical_by_path none~get->proc~wrap_json_get_logical_by_path proc~wrap_json_get_logical_vec_by_path json_value_module::json_core%wrap_json_get_logical_vec_by_path none~get->proc~wrap_json_get_logical_vec_by_path proc~wrap_json_get_real32_by_path json_value_module::json_core%wrap_json_get_real32_by_path none~get->proc~wrap_json_get_real32_by_path proc~wrap_json_get_real32_vec_by_path json_value_module::json_core%wrap_json_get_real32_vec_by_path none~get->proc~wrap_json_get_real32_vec_by_path proc~wrap_json_get_real_by_path json_value_module::json_core%wrap_json_get_real_by_path none~get->proc~wrap_json_get_real_by_path proc~wrap_json_get_real_vec_by_path json_value_module::json_core%wrap_json_get_real_vec_by_path none~get->proc~wrap_json_get_real_vec_by_path proc~wrap_json_get_string_by_path json_value_module::json_core%wrap_json_get_string_by_path none~get->proc~wrap_json_get_string_by_path proc~wrap_json_get_string_vec_by_path json_value_module::json_core%wrap_json_get_string_vec_by_path none~get->proc~wrap_json_get_string_vec_by_path proc~json_get_by_path json_value_module::json_core%json_get_by_path none~get->proc~json_get_by_path proc~json_print_to_unit json_value_module::json_core%json_print_to_unit proc~json_print_to_unit->proc~json_value_print proc~json_value_to_string json_value_module::json_core%json_value_to_string proc~json_value_to_string->proc~json_value_print proc~assign_json_file_to_string json_file_module::json_file%assign_json_file_to_string proc~assign_json_file_to_string->proc~json_value_to_string proc~json_file_get_alloc_string_vec json_file_module::json_file%json_file_get_alloc_string_vec proc~json_file_get_alloc_string_vec->none~get proc~json_file_get_integer json_file_module::json_file%json_file_get_integer proc~json_file_get_integer->none~get proc~json_file_get_integer_vec json_file_module::json_file%json_file_get_integer_vec proc~json_file_get_integer_vec->none~get proc~json_file_get_logical json_file_module::json_file%json_file_get_logical proc~json_file_get_logical->none~get proc~json_file_get_logical_vec json_file_module::json_file%json_file_get_logical_vec proc~json_file_get_logical_vec->none~get proc~json_file_get_object json_file_module::json_file%json_file_get_object proc~json_file_get_object->none~get proc~json_file_get_real json_file_module::json_file%json_file_get_real proc~json_file_get_real->none~get proc~json_file_get_real32 json_file_module::json_file%json_file_get_real32 proc~json_file_get_real32->none~get proc~json_file_get_real32_vec json_file_module::json_file%json_file_get_real32_vec proc~json_file_get_real32_vec->none~get proc~json_file_get_real_vec json_file_module::json_file%json_file_get_real_vec proc~json_file_get_real_vec->none~get proc~json_file_get_string json_file_module::json_file%json_file_get_string proc~json_file_get_string->none~get proc~json_file_get_string_vec json_file_module::json_file%json_file_get_string_vec proc~json_file_get_string_vec->none~get proc~json_file_print_to_string json_file_module::json_file%json_file_print_to_string proc~json_file_print_to_string->proc~json_value_to_string proc~json_get_alloc_string_vec->none~get none~string_info json_value_module::json_core%string_info proc~json_get_alloc_string_vec->none~string_info proc~json_get_alloc_string_vec_by_path->none~get proc~json_get_array_by_path->none~get proc~json_get_integer_by_path->none~get proc~json_get_integer_vec->none~get proc~json_get_integer_vec_by_path->none~get proc~json_get_logical_by_path->none~get proc~json_get_logical_vec->none~get proc~json_get_logical_vec_by_path->none~get proc~json_get_real32->none~get proc~json_get_real32_by_path->none~get proc~json_get_real32_vec->none~get proc~json_get_real32_vec_by_path->none~get proc~json_get_real_by_path->none~get proc~json_get_real_vec->none~get proc~json_get_real_vec_by_path->none~get proc~json_get_string_by_path->none~get proc~json_get_string_vec->none~get proc~json_get_string_vec_by_path->none~get proc~json_info_by_path json_value_module::json_core%json_info_by_path proc~json_info_by_path->none~get none~info json_value_module::json_core%info proc~json_info_by_path->none~info proc~json_matrix_info_by_path json_value_module::json_core%json_matrix_info_by_path proc~json_matrix_info_by_path->none~get none~matrix_info json_value_module::json_core%matrix_info proc~json_matrix_info_by_path->none~matrix_info proc~json_rename_by_path json_value_module::json_core%json_rename_by_path proc~json_rename_by_path->none~get proc~json_string_info json_value_module::json_core%json_string_info proc~json_string_info->none~get proc~json_string_info->none~info proc~json_update_integer json_value_module::json_core%json_update_integer proc~json_update_integer->none~get proc~json_update_integer->none~info none~add_by_path~2 json_value_module::json_core%add_by_path proc~json_update_integer->none~add_by_path~2 proc~json_update_logical json_value_module::json_core%json_update_logical proc~json_update_logical->none~get proc~json_update_logical->none~info proc~json_update_logical->none~add_by_path~2 proc~json_update_real json_value_module::json_core%json_update_real proc~json_update_real->none~get proc~json_update_real->none~info proc~json_update_real->none~add_by_path~2 proc~json_update_string json_value_module::json_core%json_update_string proc~json_update_string->none~get proc~json_update_string->none~info proc~json_update_string->none~add_by_path~2 proc~json_valid_path json_value_module::json_core%json_valid_path proc~json_valid_path->none~get proc~json_value_remove_if_present json_value_module::json_core%json_value_remove_if_present proc~json_value_remove_if_present->none~get proc~wrap_json_get_alloc_string_vec_by_path->none~get proc~wrap_json_get_array_by_path->none~get proc~wrap_json_get_by_path->none~get proc~wrap_json_get_integer_by_path->none~get proc~wrap_json_get_integer_vec_by_path->none~get proc~wrap_json_get_logical_by_path->none~get proc~wrap_json_get_logical_vec_by_path->none~get proc~wrap_json_get_real32_by_path->none~get proc~wrap_json_get_real32_vec_by_path->none~get proc~wrap_json_get_real_by_path->none~get proc~wrap_json_get_real_vec_by_path->none~get proc~wrap_json_get_string_by_path->none~get proc~wrap_json_get_string_vec_by_path->none~get proc~wrap_json_value_get_child_by_name json_value_module::json_core%wrap_json_value_get_child_by_name proc~wrap_json_value_get_child_by_name->none~get none~get_child json_value_module::json_core%get_child none~get_child->proc~wrap_json_value_get_child_by_name none~get~2 json_file_module::json_file%get none~get~2->proc~json_file_get_alloc_string_vec none~get~2->proc~json_file_get_integer none~get~2->proc~json_file_get_integer_vec none~get~2->proc~json_file_get_logical none~get~2->proc~json_file_get_logical_vec none~get~2->proc~json_file_get_object none~get~2->proc~json_file_get_real none~get~2->proc~json_file_get_real32 none~get~2->proc~json_file_get_real32_vec none~get~2->proc~json_file_get_real_vec none~get~2->proc~json_file_get_string none~get~2->proc~json_file_get_string_vec proc~wrap_json_file_get_alloc_string_vec json_file_module::json_file%wrap_json_file_get_alloc_string_vec none~get~2->proc~wrap_json_file_get_alloc_string_vec proc~wrap_json_file_get_integer json_file_module::json_file%wrap_json_file_get_integer none~get~2->proc~wrap_json_file_get_integer proc~wrap_json_file_get_integer_vec json_file_module::json_file%wrap_json_file_get_integer_vec none~get~2->proc~wrap_json_file_get_integer_vec proc~wrap_json_file_get_logical json_file_module::json_file%wrap_json_file_get_logical none~get~2->proc~wrap_json_file_get_logical proc~wrap_json_file_get_logical_vec json_file_module::json_file%wrap_json_file_get_logical_vec none~get~2->proc~wrap_json_file_get_logical_vec proc~wrap_json_file_get_object json_file_module::json_file%wrap_json_file_get_object none~get~2->proc~wrap_json_file_get_object proc~wrap_json_file_get_real json_file_module::json_file%wrap_json_file_get_real none~get~2->proc~wrap_json_file_get_real proc~wrap_json_file_get_real32 json_file_module::json_file%wrap_json_file_get_real32 none~get~2->proc~wrap_json_file_get_real32 proc~wrap_json_file_get_real32_vec json_file_module::json_file%wrap_json_file_get_real32_vec none~get~2->proc~wrap_json_file_get_real32_vec proc~wrap_json_file_get_real_vec json_file_module::json_file%wrap_json_file_get_real_vec none~get~2->proc~wrap_json_file_get_real_vec proc~wrap_json_file_get_string json_file_module::json_file%wrap_json_file_get_string none~get~2->proc~wrap_json_file_get_string proc~wrap_json_file_get_string_vec json_file_module::json_file%wrap_json_file_get_string_vec none~get~2->proc~wrap_json_file_get_string_vec none~info->proc~json_info_by_path proc~wrap_json_info_by_path json_value_module::json_core%wrap_json_info_by_path none~info->proc~wrap_json_info_by_path none~matrix_info->proc~json_matrix_info_by_path proc~json_matrix_info json_value_module::json_core%json_matrix_info none~matrix_info->proc~json_matrix_info proc~wrap_json_matrix_info_by_path json_value_module::json_core%wrap_json_matrix_info_by_path none~matrix_info->proc~wrap_json_matrix_info_by_path none~remove_if_present json_value_module::json_core%remove_if_present none~remove_if_present->proc~json_value_remove_if_present proc~wrap_json_value_remove_if_present json_value_module::json_core%wrap_json_value_remove_if_present none~remove_if_present->proc~wrap_json_value_remove_if_present none~string_info->proc~json_string_info none~valid_path json_value_module::json_core%valid_path none~valid_path->proc~json_valid_path proc~wrap_json_valid_path json_value_module::json_core%wrap_json_valid_path none~valid_path->proc~wrap_json_valid_path proc~convert json_value_module::json_core%convert proc~convert->none~info proc~json_value_replace json_value_module::json_core%json_value_replace proc~convert->proc~json_value_replace proc~json_add_integer_by_path json_value_module::json_core%json_add_integer_by_path proc~json_add_integer_by_path->none~info none~create json_value_module::json_core%create proc~json_add_integer_by_path->none~create proc~json_add_integer_by_path->proc~json_value_replace proc~json_add_integer_vec_by_path json_value_module::json_core%json_add_integer_vec_by_path proc~json_add_integer_vec_by_path->none~info proc~json_add_integer_vec_by_path->none~create proc~json_add_integer_vec_by_path->proc~json_value_replace proc~json_add_logical_by_path json_value_module::json_core%json_add_logical_by_path proc~json_add_logical_by_path->none~info proc~json_add_logical_by_path->none~create proc~json_add_logical_by_path->proc~json_value_replace proc~json_add_logical_vec_by_path json_value_module::json_core%json_add_logical_vec_by_path proc~json_add_logical_vec_by_path->none~info proc~json_add_logical_vec_by_path->none~create proc~json_add_logical_vec_by_path->proc~json_value_replace proc~json_add_member_by_path json_value_module::json_core%json_add_member_by_path proc~json_add_member_by_path->none~info proc~json_add_member_by_path->none~create proc~json_add_member_by_path->proc~json_value_replace proc~json_add_real_by_path json_value_module::json_core%json_add_real_by_path proc~json_add_real_by_path->none~info proc~json_add_real_by_path->none~create proc~json_add_real_by_path->proc~json_value_replace proc~json_add_real_vec_by_path json_value_module::json_core%json_add_real_vec_by_path proc~json_add_real_vec_by_path->none~info proc~json_add_real_vec_by_path->none~create proc~json_add_real_vec_by_path->proc~json_value_replace proc~json_add_string_by_path json_value_module::json_core%json_add_string_by_path proc~json_add_string_by_path->none~info proc~json_add_string_by_path->none~create proc~json_add_string_by_path->proc~json_value_replace proc~json_add_string_vec_by_path json_value_module::json_core%json_add_string_vec_by_path proc~json_add_string_vec_by_path->none~info proc~json_add_string_vec_by_path->none~create proc~json_add_string_vec_by_path->proc~json_value_replace proc~json_check_children_for_duplicate_keys json_value_module::json_core%json_check_children_for_duplicate_keys proc~json_check_children_for_duplicate_keys->none~get_child none~get_path json_value_module::json_core%get_path proc~json_check_children_for_duplicate_keys->none~get_path proc~json_file_remove json_file_module::json_file%json_file_remove proc~json_file_remove->none~remove_if_present proc~json_file_valid_path json_file_module::json_file%json_file_valid_path proc~json_file_valid_path->none~valid_path proc~json_file_valid_path_op json_file_module::json_file%json_file_valid_path_op proc~json_file_valid_path_op->none~valid_path proc~json_file_variable_info json_file_module::json_file%json_file_variable_info proc~json_file_variable_info->none~info proc~json_file_variable_matrix_info json_file_module::json_file%json_file_variable_matrix_info proc~json_file_variable_matrix_info->none~matrix_info proc~json_get_by_path_default json_value_module::json_core%json_get_by_path_default proc~json_get_by_path_default->none~get_child proc~json_get_by_path_jsonpath_bracket json_value_module::json_core%json_get_by_path_jsonpath_bracket proc~json_get_by_path_jsonpath_bracket->none~get_child proc~json_get_by_path_jsonpath_bracket->proc~convert proc~json_get_by_path_rfc6901 json_value_module::json_core%json_get_by_path_rfc6901 proc~json_get_by_path_rfc6901->none~get_child proc~json_get_path json_value_module::json_core%json_get_path proc~json_get_path->none~info proc~json_is_vector->none~info proc~json_matrix_info->none~get_child proc~json_matrix_info->none~info proc~json_value_add_member json_value_module::json_core%json_value_add_member proc~json_value_add_member->none~info proc~json_value_insert_after_child_by_index json_value_module::json_core%json_value_insert_after_child_by_index proc~json_value_insert_after_child_by_index->none~get_child none~insert_after json_value_module::json_core%insert_after proc~json_value_insert_after_child_by_index->none~insert_after proc~json_value_reverse json_value_module::json_core%json_value_reverse proc~json_value_reverse->none~info proc~wrap_json_file_get_alloc_string_vec->none~get~2 proc~wrap_json_file_get_integer->none~get~2 proc~wrap_json_file_get_integer_vec->none~get~2 proc~wrap_json_file_get_logical->none~get~2 proc~wrap_json_file_get_logical_vec->none~get~2 proc~wrap_json_file_get_object->none~get~2 proc~wrap_json_file_get_real->none~get~2 proc~wrap_json_file_get_real32->none~get~2 proc~wrap_json_file_get_real32_vec->none~get~2 proc~wrap_json_file_get_real_vec->none~get~2 proc~wrap_json_file_get_string->none~get~2 proc~wrap_json_file_get_string_vec->none~get~2 proc~wrap_json_info_by_path->none~info proc~wrap_json_matrix_info_by_path->none~matrix_info proc~wrap_json_valid_path->none~valid_path proc~wrap_json_value_remove_if_present->none~remove_if_present none~get_path->proc~json_get_path proc~wrap_json_get_path json_value_module::json_core%wrap_json_get_path none~get_path->proc~wrap_json_get_path none~info~2 json_file_module::json_file%info none~info~2->proc~json_file_variable_info proc~wrap_json_file_variable_info json_file_module::json_file%wrap_json_file_variable_info none~info~2->proc~wrap_json_file_variable_info none~insert_after->proc~json_value_insert_after_child_by_index none~matrix_info~2 json_file_module::json_file%matrix_info none~matrix_info~2->proc~json_file_variable_matrix_info proc~wrap_json_file_variable_matrix_info json_file_module::json_file%wrap_json_file_variable_matrix_info none~matrix_info~2->proc~wrap_json_file_variable_matrix_info none~remove~2 json_file_module::json_file%remove none~remove~2->proc~json_file_remove proc~wrap_json_file_remove json_file_module::json_file%wrap_json_file_remove none~remove~2->proc~wrap_json_file_remove none~valid_path~2 json_file_module::json_file%valid_path none~valid_path~2->proc~json_file_valid_path proc~wrap_json_file_valid_path json_file_module::json_file%wrap_json_file_valid_path none~valid_path~2->proc~wrap_json_file_valid_path proc~json_add_string_by_path_path_ascii json_value_module::json_core%json_add_string_by_path_path_ascii proc~json_add_string_by_path_path_ascii->proc~json_add_string_by_path proc~json_add_string_by_path_value_ascii json_value_module::json_core%json_add_string_by_path_value_ascii proc~json_add_string_by_path_value_ascii->proc~json_add_string_by_path proc~json_add_string_vec_by_path_path_ascii json_value_module::json_core%json_add_string_vec_by_path_path_ascii proc~json_add_string_vec_by_path_path_ascii->proc~json_add_string_vec_by_path proc~json_add_string_vec_by_path_value_ascii json_value_module::json_core%json_add_string_vec_by_path_value_ascii proc~json_add_string_vec_by_path_value_ascii->proc~json_add_string_vec_by_path proc~json_create_by_path json_value_module::json_core%json_create_by_path proc~json_create_by_path->proc~json_get_by_path_default proc~json_create_by_path->proc~json_get_by_path_jsonpath_bracket proc~json_get_by_path->proc~json_get_by_path_default proc~json_get_by_path->proc~json_get_by_path_jsonpath_bracket proc~json_get_by_path->proc~json_get_by_path_rfc6901 proc~wrap_json_add_integer_by_path json_value_module::json_core%wrap_json_add_integer_by_path proc~wrap_json_add_integer_by_path->proc~json_add_integer_by_path proc~wrap_json_add_integer_vec_by_path json_value_module::json_core%wrap_json_add_integer_vec_by_path proc~wrap_json_add_integer_vec_by_path->proc~json_add_integer_vec_by_path proc~wrap_json_add_logical_by_path json_value_module::json_core%wrap_json_add_logical_by_path proc~wrap_json_add_logical_by_path->proc~json_add_logical_by_path proc~wrap_json_add_logical_vec_by_path json_value_module::json_core%wrap_json_add_logical_vec_by_path proc~wrap_json_add_logical_vec_by_path->proc~json_add_logical_vec_by_path proc~wrap_json_add_member_by_path json_value_module::json_core%wrap_json_add_member_by_path proc~wrap_json_add_member_by_path->proc~json_add_member_by_path proc~wrap_json_add_real_by_path json_value_module::json_core%wrap_json_add_real_by_path proc~wrap_json_add_real_by_path->proc~json_add_real_by_path proc~wrap_json_add_real_vec_by_path json_value_module::json_core%wrap_json_add_real_vec_by_path proc~wrap_json_add_real_vec_by_path->proc~json_add_real_vec_by_path proc~wrap_json_add_string_by_path json_value_module::json_core%wrap_json_add_string_by_path proc~wrap_json_add_string_by_path->proc~json_add_string_by_path proc~wrap_json_add_string_vec_by_path json_value_module::json_core%wrap_json_add_string_vec_by_path proc~wrap_json_add_string_vec_by_path->proc~json_add_string_vec_by_path none~add_by_path~2->proc~json_add_string_by_path_path_ascii none~add_by_path~2->proc~json_add_string_by_path_value_ascii none~add_by_path~2->proc~json_add_string_vec_by_path_path_ascii none~add_by_path~2->proc~json_add_string_vec_by_path_value_ascii none~create->proc~json_create_by_path proc~wrap_json_create_by_path json_value_module::json_core%wrap_json_create_by_path none~create->proc~wrap_json_create_by_path proc~json_value_replace->none~insert_after proc~wrap_json_file_remove->none~remove~2 proc~wrap_json_file_valid_path->none~valid_path~2 proc~wrap_json_file_variable_info->none~info~2 proc~wrap_json_file_variable_matrix_info->none~matrix_info~2 proc~wrap_json_get_path->none~get_path proc~json_add_real32_by_path json_value_module::json_core%json_add_real32_by_path proc~json_add_real32_by_path->none~add_by_path~2 proc~json_add_real32_vec_by_path json_value_module::json_core%json_add_real32_vec_by_path proc~json_add_real32_vec_by_path->none~add_by_path~2 proc~json_file_add_integer json_file_module::json_file%json_file_add_integer proc~json_file_add_integer->none~add_by_path~2 proc~json_file_add_integer_vec json_file_module::json_file%json_file_add_integer_vec proc~json_file_add_integer_vec->none~add_by_path~2 proc~json_file_add_logical json_file_module::json_file%json_file_add_logical proc~json_file_add_logical->none~add_by_path~2 proc~json_file_add_logical_vec json_file_module::json_file%json_file_add_logical_vec proc~json_file_add_logical_vec->none~add_by_path~2 proc~json_file_add_object json_file_module::json_file%json_file_add_object proc~json_file_add_object->none~add_by_path~2 proc~json_file_add_real json_file_module::json_file%json_file_add_real proc~json_file_add_real->none~add_by_path~2 proc~json_file_add_real32 json_file_module::json_file%json_file_add_real32 proc~json_file_add_real32->none~add_by_path~2 proc~json_file_add_real32_vec json_file_module::json_file%json_file_add_real32_vec proc~json_file_add_real32_vec->none~add_by_path~2 proc~json_file_add_real_vec json_file_module::json_file%json_file_add_real_vec proc~json_file_add_real_vec->none~add_by_path~2 proc~json_file_add_string json_file_module::json_file%json_file_add_string proc~json_file_add_string->none~add_by_path~2 proc~json_file_add_string_vec json_file_module::json_file%json_file_add_string_vec proc~json_file_add_string_vec->none~add_by_path~2 proc~wrap_json_add_real32_by_path json_value_module::json_core%wrap_json_add_real32_by_path proc~wrap_json_add_real32_by_path->none~add_by_path~2 proc~wrap_json_add_real32_vec_by_path json_value_module::json_core%wrap_json_add_real32_vec_by_path proc~wrap_json_add_real32_vec_by_path->none~add_by_path~2 proc~wrap_json_create_by_path->none~create proc~json_file_add_string_path_ascii json_file_module::json_file%json_file_add_string_path_ascii proc~json_file_add_string_path_ascii->proc~json_file_add_string proc~json_file_add_string_value_ascii json_file_module::json_file%json_file_add_string_value_ascii proc~json_file_add_string_value_ascii->proc~json_file_add_string proc~json_file_add_string_vec_path_ascii json_file_module::json_file%json_file_add_string_vec_path_ascii proc~json_file_add_string_vec_path_ascii->proc~json_file_add_string_vec proc~json_file_add_string_vec_vec_ascii json_file_module::json_file%json_file_add_string_vec_vec_ascii proc~json_file_add_string_vec_vec_ascii->proc~json_file_add_string_vec proc~wrap_json_file_add_integer json_file_module::json_file%wrap_json_file_add_integer proc~wrap_json_file_add_integer->proc~json_file_add_integer proc~wrap_json_file_add_integer_vec json_file_module::json_file%wrap_json_file_add_integer_vec proc~wrap_json_file_add_integer_vec->proc~json_file_add_integer_vec proc~wrap_json_file_add_logical json_file_module::json_file%wrap_json_file_add_logical proc~wrap_json_file_add_logical->proc~json_file_add_logical proc~wrap_json_file_add_logical_vec json_file_module::json_file%wrap_json_file_add_logical_vec proc~wrap_json_file_add_logical_vec->proc~json_file_add_logical_vec proc~wrap_json_file_add_object json_file_module::json_file%wrap_json_file_add_object proc~wrap_json_file_add_object->proc~json_file_add_object proc~wrap_json_file_add_real json_file_module::json_file%wrap_json_file_add_real proc~wrap_json_file_add_real->proc~json_file_add_real proc~wrap_json_file_add_real32 json_file_module::json_file%wrap_json_file_add_real32 proc~wrap_json_file_add_real32->proc~json_file_add_real32 proc~wrap_json_file_add_real32_vec json_file_module::json_file%wrap_json_file_add_real32_vec proc~wrap_json_file_add_real32_vec->proc~json_file_add_real32_vec proc~wrap_json_file_add_real_vec json_file_module::json_file%wrap_json_file_add_real_vec proc~wrap_json_file_add_real_vec->proc~json_file_add_real_vec proc~wrap_json_file_add_string json_file_module::json_file%wrap_json_file_add_string proc~wrap_json_file_add_string->proc~json_file_add_string proc~wrap_json_file_add_string_vec json_file_module::json_file%wrap_json_file_add_string_vec proc~wrap_json_file_add_string_vec->proc~json_file_add_string_vec

Source Code

    subroutine compact_real_string(str)

    implicit none

    character(kind=CK,len=*),intent(inout) :: str  !! string representation of a real number.

    character(kind=CK,len=len(str)) :: significand
    character(kind=CK,len=len(str)) :: expnt
    character(kind=CK,len=2) :: separator
    integer(IK) :: exp_start
    integer(IK) :: decimal_pos
    integer(IK) :: sig_trim
    integer(IK) :: exp_trim
    integer(IK) :: i  !! counter

    str = adjustl(str)
    exp_start = scan(str,CK_'eEdD')
    if (exp_start == 0) exp_start = scan(str,CK_'-+',back=.true.)
    decimal_pos = scan(str,CK_'.')
    if (exp_start /= 0) separator = str(exp_start:exp_start)

    if ( exp_start < decimal_pos ) then !possibly signed, exponent-less float

        significand = str
        sig_trim = len(trim(significand))
        do i = len(trim(significand)),decimal_pos+2,-1 !look from right to left at 0s
                                                       !but save one after the decimal place
            if (significand(i:i) == '0') then
                sig_trim = i-1
            else
                exit
            end if
        end do
        str = trim(significand(1:sig_trim))

    else if (exp_start > decimal_pos) then !float has exponent

        significand = str(1:exp_start-1)
        sig_trim = len(trim(significand))
        do i = len(trim(significand)),decimal_pos+2,-1 !look from right to left at 0s
            if (significand(i:i) == '0') then
                sig_trim = i-1
            else
                exit
            end if
        end do
        expnt = adjustl(str(exp_start+1:))
        if (expnt(1:1) == '+' .or. expnt(1:1) == '-') then
            separator = trim(adjustl(separator))//expnt(1:1)
            exp_start = exp_start + 1
            expnt     = adjustl(str(exp_start+1:))
        end if
        exp_trim = 1
        do i = 1,(len(trim(expnt))-1) !look at exponent leading zeros saving last
            if (expnt(i:i) == '0') then
                exp_trim = i+1
            else
                exit
            end if
        end do
        str = trim(adjustl(significand(1:sig_trim)))// &
              trim(adjustl(separator))// &
              trim(adjustl(expnt(exp_trim:)))

    !else ! mal-formed real, BUT this code should be unreachable

    end if

    end subroutine compact_real_string