diff --git a/lib/mki18n.py b/lib/mki18n.py deleted file mode 100755 index 763da1190..000000000 --- a/lib/mki18n.py +++ /dev/null @@ -1,63 +0,0 @@ -#!/usr/bin/python -from StringIO import StringIO -import urllib2, os, zipfile, pycurl - -crowdin_identifier = 'electrum' -crowdin_file_name = 'electrum-client/messages.pot' -locale_file_name = 'locale/messages.pot' - -if os.path.exists('contrib/crowdin_api_key.txt'): - crowdin_api_key = open('contrib/crowdin_api_key.txt').read().strip() - - # Generate fresh translation template - if not os.path.exists('locale'): - os.mkdir('locale') - - cmd = 'xgettext -s --no-wrap -f app.fil --output=locale/messages.pot' - print 'Generate template' - os.system(cmd) - - # Push to Crowdin - print 'Push to Crowdin' - url = ('http://api.crowdin.net/api/project/' + crowdin_identifier + '/update-file?key=' + crowdin_api_key) - - c = pycurl.Curl() - c.setopt(c.URL, url) - c.setopt(c.POST, 1) - fields = [('files[' + crowdin_file_name + ']', (pycurl.FORM_FILE, locale_file_name))] - c.setopt(c.HTTPPOST, fields) - c.perform() - - # Build translations - print 'Build translations' - response = urllib2.urlopen('http://api.crowdin.net/api/project/' + crowdin_identifier + '/export?key=' + crowdin_api_key).read() - print response - -# Download & unzip -print 'Download translations' -zfobj = zipfile.ZipFile(StringIO(urllib2.urlopen('http://crowdin.net/download/project/' + crowdin_identifier + '.zip').read())) - -print 'Unzip translations' -for name in zfobj.namelist(): - if not name.startswith('electrum-client/locale'): - continue - if name.endswith('/'): - if not os.path.exists(name[16:]): - os.mkdir(name[16:]) - else: - output = open(name[16:],'w') - output.write(zfobj.read(name)) - output.close() - -# Convert .po to .mo -print 'Installing' -for lang in os.listdir('./locale'): - if lang.startswith('messages'): - continue - # Check LC_MESSAGES folder - mo_dir = 'locale/%s/LC_MESSAGES' % lang - if not os.path.exists(mo_dir): - os.mkdir(mo_dir) - cmd = 'msgfmt --output-file="%s/electrum.mo" "locale/%s/electrum.po"' % (mo_dir,lang) - print 'Installing',lang - os.system(cmd) diff --git a/lib/version.py b/lib/version.py index 230912a1a..83a47a421 100644 --- a/lib/version.py +++ b/lib/version.py @@ -1,4 +1,4 @@ -ELECTRUM_VERSION = "2.0b3" # version of the client package +ELECTRUM_VERSION = "2.0" # version of the client package PROTOCOL_VERSION = '0.9' # protocol version requested NEW_SEED_VERSION = 11 # electrum versions >= 2.0 OLD_SEED_VERSION = 4 # electrum versions < 2.0 diff --git a/plugins/README b/plugins/README new file mode 100644 index 000000000..a8e4db1a0 --- /dev/null +++ b/plugins/README @@ -0,0 +1,31 @@ +Plugin rules: + + * The plugin system of Electrum is designed to allow the development + of new features without increasing the core code of Electrum. + + * Electrum is written in pure python. if you want to add a feature + that requires non-python libraries, then it must be submitted as a + plugin. If the feature you want to add requires communication with + a remote server (not an Electrum server), then it should be a + plugin as well. If the feature you want to add introduces new + dependencies in the code, then it should probably be a plugin. + + * We expect plugin developers to maintain their plugin code. However, + once a plugin is merged in Electrum, we will have to maintain it + too, because changes in the Electrum code often require updates in + the plugin code. Therefore, plugins have to be easy to maintain. If + we believe that a plugin will create too much maintenance work in + the future, it will be rejected. + + * Plugins should be compatible with Electrum's conventions. If your + plugin does not fit with Electrum's architecture, or if we believe + that it will create too much maintenance work, it will not be + accepted. In particular, do not duplicate existing Electrum code in + your plugin. + + * We may decide to remove a plugin after it has been merged in + Electrum. For this reason, a plugin must be easily removable, + without putting at risk the user's bitcoins. If we feel that a + plugin cannot be removed without threatening users who rely on it, + we will not merge it. +