Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ruby/iconv

iconv wrapper
https://github.com/ruby/iconv

c hacktoberfest iconv ruby

Last synced: about 2 months ago
JSON representation

iconv wrapper

Awesome Lists containing this project

README

        

# Iconv

[![Build Status](https://travis-ci.org/ruby/iconv.svg)](https://travis-ci.org/ruby/iconv)

iconv wrapper, used to be ext/iconv

## Abstract

Iconv is a wrapper class for the UNIX 95 iconv() function family,
which translates string between various encoding systems.

See Open Group's on-line documents for more details.
* iconv.h: http://www.opengroup.org/onlinepubs/007908799/xsh/iconv.h.html
* iconv_open(): http://www.opengroup.org/onlinepubs/007908799/xsh/iconv_open.html
* iconv(): http://www.opengroup.org/onlinepubs/007908799/xsh/iconv.html
* iconv_close(): http://www.opengroup.org/onlinepubs/007908799/xsh/iconv_close.html

Which coding systems are available is platform-dependent.

## Installation

Add this line to your application's Gemfile:

```ruby
gem 'iconv'
```

And then execute:

$ bundle

Or install it yourself as:

$ gem install iconv

## Usage

1. Simple conversion between two charsets.
```ruby
converted_text = Iconv.conv('iso-8859-15', 'utf-8', text)
```
2. Instantiate a new `Iconv` and use method `Iconv#iconv`.
```ruby
cd = Iconv.new(to, from)
begin
input.each { |s| output << cd.iconv(s) }
output << cd.iconv(nil) # Don't forget this!
ensure
cd.close
end
```
3. Invoke `Iconv.open` with a block.
```ruby
Iconv.open(to, from) do |cd|
input.each { |s| output << cd.iconv(s) }
output << cd.iconv(nil)
end
```
4. Shorthand for (3).
```ruby
Iconv.iconv(to, from, *input.to_a)
```

## Attentions

Even if some extensions of implementation dependent are useful,
DON'T USE those extensions in libraries and scripts to widely distribute.
If you want to use those feature, use `String#encode`.

## Contributing

1. Fork it
2. Create your feature branch (`git checkout -b my-new-feature`)
3. Commit your changes (`git commit -am 'Add some feature'`)
4. Push to the branch (`git push origin my-new-feature`)
5. Create new Pull Request

## License

Ruby License/2-clause BSDL