Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/silviucpp/unicode2gsm

Transliterates Unicode characters outside of GSM alphabet with a similar GSM-encoded character
https://github.com/silviucpp/unicode2gsm

gsm7 transliteration unicode

Last synced: about 1 month ago
JSON representation

Transliterates Unicode characters outside of GSM alphabet with a similar GSM-encoded character

Awesome Lists containing this project

README

        

# unicode2gsm

[![Build Status](https://travis-ci.com/silviucpp/unicode2gsm.svg?branch=main)](https://travis-ci.com/github/silviucpp/unicode2gsm)
[![GitHub](https://img.shields.io/github/license/silviucpp/unicode2gsm)](https://github.com/silviucpp/unicode2gsm/blob/master/LICENSE)

## What it is ?

A library that transliterates Unicode characters outside of GSM alphabet with a similar GSM-encoded character. This helps ensure that your message gets segmented at 160 characters and saves you from sending multiple message segments, which increases your spend.

When Unicode characters are used in an SMS message, they must be encoded as UCS-2. However, UCS-2 characters take 16 bits to encode, so when a message includes a Unicode character, it will be split or segmented between the 70th and 71st characters. This is shorter than the 160-character per message segment that you get with GSM-7 character encoding.

For example, sometimes a Unicode character such as a smart quote ( 〞), a long dash (—), or a Unicode whitespace accidentally slips into your carefully crafted 125-character message. Now, your message is segmented and priced at two messages instead of one.

Currently the library transliterates symbols into the following Unicode Character Sets:

|Start |End |Character Set |
|:-----:|:-----:|:------------------------------|
|0x0000 | 0x007F| Basic Latin |
|0x0080 | 0x00FF| Latin-1 Supplement |
|0x0100 | 0x017F| Latin Extended-A |
|0x0180 | 0x024F| Latin Extended-B |
|0x0250 | 0x02AF| IPA Extensions |
|0x02B0 | 0x02FF| Spacing Modifier Letters |
|0x0300 | 0x036F| Combining Diacritical Marks |
|0x0370 | 0x03FF| Greek and Coptic |
|0x1D00 | 0x1D7F| Phonetic Extensions |
|0x1D80 | 0x1DBF| Phonetic Extensions Supplement|
|0x1E00 | 0x1EFF| Latin Extended Additional |
|0x1F00 | 0x1FFF| Greek Extended |
|0x2000 | 0x206F| General Punctuation |
|0x2070 | 0x209F| Superscripts and Subscripts |
|0x20A0 | 0x20CF| Currency Symbols |
|0x2100 | 0x214F| Letterlike Symbols |
|0x2150 | 0x218F| Number Forms |
|0x2190 | 0x21FF| Arrows |
|0x2700 | 0x27BF| Dingbats |
|0x27F0 | 0x27FF| Supplemental Arrows-A |
|0x2900 | 0x297F| Supplemental Arrows-B |
|0x2C60 | 0x2C7F| Latin Extended-C |
|0x3000 | 0x303F| CJK Symbols and Punctuation |
|0xFE10 | 0xFE1F| Vertical Forms |
|0xFE50 | 0xFE6F| Small Form Variants |
|0xFF00 | 0xFFEF| Halfwidth and Fullwidth Forms |

Also the transliteration process is replacing all the `CRLF` (`\r\n`) sequences into `\n`.

## Building

Building the static library:

```sh
mkdir build
cd build
cmake ..
make
```

In case you want to build the unit tests make sure you have `libboost-test-dev` installed and run `cmake` as follow:

```sh
ENABLE_UNIT_TEST=1 cmake ..
```

## API

### Initialize the library

You can include the library as follow:

```c++
#include
```

Before using any API function you need to initialize the library using:

```c++
bool init_transliteration_map(bool transliterate_gsm_extended)
```

Extended GSM alphabet symbols are escaped so each one will count as 2 characters. For the symbols that have a decent GSM-encoded replacement you can optionally enable transliteration using `transliterate_gsm_extended` parameter and these symbols will be mapped as follow:

- `{` -> `(`
- `}` -> `)`
- `[` -> `(`
- `]` -> `)`
- `~` -> `-`

### Check if a string requires transliteration

```c++
// for NULL terminated strings
bool requires_transliteration(const char* utf8);

// can be used for strings that are not NULL terminated.
bool requires_transliteration(const char* utf8, size_t length);
```

### Perform transliteration

```c++
// for NULL terminated strings
std::string transliterate(const char* utf8);

// can be used for strings that are not NULL terminated.
std::string transliterate(const char* utf8, size_t length);
```

### Example

The following example is passing to transliteration process all characters from the GSM alphabet. The output will be equal with the input
but if we change the parameter passed to `init_transliteration_map` to `true` the result will be different as `{ } [ ] ~` will be transliterated.

```c++

#include
#include

int main()
{
if(!unicode2gsm::init_transliteration_map(false))
{
printf("Failed to init\n");
return 1;
}

const char *only_gsm=u8"@£$¥èéùìòÇØøÅåΔ_ΦΓΛΩΠΨΣΘΞÆæßÉ!\"#¤%&'()*+,-./0123456789:;<=>?¡ABCDEFGHIJKLMNOPQRSTUVWXYZÄÖÑܧ¿abcdefghijklmnopqrstuvwxyzäöñüà^{}\[~]|€";

// the output here is equal with the value of `only_gsm` variable
printf("Output: %s", unicode2gsm::transliterate(only_gsm).c_str());
return 0;
}

```