Sha256: b72c0a3f32f233f018668ce1e2069b629ac80177332e6c4f7992bf5e50a5b8f4

Contents?: true

Size: 1.68 KB

Versions: 2

Compression:

Stored size: 1.68 KB

Contents

# encoding: UTF-8
=begin

 region.rb - Locale::Info::Region class

 Copyright (C) 2008  Masao Mutoh
 
 First Author:: Brian Pontarelli

 $Id: region.rb 27 2008-12-03 15:06:50Z mutoh $
=end

require 'zlib'

module Locale

  module Info
    # This class models out a region/country from the ISO 3166 standard for region codes.
    # In ISO3166, it's called "Country" but Ruby/Locale the word "Region" instead.
    class Region
      attr_reader :code, :name

      # code::  The 2 or 3 digit ISO 3166 region code.
      # name::  The name of the region.
      def initialize(code, name)
        @code = code
        @name = name
      end

      def iso_region?
        @@regions[code] != nil
      end

      def to_s
        "#{code}"
      end
    end

    @@regions = Hash.new
    Zlib::GzipReader.open(File.dirname(__FILE__) + "/../data/regions.tab.gz") do |gz|
      gz.readlines.each do |l|
        unless l =~ /^\s*$/
          parts = l.split(/\t/)
          region = Region.new(parts[0], parts[1].strip)
          @@regions[parts[0]] = region
        end
      end
    end

    module_function

    # Returns a hash of all the ISO regions. The hash is {String, Region} where
    # the string is the 2 digit region code from the ISO 3166 data.
    #
    # You need to require 'locale/info' or 'locale/region'.
    def regions
      @@regions
    end

    # Returns the region for the given code.
    #
    # You need to require 'locale/info' or 'locale/info/region'.
    def get_region(code)
      @@regions[code]
    end

    # Returns the region code is valid.
    #
    # You need to require 'locale/info' or 'locale/info/region'.
    def valid_region_code?(code)
      @@regions[code] != nil
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
locale-2.0.0 lib/locale/info/region.rb
locale-0.9.0 lib/locale/info/region.rb