Project

nabokov

0.0
No commit activity in last 3 years
No release in over 3 years
One of the way to work on the localization - store it in the separate github repo and asks localization team to update files in that repo. This solution brings as well advantages but as well a disadvantages, to minimize the disadvantages nabokov was invented. It helps developer to automatically keep remote localzation up to date and also remain the project localization up to date as well.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.3
~> 3.0
>= 0
~> 0.42

Runtime

~> 1.0
~> 0.1
~> 1.0
~> 3.4
 Project Readme

Nabokov

License codebeat badge travis badge Gem

Move mobile localization process up to the next level .

Getting Started

Add this line to your application's Gemfile:

gem 'nabokov'

Next, use Bundler to install the gem.

bundle install

Where the idea come from

Nabokov is has been developed in order to improve and simplify the process of the mobile app localization (specifically iOS, but the idea can be applied to Android and probably WP as well). One of the way to manage localizations is to create a separate repo with strings files. Then flow can be described in the way like this:

  • Developer uploads all strings files into that repo
  • Translator updates all untranslated files
  • Developer updates project's strings files with the new one from repo
  • After a while developer adds new strings that have to be translated
  • Goto step 1

Also once it comes to the conflicts - remote repo has updated translation which is not on the project yet, and project has new strings which are not translated yet, the whole thing becomes a pain at least that was what I feel.

Why nabokov could be useful

With Nabokov the flow above could be replaced with two commands:

  • bundle exec nabokov sync localizations - uploads strings files on to remote localizations repo
  • bundle exec nabokov sync project - apply remote localizations into project

When it comes to the merge conflicts - nabokov allows user to user the preferable merge tool which is smoothify the process.

Usage

Nabokovfile

The projects settings for Nabokov are stored in the files Nabokov.yaml which has YAML format and places in the directory with the Gemfile. The structure of the file is explained below:

localizations_repo:
  url: 'url to the localizations repo'
  master_branch: 'master branch of the localizations repo'

project_repo:
  localizations:
    :en: 'relative path to the English localization strings file in the project'
    :another: 'relative path to the another localization strings file in the project'
  local_path: 'relative path to the project'

Initial set up

After running bundle exec nabokov setup strings files uploading to the remote repo will be done automatically via pre-commit git hook. Remember that the project synchronization still has to be done manually by running bundle exec nabokov sync project

Synchronization

If you need to synchronize the strings with the remote repo manually of without pre-commit git hook, you can use the bundle exec nabokov sync localizations command. When you want to update the project's strings files with the remote one you can run bundle exec nabokov sync project command.

Current status

This project is in the early development stage but is ready for production since even in a case of data corruption the valid state can be rolled back via git.

Behind the scene

This is my first ruby project except for small experiments on the local machine before. So please bare it in mind and I would really appreciate any point about code style or better way to implement something.

Contributing

I’d love to see your ideas for improving this library! The best way to contribute is by submitting a pull request. I’ll do my best to respond to your patch as soon as possible. You can also submit a new GitHub issue if you find bugs or have questions.

License

This project is open source under the MIT license, which means you have full access to the source code and can modify it to fit your own needs.