Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWalter Bender <walter.bender@gmail.com>2013-05-03 14:09:52 (GMT)
committer Walter Bender <walter.bender@gmail.com>2013-05-03 14:09:52 (GMT)
commitd7d52c48a1ecd527335de53a36e86a3cd1ec79b4 (patch)
tree63f7d0653a869c8ba1714966872d525b32136783
parentfba8e527fd22b61f0e94b0f87073ead603db61e3 (diff)
OLPC AU branchv175.1
-rw-r--r--NEWS5
-rw-r--r--activity/activity.info2
-rw-r--r--plugins/currency/__init__.py0
-rw-r--r--plugins/currency/currency.py83
-rw-r--r--plugins/currency/icons/currencyoff.svg45
-rw-r--r--plugins/currency/icons/currencyon.svg121
-rw-r--r--plugins/currency/images/1 dollaroff.svg298
-rw-r--r--plugins/currency/images/1 dollarsmall.svg54
-rw-r--r--plugins/currency/images/10 centsoff.svg292
-rw-r--r--plugins/currency/images/10 centssmall.svg54
-rw-r--r--plugins/currency/images/10 dollarsoff.svg104
-rw-r--r--plugins/currency/images/10 dollarssmall.svg55
-rw-r--r--plugins/currency/images/100 dollarsoff.svg54
-rw-r--r--plugins/currency/images/100 dollarssmall.svg105
-rw-r--r--plugins/currency/images/2 dollarsoff.svg279
-rw-r--r--plugins/currency/images/2 dollarssmall.svg54
-rw-r--r--plugins/currency/images/20 centsoff.svg257
-rw-r--r--plugins/currency/images/20 centssmall.svg54
-rw-r--r--plugins/currency/images/20 dollarsoff.svg105
-rw-r--r--plugins/currency/images/20 dollarssmall.svg55
-rw-r--r--plugins/currency/images/5 centsoff.svg288
-rw-r--r--plugins/currency/images/5 centssmall.svg54
-rw-r--r--plugins/currency/images/5 dollarsoff.svg95
-rw-r--r--plugins/currency/images/5 dollarssmall.svg55
-rw-r--r--plugins/currency/images/50 centsoff.svg54
-rw-r--r--plugins/currency/images/50 centssmall.svg54
-rw-r--r--plugins/currency/images/50 dollarsoff.svg54
-rw-r--r--plugins/currency/images/50 dollarssmall.svg105
-rw-r--r--plugins/wedo_plugin/99-lego-WeDo.rules1
-rw-r--r--plugins/wedo_plugin/WeDoMore.py192
-rw-r--r--plugins/wedo_plugin/__init__.py0
-rw-r--r--plugins/wedo_plugin/icons/WeDooff.svg71
-rw-r--r--plugins/wedo_plugin/icons/WeDoon.svg71
-rw-r--r--plugins/wedo_plugin/plugin.info5
-rw-r--r--plugins/wedo_plugin/usb/__init__.py92
-rw-r--r--plugins/wedo_plugin/usb/_debug.py77
-rw-r--r--plugins/wedo_plugin/usb/_interop.py135
-rw-r--r--plugins/wedo_plugin/usb/backend/__init__.py368
-rw-r--r--plugins/wedo_plugin/usb/backend/libusb01.py582
-rw-r--r--plugins/wedo_plugin/usb/backend/libusb10.py654
-rw-r--r--plugins/wedo_plugin/usb/backend/openusb.py707
-rw-r--r--plugins/wedo_plugin/usb/control.py252
-rw-r--r--plugins/wedo_plugin/usb/core.py856
-rw-r--r--plugins/wedo_plugin/usb/legacy.py334
-rw-r--r--plugins/wedo_plugin/usb/util.py260
-rw-r--r--plugins/wedo_plugin/wedo_plugin.py304
-rw-r--r--po/af.po3209
-rw-r--r--po/am.po1820
-rw-r--r--po/ar.po1963
-rw-r--r--po/ayc.po5396
-rw-r--r--po/aym.po15
-rw-r--r--po/bg.po1531
-rw-r--r--po/bi.po1531
-rw-r--r--po/bn.po1560
-rw-r--r--po/bn_IN.po2000
-rw-r--r--po/br.po1530
-rw-r--r--po/ca.po1970
-rw-r--r--po/cpp.po1531
-rw-r--r--po/cs.po2517
-rw-r--r--po/da.po5205
-rw-r--r--po/de.po5218
-rw-r--r--po/dz.po1531
-rw-r--r--po/el.po4299
-rw-r--r--po/en.po5507
-rw-r--r--po/en_GB.po5215
-rw-r--r--po/en_US.po5223
-rw-r--r--po/es.po5573
-rw-r--r--po/fa.po1531
-rw-r--r--po/fa_AF.po1570
-rw-r--r--po/ff.po1531
-rw-r--r--po/fi.po2003
-rw-r--r--po/fil.po1543
-rw-r--r--po/fr.po5191
-rw-r--r--po/gu.po1531
-rw-r--r--po/ha.po1531
-rw-r--r--po/he.po4363
-rw-r--r--po/hi.po4309
-rw-r--r--po/ht.po1531
-rw-r--r--po/hu.po1531
-rw-r--r--po/hus.po5028
-rw-r--r--po/hy.po4897
-rw-r--r--po/id.po2447
-rw-r--r--po/ig.po1531
-rw-r--r--po/is.po1531
-rw-r--r--po/it.po4040
-rw-r--r--po/ja.po2561
-rw-r--r--po/km.po2803
-rw-r--r--po/ko.po2307
-rw-r--r--po/kos.po1543
-rw-r--r--po/mg.po2961
-rw-r--r--po/mi.po5033
-rw-r--r--po/mk.po1531
-rw-r--r--po/ml.po1531
-rw-r--r--po/mn.po2868
-rw-r--r--po/mr.po2827
-rw-r--r--po/ms.po1531
-rw-r--r--po/mvo.po1531
-rw-r--r--po/nb.po2163
-rw-r--r--po/ne.po4936
-rw-r--r--po/nl.po5149
-rw-r--r--po/pa.po1531
-rw-r--r--po/pap.po3807
-rw-r--r--po/pbs.po3667
-rw-r--r--po/pl.po5078
-rw-r--r--po/ps.po2321
-rw-r--r--po/pt.po5019
-rw-r--r--po/pt_BR.po3572
-rw-r--r--po/quz.po5462
-rw-r--r--po/ro.po1531
-rw-r--r--po/ru.po3771
-rw-r--r--po/rw.po3727
-rw-r--r--po/sd.po1531
-rw-r--r--po/si.po3657
-rw-r--r--po/sk.po1549
-rw-r--r--po/sl.po1609
-rw-r--r--po/sq.po2389
-rw-r--r--po/sv.po3505
-rw-r--r--po/sw.po1908
-rw-r--r--po/ta.po4238
-rw-r--r--po/te.po3219
-rw-r--r--po/th.po3299
-rw-r--r--po/tr.po1932
-rw-r--r--po/tvl.po1543
-rw-r--r--po/tzo.po1531
-rw-r--r--po/ug.po1548
-rw-r--r--po/ur.po1531
-rw-r--r--po/vi.po4196
-rw-r--r--po/wa.po1531
-rw-r--r--po/yo.po1531
-rw-r--r--po/zh_CN.po5071
-rw-r--r--po/zh_TW.po4618
131 files changed, 186493 insertions, 65983 deletions
diff --git a/NEWS b/NEWS
index 0fc53e0..b19a7e0 100644
--- a/NEWS
+++ b/NEWS
@@ -1,7 +1,12 @@
+175.1
+
+OLPC AU branch
+
175
ENHANCEMENT:
* Power management utility: Alan Aguiar
+* Game keys exit fullscreen mode
BUG FIXES:
* Force audio sensors to use single channel on XO 4
diff --git a/activity/activity.info b/activity/activity.info
index 3d1e9d5..b836dcc 100644
--- a/activity/activity.info
+++ b/activity/activity.info
@@ -1,6 +1,6 @@
[Activity]
name = TurtleBlocks
-activity_version = 175
+activity_version = 175.1
license = MIT
bundle_id = org.laptop.TurtleArtActivity
exec = sugar-activity TurtleArtActivity.TurtleArtActivity
diff --git a/plugins/currency/__init__.py b/plugins/currency/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/plugins/currency/__init__.py
diff --git a/plugins/currency/currency.py b/plugins/currency/currency.py
new file mode 100644
index 0000000..4d9a7ed
--- /dev/null
+++ b/plugins/currency/currency.py
@@ -0,0 +1,83 @@
+# -*- coding: utf-8 -*-
+#Copyright (c) 2011, Walter Bender
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+
+import gtk
+from time import time
+import os.path
+from gettext import gettext as _
+
+try:
+ from sugar.datastore import datastore
+except ImportError:
+ pass
+
+from plugins.plugin import Plugin
+from TurtleArt.tapalette import make_palette, define_logo_function
+from TurtleArt.talogo import primitive_dictionary, logoerror, \
+ media_blocks_dictionary
+from TurtleArt.taconstants import MEDIA_SHAPES, NO_IMPORT, SKIN_PATHS, \
+ EXPAND_SKIN, BLOCKS_WITH_SKIN
+
+class Currency(Plugin):
+ """ a class for defining palette of money """
+
+ def __init__(self, parent):
+ self.tw = parent
+
+ def setup(self):
+ self.heap = self.tw.lc.heap
+ self.keyboard = self.tw.lc.keyboard
+ self.title_height = int((self.tw.canvas.height / 20) * self.tw.scale)
+
+ SKIN_PATHS.append('plugins/currency/images')
+
+ self._currency_palette()
+
+ def _currency_palette(self):
+ palette = make_palette(
+ 'currency', colors=["#FFFFFF", "#A0A0A0"],
+ help_string=_('Palette of Australian currencies'))
+
+ self._make_constant(palette, '5 cents', 0.05, expand=(0, 10))
+ self._make_constant(palette, '10 cents', 0.1, expand=(0, 10))
+ self._make_constant(palette, '20 cents', 0.2, expand=(0, 10))
+ self._make_constant(palette, '50 cents', 0.5, expand=(0, 10))
+ self._make_constant(palette, '1 dollar', 1, expand=(0, 10))
+ self._make_constant(palette, '2 dollars', 2, expand=(0, 10))
+
+ self._make_constant(palette, '5 dollars', 5, expand=(60, 20))
+ self._make_constant(palette, '10 dollars', 10, expand=(60, 20))
+ self._make_constant(palette, '20 dollars', 20, expand=(60, 20))
+ self._make_constant(palette, '50 dollars', 50, expand=(60, 20))
+ self._make_constant(palette, '100 dollars', 100, expand=(60, 20))
+
+ def _make_constant(self, palette, block_name, constant, expand=(0, 0)):
+ """ Factory for constant blocks """
+ palette.add_block(block_name,
+ style='box-style-media',
+ label='',
+ default=constant,
+ prim_name=block_name,
+ help_string=_(str(constant)))
+ BLOCKS_WITH_SKIN.append(block_name)
+ NO_IMPORT.append(block_name)
+ MEDIA_SHAPES.append(block_name + 'off')
+ MEDIA_SHAPES.append(block_name + 'small')
+ if expand > 0:
+ EXPAND_SKIN[block_name] = expand
+ self.tw.lc.def_prim(block_name, 0, lambda self: constant)
+
diff --git a/plugins/currency/icons/currencyoff.svg b/plugins/currency/icons/currencyoff.svg
new file mode 100644
index 0000000..7a4825a
--- /dev/null
+++ b/plugins/currency/icons/currencyoff.svg
@@ -0,0 +1,45 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ version="1.0"
+ width="55"
+ height="55"
+ id="svg2">
+ <metadata
+ id="metadata10">
+ <rdf:RDF>
+ <cc:Work
+ rdf:about="">
+ <dc:format>image/svg+xml</dc:format>
+ <dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+ <dc:title></dc:title>
+ </cc:Work>
+ </rdf:RDF>
+ </metadata>
+ <defs
+ id="defs8" />
+ <rect
+ width="55"
+ height="55"
+ x="0"
+ y="0"
+ id="rect3269"
+ style="fill:#282828;fill-opacity:1;fill-rule:nonzero;stroke:none" />
+ <text
+ x="10.554688"
+ y="42.207031"
+ id="text2993"
+ xml:space="preserve"
+ style="font-size:11px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"><tspan
+ x="10.554688"
+ y="42.207031"
+ id="tspan2995"
+ style="font-size:48px;font-weight:bold;fill:#ffffff;-inkscape-font-specification:Sans Bold">$</tspan></text>
+</svg>
diff --git a/plugins/currency/icons/currencyon.svg b/plugins/currency/icons/currencyon.svg
new file mode 100644
index 0000000..9bcba86
--- /dev/null
+++ b/plugins/currency/icons/currencyon.svg
@@ -0,0 +1,121 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ version="1.0"
+ width="55"
+ height="55"
+ id="svg2">
+ <metadata
+ id="metadata20">
+ <rdf:RDF>
+ <cc:Work
+ rdf:about="">
+ <dc:format>image/svg+xml</dc:format>
+ <dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+ <dc:title></dc:title>
+ </cc:Work>
+ </rdf:RDF>
+ </metadata>
+ <defs
+ id="defs5">
+ <linearGradient
+ x1="0"
+ y1="22"
+ x2="74"
+ y2="22"
+ id="linearGradient2431"
+ xlink:href="#linearGradient3166"
+ gradientUnits="userSpaceOnUse"
+ gradientTransform="matrix(0.3333,0,0,0.3333,27.031478,32.193732)" />
+ <linearGradient
+ x1="0"
+ y1="22"
+ x2="74"
+ y2="22"
+ id="linearGradient2428"
+ xlink:href="#linearGradient3166"
+ gradientUnits="userSpaceOnUse"
+ gradientTransform="matrix(0.3333,0,0,0.3333,27.031478,45.064925)" />
+ <linearGradient
+ x1="0"
+ y1="22"
+ x2="74"
+ y2="22"
+ id="linearGradient3172"
+ xlink:href="#linearGradient3166"
+ gradientUnits="userSpaceOnUse" />
+ <linearGradient
+ id="linearGradient3166">
+ <stop
+ id="stop3168"
+ style="stop-color:#ffffff;stop-opacity:1"
+ offset="0" />
+ <stop
+ id="stop3170"
+ style="stop-color:#ffff00;stop-opacity:1"
+ offset="1" />
+ </linearGradient>
+ <linearGradient
+ x1="0"
+ y1="22"
+ x2="74"
+ y2="22"
+ id="linearGradient2557"
+ xlink:href="#linearGradient3166"
+ gradientUnits="userSpaceOnUse"
+ gradientTransform="matrix(0.3333,0,0,0.3333,9.2560985,9.9123239)" />
+ <linearGradient
+ x1="0"
+ y1="22"
+ x2="74"
+ y2="22"
+ id="linearGradient2561"
+ xlink:href="#linearGradient3166"
+ gradientUnits="userSpaceOnUse"
+ gradientTransform="matrix(0.3333,0,0,0.3333,8.962951,22.783517)" />
+ <linearGradient
+ x1="0"
+ y1="22"
+ x2="74"
+ y2="22"
+ id="linearGradient2461"
+ xlink:href="#linearGradient3166"
+ gradientUnits="userSpaceOnUse"
+ gradientTransform="matrix(0.3333,0,0,0.3333,27.031478,32.193732)" />
+ <linearGradient
+ x1="0"
+ y1="22"
+ x2="74"
+ y2="22"
+ id="linearGradient2463"
+ xlink:href="#linearGradient3166"
+ gradientUnits="userSpaceOnUse"
+ gradientTransform="matrix(0.3333,0,0,0.3333,27.031478,45.064925)" />
+ </defs>
+ <rect
+ width="55"
+ height="55"
+ rx="0"
+ x="0"
+ y="0"
+ id="rect2839"
+ style="fill:#ffd200;fill-opacity:1;fill-rule:evenodd;stroke:none" />
+ <text
+ x="10.554688"
+ y="42.207031"
+ id="text2993"
+ xml:space="preserve"
+ style="font-size:11px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans"><tspan
+ x="10.554688"
+ y="42.207031"
+ id="tspan2995"
+ style="font-size:48px;font-weight:bold;fill:#ffffff;-inkscape-font-specification:Sans Bold">$</tspan></text>
+</svg>
diff --git a/plugins/currency/images/1 dollaroff.svg b/plugins/currency/images/1 dollaroff.svg
new file mode 100644
index 0000000..1299d26
--- /dev/null
+++ b/plugins/currency/images/1 dollaroff.svg
@@ -0,0 +1,298 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="70"
+ version="1.1"
+ viewBox="0 0 71 70"
+ width="71"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="1 dollaroff.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="1"
+ inkscape:cx="-108.06607"
+ inkscape:cy="112"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" /><image
+ y="0"
+ x="0"
+ id="image3046"
+ xlink:href="
+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
+"
+ height="70"
+ width="71" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/1 dollarsmall.svg b/plugins/currency/images/1 dollarsmall.svg
new file mode 100644
index 0000000..4f887a0
--- /dev/null
+++ b/plugins/currency/images/1 dollarsmall.svg
@@ -0,0 +1,54 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="40"
+ version="1.1"
+ viewBox="0 0 40.57143 40"
+ width="40.57143"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="1 dollarsmall.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="1"
+ inkscape:cx="-115.56607"
+ inkscape:cy="107"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" /><image
+ y="0"
+ x="0"
+ id="image3046"
+ xlink:href=" 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 "
+ height="40"
+ width="40.57143" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/10 centsoff.svg b/plugins/currency/images/10 centsoff.svg
new file mode 100644
index 0000000..821f6f0
--- /dev/null
+++ b/plugins/currency/images/10 centsoff.svg
@@ -0,0 +1,292 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="70"
+ version="1.1"
+ viewBox="0 0 71 70"
+ width="71"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="10 centsoff.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="1"
+ inkscape:cx="-123.06607"
+ inkscape:cy="99"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" /><image
+ y="0"
+ x="0"
+ id="image3046"
+ xlink:href="
+eJy9vGl8VGW29v3ftXfNVUllnueJJCQESAKEIQEigxOogCCDCog4tNpqq9223e3UzkqLKM7iiMoM
+AmEQkDnMgYQEMs+pkKRSSVVq3u+H0HnO854+/fTp033uT/Uh+dVeV6217rWuda0t8L9w1vzlbR56
+9HEAGpubNK+/+kpyW2ubTqPV2CZPnJgVGBg40uv1hvp8PoVKpfJKkmSx2Wy97W1tmy+Vl6PSar0F
+4ye0L1q0uOt/43n/eoR/9xds+uE7xe3zFshfff7JIydOnFg0fPjwqDFjxkQkJSVh8PPD6bDT39+P
+y+VCFEUkSUKv1yNKkiyJouB2u+nptlBfX19+7Nixwzqdrnt8QcHqrTtLOn//+997BUHg4MGDFBUV
+/cuf/d8Gzsb13wzbuWvX4tmzZ88dlZsX4W80GM6dO8exY8c4cOAAtbW1WK19eD0OJElCFEVEhQJR
+klAoFNjtdmQZAgJMJKekUTR5ChMnTCAtbRgqlbL+4uWr8meff/ZiVlZW/YMPPHDg32HDvwScysvl
+DEvPBGDJ4oUzp06d+nx6Wqo1Njpq6vnz5/n662/Zu7cErw/i4+PIzs4mKyuLpKQkQsLC0KjV+GQf
+Pp8PhaAAn4++vj7a29uxWq1cvHieysrLVFfXEBBgIjt7BHPm3ElBwTh8PvnKhQsX6nfv2vXHG6bf
+WDHtxhuth/bvo3Bq8f/Yrn+Z53ywelWwuavruwUL7io2mfz5at063nrzDQbsdm699VZmzJhB2rB0
+QkND0el0OJ1OfD4fAF6vF5/PhyAIdHd3093VhUqlIjg4GK1WC4DN1o/D4aC5uZmTJ0+yfcdWfF4f
+N998M0888QR6g56tW3c+Eh0dvQ9RvDKpcLL3f2rT/wicFUvv5qPP1nHXvDt+WLNmTYpKrc5Zef/9
+8tYtW4Tx48ezcOFdTJgwAaVSiUIhICgkvF4vsizj8Xhwu92oVCqUkoTb7ebw4cOUl5fT3d2N1Wol
+NzeXwsJCDAYDgiAgSRI+nw9Jkujr76KpqYndJSXs37ePETk58gt/ekVITE3p3rpx88Lmjra6Rx55
+vOrY0UMUjC/8p+wT/5l/euH5P3Lg4CFSkhLv/t3TT939hz88t2z16tXhCxbMJzIiQli1ahVLl95L
+dnY2gjCIv9vtweF0olAo8PkGQ0ij0aCWJCRR5NChQ9htNhobGrHZbRQXF+Pz+aisrCQyMpLw8PDr
+SVuBICiQJA3hYVGMGzuR4uIZtLWYhTffeJmW5mbNgoULFo3MyUkOCg45OH/+wr5/Chn+Sc95+603
+Rbut/5V7lixeZunpDrz3nntRKiVefe1VRuaMxOvzMWC343A4ARkQUColFJISQRBQqVSDXiD7ELwy
+oiiybds2WltbOXPmDJ989ulQmEmSxL59PzNp0iTcLjc+n49rXdeQfQpUKhVqtRqlSonH46WtpZrV
+q9+j/HIFb7z1lq+wcNLlqit1azs7O78qmlLc+28F59jRw4wrmCC89OLz53//3O+HvfTHP6jeeP0N
+Xnv1ZWbOnMmOHTuor6/HbDYTGBhEbEwcM2bMICoqCo/bjaBSoVKpEARhKDxkUYEoivzqgQeZMmUK
+XdeusWDBArRaLV6vF5VKhcPpHPosyzJ9fX14PJ6hvDV02wka+vstXK2u5JVXnyc9PYOXXnwNU0Bg
+8cWKyxVms7nt5ltm/XvA+eabryapRPHNm26cmXfrLTdzteoK69Z9RnJKCvfcfTdKpZKYmBjCwsIY
+sDswmzvJzMxk5cqVqFQqfArFUFgBSJKEQinhdDrp7rzGl+vWkZGRwW1z5+Ky21GpVLjdbjxeLwMD
+AyiVSpRK5VDecjqdDAwM4PV6EQQBr1vGaNThcjvp7u5k1aq/0NjYwocfrgVB/HWXxfJjXv7Yln/U
+XsU/+oc//vBdjEGjfmR8wbi8yUWF2PptbNz4A1nDM3n15Zd4+umnWb16Nc899xxJSUmEhoYyd+5c
+uru7cblcyLKMUqkcKvREUUQhCPhkGZVaTVR0NF6vl9raWn75+Wes/f34AJ8ggCyj1+uHgJWkwcSu
+1Wrx9/dHo9EgyzIGo4bqmmrq6+uRZQXPPP1bJk0Yy22zZ9Hdde2diNCQzGNHj2j/peBs3741q89i
++WjmjOl3TJlchMnfxIYf15M1PJNLZRe4b/lSYmJi8Pl82O12SktLWfnASrRaLV1dXSgUCjRa7WAi
+luXBL1YoBj/L8iBIXi9/+NOfmDRpEiUlJZw5dYq9JSVISiUqjQZJkgY9TaFAEIQhoEVRRKPREBAQ
+QEd7K7t37+Lnnw+wbt2XlF24xNw77mDJ4kXMmzePivJLJbHRUQUVFZclgCMH9/9du//ubfXoIw9z
+8mQpN86YdnzGtGl5EyZMkDPTM4SP1r5PQEAAKqWSfft+ZtfuEurrm4iOicFo9CM0JJTU1DQ6Ozsp
+LCxEqVJx+fJlWpubaW9rw9rbS093N26XC7fbhdFoRKFSg0JBRGQEw9JSuVJZxdatW/B5PHSZu4iL
+jkP2+FAq1eCTERQiXrcXr8cHMhj0Rr5Z/y0KQaChto5rHWbOnj1Nbl4+EyZMJDkxid/85km5uLj4
+7vjY6NZbbprpmFA0tfPv2f9f5pxv1n3Grp92CH5BIY+/+87bt95995JJAzYb77z9JgGmAJTXQ+Ps
+2bP09PTQ1NyKSqUiJCQEgMrKSsLDw+nv78dqtaLVanE6nRgMBsxmMwaDAY/Hg0avQ61W43Q6MZlM
+xMfHExkTQ1hICJWVlRw5fJhLZZdISU5mypQppKeno/f3w26zoVKp8Hg8KBQKHA4Hr7z+Cj63lwnj
+CsjMyOT06VOcOXuWJ598EqfTyb59+3jplT+zefMWoqKjFy178rffTMtI5MHf/vG/Bw7Apx++//Si
+hQtffeqpp+TGhnph9burCAoKQiUpcblceL1eWlpbeeaZZ7jrrkU0NzeTmppKV1cXGo2GlpaWIQPS
+0tIQRZHu7m5CQ0NpamoCYNbtt7Fjxw56e3uJi4vDYrHQ0dGBKIrExsZSVFSESlKyd89edu/eRXp6
+OpOLJpM8LG2ohgIQBIHX33wdc3sHv37kURSCgsCAAMouXaSmpoaFCxfS09PDt999zbfrf2DTpk14
+fXJhXFLqL2dOHmP0mIL/ZP/fDKu33nydrGGp4ydPmfLVmTOnFVs2bRLWfvA+0ZHhuF0uZBmUSiUD
+AwMEBQUxa9ZsXnv9DQYG7Hz11VekpaVx/PhxkpOTaWtrIyAggKamJmw2GzNnzmTfvn3k5uYyatQo
+vvz6K0aNGkVhYSEnT56ku7sbWZZZtnw5yDJbt27lSlUVoWGhrFy5kpCQEL744guaWpqJT0jA388P
+l8uJ2+3GZrfR3dVN+rBhGAwGtBoNOr2OrKwsHA4HoiiSlBhPdfVVNm7cwMKFi+Y5Xe637ll2399s
+Nf4TOCuW38crr77GY48+umbEiOxhy5ct4+WXXyAxMeH6F4DHO1hr+Pv743a7kZQSs2fPJiMjg5iY
+GAICAujt7UUpKSkrK8Pr9XHw4AF0Oh0vv/wyOTk5fPnll2zevJkHHnwQnV7P9+vXU1RUxLD0dKZO
+ncqGDRuQZZng4GDGTyjAbG5j586fMBj1zJl7O0giX37xBbLsIyYmGo1GTWR0DHv37GXi+Ak4BgYA
+MBiNOJ1ORFFErVaj02oYnpnB+vXfo9MblIsXLZRuu2Puhc8++8z+D4XV/fetWLf2ow+dSxffdd+k
+MaOYdeut9FosaK4XZvW1taSlZ+JTSPR0dREdHcfRE8fIycnh2LFjFBUVcbniEqPH5HHm5AlGZI+g
+qqqKxMQ0Ll++jFarpaKiAr1eT1dPN1u3bmXevHlotVqioqLYf/Agv/rVr6ioqCA9K4ujBw4gKhTE
+xsZy/vx5mhqbyM7OprCoiHfffZcAk4l58+bhk31YeyyU7NnD3DlzsA8MoJDEoWpbq9UiCAJut4cL
+F86zbNkytm/fjn9EWO7lS+Xn1Wq1d/KUaX/bc37avgMBQbti+dKPqyrKC0pKdnPf0rsxmUycPXcO
+vV5PXV0dacMyGHA6MXeYGZYxnOrqq+Tm5VFZWUlBQQEbNmxg0tQpHD9yhNG5eezYuZPk1FRKSvYw
+PGs4J0tPUnzDDVzr6mLkyJHMmDGDwMBAYmNj+fHHH4mNieHCuXPkjhrFV59/zpw77qC6upq0tDTy
+xo8nJCiQEydO0NdnZcKE8eh0Orbv2E7+2Fx0Wi0trc04HQNIogIEGdnnRatR4/N6kCQlCoWCoKAg
+mpqaKC0tlYumTi3us1qPTp4yrfXves6fX3j+o6ee+s2SuxcvUt96yy0UFxbQ0tyMUqmko6MDn9fL
+qPxxlJSUICiU7NpbQs6IHHKys5k0dSq/7N/P+PHjOXDwAOnDMzF3dHCq9BT1DfXcMPUGQiMi0Gs1
+OBwOKisr6eq8xtixY9HpdLS3txMRHg7IXLp0if3793P3Pffg88lkZWWxfv16MjMyqK6pYeTIkTgc
+DkpLSykqKsLtdrNh43p+88STOBwO3njtDe5cMB+VWoW/nx8DAw78/f2QEQEBjUZDfX09C+bP5/tN
+m6irryuKS0opHZ6ZNfCfPOfEiROMHpGVMmHC+CmNjQ2jT584ydKl96BRSRw4cIDk5GSuXr2K2+Nh
+47btWHr7yMjO4tEnnubLL79kwrhxtLW0kJeXx5YtW5g4qZCjR4+xf/9+xo0fz70rHiQkLIRfDhzg
+62+/xWazMX3mTCZOKqSupobW1lZCQ0O5cvUqapUShQJmzbqVqspKvvvuO06dOsWKFSuor69n6tSp
+2Gw2AAIDAzl8+DApKSmkZ6Sx9oO15ObmMmXyZD795BMS4uORRAmtRoPP68MnC4iSNBRm/TYb6778
+Ul66dOm9O3fs/GD3nj1DXbwE0FxfQ3R8Eh+8925cbu7oJXfecQe3334bep0WfG56enoQRZETJ07g
+GBjg1Xffx2gyIfsGq12NTkdHRwdnzpxh27ZtmM1mSs+c4djx4+zfvx8ZsHR3UlQ4kZycHFwuF+UV
+5byYk83lsnLyJ0ygpa6ODnMHY8eOoaerE3xejh89yrVr13jwgQeoqa1jyZIlfPrpp7zzzjssWbKE
+hoYGgoKCuP/++3n99TdYuGgOCxbcydq173P3kiVMnlLIqdMnGTNmDJJSgdFowOka5JJ8Ph8CcMft
+t/P9xg2Cy+mUMzMz1gFDFKIC4NNPPwUgNib69faODlnGy+hR2TgG+vAPMKHTaVEqJVJSkplUOIml
+i+cj+2RcnkFwDCoFn3z6EWqNEq/PTWJSPP4BJh599FEkSUKt1fL2qy8zYcw4RmfnEB4UQnHRFO5d
+uIS33ngFQZYJiYnF4XSy5t1VfPDRR+j9/fELDCQ0MpKa2qvERIfz0ot/ZNHCO1l01zya2loZN2E8
+NfV1rPvma+5cuIBDPx/GaAygqKiYg4eOEhwczpWqalpb25F94HH7kH1ONEoFkijj9bqJjIpmzm23
+smXLJiEsLHjs1198mvN/gfPHF//My8//YUZmZubIzz75WCgqLMRkMqGWJA79/DM1NTW8//77lJeX
+U1NTQ0R4OAKgUimRPS46OjpYvHgxDoeDgoKCoR5rzvz5uN1uzp0+RWNjI4lJ8bS1txARGUZF5SVC
+QoPos/YNMoNuNwmJCdjsdlwuF3/5y184cuQIISEhmEwmGhsbaW1t5c033+SFF18Ej5eP135Iemoa
+I7Oy6WxrZ96dd7J//37i4+OxWCy0d7STkZlBWdlF3B4PAw4HsixjsVgA0Ov1eDxuZs68kXfefgc/
+Pz99ZWVlWuWlC/8HnIaaK1gslniVSsnevXuYOmUyHqeDM6dL6ehox263s2DBAgRBYMGCBbS3t4NC
+gdvjQbhOYF24cAFRFDl+/DhNTU3kjs5F9noRRZFTpaUkp6RgtVowGvV4vW5cTgcqlYTNZuPkyZPI
+skxoSAh6nY7s7GySkpK4evUqb731FuYOM2lpaUiSxOXLl3n55Zf4YM0H3DC1mIbaOox6A/GxcZy/
+cJ4RI0Zw6dIliouL6egwk5I6jKbmFnosfTicbmQZtFotDocDu92OQqEgOjqK9IwMqiqr5NmzZ7+3
+fft2xeWKS4MJOTM9TTF16tRPmxobwi6XX2LWLTehlkTCwkK4eqWaqOhozGYzqampVFVVkZCczLD0
+4ag0OvB52bJpA1FRUTidTqKiojCbzdw8axay14fBZGL71i20tbYQGRmJ2dyB0eiHRqPBZDIRYAqg
+9PQ5pt94I5JCwOt2U1tXh91uR5IkEhMTKT15kqamJpxOJ7Is09l5jTlz5vH888+Tm5fHmTNnSElJ
+YWDAjsPhwOVy0dzczKlTp7DZHQQHh7B7dwlHjhzF5XIg+2T8/P1RKlUoRAmv14NSqeLosePC1KlT
+u6bNmPlBWESUR/HZRx9y3wMP+6IiIrWVFRXk5+YhSRKIIna7nQMHDzJu3DhOnjxJbm4eDoeTK1eu
+oPPzQ5ZlvF7vUE2gVUk4B+x0dF4jITGZgMBAAGqrqxlfMJ6QkCCSkhIJCPDH43FjsfSgUivpaGvF
+63ThdLowmkz4+fnh7+9PREQE4eHh5I3JR5SUVF25QkpqKp3XuqisusTrb77C0eO/MHZcHucvnOHQ
+4SNcrrqCwc+f9MzhTCqajMlkIicnh4cffpiCggIsFiunTp/h6tVqvF7vIDCSRH5eLhfLLqBWqWLe
+efutVQDS0hX3U/LTjhv7enuTL14oY86c2xEE8Lg9+JBZseJ+tm7dxsSJkzh8+DBpaWmcOX8Or9OJ
+V5BQSSJer3eQALf3ERwaSlNbJ6JCxOeTweMhJTmFI4cP09PbjcViwd/fH0EQsFqtBAcF0NFhQRJF
+PLIPndEw1I+NGzeOsrIydDo9CYlGBEFg+46fKC4uprW1heMnjjO1eCpHjh1Br9djMPoRFR3Dte4e
+zJ3XsNsGifoTJ46zffs2kpKSCAoOoaW5mdLSU4iiRE5ODoIgERISjIBMf38ffVar/1DOOX78+Dyt
+Toelx0JcTCxKxeD0UYGC48ePDd5IBgN9fX309PRgsfQiKpWAjMvlwm6309LcjMlkIjo6Gr1eD6IE
+sgzSYPGYnZ3NpEmTSEtL484770SSJLKysrhx5kyUSuUgxyyDVqfDZrMRFhbGZ599xi+//IIsy4SE
+hBAUFER2djZlZWVkZmYQEBDA8ePHqa+vJygoiPS0NBRAl9lMRFgYXo+b3zz5OK0tzWQNz0QpSbic
+TgIDA+nr6+Obb77Bbh/A7XYP/cDlFRVkpKfv+WDt2ngJIMBk6ui1WDAYDagkJbIM1t5eGutqmTRx
+EmUXL6LT6Rg1ahRer5epU6cgyzI+WUb2etHr9fhkmZI9e/B4fWTm5AKDcweXrR+v10tPTw9avYak
+pCRqampIS0vDZDLR0tKCRqPB6/EiiSK66/2bzWZj5MiR+Pv709zcTFNTE0FBQcTGxqJWqyktPU1X
+dxcXzl9g6dKl9PX309bazNWrV5k6dSpvvfE6YWGhjB2Th16nIS42GlEUaWs309vbS1JSEi0tLVgs
+PURGhqNSqcjNzeXQwUPy7Ntu+3T/+g3DFRfKzqvj4uPF+oYGjHoDkihyzdyJKCjQaNS4PW4KCwtp
+bGwkIyMDWZYpLS1FUChQKZUoFIPdbk1NDRnp6dx77z3o9YbB8luSGBgYIDAwcIiQamhooLunB71e
+T3d3N1qdDo1Gg6RW43K5cDqduN0uDAYDsixjt9sJDg5m9OjRGI1GWltbSUlJIToqDkmh4rVX3yAx
+IZnkxBSudXYw7YZiXnzhT0ycWMDkyYXo9XoE4EpVFeXl5dTV1uJ0OCgvL0eWZYzXu3aQiY2L4+rV
+q0JYWBgKhQJFRdkFXUR46BOdHR3ExsYw4B4gKCSIK9XVDB8xkoOHD6PSahhTMI5Vq98lOS2V6Mio
+wZzj9qIQBBQKBcPTM3C4XdgHBsAzmKRlnw+n04HTNYDb7STIFEhO9giiIyIJCwmlubGJqsqrtLW3
+4HUPXCevJCzdfZSXl9PV1UlrazOiKGCxWIiLiyMpKYnAwEDWrHmPFStWYDKZEEWRjRs3EhOfwMef
+fEzasGGkpCTR0dFGX18vCUmJTJ46lVF5+djdLvqdDtxeD/Hx8ciyjFajQSkqSU5IxGqxoBAEtKJP
+lPr6+nxGo5Fei4WgoCDUKjWyLKNQKPj555+ZPXs2GzZsoLCwkOTkZP785z/T12tFVKvxOjy43C66
+u7sZGBhgWEYqhw8fJiAwfLDElGV8Ph9dXV3Ex8bgdDk5cfIEHo8Hr9fL7bffjtfr5XLVFSSVErt9
+gIGBAYJDgomKikKjUSGKIrIsI8sylZWV+Pv7U1FRwfTp0zlz5gxpaWlcvXqViIhIrlZfxWKxUFxc
+jFKpJCcnh61bt9Le1k5zcws+BHp6ejDodJw+fZoP1ryPv9GPAbsdSaVGp9UNerwokpycPFzhdrtN
+Op0OS28vPtmHn58f/f39JKckDw7oOjrQaDSsWrUKh8NBXFwcYWFh+DyewZxz/Tp3Op3U1NSg0+lo
+aGi43vMPTiyVSiUVFRVcunSJqKgopkyZQn5+PseOHaOiomKQYFcMThEqystRqVQ4nU6sVistLS3I
+8uCFkJCQQGpqKm63m3HjCki43gw3NDSQmprC7l27eeyxx/B4PJhMJg4fPszixYvJHJ5JTEwM7e3t
++BkMlF24QN7oXCRRwm6zIwgCsiwPDhllGbVajVarG6EAQmRZxuvxIAiD7msymbDb7ISGhrJ+/Xr8
+/f0JDQ1l1qxZBAQEDJHaojiYR5RKJVarFZfLxaJFi7l27Rp43HjcrusiAgXjCwooLi4eAq+trQ0A
+j9s9+GsplSBDc3MzkZGRREREEBwcTGxsLNHRUfh8Pqqqqli7di2hoaEkJMRTV11NZWUlsiyzadMm
+JkyYwNmzZ5k0aRLt7e1ERUWxfft2NmzYwNGjR7ly5Qqy10dLcwv3L7+PYFMAoiDg8Xiu38h6RFEc
+zEECAQpRlCSFQoHH68Xf3x+lUonD4WDb9m2oVCpUajVZWVkMOBz09/ej1Wqx22ygEPF6vHg8Hjxu
+N2PGjGHEiBFs2bKZ1tY2BvptOF0utDrd9WTsxOVyERwcjNvtRqFQkJ6ejsVqJTcvD4/TiUql5Oy5
+c2g02iGlV1dXF1evVuNwOIiIiECj0ZCSkoLH4yEhIYG2tjbS0tJobW0jOzubO+64gwMHD9Lc3ExC
+QgKZmZlER0UzMDBASEgo+/fv54XnX0Cj1eIYcCCJIgpRgdvtRmaQGxcEAYWgcCh6+iyNNrudiKhI
+LL1WBFHCIwtMn3ETWdkjUIkibocDlUJBU3093WYzFrcLr2cAhcKNKEJHl4XeXgstTW3oNHqCAwxU
+VZajRolKo8PPz4jDPUBVVRVVVVVD1/HJ0lJkZz9TJk8BSUVLu5ma6it4PXbM7W309lgIDw1DIUjU
+1zUREx1H+rDhaDV6mloauNZlJiNzGNY+C7fdMQuXzcbekj0E+PkTHRXL5ctXuFRZxcXyctQqNaeO
+H+MPv3uaqPAgRElGoVEgaCS0Oh2CqABRgcPlxOP14hXoUhgNRrckSajVaqxWK5Ik4Xa5CAwMQKcb
+TFA9PT1ERUVx5MgRYuPiaGlqQhQlXA4XHrcXP6MRq9VKXV0tBw8e4PHHH2f71i0o/Q14HQMkJ6dQ
+XV0LgMlkorS0FLPZzPRp0wiPjCF/7Bhkn4+d27eRkz0ci6WX0NBQNBoNp06dwtLTxehRIzh96gSB
+AX6cOH6UE0ePcvHCedRKiX17ShienoZSpcLf3x+VSkVVVRVmsxmVUsm4sWMpu3CBJ598kqSkxMH2
+CPD5ZOw2GzabDY1ajd1uR6lU4XQ6ZYdjoFMRl5hgtdlsBAYGyl1d1/B4PGi1WmRZpr+/n1mzZnHh
+wgWGDRuGy+XCYrEwJi8fr8OBAlB4vYQFh3Cy9DgjcrLx8zfS1t5K1dXL+Ab6EJUKhmdm09Pdh8lk
+oqGhgczMTCZOnIjNZsMriChUWgacTj77+EOiwkMxGAw0NDRw4sQJiouLUamUVFRcwt/fj4yMYSQl
+JZCVlUVYWBhutxtRFDl9+gxRUVFD4ERFRRETE0162jA0KjX333cfBp0OWR6ccen1elQq1eCoWqPB
+4/VisVgGWyePR7h46eIRRVFRkau7u3tCTHS0MHC9o4XBtl6tVuPz+YiPj8fr9RIbG8uYMfm0tbTi
+cbtxO13gk+nsMDNx4gTsdhuSJNLU1MiwYan87ndP4/F4yMrK5p67l1FWVkZxcTFJSUlYrVa2bNnC
+XUvuxevx8vQTTxAaEkRsVCTd3d3U1dVhNBo5e/YsapUavVbH1aor4JOJjohCKSmw9vbg87jIzBjG
+jOk3oNVqUSqV1NfXo9fraW9rJyUpmdmzZhEdFY1Rbxisu5xObDYbHo8bWZZxu90IgkBzUxMxsbHY
+bDbsNrtGYdT5yxaLJcXfZBpSMKjUagSFAkEh4nF7MJvNZGRkIEoSP27YyEMPP4zT6cLpdOBv8qdo
+ciEhISH09PSQlZWFXm/A63Zjbm/jh+++RW/yo3ByEUuX34egELlcWUVTcyuPPPZr0jKH89knH7N1
+yyZumz2LmprqodJg7Nix3HzzzcTHxxIUHIBao6TicjlHTxylra2NPmsfXd095OePISwsnIjICIx+
+RmLj4pCUSu5bsQKNVovL5aShvo7eXgsatRqdVotGo0GvN6BQDIqgtFotV69eJTEhkWvXrhEcEjog
+AXi9g3Sny+2mt8+Kz+dDrVLjkxX4+/uTNXw4e/fupb3TjNFopK29g/5+G11d15AkiZS0JNqaG+nq
+6qa7u4fu7m6iIsIpyB/DqZODJPtbq1Yzceo02pqaGFPgJiIyElmWuXf+HHbu3MnLL7/MgMOJqNbT
+Wl1NSEgIyamplJaWkpyUiLnTTFJyKunp6dTVNdDZ0U5ubj579uxBpVQFvdBrAAAUpElEQVRj67fj
+kz2EhYfS199Pn83G3v37iYmOwmDQUnbpwqBWWRAQFAoGBgZwub1D42qtQkF5eTl3zJ3HhQtlrHzo
+8XoJID4+/khgQEB9YkJCfGNjI1mZw3E4HIMU57lzZGSkk5qaig8Zo58fq1e9Q0JCAn5+fvh8PsrK
+yhg1cgQhISH4fD4MBgN2mw2L1UqAKRij0cvyexZjsfajVCqJjY3h6NHjJCYm0Nfbw7fffnv9yr5K
+fX0913MgwYGBjB41irKyC0yYMIEvv/ya1NRU2ts7kBQCoigSEBCA0WgczD1KAa/HQ0pKCimpCrR6
+PVaLha1bt5OclobdZhuSrLh9PtQa3ZDSDGTMZjP5+fl8++13lb9NSeyTLp0/x/CckdXlZ08p4+Pj
+OX36NKNHjqLXPsizmgJMNDc3Mzo3l5b2No4fP8byZUs5WVrK3LlzOHvmDDkjsomICKexsZHIyEj8
+/PwQBJHy8grKy49w6803MW1KEbVNTfy8/2d8bie33jxjcL5ts9PW1kZ9fT0ajQadToefnx+5ubkc
+PXoUPz8/UlJSqK6uprOzk7KyMkaPHo2l+xotLS1DggatVougkHG7PEiShEanw+XxIQsCBpOJikuX
+mDChAOG6AEq4rgny+XyoVCosll4CAgL/Kmg4CyC+v/ZDfvl5r9BnsdwRExMTs2vXTvLz8ge1wg4H
+kgidnZ00NDRw8NAhJElJbm4uFeXljBs3ls2bN5GQkEBJSQl2u52Ojg6uXbvG6TPnqKqs5onHHqXn
+mhmNUuLgkcOkpqViMBqw2+20traQlZXN3Llzqaur4+TJk9x6663s2bMHpVLJ+PHjOXfuHAaDHp1O
+R3R0DAkJCbS0tGHr7yMuLo6GhgaSk5NRqzU0NtZTXV3NL4cPs2nTZnbt2sW5C2XAoKqsv78fSTE4
+x1SqVEhKFRqNBlEU2bJ1K9ExMXR1d7sLCgpu/vjTz/oUAJOm3CAfPX3mHY3BSGhwEG2tLWiVCpSi
+D38/P/Ly8jhx/Dgjs7K55cYb6e7pYcSIERw6dIjAwEAqKiqQAa9PRkbA6xNQq9UUFk2gzdxO74AD
+pdEPSammo6OT7KwRVFRcxmrt46GHHmLz5s389NNPFBQUsG3bNrKGZ/LoI7/i+/XfUjx1MuZ2MwXj
+JmBu70D2+mhvbWHDhg04HA5Cw8MwX+tE0iiJDAzDZPAnOTGJ2LgYEpPiSYqLwqhT02lu4/zpU6iU
+SjQazaCG0OtFoVCgFFWs+/wLJk6cJF+5ctXz8ccft188d/r/TDx//dijVhF5fERoeHRN9VVSkpMH
+RY5eH8ePHyM4OJiamhpuvvlmjp88ycyZM69f01lMnz6dkaNGMXbsOBwOJ4KgwOEYID8/jyNHjpCU
+nEx5eQUZGRmDV7SfHx6Pl+XLl1NTW0tfXx+jRo2iurqaoqJCDvy8n7q6GjIyMq9rdSTKyspITEzk
+p59+Ijs7mylTpuBwONDpdTQ1NRGfEI9SUFBxuQKP10tYeBhWay+tLS1UXr5MYlw88+bNG+r1dHo9
+oihhMBjoutbDjh07mX377cKHH320Zf2GzT+ERUQNTjwvV1wiPWN4809bN1fGxUaP2blrF0VFRei1
+GoKDg7DZbEyePBm73U5nZyeiKPLDDz9QU1NDfHw8u3btQqVWI8vQ1dWNQiGxYMF8du/ezaRJk9Dr
+9Vy5coWvvvqKhx9+mI0bN2I2m3G5XAQEBbF92zbUajVjxoxh585d5I8Zx4IFC6itrRukJVJSUKlU
+xMbGUlBQgNPpHJLaKtUqJKVEcHAwF06dobaxEXNHB5cvX8br9XD7Hbdx17w7B6kPrw/F9TCSZRm9
+wYBarWbb9h08+NBD7N2/n2X3P7D6r6IoEWDNmvcBGJaaXJOZnvGA1+ujtbWVzMxM+vsGKUVBEIa6
+dqVaTWBgIPHx8dx2223Ex8ezc9cu5syZgyAoSElJJSwslJqaGrq6uti1axdTp06lrq6OY8eOERsb
+S3p6Ounp6ezetYsbbriB3t5erly5wkMPPsjnn39OZWUlnZ2d3H333ahUKhrq60lNTWXLli34+/sP
+hXREZAQN9Q288eYbtLa1UVtby8033cT8OXOZNm0aOdnZABj1BvqtVhBAp9djs9sJCAhAFEUefewJ
+fvv7Z+UNm7f0PPHkUw/9NZr+LwnKS8//yVFXXz8iLSU15dz5cySnpKJRiiDLGA0GgoODB6WyajV6
+vR7Z56O5uZmjR48iKBTs2LGDs2fPMXp0LpIkUlhYSFdXF6IosnXrVp555hncbjcdHR34+fkhSRJB
+QUEcPXoUvV5PYWEhX371FVOKb2DpsuXkjxnDzl27uFJVxdgxY1BcXwOYO3cugYGBDNjtNDQ1EhsX
+y/wF87nplluYfdtsNJISvUaLJAh4fB4MOj0uh2OIZfD6vOgMBox+/nz00YcoRJUcEhIufP/9D083
+NDWV/hWP/yRB+fG7rxeGh4V+3txQq5S9LopvmDE43/G4GOjvp6ysjOrqGmRZxj8wgIjISBITE1Ep
+lVy9eoWNGzfS22tl1uzZWK39NDQ0DOkBDx06RHHx4Jw+Ozubnp4eLl6sIDMzg6qqKux2O7fceivb
+tm+js7OT/Px8xo4dOyjx31NCamoqOp2O77//njnz7mLTxk10dHQQExPDqNGjGJ+bxS+Hj+J0e5kw
+aSJOl5eenl48bgd6vRa1SoXXZQcETEHBqLQGiqdN57v1P/DAAw94S/Yf1AmC4Pqb4Jw/fZKSkhJV
+fl5eo8moC9u6ZTP33HMPGo0Gp8MGvr+SYgq8Xi8avY629nYulpVhtVo5ceIE+fn55OXlcfHiJfb/
+fIDi4mL27t1LaGgoL730EmvWrKGtrY22tjYWLVrEnAULeWD5cgoLC4cKtJ5eC2lpaQwfPpydO3fS
+3tpKREQ4oaGhPPvsszQ0NBAXn8Kzz/4OPz8/Tp06xYDDQYifll8OH+a999fyu98/h0IUufHGm3E5
+B/hpxzaWLF6Cyd+An58fpsBA3nh7FXqjiYzM4fT09Ny1ZOl93/1HPP6m7O2zjz5YkJOVeY+11zLt
+SlUls2bPxjlgQ6lQYLH0sHv3HhQKBS3tbUhKJdHXu+Guri7i4uIoKiqivOIyLS2tbNiwgbCwMCRp
+MGneeeed7Ny5k4cffpjm1lbee/c9hg8fTnl5OYmJiXi9XrJGZLN69WqMRiOpqamUXTiPn9GIyWQi
+KyuLdevWMe/OhQQGBlJUVMSXX35JY2MjY/NGMn36DH716KM889tniYyIZPV777H+u6/p67Py9Zdf
+ER4ahMHfH0GhZOYts/jhxw3Mnz+/Y/To0VE33XST99bb5/7X4Hz75efcteRetm/esCok0P/RsvPn
+5LS0NCEjPQ2HzYYgCDidg54nqVX09ffT39/Pti1b6O7p4bXXXmPHjh3MmTuP1avfo6+vj6amJjwe
+D319fYiiyKVLl8jMzOTWW26hta2DQ4cOkZOTQ2lpKbGxsVRdvUJAQAD33Xcf1dXViIJAYOBg8vwr
+O3Dv0hW89957XLx4kYGBAcLDw2lpqmfW7NtY8/5aHn74YV5/80062to4f+4cDz10Pw/cvxIfHqIi
+Y7hhxo2sWr2G1WveR69Rz1+99uPv//9Y/E3POfbLAUpPnhifM3KU1qTX7D137izjC8ahUQ6SRF98
+/gVXq6tR6zQEBARiCjChUWuYPHkyly5dYvGyZbzw3B8oKBhPTU0NVquV2tpaIiIjmTB+PKWlpdx5
+53zOXzjPqVNnmHbDDez4aQdz58xl1+5dLFu+nG+++YYLFy4wduxYkhITCAwIICYmBp1Ox8WLF5GU
+GhYvXsycuXOZNm06vb297C3ZRUZGJvYBB/sPHqTswgVMfkbm3HEby5ctxe1yExUTyXvvvc+1Hos8
+PCtH+GHT5i927d5z79/C4e+KtL9bv74gNSbqsKW7W7hypUq49ZabwefB2tuJwzG4WObv709/fz+f
+fPEleXl5jBkzhvLyckymAFa/t4ZFixaRmJhIbW0tZ86dx+Vy0dfXR0hICGPHjWPGzJm89MILpKam
+YjabGT9+PFeuXGHbtm3k5eXxwCOP0G0209rSQm9vL1VVVXR1dZE/OocNGzezedsOwiKjCYuI4p75
+8+gwm6mrq2Pduq+IjgzjsV+tZPz48WgNBkwBQZTs2csPGzaybPl9fLB2Lbv3HRQ2/Pg9c+be+Y+D
+c+rUKRrbOoSuxtrFqakpz/dZeuP6rD3C5MlTOH/6GHv27MFmtxMUFITFYmHFAw/R22uhrq6OCRMm
+8MvhI8TFxQ8my+ti7lG5eTidTi5evMjChQuprq7m8OHDREZG4vF46OnpITAwkJKSEl566SVee+01
+QkNDCQ0NRalUYjAYiE1IoN/SS11tNXljx+JyuXnrrbcxd3bS3dFOQkIifX195ObmMm/uHIx6DQZ/
+P9QaHWfPnefFl1/hzbffke+/fyVPPvlk/NIVDzT+Vxj8Xc/58L2/cP/Dj/L+6r/clp6W+oHLMRDW
+3tHO+NwcrnV1De097dixAz+TieXLl/PDDz9w58KFfPX5F5gCApk/fz6lpaXs27cPP1MAlZWVxMTE
+EBQURExMDLPuuIPDBw7Q2NhIcHAwW7du5dVXX+XDDz8kNDSUMWPGEBcXR0dHx9A4ub2tja7uHh56
+6EFcjgFEUeTYsaM01FRjMpmIiYnF388PhSRhCgxAISo5e+48z/z2t6xe84H8++eeE2bOvPGpp5/9
+wxt/z/7/5zLaF598zD3L7+PtN18/NCJr+CSFQqC28iKFhYVIkoTVauW7775j5cqVbN68mdmzZ9Pa
+2kpubh67dpdw+PBh7r//fsxmM92WXrq7u1EqlWRkZNDQ0IAsy5SXl3PLLbewatUqXnjhBbZt24af
+0cjNs2bx9G9+MzjOcblwOJ2kpaXR0NDAr5/4Df5GPQrZi2vAzsCADbvNAchDinWD0Q//oGA2bd7C
+m2+9xZoPPpR//evHhajo6Dc2b9/51OOPPMTb767558EBuKF4Cms//VDct6NkX0ZmptHZ1zO6obGR
+SRMn4PO6kUQJpQR2mx2jXosoKjh0+ChJyWnUNTRw6JdfGBhwIEpKEhMSUakH1xEdAw7yx+aRmTmc
+P/3pee5auBhZlqmtrWbRkiU88eij3HLzLbg8HsIjwqmvq+NaZycrVq6k7MwZtFoNokLAoNchiiLu
+ATs+wNrXh8kUgF9AIJ+t+4ZtO3bw1NPPyL/93bOCSqV67sTpsy/9I3b/txdgX3nxpV9yRmQmi4IQ
+3tzUIIzKySEw0ITsdeN1uwdlZV43Gq0eu8PF9z/+yC2zZmMw+mHrt3HmzBm6u3uu71I42bNvN7Gx
+caSlDmPkyFF8/fW3vPLW67zy/PPcOPNGLl++jN1uIyMzk9OnT5OUmsLM6dP5bt0Xgz1XQwMrVqyg
+p6cHQfbicnsJCQvF5fLyymuv0dLeyZJ77pGfffY5ISU1dc3Grdse/kdt/W+tTldXVjHrjts/jwoP
+G5uQmJgeFxsrnDl7BqfThSnQhMPtpvta1+D0UJYxmzvIHZ1LQ0MDarWKc2fPcejgQY4fO0pgQADm
+jnZeevlFhqWlcfz4MY4dO84bb7zOhx99yLixY7lcXkF4RASBAQEkJieRPiyNAZuNi2Vl6DQaxowZ
+Q05OztB6o8HoR0BIMFVXa1i4eAn5Y8aRN2as/Nhjjwu3zpr1dFtb27PVtbX/sL3/bc956tePYAwI
+U4QF+S/o7e35evzYsdhsNiouX2R4ZibRUZE0NtRj0KpRigJ6gz+ipKRkzx68Hh+Llyzmm6+/Ydmy
+pdjtA9Q21BIfH4/D4WTduq9RqVSYe3oIDgykvraO/Px8goMCeHf1X0hLTUW6rl71ulxERkbi7+/P
+9OnTiYyMxOmRefqZZ2jvMLPyoYf59ttvOXGylN/97tm4Zfev/C9vpX8ZOAAlP+1g+k0389Iffz+h
+p7v788zMjOSY2FgaGurxul0kxsdh1KqQPQ4Cg0Lp67fRa+0jLi7hekFYQ0ZGBlqtDkkj4fV4kYHv
+1/9IW1s7klZHb08302+Yhtvt5uf9e3niyccRRZG+64KFuKhoAoOCrstZPHzz9TfsOXSUwsIilGq1
+/PEnnwkqlfqnU+fO3fzP2PhPg/PX8+IfnuW5F17m/vtXrgsPNs0eO3asQRAERXVNjWzt7hLS01II
+DwtBJYnXE+bgjpbH47m+MexDEAeXV9euXUtNTQ233347+ut9WltbK6dPn+FPTz+F2+VErdOjMhgw
+BPgj+JQ4HE5K9uzjh00bmT5tOgmJCfK7774rVFdX9xQVFc757sfNP7/71ls88sQT//vg/Mfz8Mr7
+1AqFotTr9ZqmTJkSa9Rr5U5zh9DS1IjX4yY/P4+w4GA0Gg0ul4tei4W+/n4iQoKx2WxUVVWRl5+P
+LMu89OeXKSwsIicnBz9/P7RKFS6Xh5CIcJxeD6fOnGPDhk0Y9f7MvOUmmppb+OCDD+Vr18zCypUr
+n543b96qYcNHuP7fT/33z78MnKefeIzX3lrFgw+uvL27q2u5QaebmZmRzoisTHq6u+Sua9eEluZG
+tBoN/iYToaGhBAUFEebvh9vjJiQkhL6+QXGlw+UkPDycDrMZu81Gc1s7za1t9Fr78coQHRODRqvj
+8uXL8o8/bhT0RqPL3xTwpzVrP/hoRNaIrnfffoNHHv/N/9imf/nLhV54/o/84Y/PI8uyZtnSe95p
+rKsdm52dnZOWmkJERARKpUp2e9xCc1Mzndc6sVut6HS6oRGw0WjE6/PgcjoHVao+H6bgIDQ6I1qN
+Rj518pTw888HqW+so8/muHTol4N/mjSpaOO/2g74X3gtVXn5RSEzM4sP17z76JYtW16xWq2akJAQ
+0tPTiY6Okk3BkYJSqRx6T4XT6cB6Xczd1tZGWVmZfKnikmC32wkOCuGGycXf5Ofnr/n4sw/PnDh5
+xiUIAhs2/MCcOfP+5c/+bwcHYNumH/mPJNLLL7+YtXfPnpjW1jalv15tSExMmihDNDJtPp+3q6en
+55rdblerVGpvRUV5/ej8goFdJSWHBEGw/G8871/P/wcpt7+5NSukBwAAAABJRU5ErkJggg==
+"
+ height="70"
+ width="71" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/10 centssmall.svg b/plugins/currency/images/10 centssmall.svg
new file mode 100644
index 0000000..825d0ef
--- /dev/null
+++ b/plugins/currency/images/10 centssmall.svg
@@ -0,0 +1,54 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="40"
+ version="1.1"
+ viewBox="0 0 40.57143 40"
+ width="40.57143"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="10 centssmall.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="1"
+ inkscape:cx="-365.56607"
+ inkscape:cy="12"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" /><image
+ y="0"
+ x="0"
+ id="image3046"
+ xlink:href=" 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 "
+ height="40"
+ width="40.57143" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/10 dollarsoff.svg b/plugins/currency/images/10 dollarsoff.svg
new file mode 100644
index 0000000..73d94e6
--- /dev/null
+++ b/plugins/currency/images/10 dollarsoff.svg
@@ -0,0 +1,104 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="55"
+ version="1.1"
+ viewBox="0 0 117 55"
+ width="117"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="10 dollarsoff.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="1"
+ inkscape:cx="-67.723576"
+ inkscape:cy="87.999997"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" /><image
+ y="-8.0163699e-07"
+ x="2.2370994e-14"
+ id="image3048"
+ xlink:href="
+HBwgJC4nICIsIxwcKDcpLDAxNDQ0Hyc5PTgyPC4zNDL/2wBDAQkJCQwLDBgNDRgyIRwhMjIyMjIy
+MjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjL/wAARCAA3AHUDASIA
+AhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQA
+AAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3
+ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWm
+p6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/8QAHwEA
+AwEBAQEBAQEBAQAAAAAAAAECAwQFBgcICQoL/8QAtREAAgECBAQDBAcFBAQAAQJ3AAECAxEEBSEx
+BhJBUQdhcRMiMoEIFEKRobHBCSMzUvAVYnLRChYkNOEl8RcYGRomJygpKjU2Nzg5OkNERUZHSElK
+U1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6goOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3
+uLm6wsPExcbHyMnK0tPU1dbX2Nna4uPk5ebn6Onq8vP09fb3+Pn6/9oADAMBAAIRAxEAPwCW7uRu
+dBIN6oXAY9cevI45Gen4VWt0ttUFxNcxlmhIjASTryeO2DnjBq/dW6pZSBlDOAW54+b16j+Yqnp0
+YGmXAO1svxyQOg9OfyAx6DGB2Xs9DmsmtSL+zoBHu+yOsmOFMvBz6HPTn0z7VdiiSMkC2nMePv5H
+X6Zz3/nWeVlhk+VFdm7q8iY56554/wABWlD5Una4Ix0Vn+nY1hioqUbS1Ekk9AnVFRW8tjuOMZx/
+npUZcpykfB65bnqf8auXyolpG4RzggY5Jxg9utYx1Oy3FJLlYJB/DIjZH4YrghhotXsapIe99Ibq
+OOOHK5Cu+/gH0x3pl5eyxyGNI1du2X25/TH6ipYpNO8uNItRtyV5y7HLHuScVfSG2uc+U9vOT/zz
+kVv65rqjhqa9SXBM5abU54ZCj2rI4OcO+D/KrtjNJfxswVUwcFS24npgD35rVudMhlTyZo+M/Lng
+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
+U4pK5Ase8nPI7UUUVtcwsf/Z
+"
+ height="55"
+ width="117" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/10 dollarssmall.svg b/plugins/currency/images/10 dollarssmall.svg
new file mode 100644
index 0000000..f2784ea
--- /dev/null
+++ b/plugins/currency/images/10 dollarssmall.svg
@@ -0,0 +1,55 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="25.8547"
+ version="1.1"
+ viewBox="0 0 55 25.8547"
+ width="55"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="10 dollarssmall.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="2"
+ inkscape:cx="41.363688"
+ inkscape:cy="21.113258"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" />
+<image
+ y="0"
+ x="0"
+ id="image3048"
+ xlink:href=" HBwgJC4nICIsIxwcKDcpLDAxNDQ0Hyc5PTgyPC4zNDL/2wBDAQkJCQwLDBgNDRgyIRwhMjIyMjIy MjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjL/wAARCAA3AHUDASIA AhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQA AAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3 ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWm p6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/8QAHwEA AwEBAQEBAQEBAQAAAAAAAAECAwQFBgcICQoL/8QAtREAAgECBAQDBAcFBAQAAQJ3AAECAxEEBSEx BhJBUQdhcRMiMoEIFEKRobHBCSMzUvAVYnLRChYkNOEl8RcYGRomJygpKjU2Nzg5OkNERUZHSElK U1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6goOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3 uLm6wsPExcbHyMnK0tPU1dbX2Nna4uPk5ebn6Onq8vP09fb3+Pn6/9oADAMBAAIRAxEAPwCW7uRu dBIN6oXAY9cevI45Gen4VWt0ttUFxNcxlmhIjASTryeO2DnjBq/dW6pZSBlDOAW54+b16j+Yqnp0 YGmXAO1svxyQOg9OfyAx6DGB2Xs9DmsmtSL+zoBHu+yOsmOFMvBz6HPTn0z7VdiiSMkC2nMePv5H X6Zz3/nWeVlhk+VFdm7q8iY56554/wABWlD5Una4Ix0Vn+nY1hioqUbS1Ekk9AnVFRW8tjuOMZx/ npUZcpykfB65bnqf8auXyolpG4RzggY5Jxg9utYx1Oy3FJLlYJB/DIjZH4YrghhotXsapIe99Ibq OOOHK5Cu+/gH0x3pl5eyxyGNI1du2X25/TH6ipYpNO8uNItRtyV5y7HLHuScVfSG2uc+U9vOT/zz kVv65rqjhqa9SXBM5abU54ZCj2rI4OcO+D/KrtjNJfxswVUwcFS24npgD35rVudMhlTyZo+M/Lng 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 U4pK5Ase8nPI7UUUVtcwsf/Z "
+ height="25.8547"
+ width="55" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/100 dollarsoff.svg b/plugins/currency/images/100 dollarsoff.svg
new file mode 100644
index 0000000..8a65bb9
--- /dev/null
+++ b/plugins/currency/images/100 dollarsoff.svg
@@ -0,0 +1,54 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="55"
+ version="1.1"
+ viewBox="0 0 134 55"
+ width="134"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="100 dollarsoff.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="1"
+ inkscape:cx="-172.24001"
+ inkscape:cy="44"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" /><image
+ y="0"
+ x="-2.253418e-06"
+ id="image3048"
+ xlink:href=" HBwgJC4nICIsIxwcKDcpLDAxNDQ0Hyc5PTgyPC4zNDL/2wBDAQkJCQwLDBgNDRgyIRwhMjIyMjIy MjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjL/wAARCAA3AIYDASIA AhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQA AAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3 ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWm p6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/8QAHwEA AwEBAQEBAQEBAQAAAAAAAAECAwQFBgcICQoL/8QAtREAAgECBAQDBAcFBAQAAQJ3AAECAxEEBSEx BhJBUQdhcRMiMoEIFEKRobHBCSMzUvAVYnLRChYkNOEl8RcYGRomJygpKjU2Nzg5OkNERUZHSElK U1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6goOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3 uLm6wsPExcbHyMnK0tPU1dbX2Nna4uPk5ebn6Onq8vP09fb3+Pn6/9oADAMBAAIRAxEAPwCzqGqi zuFiKEkrn72PwqI6q5TasJcFcNtlAwOmMVS1e3M96/zkBIuF7dTVNLePOAFDYPAXnAB/wrP2MZx1 PJpxVrmxJqTRMwaFmbGQFkUjORih9XSH/l3JAxysykH1x+tZa2auRvlcxrgtzj8KZdm2hcBQGZeg 6/nWf1aDfU1Sivso37XW0uQfKgLAdSJBwc1MLyVmINvsGzcHeQBcjqM/rWfpUj2+k3Go3BUxRcQo f4m7/wAjXLX2ozXs7zTzMxzkIzcAdRgVKwNOW9/vO2niZxjZJI7T+0ZpXdY3s3ZR8/77oOoOcdqp Sa5cq7qLeKXaRlY5g3Pf+dcT9pyGUOY88HBxn/61RCcgnLAE9ea0/s+jtYp4mo92dr/wkxBKGxlU rwcyDOK6XTr8ajpcN0FKbwRhvUEjt9K83s9SZ2YytuDKRknn611mkXWPDdunz4YOBIp4zvbjjv0x 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 "
+ height="55"
+ width="134" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/100 dollarssmall.svg b/plugins/currency/images/100 dollarssmall.svg
new file mode 100644
index 0000000..3695601
--- /dev/null
+++ b/plugins/currency/images/100 dollarssmall.svg
@@ -0,0 +1,105 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="22.574627"
+ version="1.1"
+ viewBox="0 0 55 22.574627"
+ width="55"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="100 dollarssmall.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="1"
+ inkscape:cx="58.911764"
+ inkscape:cy="31.000877"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" />
+<image
+ y="0"
+ x="0"
+ id="image3048"
+ xlink:href="
+HBwgJC4nICIsIxwcKDcpLDAxNDQ0Hyc5PTgyPC4zNDL/2wBDAQkJCQwLDBgNDRgyIRwhMjIyMjIy
+MjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjL/wAARCAA3AIYDASIA
+AhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQA
+AAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3
+ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWm
+p6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/8QAHwEA
+AwEBAQEBAQEBAQAAAAAAAAECAwQFBgcICQoL/8QAtREAAgECBAQDBAcFBAQAAQJ3AAECAxEEBSEx
+BhJBUQdhcRMiMoEIFEKRobHBCSMzUvAVYnLRChYkNOEl8RcYGRomJygpKjU2Nzg5OkNERUZHSElK
+U1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6goOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3
+uLm6wsPExcbHyMnK0tPU1dbX2Nna4uPk5ebn6Onq8vP09fb3+Pn6/9oADAMBAAIRAxEAPwCzqGqi
+zuFiKEkrn72PwqI6q5TasJcFcNtlAwOmMVS1e3M96/zkBIuF7dTVNLePOAFDYPAXnAB/wrP2MZx1
+PJpxVrmxJqTRMwaFmbGQFkUjORih9XSH/l3JAxysykH1x+tZa2auRvlcxrgtzj8KZdm2hcBQGZeg
+6/nWf1aDfU1Sivso37XW0uQfKgLAdSJBwc1MLyVmINvsGzcHeQBcjqM/rWfpUj2+k3Go3BUxRcQo
+f4m7/wAjXLX2ozXs7zTzMxzkIzcAdRgVKwNOW9/vO2niZxjZJI7T+0ZpXdY3s3ZR8/77oOoOcdqp
+Sa5cq7qLeKXaRlY5g3Pf+dcT9pyGUOY88HBxn/61RCcgnLAE9ea0/s+jtYp4mo92dr/wkxBKGxlU
+rwcyDOK6XTr8ajpcN0FKbwRhvUEjt9K83s9SZ2YytuDKRknn611mkXWPDdunz4YOBIp4zvbjjv0x
+65rmxOGhTcXHuYTvJM6/S5WjvCwxkKRWz9slB5I/KuT8ONPMHklckY+QsQT+n9cH2rrIVULle/r1
+NawTSJoppWMi58UtD4gtNJW3ZmmzvlPCrwSAPU8Vl+IPFtisptv387QMRI0ERZU+ppPFQlj1bSTb
+58/9+YsDkt5Tbf1xVfQlth4UsDbYJYsZT3355z+n4YrR/CdFVJU+Zkcep2c1h9uSdPswXJc8Y9jW
+WvinTpZEUi4jRzhZpIiEP41g34RdUuolGNN+3ReeF+6D/F/XNdTqCwHS7gTBRB5bZz0xjjH9KSik
+eRJK5bXn0x68HP50VS0ITNoFk0g/eeWBz6c4/pRQ79DJqxBqAC3zNwf3a8HgHk/zqjDM6yeR5TFm
+B2/KDnOe/wCn41Yvljk1yYTRFsJ8gUckdfxqZLmKG5QiBCFO52btg4Offt+Vbx+E66fwlW7eWNP3
+cZR2O11QHAxgZJ7ev4GsqKGadZJSg2KwyScHP9a05XiklkKureZIyIeuRnj8KaLSS4leOOMPtTeR
+0Xp39qUm0ddGmp3uT6/M1todnbHMWYi0Xq47njrXF2lvJqNwYkkjiH8cszhVQepJ/lV3xDczuLeC
+eIq0Ee1MH7oJyRj1zmug0bwvJceHLOaJolkmRpXdxk5P3R9PWto+7EbVhYPCWnm03Q3kV4/dlYEZ
+9iDXJ3ViizPDFPGHUkbWOT9K7TTvDV5pGhavIzxrdzQkpsI+TAPOfxrnV0C5tTHK9s0qGIyb0XKZ
+3YOT2455pp+Ykc6YrkFzt/dRthjngf413fhJPIMtsHDRSoVbeAwyvf06foQe+a5uQzrcPJcW4ih4
+UkgKOOAcfjgn/arpPCRAs72KFC5iZSswTcrDsMHqccfQD0rHEtcmpTtZ3Ow8OHypZRuIG75S3XHo
+fcfjwc5wRXRhxgqo+X3rlfDjOztGTIFj+VVboo/2c9B09vSum6AAHvXMmRSZn31ibvUrO6ZHzaOW
+Qhh824YOfzP5Vz2seGke4e4tzdWhmc+YlvPtV/fHqa7UAEU0WIvbmKNgdgJZsenp+NafZ0Najbhy
+o4iHRol017CHTi8H8QJ3bjnqSO/f2xVFPCJG1ZI9QngQ5SB5Ds46fhXtkNvHbxKkaBQBwBwKkAyS
+P1oSfc5vqvmeXpE0SqrxGPA4UjGBRXQeKhjVU7fuh/Wis20mcVSPJJxPP9QRxrEsgc9FIA7YJz/M
+1EkMcASRMBo2XZvJ+8SB/wDXq9faTqN6xubdmWNEwcZ6/X0rHhiaJnW7uCtyhG0r09QQT1PHb07V
+0QkrWNqT0sMmEaRLPHyYiPlbGCM8EgdDkj8zW7pqx3cs56KSrMqDse3Hbg1kvLDNtj8zZvIGQM7s
+cjOeOvPNaOjQXEUtxH8ioxBZlz8q84x784x/hTkd9DZmfrieXZTK82FYgZVR85xgnn2H6V03hR8+
+HbcSEbY8xjnnArnPEx32gWLGEcKNp6YB6H9Kl8Ha7Hb6bcLetiON9zFeducDJHoT+HNVHWNiqkep
+oeLLx7PTWWK/t1kfl4GYKxHcZJzjGR9SPeuUutZkGix2cd2x4JCxt09CfTjqPrXRa7daLPaIEvbe
+Irlgkdurl2IHJOM5wAK4K52ALsUBmOTtGK0iZILlJ5ZobbkqVD7Y1Cg9eeK7XSH+w+GYj5QNvJu3
+HH3TuIJPqMAVl26BS6gcrAqk/wDARn9c10mkxB/CVpnoWbnv/rDXFjZfB6g37rLnhwGAySSsCOW4
++bjrx6+v+PU70N9HPE0gjmBHOwocn6djXP2kUVvb3MKoqKY23bTtBB7jsO/t19aZHfNbyCUzycZA
+C3AY/kTilCN0Y052OnfUIY5VjZZQSNxZY2ZR7Egda2dKYNOWU5BA/nXMR6hDwz6iVOMbSV6+n610
+mhSJL86yeYCv3vXmtbWR0xlc6A8DcOP/ANVDcHI9cUA470hIzk/lTNDkPFY3asgzj90P50U3xWc6
+onU/uh0/GisWrvY8mv8AxGZC30VvAyyRsZEb5W3cHByM/nXOXunPPI0mY9oQAh03dO1FFZ1ZOC5k
+EJNv0K/9kBlCH7MQG7RHjPGf5VfjOohDGlxb7CD96I5zj1HaiisJTm/tM2pYucdEl/XzIbnS9Qnt
+WjE9uC5OSYyRg4z36iotI8OnSknU3Cym4iMUmV4xkdBRRXPUxNWGike3R5asU5JGTceD7t23W7QJ
+jJwGI+vaqT+D9TDAyS26kH++e/Tt7UUVpHG1ublv/V7Fzw9NbI6KHQrt0JDxLIV2OeSCc4z+hrf0
+2xbT9Ihs5irtHuzxxySf60UVh9YqVKijJnmV0lF2LFlZGeV4YeHdDyTU/wDwjN8T/wAfHA6He3+N
+FFerSb5TGhBSjdk8WgahBJvS6HTHzZP8zUl4l/Z2Sb7jEpfAZOMj0ooq5NtWNKkUoOxlm+vixH2u
+Xr/z0NYpu/FpyRfw/wDfbUUVMWea5yvuWLebUnjP9pXCPLnh1JPHYUUUVcY8yuQ3c//Z
+"
+ height="22.574627"
+ width="55" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/2 dollarsoff.svg b/plugins/currency/images/2 dollarsoff.svg
new file mode 100644
index 0000000..0f1a6ce
--- /dev/null
+++ b/plugins/currency/images/2 dollarsoff.svg
@@ -0,0 +1,279 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="70"
+ version="1.1"
+ viewBox="0 0 70 70"
+ width="70"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="2 dollarsoff.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="1"
+ inkscape:cx="-124.56607"
+ inkscape:cy="94"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" /><image
+ y="0"
+ x="0"
+ id="image3046"
+ xlink:href="
+eJzFvGfcXWWV9/+9dj/9nLuX3D29kDukFxISQGpAEBRRFBuKjqjYGUXHccQ2dsECgihIk14FEkpi
+IKT35E7u3vvpZ9fr/yIz/mfGxymf0ee53p7z2Wf/vmfta6+9fmttwf/lJaVUnn/qvsrtW18oH+49
+FtN0wxRCaVI1Vc9mS73XfviLu7pPnohe87FPjYaEcP5vn9+/LvG3OOiOPzzI6re8HYBn7r9bHRub
+0KxQ4aND/b3zclNjS6tTiTMbaqspS0VIJhKYpimFIpiYSotcyeVoxwkcJzg8NjExXNnUejiVrO6u
+qW194dU/vHx8xYp1wcXXXuf/62+d3LeNme3r/uoa/upgHnnkEa644gqO73ql/Qff/do1C+c2LlvW
+vqC9ujyZUoSC7wVMTaaxSzZ7j3UzPT2F5/sUCwWscBgEtC+aQ8RQqKuqIBe4hKwomm5N79t7kInJ
+zJ3pQmHYDCfyn/7q9x4Uanji1ccfYP1l7/ir6virg/nUO9ZcXlYVfscZ8+ZunDtnQZUX2AyNnWL3
+viK7du2ip6uX4cFJcjZETEjEIRpVMS0TKSWqolHIFPEKHk4BpA5nLJ7P4jNnsnBxm6yfUSniZozR
+sWlGJ6aPCmE8Mjh46unrv/rATiGEP9Z5mMrWBf9rHf8rMLu2PM6yTZchpVS+/emr5w/2nnzuvHPW
+15+98Tx6+/p57NnHuf/B5+jq94nr0NIYZtG8apYumkX7onlUlCcJhcIkEjF0Q6VYLBCOhMllCwhU
+crkcXeOD7Ny5l1dfPkh3Z4lCzmHO3Douv2Iz8xe0UVaepFAqMjpe/Kawkr+NVNYfW7Vhs7/9D/ez
+9i1X/78BAyClrP/Que2/+eBHL984o7lGdnXn+dGPfi22v3YIXQmYNzfF5W9bwcXnrqSqtgbhuEjX
+Rdc0pJbCdx1UywThE3gBqlApFTJIAkAS+BLLsvB9H5D09nXx0L17eOoPrzBdUlmxpoXrP/B+GQ+p
+QovHOHhq7JrG1sVHV258674D+17hjPYN//fA/OzWz/KRL36HS9bN+t5FZ6/9yCWXrQilc2F585e/
+LXbuPEJdGVx35TIuvXQ9FfEwUSuBHapFESqKpoDno6gaQvHA95GuTRC4qFYMvwiKrhMEHq5dwlAN
+FFPHtwsoqsB1XBR9mtHRHNt2HOD5lw6x7Y8nWbasife//ypZW1MpSnl7X18pcstl77rpOSGE+zcH
+07njWVpXX8gHr3tnjZbpfvKKC89atmBeG7/53RZ++vMHaJph8Z63reDdV19AqDyGUzRQVAMlJJBZ
+iaKrCMXHKWUBH0VEEUIAAYoKUlVwiwVUxUAzI/h2gGt64At0I0LgCVTVRJGTBIEEKVCEyoEDh7nj
+Fw+wc3c3F1y6kUsuP09WpVKie2D6Tatu/UUr168dH3j9GepXXfTXB/PoXT/g8vd9kr3P/W7JrV/9
+6q7bfvpFpWdsgBtuvJ2pjn6ueUczn77pvUSj1RCpxbdLqAKEtAlcG+HmEEYM21fRFR+KU4hwGRIX
+EUTxpYOmFchN59AjOp5U0LQoRqIa1y+AnSfwDCw1RdHyCQmBkx1H2Bk8zyZUVU/nsUE+/onvkM7m
++PoPPkZTy2qZGz1xKlW2+KqG1Zfs+8oHz+cf7nj+rwsG4Bff+fK1e7Y++esvfe0GsXXLLm6+5W4a
+qiW3/uOHWLtiMaoApIVtB+ghFbuQQVcECj4CBWFYSM3Czk5iKgJpRgm8AqpWhlQ8ersOcvzgMaZy
+kzTPnMOyZWehWXGcko0MAsyqMnZvfZ6WxmamJiZom92K77lIoSAdHz1WQRDo3PpP3+E3d/+R9914
+MeeefQ6pRKnvYKf14be+/5PPOsMnMWpm/pdalf/qC0/c+xMA3nvFxg8de/P5e773zS+K++5+jM9+
+/pdsPqeRpx7+Ees3rcH3BEgNx55EMbIowkHggvBAg0DV8T2foFTAtEIIK4zn+QhVBaGgKDp2yaan
+u48rr3wHfT39aGaYYqGAqpqY0RQnd+7gwIEd4GTY+8Y2fn//gxR8FRloIDQCJ4/nTXPzl2/gez94
+O3f+6Eluu+235KcrGpY2TjzzxqN3/p1RM5OHf/H1/xKM+p99+MITv+eiq67jx//4yfdkRrp/9dVb
+Ps0Pf3gHd/7iea5//0q+/KVrSYRTeOhomk4xPYUVMXCdEoovEYqGkAqK0AiUENJzkW4J1QoRoCOE
+QKigEMLzXAK/yKtbt9Pd20NNbT2tcxad/ucUBb9UIFpRyanDx7Btl0yhiBGOsXDJUlQhCHwfISS6
+IvCLJVpmVbJuTRPf/c6TDE/2s2T+bKpryoprVq9Qr7z+S4cev/f73P/IX76s/stL6YkH7l370oM/
+2PaNf/ic/OGv7hW//dUzfOwja/jo+68EWYUvPQIjjyyW0MMpZB4EAhGkwQoReD5CqGBGwM4gvBKO
+J5FWAl0V2E4GKzwD38nR3bkPO22TLeWYM28hyaom8FykcFCUgMmhNB/9yOf4wKfez/LlywhFIwjP
+Q7cMZDGPZ3soQkHTTTw1QEXh2MlDnHP5N7nmsrV85INvJV7ecOr1oyO3XPauT9z3n+n+i2A+ff3b
+CTKTbcNDJ05++xtfkg/89knxk18+yVc+v5F3v+tdSEVBNwx820a1TOySgxmJgqYxNTqCho9uWljR
+BNK2wc4hgwAhFNxiCSNkIa0EOC5CN/AVAxEyEcUsnuehCQWvWESxNPBVRCRKYOewKREBfE9BUQ0C
+z0GRAULXsUslDF0HXUfmcwhsfE2lqzfLVVfdzCVXbuKdV24mMJ2Bkaxx5Xlv+9Tr/yMwJ/dto23x
+WvWKs1oHv3bzJyu3vLJT/Pj79/Kpj6/ng++9EkXXyUxNMZ2epqatjYnefoYHBujs7kIKDdPQse0c
+qqoTj8U544x2KuqaCWwbMx7Hy+ZQhYojPUwzAqh4ikAGHl4hS6isDHc6i6breHoE3bRws2m6Ow/j
+2VOEwwnqWmahqRZB4CFLORy7iAAUVcUMh/ExCFQXWcpiRMp4fcvrXPGh2/nyzW9n4YJ2OVnon/Kz
+NTOTc+dPnXPRlX/G4M/2mId+8W3OuvidPHnH11/8xpc/vsB1ffGPX/8Zl1ywgJs/8wFGhvvYs2sn
+e3a/SdgyGO3vJRkOMTUxTnVFBWvWrEIGLtWVFaiKYOmSJRw5fJjJTJEZjc34jotE4AuBGhRB6niB
+ihYPkR8fZnykn6G+PgKhoJsWihXDK3kYZQmm+rrp6z1BZ1c/VdX1/5II+uB7aJqCYZpokQjS88AK
+EwQBIvCRxRyNbfXEExbf/86jrN1QJxor54UmskcLm6/9+1f+T8Hx52CefIE9Wx8/pzzifWXZ0jPE
+33/5VhKWz+0//ALpbJrtW18mGU9y1tp19HT10NTQRDqdRg+FyRWL7N69j3Q6w6zWNhpnNCNQIIDh
+sTEOHdhH2DQpryjHLRRRKaFaSZRoHOGVuOO279Pa2EA2l8cLBFW1MwhsG11VQNXQFbCiMUZHRli2
+YRNOycE0DHTdAMXA9QWKqiNREUIgHQdds3A8l3w+z5oVsxgcGOPOX7/I+Re3y5qylrOvvPT8Pfc8
+8ocT/ymYva88w5pZjdYPv3PL7r//4o3mQ79/gtde3s+Pv3sjxewIJ052sKR9CSdPnaS/f5DW1jZs
+2wFVEA5H6DzVR9v8hWy64ELCho5AxTBDxGJRGhqbiIYNBgY6SZXHMaIGQaAhhYaiaIjApa+nB0PX
+2b59F32Dw6zadD6a8AmcEnguVlkKxdBpX74KP5/DLE9APgeKCqoGioJEohoG0imhqTqe46KqCrqm
+4JYKrF69lEcf30HBlWL+ogYK05PXnL1h2U+e+MMbxX/L4t/lMUs2XMTBU8c+cMOH3hebTue5487H
+uebta1i4pJVjJzoZHRnhiaefIJqIUV5dgWbppPNZisU8J44fJ5mI01Jdjz2ZRehxND2FlAZIhcCF
+2spaktEU/b3D5HIBRqoG2/ORngsYRBI1/OS2BxgdmeBjN99CPp1Huj6KZSEsHXyfeCiO76ko0QjF
+4UGEbpy+6wUBmvTRdIWglMN1PQLpAS4icFGlxJMakajPl774Hu65+wX6R9JCCymYlvnV/xgx/27z
+lVJGV8xMZl964nd89qYvMjbRzz9/+0aSYcHjDz/GGUuXk05PY9s2Tc1N+J7PyMgIMcuiWLRZtmwF
+6ekMMtCorWkkPZ0hkCXypXHCsQTxUIj+7l7Kq2ewa+8hVm44j3BFOd50Gj1Vjjs5gUhGyPd1Y8QT
+6KEkmqlB4FNK57AiUSiWCEIavldEVUFRLOxMBuw0EKBqKoqq4KGgGyYycAlcDyEUfJlFBmG0kM6N
+n/keh49lufXbH2HPwaOUVS4/49zzLzxY1TbvzyNmw8K6T33y49dw6NBRXv/jfq65+jxmzKgnM+Xg
+OCWmJycpFR1CVoRYJIEMBJFwjNamVpavXsPI0CCTk6MYpsf0dB+50hi7Dr7Oazu3c6L7BEdOHkJo
+NoXiMJ1de3nskQcQpQKqAjIzhZZM4E1OE0sk0JD4ToliLkegqoCEwAcBpUKa3q4T5HJZxkaH0KNR
+dNNCaBpqOIwwdITvQeAi/YBAKAjVQNMMcBWkU+DjN7ybkYFBjhw5yVkrFjM1dvKjVW3zGOg6CIAG
+cNvXvshHb7mVmK7ddNbaldzy+W8zd24569fPRgtVsnP7U2zauImDhw/R2DKXqqoqJiYm2b9/P+MT
+EzTV1qMEAYgA8BgbG2XXrmP0DU3zwsv7qG8uY+S322ltqKS5Lk7gO8w/Yz6elJw6cYCW1jakBHfK
+xkymyI/2Ey0rR/rglQr40yXMsInrFyji8vSv72DB0sXce9fPufGzXwbXRokk0AMP33VQFBXPnkJX
+BYE8ne84ElRfB8XDs3XaWmo4+7xZ3PnLR1m2uAVT96+WUn5BCJH+U8R89JZbuf8n37muqr4qWcz5
+7H79OO+85kxMvQo3N03j7BjHjnfg+3Fqa+sZGBhEURSGh4dYs2YV2UyGXHaaiclJnEDl6edfYyw9
+Se/gCS688Awuu3ADs2fNwLIC5i2YS8/wOM9u2cezjz9Jb1cfimIh1RiaGUEUpolYGrKYwc6n0bUA
+TXp4pRKKohOPl5NIpJg5cyErVp9LPF6BCIfB98B3cEtZCtkJRCiFq+i4no0spjHtaVzPxZEBqqGj
+BIL3ve0CenuyHO4YYm5TdfLmG8675c/uSgPH9/3kkouXN46PTnJw/04+85mPUFbRALrKm9teZtWK
+5STLKti65SUqK8rxfBfXcdj22qsQSFAkuq6jGRaLFy1h6fIlnLvpHM499zwOHz3KhrPXsWJpO45T
+ZPPmS1i5ehW+W2Rx+xmUV1VQKhbQtNP1mMzkOLquY1jh0zkJAlXTEYaGnS/wz9/4Bs88u4WWlgbm
+L1mMk54mcPIEThFNkeiKBKHiuy6KBE1XsR0HHwXLMtB0DRlAZWWKE509DI5Nct7GDXT1d1a+793X
+3/7I038I/gRmQ3vTJVdcfva8393zBKtWzmXTxk1IqaNaGn4+Q39vH45vs3TpMkzLQNc09uzdRTKV
+pK25ldraakKhMKqq07pwEZNDg0ynJ+nu7mJkaJCuvg5OHD1MMpakubUZxyuyeOlyUqkUhm4gZICi
+gFMqEY2GUTQNPwAZnK725XNZTNPAKeZZvLSdRQvmsGbNKtTARVFAeDYCiRJ4yOA0TAWJlD6O4yAB
+VdfQdQ3P808nf9IjWRHj9p8/xiUXbEI1/LgWKb/tgUefLygA77p4pTXUf+rSusoauW/XcTaccwaq
+ZqCZKqcOHCCftamtrUUoDt2nTtHT2UVvVyerli3lLZs2IqUkEo3S09OD53mMdnbR23WK+uoazmw/
+gyuvuIyeri4KuYCqika6TvaTzaQ5dWqQgYEJMELomonv+miahggCCrk8INAMC8/1iFWkcIo5PE1S
+HovT2tKMInxQAzw7j2pFEKpOyQvwEajSoZSbxrGLWFYIT0oUVZwGIsA0T2/G82bXkC6odJzsoHVG
+izY8OPYBAOW53/2UAwd3+ZdffpF/9MAJEdINlpw5Gz9wCPD5wwsvUCjYDA8PUyxmcF2HeDxKKpVE
+Suju6eTVV17lgQceQNM0hoaHCYctDh3Yj6YruKUiX7vlq3zyE5+iubGZxx9+lnvvuZ9HHn6MW2/9
+BU8+9Txe1oVARQkUNE0HIBQOoWoavgwwUkkO79rN808/yWTnKYyQhaIKujpPMdrThVAUSo5EWFGM
+WBIPHem7aKqCAnieh227eJ6L49pIGVAo5FCkSnkyyczWKvbs2Yebh6MH954NoF3wzo/x3ktXP9FU
+W2Xs2neSeQsTmDKJVDzcQobM+AB9RkBdXR22K2isL8d1XfKFIpFInHzJpf3MlURjOpVV5VRW1OG4
+Dtdc9wHcQNDXP0ikrBpVBFx4wWrmzCojEi/jRM8AkdAwS9oXoIZ1JBK7mEd189hKiHBZBU4+SyiV
+4OG77mLWzDbOWrsBXVXJTE+QSkYpi4QwrBheILFiEukUCFxJOJqEvEDVXQxVIZOZJBUO4QsDVVGQ
+PoSsENIv4hcd3ntVK489NoK42pMzqv3zX/z9YzUKQEtT48TMWa0cOdrJ8hUL8e0SihCoQuGiizdT
+WVlFd3c3hVyRrq4uBgcHmZiYoKOjg46ODs45/zwGB/vxfZ+DB/ejqAIRBEQjEfbs2cmS9gUUiyVK
+RZvKimoikRiGbvH2q8/FNAVjgwMIPYyqWGi6gR4Kg1MiFAvz+G9/y7JlyyirrODEieMMDg5iWBZq
+IIkn4jiuw/DgEAd270cNRwh8F4RAhsKga5RsGzNkgaKc3osU0HUFu1Qgm8mgqiZz5y3i2PGTjIyM
+iLrqep58/K5aRUqZ+PntD7yrsrxMTk8N0L54IaouCFwPUJg3dwGgYBgm1dXVTE9Pk8/nKS8vZ2xs
+jBUrVhCuqsDQNV599RU0TWHfnl3s3vUGUnrkMmnKyxNEwjGEogAKb+7azeDgCCc7DnNg7y6y2Smc
+bAYzEkEqOmY4gqZrHNr5BitXreTJJ5/ith//mN7ePu677z5efnkreipFLpdD0VSSqTIO7D1EYHto
+qoos5RGeg6HrCE3FiscxolEUGaAJ8BwbXRFEwmE0NUoqWYFlgu0UaKxvJJHU4hqQbmsrI5vJCsee
+pLGhDlXTcJ0A3dAo5j3efHM3Zy5tZ9nSZTilElYoxNGjR2lvb6elpQV7eJgNGzcwPDJINpNnzpw5
+eF6JRx76Heefdy4+AZOTk9j5LJmpSdLTGY6e7GW41yKeTPD4Y4/w0b/7OHYRPE+iZLOEYjFefXkr
+O/cc5+ZbPsfMxgZKpQJvu+JtvPzmdrY++zTLlp4JmoXtSrLZHEHRRtU1fKeA4/poqsD1PO79xc95
+93uuxVQtAt/Fc20CRUUREgKFivJqwhGDTHaaObMXy7Kq3gu1d168bnnYDAhQ0TTALeD7oEZTyJKN
+ous0N1UwZ3Yjkao6zrv6nex+6Q9U1VZTyLvseuMYbQsaaKhJcfjoISwjxOHDBygrS9LW1ko4bNJx
+spO5CxYTRCNYponUdM55ywWYlsZA/yD5XJEXn3+OzW+7Ct1xUawQxWyWGz7xcS462Unz/NkUJibR
+zDCObrFx7VnccdsPWLNuNenpArmih6bpaJEQXi5N4AdYmgGaSlAs0dU3QMkLsHTlX5zNEIph4LsO
+QglQsgHJZIqpiSkctyhyk7lGbd3qVYXXXuxiYipDMhmnsiyFakXxvNM5hBFL8NbLL+XVl19hcsrj
+zDPXsGTFBsKRPcxbuZaBoycxzBD5Uh7DtFi9ciWnOk7x2rZt5HI5Vq9eS9fJU4xPpFm3bi1SKHie
+S3ZqhNeOH0MECioqilApTE0RSiRxcxlwbaRqMqOuBntsGE1VMWIxiJbBcBe1dTMQqHiuTy6dZeny
+M0EGqKqKpkIQaHieR6HkoBgWRccnqnlkslmi0SiqdPAkWEqBsspqIrEoxYKNFVWxc165smfXm01r
+Vq5kanKKVCKCYWjgeHiujR4xcAsZwmYN6y64ikxuHN2KoKgh6uubefLB+0iXxigra6KiopEZ9S08
+/vgTqJrBnLkLWXLmCnbv2cOy5WdSXpbi0OGD5PJZcrkM6Uya8mQj4VCShsY6FiyaxYmOAwjXRXou
+oUiIQu70E7MfuCgEELjYE8NgGKTKqnB9lerael5+dQvL1qyilMviOiXsQpFiIY8QAtOyCBwPr2Sf
+TgNCITzPw3Gc06WJQAIu8ViYYrFENBJlfHwyrgwN5zedubRdxqIRTFMDGYCmYGgqMvApuRI1miQV
+TnDuBRezZ88LDPUew1dNNl90FfPnLUdRHPr7uxkeGKCyrBrXkYyOT9Pc2sb8hYvI23m8wCOTyRIK
+WaRSSYaHB3nowd9z9OhRdu/ZQ3l5kqnJCSbHRtAVKExNnPa0NRVD13CdAkF+CuEXQdc4eLgDL9DY
+8uo2Zs6ZBYGPCHx8z0XTFMLRCIqus/UPL2DnC7iFErZjY4VCRCIRgiDANC1QVdA8EA5SSoaHRpme
+zkS0VELXLd0QY0PDaIoA/3RBWpgxhAfxZBmFqUkmx0eZzhdYtHoDwlVQvYDscD+maVOQKnjTxONh
+tMBi+6uvc/TUSRLJBKlUjPGJYUolSV1dNd3dnYxPjDFnThvXvqeN9iWL6O3s4vnntlBZXolt55FB
+CN9zsAyTQi6DqUg0RSKCEn6pwN5Dhzjn/AvJFwPe3LWbm2/5PNK2CfwAVQhcx0bVQwz29DE0OMiC
+ufOoLa8inEow2N1NybZpaGjAcVw0zUSWcri+QyKRJJvNoSniNSVZaWEISaKmBUca5FQdNZxCMSPI
+kIEzPsSeHVuZUV9GZRT6Tx4kPdELmo/t+LhOiIKXoqaqle4TXfh6QBCxuOHvbsTNTSBLJXZsP8Kc
+OXMYGRkjFIoyb+4i9u87QeeRN+nvOMxgzwnqq8qImDDYcwzPd4hV1iDCCTzfwnNVijkbYUQJ1bdw
+5FgXjc31fOubX+J9H7gGO5MhsG0oTZGbHsELJJpTwC4VkbqBrYBVU4Zf9LjzV/dw4NBR9EgMVdWw
+7SKBVIkoMVpmtDE5Nky25D6kFPKF8Wg0jm0XCakBEV1FukV8t8j2l55haHKE1Rs24RMiUd5EQ0UL
+plA5sOs1fC0gUtNATVsbajTBmWvXM5XJU19XRziq0djaRDQe4pLN59LT00M6naajowPP86itrWHh
+wkX09PQwMjKC53m0NLcwNZVBMy3sXIZ8Oo3nFjEMDTMaBVXn/l/ewduuuJy7fnknH/nwhyiLxVE1
+Dcd2CBQD04oRskIEQUDINOnt6aFYKBAUCtz/4P2ousaadWvp7u4iIKBQKKFGkpSKaULhEFNTaSkV
+c50y1D/cn8nmKasqw81nEJ5DbmSA7kP7aV96Jk3NzQjdRAoT3SpDyAhbnnueeYvnEiuPg25BPocv
+NaqaZ9PWNouKsiidHcfp6DpF0XUY7O2kpaWFxYsX47oux48fJxaLEw5ZNDc3UV1VRSGfJ5vLM53N
+nr67IAnpUBYzcH0XM5Kka2iUJYva+f2DD9LYUM+8efPB91BlgON6oIZAPw0ll8tRXlHB0qVLicVi
+TE9Pc+R4Bxdespmtr77Gcy+8xLETJ4knUjhZm+HRQRRNsv/gUdHc2Pi0ogq959Xtr5POTWGZYVzX
+pbenn+aZsxGOT2BFcUs2ihKQnhji4d/fQ3XDDDQs/KJHkM/i5yfRLANpl4haGklLJ5PJYoRSvPza
+6wgEzz7zDENDQyxbtoyqqiqGhgZRAnDyRcKGRUtjE0cPH8YwLU4dO4Z0HTQ8Ai9HJBZhOl/ggTvv
+5uCe3Vi6zrnnbALXQZPBaQfBCuEJE6mauI7LyMgIoX954lcUhZe3bmX2/AWMjE8QjiWY0djMrr37
+mJhMMzGeRSgqmqkwMTnJnn3765UlS1dO9fX2Y+gaqh5ibCpDsqwKLVmOpocR6SI4DqWpUe656ycU
+yLLy3HNQpEUslEDYOXQcZHaKqfFh1MDGzkziFFzOaF9B26yFGIpFf38/hmGgKAqmaVJVXc3w8DCe
+7xMKh0in03h+gBAqoyMj6NEQipSYuoBIiOeee4G3vOVCyuIJLrrgAgLHBVVF6AbIgB1/3MGWV7bh
+BgpPP/0UBw8c4NTxE1RWVtLW1oZpmtiOzdHjx0mWpRgZGyUUCdHfP8jREyfRtRThiEUmm+fVg6ee
+175++72n1rfH+FD4XcTLyjhxrIfVK9qhOIbi2wQ4dBzZRXdPF+s3nsX8M1eD51O08xhSoioKXiiE
+4ukkw+WMDhwnGk+RzBXxMyMkQzCam+a6972XU6dOYdtF0uk0xWIRoSoc7OigvLwcu1Ckra2FwHeI
+JmOMTU2TKq9Ciyk88puHWbVsFbv37GbF6na6u46jqiqu65FMpRgYGcJRAoJSFlW6nBgeZuas2fRO
+jrNqw3pGRseZKPm4TsCstjm89PwWZs2cybzZs5g7bx533f00TS3lqGpYnjjlCCCsCSEyF65uHlOE
+WhmOVdDbN8bSxWA4klKuiCYLKFKyYeN5RKsaKBFDGCpaaQgtWY0f6Ai/AIEDlKisqkAoZXgIRkdH
+yeVy2LbD8PAwM2fO5KGHHqKuro6R4WEaW5oZGholmUwSi0aZMWMGhw7up6HRZHRwiPJkOdue2cfC
+BauJxSs459zzyBemSdS24Dg2cctC0zRqrBQzY+X0HNlHPFHFZedcxEvb9zHUmyNfPEzJddm79xBr
+l7eiNNQwp62Riy86j3hZkkLeZ8eOXaxYu4KhoTHxic989hYhRFoDuPiiq344OZX+ujCi6IpNb/8Q
+M00dAehCZ96iRRBKIDQLSw2T6TlFZnSUWiuOjMXQPBu3lEZ6JQr5DL4fUCgUqK6uJpPL0draimFF
+8X0f0zSpra2lvb0d23VYuXwF+XyeqfEJMpkMs2bNYmJinHiinK6uTpJQyOjvAAARkUlEQVRljVRU
+VhHgoOo6uhEj5yooWoSxqQzRaJRMvsCBowdZuagZzx2jr+84obBDPl8kl5/A8wMuf+tGaitSSAlt
+bW3s33+ANetWUyj69PaN8a55TXR2jXNsaKr6Ty5BIZv56aEjR/zZC+YTKBJdlxTyaXRDI2tL3JKH
+m5mmlB4lyI6imwrVrTNRYyE0tUBpMoP0imQyY/T29xKORlEUhY6Ok4yPjyGlxHVdhoaGmDNnDvv2
+7WN6eprKykqOHTvO4cOHSaVSOI7DyMgIhUIB0zLZtm07dfUVaLrENMAuuTglg0g4TCIWpzxVhq5q
+1FRUMdrTg13Ms337DsrrZ5NMxDAMhbaWRjZvvpBZMxuQRpSVZ21CCycZnsxyz30P0jcwSuvMWoyQ
+YGx8YmrzuRs/8ydfKRoO5f6w5aWptevWlLu5WnGko495qmROUy2+EsH3ioSSMbxSCac0QSieJPA8
+PNeFXIZicRrHy5Mv5CirKGNgsI/yygrmnbGIna+/QWV5DbsPHaRUKNDW2sLG9Wexa9cutm55mXgs
+SnNLIyMjA5w8eYp5c+bjS59cLo+iaPzsZz/EMFWQ4JR8nFJAvCKMQCGdzWJZFsVckbltTbz+2m5s
+x2E6O0w2O8HY2Bhz587jkQefwTQMqhsa2PLiq5TsHIlUkosvuYBHHnuc9WvXoSkGO3bt1m2ZDP4E
+5qNf/YH31rOXPjXY3XddOBwlLTNUVFSTGxsiZNbgqSbSA0UPYYWj5NNpTMvAzkyRTadJlidJGHEY
+O/3kHIuFKJYckALLshgeGaCvt48g8GlftIh9e/Zw1upVbHt9N5s3X8zI6CBv7nyD9iVLkJ5gMj1O
+zCty7Qfej18KUE0TO5vBjIbB84DTLgBCQQYgFAXfLpHJZEjV1ZEZGSFbtKmsrGRiYorLL78CgUDV
+DRzXpqqpkVI2TU//EM88v5d3v70M35tBV9/EyPPbbnO/+cv7/39f6WjX4LY7vve1z23YsByvWGB6
+bBhVK2EYBggoFl1UxUS6Adl0jpHhfgxDRTMgHKrA9yEaTaJpJh46tVX1pKenKDlZTp06RiSSYN3a
+tdTV1zM6Mk5jUwvnXHQBfd3d1NXW0tLShqpqxONhmlsbsR2b6rp6hO8R+DaqKpF2EdfNg20jAg+h
+gFcsooZDKEJghUJMT4wTjkQQSoBpaXiei2XpOI6NZoVQVQMhAUXjiSe2YlmSjRtXsGXbLhav2vyt
+jRdfuf1PhtvBN16mekZLsa48vvLsTatmFfM5MpkpaqvK8T3/dBi7LplMhv27d9LW2kQimThdrY9E
+Mc04gX/aV5YILNNAVxVGRgbJZNKUV5bRdbKLyvJKXnrpZZpaZ3L7z+6ntSHF3IWL6O7s5tFHHqe/
+b5Azlyzh+InjTExM8+bre1i4fBl33X4b0nPZ+eYO5i06A1WodJ3q4uDBQ9TVz+DZp54mCAKeevpp
+UqkUlmWxd99eXnjxRfLZAqYRIhQKn/awFZVsvsTY2BTf/8EvOPctZ5FMRuSW7cdKP/nN03/qkFYB
+br/jbv74xAMMjKdHj3Tsu3bBvHlk0xkmJ0epKq/C93w0TeJ4BZziFIoiQKh4noqpJ7DzkwR4BNLH
+9z28oIhdyuIHPrpucWDfEZob6glHw9TVNzE6nmbO/FkUC5NEQ2E6O3uQgcKHrr+BfXv3YxgWqbJq
+pqeLNFRWUFlRxeTEJOXJcmoqKkGz2PraNuaf0U6ASn1TE37gkUgmCYVD7Nu/jxn1rZSnKpkYn0YG
+gqaGFqQKhWIJoRjc8+vfY4VVmttmMNA/LI4cnfzW8YHxrf8K5k/dDmsufQf//Mt7XzhxZPxkIhyl
+vrGRgqvRN9BHemoS1w3IFBz6+0fQUSmLxDGlz8TYIIWpMXShk8uUKKQzGL5CenyaQrZAZmqC6poy
+DveN4Xg+ZRHB7KYyVq04g+aaJkb7h1nR3k4ibJAe7yebHmVqfAScPPGQjybylFVGGJkaJVmZRNVc
+PHx273qT40eP09vTi25E8H0Nz1PZtu1Nli8/i1dee4UZzc0sX7eWRStXUdIMFCNMoqycklNk55uv
+cv45K0lYEW779Ws8/sbRf/i3nR9/1mp2/rolL3Z2nbxhafsiFKGIiK6Qimt4bp7pyTwvvrqVP+7Y
+weTkJNPZDEbYIpmMgmGArpLNTTM8MkC+VMBDoW5GC43Nc5k9ZybRcJjhgQGKxRJVMxooFWyefvY5
+hKqRLCunae58hkZGON7RSUV1LYYVxtR0+nqHcFyF+tpajh06wsjoGPv37SdXKFJRUUFFRTnT6XGe
+ffYpNmxYSyoVJ6zr5LNZjhw5Ql9fD63NjWTzRYRQ+fznvsC5527CtMJ09Y9SVjvz+guveOeuf8vh
+/9i1uXnt3C23fO7D66dHetSZMypIjx/AUAQySPDCntdZMn8Bv73rYaLxMFL1WTi3hbLqGYSjMYqZ
+KSrKEgQCzli0DEWJYtsSgjSJeJzHH3uUupoq0tPTbNu5h7POOovxsXGi0QiapnHwyBFmz57N+NgY
+juOgOi6OVKhraMIplchPjZIp5lm9eg35goMXBOTyBRoaa8nn8wwMDJBKpZgYHGTO/AVsfeU11m88
+lzOXLafoCp579hmGh0dpbm5Bt2Lc8u1fFJ94dnsinc64S9a/5S+D+c7f38hn/+lHXHPu/OlP3PCu
+hF0sMKtWJz3Wj513eXjrS9z08RtJhiPs2rGNrF1gYmSYqXyJbK5AMmIxZ3YbhhUhkarkZEc3CxYt
+pqmxhnQ6x/D4OG4ui1dMs/DMlTi2TTgR58SRI3R2dlFZVcXs2XPoONlBeVkZhXQGdIu842JpKiEV
+9JCFqhokkuUcO36CuhkNHD9+jPKKCkKhENlsFtPQyeZyhKIJ5syZj+MHHD16jC984bt86lPvw7JC
+3PvQs3z1xw8ub52/ZNd/5PAXG6C/9/lr/26g/+iPzrvwYtEQM6iIBBw9tIu9J07xyc99gZcfuJ9i
+MceGt2zCEBInON1ZqUmP/p5efDRqamvRdQUtZKKhM5mz0UJxpkb6KQ8JhK6iqRqmaSKBQqHI3n0H
+WLdhA06xiKbroEgCxTjdYs9p2xhhoKk6uYKDqumUbI9UWQWe61KyTxe9paqgGSauHzA2NY2mm3z8
++hv54Ifei+u6pKcz8uHfP/X0S51sfujXt3PVe2/4d/r/4izB89sP7CyLhPU5jTXrzWhSFhwpFp7R
+TtfAKdpXr6WUzTE63MdI7wkqUlUEgY9qGGhWlKzjU1lZQyxZhi8NUMIUCkU8u0QqFUcXCtFUJcKI
+YMRTpKemURVBplCghKC6vALfDU63jEkDt+QQOA6+44FU8VWLQD2dL6nhOKoRo+QKVEPHlR6+crp1
+xLJCICSe63Pz5z/HlVdeiiaKFD0pn3ml4/gz+8fWAjz02NN/pv8vTp8cOnCQp3Z0fPnXDz27v5DL
+C6dUkAcOn+Tycy9mZN9uLN2lsqqK/pEioXicTL5IPpslPT1BVXkK1ynhOSV0TWCXskQiISLRME6p
+gB+4OHaB9OQ4dmYaVVWxHZ98toChahAoCM0gny+R9zVyvkYRC9+IE5hxHE/H8zSEauE5ksAPMHTw
+XBdVUbAMCyEERdsmk8lyyy23cNHFF1NXWYmiJ/npnU+KFes3bvz+V276S/L/csTcdvvtzKw2aaxr
+/fldd915zZpVy8rH0xmZ1E2RSMbRdIFmhMgXfGpqK1A0jcmJCfr6+6irq0FIH0VVmJ6eYnJ6AqdU
+wvPc0809QhAEPq5dQlVVVFVHonD42BGWn9mOU3QwQ2GyRRcjWo5QTRTNxEfB8SSqGcEPQFNVLNMi
+ZOq4bgFdV7BME6TA9T3y2RzfuPVWNl96GVNTU5SKgfzn2+/jJ3c/WvHOD9009vwrO/4imP/WINc/
+f+Wz4Tdee6Ljpo9cU9fT1UNNVTnzZzWSnuijubEaHxXPLnDqVAduqciMGbWMDI+j6RpWOAJCJRY+
+PeanaRpCCBRFIZ/LYIWjhCMJJqbSvPHGHznvnPWE9SiO1ChIgY+JqqpI+JchDUHJh0QsQjGfRfoO
+QgYEgUtZWTnp6SyRcITDJ47xy1/ewfkXXUix6CADn1/9biuXXf3hc2780j9t6T+xnxmzF//vwNz0
+gUs5++xltffe9ssXPv7J6xf4HmTTkyxf2EREy+MFpwfnE6kykIJsegpkCV03sUsuvh9g/YsDaJkm
++UIBz3MxNBNNM/AR+EHAyPAQvlNiQftypiezYJg4gYoQChJBIAMkAtMwgAAZuKgiQNcNDDMBONhO
+nt/d9ztO9gyz7MzF5HIZfBHj1/c+RlXT+rc+8tKLj2979lHWXXj5f6r5fzT6J7MTqbcsqTlw/Ueu
+m1FXXy8z0+OiYUYtlZaNYYXRDB3bcYhELIR0SE+niZhhbNshmoiRz+cIh0OUSkWk9InFqshls7iu
+g+M4pNNpRkZGOHvTeUxOTONLMOPlp61UFLwgwPcDyqMRHLeEokIobJLN5TGtGL19nfzqV3fR2NBG
+RV09U+PjqHqE2+5+1PnUF7+58bqPfe6P/12t/+Xo37+u8Y79iFj51G0//YfGZ17cueXxhx8RrQ2N
+7Nixl47OaXJFhcGRcRCQzWWRwsQIxUAzMENhHNdHN0JIBEJVMawwxVKJAAhFomiGSf2MBoQQ5HNZ
+VEMnnkwgCJAyQFNAU06XMVzfwfE8Agm+L4hGYvzwu9/g4QcfYN3qDehaAs+RnDiVlrffvWXqYzd9
+NXHdxz73xze2PvPfDoL/8dz1lt//nE1v+zCffufGTw12Hvne+6+9CowQQwPdlCVD1NWkUBVBZWUN
+5WUJFCVABj6O4yKEQiA9ZOCjqgqqYhIEAUEQUCwWiUYj7N+3hzOXrcDxJEiFcCxJNpfDcVy8QGKY
+IQzj9F41OjLBfffdj+cGVFXUEmg+rhToZlTe+9ALwoxWPf3CK0evViJKbuhUB7Vts/52YAAmuw9S
+1ryIE3u3L/rIe97+u7NWtC1Yv261dAoZofg+pqkRSB/LVKitKaeqqoywFcO2S5RKp8uWpVKRaCRB
+EPhomo5QBCDp6emkuqYOXQ9juy6+IxFCQdF1irZDNpNjeHyArVteYWoqS0NDM1VV1QxPjBKKpeQb
+ezrFsY6hzNpz3vqZ7/709l8+9dB9XHLVNf9jjX+Vl178/Jtf+eBdv/jWL95+yXqxYsF8xienSEuX
+eDSGqWn0dfdihl0WnbGQloYGorHw6e4EYRG4DgQBiqmB6xMEgt6+fqpqa8nl8pRwyGVzdJ06ya7X
+38AuFQmXldPWOpvurgFUNUQsFpW+DImf3Pmc37hwxaNbt7981f9W0/8azLYnH2bd5ivZ/sx9iZee
+fe5jO1577utlyYhYu2YVTU11OMUMyXiE8fFJhARFkafb1QyTTGkS0zg9dWvoOkJKNFVldHSUfNFh
+anoaM1xGNBIjlUxh2zaqojGRHiOaqEC1kuw/fJLnX3yDdZs2PFlfO+fGb/z4tm6AE92dzG5u/X8H
+5j8uKWX5tZetv76no+9q286fMaMmTEW5SXkyKisrykXDjBmEQxZTE2MoZopI2KRUzFPMF4iETQLH
+w/FchKKhmxbFUpp8voAXCMLROK7jcPLEIG8eGsBGTnpK9MEv3PLF295+9XUH/5o6/upgujv309x6
+OnF68J6fXbpwwdyee3997zn33n3PTQ0zjFA+ny+bN6eNGXUzsKIO9XW1DA8NUldbDQiCQJBMptBM
+g5GRUfIZDyFU9h8+xdETJ+kfcNMVFcnjX/3aV777tvd+9CGAnX/czoo1a//aUv62a2RolEfuf1Dp
+2LvLOrJje+1NH/jQx77+mU/OOWvRwpO/+tYt76nSFPnjv//ENxojppwd04I6U5FJgSwTyDgETVFd
+Xn3eJvmtL31p729+/qv1Tz38WEJK+afjd3cc/Zuc99/kHVX/nSWlNIUQ9j986XPLv/L1b7/58Rs+
+cKFdspfGYlEnmUj4NTU1perqamfz2975IJARQvyJRu/JYRpn1vxNz+//AxJkqfZPhY3BAAAAAElF
+TkSuQmCC
+"
+ height="70"
+ width="70" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/2 dollarssmall.svg b/plugins/currency/images/2 dollarssmall.svg
new file mode 100644
index 0000000..ef8e77d
--- /dev/null
+++ b/plugins/currency/images/2 dollarssmall.svg
@@ -0,0 +1,54 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="40"
+ version="1.1"
+ viewBox="0 0 40 40"
+ width="40"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="2 dollarssmall.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="1"
+ inkscape:cx="-472.06607"
+ inkscape:cy="-156"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" /><image
+ y="0"
+ x="0"
+ id="image3046"
+ xlink:href=" eJzFvGfcXWWV9/+9dj/9nLuX3D29kDukFxISQGpAEBRRFBuKjqjYGUXHccQ2dsECgihIk14FEkpi IKT35E7u3vvpZ9fr/yIz/mfGxymf0ee53p7z2Wf/vmfta6+9fmttwf/lJaVUnn/qvsrtW18oH+49 FtN0wxRCaVI1Vc9mS73XfviLu7pPnohe87FPjYaEcP5vn9+/LvG3OOiOPzzI6re8HYBn7r9bHRub 0KxQ4aND/b3zclNjS6tTiTMbaqspS0VIJhKYpimFIpiYSotcyeVoxwkcJzg8NjExXNnUejiVrO6u qW194dU/vHx8xYp1wcXXXuf/62+d3LeNme3r/uoa/upgHnnkEa644gqO73ql/Qff/do1C+c2LlvW vqC9ujyZUoSC7wVMTaaxSzZ7j3UzPT2F5/sUCwWscBgEtC+aQ8RQqKuqIBe4hKwomm5N79t7kInJ zJ3pQmHYDCfyn/7q9x4Uanji1ccfYP1l7/ir6virg/nUO9ZcXlYVfscZ8+ZunDtnQZUX2AyNnWL3 viK7du2ip6uX4cFJcjZETEjEIRpVMS0TKSWqolHIFPEKHk4BpA5nLJ7P4jNnsnBxm6yfUSniZozR sWlGJ6aPCmE8Mjh46unrv/rATiGEP9Z5mMrWBf9rHf8rMLu2PM6yTZchpVS+/emr5w/2nnzuvHPW 15+98Tx6+/p57NnHuf/B5+jq94nr0NIYZtG8apYumkX7onlUlCcJhcIkEjF0Q6VYLBCOhMllCwhU crkcXeOD7Ny5l1dfPkh3Z4lCzmHO3Douv2Iz8xe0UVaepFAqMjpe/Kawkr+NVNYfW7Vhs7/9D/ez 9i1X/78BAyClrP/Que2/+eBHL984o7lGdnXn+dGPfi22v3YIXQmYNzfF5W9bwcXnrqSqtgbhuEjX Rdc0pJbCdx1UywThE3gBqlApFTJIAkAS+BLLsvB9H5D09nXx0L17eOoPrzBdUlmxpoXrP/B+GQ+p QovHOHhq7JrG1sVHV258674D+17hjPYN//fA/OzWz/KRL36HS9bN+t5FZ6/9yCWXrQilc2F585e/ LXbuPEJdGVx35TIuvXQ9FfEwUSuBHapFESqKpoDno6gaQvHA95GuTRC4qFYMvwiKrhMEHq5dwlAN FFPHtwsoqsB1XBR9mtHRHNt2HOD5lw6x7Y8nWbasife//ypZW1MpSnl7X18pcstl77rpOSGE+zcH 07njWVpXX8gHr3tnjZbpfvKKC89atmBeG7/53RZ++vMHaJph8Z63reDdV19AqDyGUzRQVAMlJJBZ iaKrCMXHKWUBH0VEEUIAAYoKUlVwiwVUxUAzI/h2gGt64At0I0LgCVTVRJGTBIEEKVCEyoEDh7nj Fw+wc3c3F1y6kUsuP09WpVKie2D6Tatu/UUr168dH3j9GepXXfTXB/PoXT/g8vd9kr3P/W7JrV/9 6q7bfvpFpWdsgBtuvJ2pjn6ueUczn77pvUSj1RCpxbdLqAKEtAlcG+HmEEYM21fRFR+KU4hwGRIX EUTxpYOmFchN59AjOp5U0LQoRqIa1y+AnSfwDCw1RdHyCQmBkx1H2Bk8zyZUVU/nsUE+/onvkM7m +PoPPkZTy2qZGz1xKlW2+KqG1Zfs+8oHz+cf7nj+rwsG4Bff+fK1e7Y++esvfe0GsXXLLm6+5W4a qiW3/uOHWLtiMaoApIVtB+ghFbuQQVcECj4CBWFYSM3Czk5iKgJpRgm8AqpWhlQ8ersOcvzgMaZy kzTPnMOyZWehWXGcko0MAsyqMnZvfZ6WxmamJiZom92K77lIoSAdHz1WQRDo3PpP3+E3d/+R9914 MeeefQ6pRKnvYKf14be+/5PPOsMnMWpm/pdalf/qC0/c+xMA3nvFxg8de/P5e773zS+K++5+jM9+ /pdsPqeRpx7+Ees3rcH3BEgNx55EMbIowkHggvBAg0DV8T2foFTAtEIIK4zn+QhVBaGgKDp2yaan u48rr3wHfT39aGaYYqGAqpqY0RQnd+7gwIEd4GTY+8Y2fn//gxR8FRloIDQCJ4/nTXPzl2/gez94 O3f+6Eluu+235KcrGpY2TjzzxqN3/p1RM5OHf/H1/xKM+p99+MITv+eiq67jx//4yfdkRrp/9dVb Ps0Pf3gHd/7iea5//0q+/KVrSYRTeOhomk4xPYUVMXCdEoovEYqGkAqK0AiUENJzkW4J1QoRoCOE QKigEMLzXAK/yKtbt9Pd20NNbT2tcxad/ucUBb9UIFpRyanDx7Btl0yhiBGOsXDJUlQhCHwfISS6 IvCLJVpmVbJuTRPf/c6TDE/2s2T+bKpryoprVq9Qr7z+S4cev/f73P/IX76s/stL6YkH7l370oM/ 2PaNf/ic/OGv7hW//dUzfOwja/jo+68EWYUvPQIjjyyW0MMpZB4EAhGkwQoReD5CqGBGwM4gvBKO J5FWAl0V2E4GKzwD38nR3bkPO22TLeWYM28hyaom8FykcFCUgMmhNB/9yOf4wKfez/LlywhFIwjP Q7cMZDGPZ3soQkHTTTw1QEXh2MlDnHP5N7nmsrV85INvJV7ecOr1oyO3XPauT9z3n+n+i2A+ff3b CTKTbcNDJ05++xtfkg/89knxk18+yVc+v5F3v+tdSEVBNwx820a1TOySgxmJgqYxNTqCho9uWljR BNK2wc4hgwAhFNxiCSNkIa0EOC5CN/AVAxEyEcUsnuehCQWvWESxNPBVRCRKYOewKREBfE9BUQ0C z0GRAULXsUslDF0HXUfmcwhsfE2lqzfLVVfdzCVXbuKdV24mMJ2Bkaxx5Xlv+9Tr/yMwJ/dto23x WvWKs1oHv3bzJyu3vLJT/Pj79/Kpj6/ng++9EkXXyUxNMZ2epqatjYnefoYHBujs7kIKDdPQse0c qqoTj8U544x2KuqaCWwbMx7Hy+ZQhYojPUwzAqh4ikAGHl4hS6isDHc6i6breHoE3bRws2m6Ow/j 2VOEwwnqWmahqRZB4CFLORy7iAAUVcUMh/ExCFQXWcpiRMp4fcvrXPGh2/nyzW9n4YJ2OVnon/Kz NTOTc+dPnXPRlX/G4M/2mId+8W3OuvidPHnH11/8xpc/vsB1ffGPX/8Zl1ywgJs/8wFGhvvYs2sn e3a/SdgyGO3vJRkOMTUxTnVFBWvWrEIGLtWVFaiKYOmSJRw5fJjJTJEZjc34jotE4AuBGhRB6niB ihYPkR8fZnykn6G+PgKhoJsWihXDK3kYZQmm+rrp6z1BZ1c/VdX1/5II+uB7aJqCYZpokQjS88AK EwQBIvCRxRyNbfXEExbf/86jrN1QJxor54UmskcLm6/9+1f+T8Hx52CefIE9Wx8/pzzifWXZ0jPE 33/5VhKWz+0//ALpbJrtW18mGU9y1tp19HT10NTQRDqdRg+FyRWL7N69j3Q6w6zWNhpnNCNQIIDh sTEOHdhH2DQpryjHLRRRKaFaSZRoHOGVuOO279Pa2EA2l8cLBFW1MwhsG11VQNXQFbCiMUZHRli2 YRNOycE0DHTdAMXA9QWKqiNREUIgHQdds3A8l3w+z5oVsxgcGOPOX7/I+Re3y5qylrOvvPT8Pfc8 8ocT/ymYva88w5pZjdYPv3PL7r//4o3mQ79/gtde3s+Pv3sjxewIJ052sKR9CSdPnaS/f5DW1jZs 2wFVEA5H6DzVR9v8hWy64ELCho5AxTBDxGJRGhqbiIYNBgY6SZXHMaIGQaAhhYaiaIjApa+nB0PX 2b59F32Dw6zadD6a8AmcEnguVlkKxdBpX74KP5/DLE9APgeKCqoGioJEohoG0imhqTqe46KqCrqm 4JYKrF69lEcf30HBlWL+ogYK05PXnL1h2U+e+MMbxX/L4t/lMUs2XMTBU8c+cMOH3hebTue5487H uebta1i4pJVjJzoZHRnhiaefIJqIUV5dgWbppPNZisU8J44fJ5mI01Jdjz2ZRehxND2FlAZIhcCF 2spaktEU/b3D5HIBRqoG2/ORngsYRBI1/OS2BxgdmeBjN99CPp1Huj6KZSEsHXyfeCiO76ko0QjF 4UGEbpy+6wUBmvTRdIWglMN1PQLpAS4icFGlxJMakajPl774Hu65+wX6R9JCCymYlvnV/xgx/27z lVJGV8xMZl964nd89qYvMjbRzz9/+0aSYcHjDz/GGUuXk05PY9s2Tc1N+J7PyMgIMcuiWLRZtmwF 6ekMMtCorWkkPZ0hkCXypXHCsQTxUIj+7l7Kq2ewa+8hVm44j3BFOd50Gj1Vjjs5gUhGyPd1Y8QT 6KEkmqlB4FNK57AiUSiWCEIavldEVUFRLOxMBuw0EKBqKoqq4KGgGyYycAlcDyEUfJlFBmG0kM6N n/keh49lufXbH2HPwaOUVS4/49zzLzxY1TbvzyNmw8K6T33y49dw6NBRXv/jfq65+jxmzKgnM+Xg OCWmJycpFR1CVoRYJIEMBJFwjNamVpavXsPI0CCTk6MYpsf0dB+50hi7Dr7Oazu3c6L7BEdOHkJo NoXiMJ1de3nskQcQpQKqAjIzhZZM4E1OE0sk0JD4ToliLkegqoCEwAcBpUKa3q4T5HJZxkaH0KNR dNNCaBpqOIwwdITvQeAi/YBAKAjVQNMMcBWkU+DjN7ybkYFBjhw5yVkrFjM1dvKjVW3zGOg6CIAG cNvXvshHb7mVmK7ddNbaldzy+W8zd24569fPRgtVsnP7U2zauImDhw/R2DKXqqoqJiYm2b9/P+MT EzTV1qMEAYgA8BgbG2XXrmP0DU3zwsv7qG8uY+S322ltqKS5Lk7gO8w/Yz6elJw6cYCW1jakBHfK xkymyI/2Ey0rR/rglQr40yXMsInrFyji8vSv72DB0sXce9fPufGzXwbXRokk0AMP33VQFBXPnkJX BYE8ne84ElRfB8XDs3XaWmo4+7xZ3PnLR1m2uAVT96+WUn5BCJH+U8R89JZbuf8n37muqr4qWcz5 7H79OO+85kxMvQo3N03j7BjHjnfg+3Fqa+sZGBhEURSGh4dYs2YV2UyGXHaaiclJnEDl6edfYyw9 Se/gCS688Awuu3ADs2fNwLIC5i2YS8/wOM9u2cezjz9Jb1cfimIh1RiaGUEUpolYGrKYwc6n0bUA TXp4pRKKohOPl5NIpJg5cyErVp9LPF6BCIfB98B3cEtZCtkJRCiFq+i4no0spjHtaVzPxZEBqqGj BIL3ve0CenuyHO4YYm5TdfLmG8675c/uSgPH9/3kkouXN46PTnJw/04+85mPUFbRALrKm9teZtWK 5STLKti65SUqK8rxfBfXcdj22qsQSFAkuq6jGRaLFy1h6fIlnLvpHM499zwOHz3KhrPXsWJpO45T ZPPmS1i5ehW+W2Rx+xmUV1VQKhbQtNP1mMzkOLquY1jh0zkJAlXTEYaGnS/wz9/4Bs88u4WWlgbm L1mMk54mcPIEThFNkeiKBKHiuy6KBE1XsR0HHwXLMtB0DRlAZWWKE509DI5Nct7GDXT1d1a+793X 3/7I038I/gRmQ3vTJVdcfva8393zBKtWzmXTxk1IqaNaGn4+Q39vH45vs3TpMkzLQNc09uzdRTKV pK25ldraakKhMKqq07pwEZNDg0ynJ+nu7mJkaJCuvg5OHD1MMpakubUZxyuyeOlyUqkUhm4gZICi gFMqEY2GUTQNPwAZnK725XNZTNPAKeZZvLSdRQvmsGbNKtTARVFAeDYCiRJ4yOA0TAWJlD6O4yAB VdfQdQ3P808nf9IjWRHj9p8/xiUXbEI1/LgWKb/tgUefLygA77p4pTXUf+rSusoauW/XcTaccwaq ZqCZKqcOHCCftamtrUUoDt2nTtHT2UVvVyerli3lLZs2IqUkEo3S09OD53mMdnbR23WK+uoazmw/ gyuvuIyeri4KuYCqika6TvaTzaQ5dWqQgYEJMELomonv+miahggCCrk8INAMC8/1iFWkcIo5PE1S HovT2tKMInxQAzw7j2pFEKpOyQvwEajSoZSbxrGLWFYIT0oUVZwGIsA0T2/G82bXkC6odJzsoHVG izY8OPYBAOW53/2UAwd3+ZdffpF/9MAJEdINlpw5Gz9wCPD5wwsvUCjYDA8PUyxmcF2HeDxKKpVE Suju6eTVV17lgQceQNM0hoaHCYctDh3Yj6YruKUiX7vlq3zyE5+iubGZxx9+lnvvuZ9HHn6MW2/9 BU8+9Txe1oVARQkUNE0HIBQOoWoavgwwUkkO79rN808/yWTnKYyQhaIKujpPMdrThVAUSo5EWFGM WBIPHem7aKqCAnieh227eJ6L49pIGVAo5FCkSnkyyczWKvbs2Yebh6MH954NoF3wzo/x3ktXP9FU W2Xs2neSeQsTmDKJVDzcQobM+AB9RkBdXR22K2isL8d1XfKFIpFInHzJpf3MlURjOpVV5VRW1OG4 Dtdc9wHcQNDXP0ikrBpVBFx4wWrmzCojEi/jRM8AkdAwS9oXoIZ1JBK7mEd189hKiHBZBU4+SyiV 4OG77mLWzDbOWrsBXVXJTE+QSkYpi4QwrBheILFiEukUCFxJOJqEvEDVXQxVIZOZJBUO4QsDVVGQ PoSsENIv4hcd3ntVK489NoK42pMzqv3zX/z9YzUKQEtT48TMWa0cOdrJ8hUL8e0SihCoQuGiizdT WVlFd3c3hVyRrq4uBgcHmZiYoKOjg46ODs45/zwGB/vxfZ+DB/ejqAIRBEQjEfbs2cmS9gUUiyVK RZvKimoikRiGbvH2q8/FNAVjgwMIPYyqWGi6gR4Kg1MiFAvz+G9/y7JlyyirrODEieMMDg5iWBZq IIkn4jiuw/DgEAd270cNRwh8F4RAhsKga5RsGzNkgaKc3osU0HUFu1Qgm8mgqiZz5y3i2PGTjIyM iLrqep58/K5aRUqZ+PntD7yrsrxMTk8N0L54IaouCFwPUJg3dwGgYBgm1dXVTE9Pk8/nKS8vZ2xs jBUrVhCuqsDQNV599RU0TWHfnl3s3vUGUnrkMmnKyxNEwjGEogAKb+7azeDgCCc7DnNg7y6y2Smc bAYzEkEqOmY4gqZrHNr5BitXreTJJ5/ith//mN7ePu677z5efnkreipFLpdD0VSSqTIO7D1EYHto qoos5RGeg6HrCE3FiscxolEUGaAJ8BwbXRFEwmE0NUoqWYFlgu0UaKxvJJHU4hqQbmsrI5vJCsee pLGhDlXTcJ0A3dAo5j3efHM3Zy5tZ9nSZTilElYoxNGjR2lvb6elpQV7eJgNGzcwPDJINpNnzpw5 eF6JRx76Heefdy4+AZOTk9j5LJmpSdLTGY6e7GW41yKeTPD4Y4/w0b/7OHYRPE+iZLOEYjFefXkr O/cc5+ZbPsfMxgZKpQJvu+JtvPzmdrY++zTLlp4JmoXtSrLZHEHRRtU1fKeA4/poqsD1PO79xc95 93uuxVQtAt/Fc20CRUUREgKFivJqwhGDTHaaObMXy7Kq3gu1d168bnnYDAhQ0TTALeD7oEZTyJKN ous0N1UwZ3Yjkao6zrv6nex+6Q9U1VZTyLvseuMYbQsaaKhJcfjoISwjxOHDBygrS9LW1ko4bNJx spO5CxYTRCNYponUdM55ywWYlsZA/yD5XJEXn3+OzW+7Ct1xUawQxWyWGz7xcS462Unz/NkUJibR zDCObrFx7VnccdsPWLNuNenpArmih6bpaJEQXi5N4AdYmgGaSlAs0dU3QMkLsHTlX5zNEIph4LsO QglQsgHJZIqpiSkctyhyk7lGbd3qVYXXXuxiYipDMhmnsiyFakXxvNM5hBFL8NbLL+XVl19hcsrj zDPXsGTFBsKRPcxbuZaBoycxzBD5Uh7DtFi9ciWnOk7x2rZt5HI5Vq9eS9fJU4xPpFm3bi1SKHie S3ZqhNeOH0MECioqilApTE0RSiRxcxlwbaRqMqOuBntsGE1VMWIxiJbBcBe1dTMQqHiuTy6dZeny M0EGqKqKpkIQaHieR6HkoBgWRccnqnlkslmi0SiqdPAkWEqBsspqIrEoxYKNFVWxc165smfXm01r Vq5kanKKVCKCYWjgeHiujR4xcAsZwmYN6y64ikxuHN2KoKgh6uubefLB+0iXxigra6KiopEZ9S08 /vgTqJrBnLkLWXLmCnbv2cOy5WdSXpbi0OGD5PJZcrkM6Uya8mQj4VCShsY6FiyaxYmOAwjXRXou oUiIQu70E7MfuCgEELjYE8NgGKTKqnB9lerael5+dQvL1qyilMviOiXsQpFiIY8QAtOyCBwPr2Sf TgNCITzPw3Gc06WJQAIu8ViYYrFENBJlfHwyrgwN5zedubRdxqIRTFMDGYCmYGgqMvApuRI1miQV TnDuBRezZ88LDPUew1dNNl90FfPnLUdRHPr7uxkeGKCyrBrXkYyOT9Pc2sb8hYvI23m8wCOTyRIK WaRSSYaHB3nowd9z9OhRdu/ZQ3l5kqnJCSbHRtAVKExNnPa0NRVD13CdAkF+CuEXQdc4eLgDL9DY 8uo2Zs6ZBYGPCHx8z0XTFMLRCIqus/UPL2DnC7iFErZjY4VCRCIRgiDANC1QVdA8EA5SSoaHRpme zkS0VELXLd0QY0PDaIoA/3RBWpgxhAfxZBmFqUkmx0eZzhdYtHoDwlVQvYDscD+maVOQKnjTxONh tMBi+6uvc/TUSRLJBKlUjPGJYUolSV1dNd3dnYxPjDFnThvXvqeN9iWL6O3s4vnntlBZXolt55FB CN9zsAyTQi6DqUg0RSKCEn6pwN5Dhzjn/AvJFwPe3LWbm2/5PNK2CfwAVQhcx0bVQwz29DE0OMiC ufOoLa8inEow2N1NybZpaGjAcVw0zUSWcri+QyKRJJvNoSniNSVZaWEISaKmBUca5FQdNZxCMSPI kIEzPsSeHVuZUV9GZRT6Tx4kPdELmo/t+LhOiIKXoqaqle4TXfh6QBCxuOHvbsTNTSBLJXZsP8Kc OXMYGRkjFIoyb+4i9u87QeeRN+nvOMxgzwnqq8qImDDYcwzPd4hV1iDCCTzfwnNVijkbYUQJ1bdw 5FgXjc31fOubX+J9H7gGO5MhsG0oTZGbHsELJJpTwC4VkbqBrYBVU4Zf9LjzV/dw4NBR9EgMVdWw 7SKBVIkoMVpmtDE5Nky25D6kFPKF8Wg0jm0XCakBEV1FukV8t8j2l55haHKE1Rs24RMiUd5EQ0UL plA5sOs1fC0gUtNATVsbajTBmWvXM5XJU19XRziq0djaRDQe4pLN59LT00M6naajowPP86itrWHh wkX09PQwMjKC53m0NLcwNZVBMy3sXIZ8Oo3nFjEMDTMaBVXn/l/ewduuuJy7fnknH/nwhyiLxVE1 Dcd2CBQD04oRskIEQUDINOnt6aFYKBAUCtz/4P2ousaadWvp7u4iIKBQKKFGkpSKaULhEFNTaSkV c50y1D/cn8nmKasqw81nEJ5DbmSA7kP7aV96Jk3NzQjdRAoT3SpDyAhbnnueeYvnEiuPg25BPocv NaqaZ9PWNouKsiidHcfp6DpF0XUY7O2kpaWFxYsX47oux48fJxaLEw5ZNDc3UV1VRSGfJ5vLM53N nr67IAnpUBYzcH0XM5Kka2iUJYva+f2DD9LYUM+8efPB91BlgON6oIZAPw0ll8tRXlHB0qVLicVi TE9Pc+R4Bxdespmtr77Gcy+8xLETJ4knUjhZm+HRQRRNsv/gUdHc2Pi0ogq959Xtr5POTWGZYVzX pbenn+aZsxGOT2BFcUs2ihKQnhji4d/fQ3XDDDQs/KJHkM/i5yfRLANpl4haGklLJ5PJYoRSvPza 6wgEzz7zDENDQyxbtoyqqiqGhgZRAnDyRcKGRUtjE0cPH8YwLU4dO4Z0HTQ8Ai9HJBZhOl/ggTvv 5uCe3Vi6zrnnbALXQZPBaQfBCuEJE6mauI7LyMgIoX954lcUhZe3bmX2/AWMjE8QjiWY0djMrr37 mJhMMzGeRSgqmqkwMTnJnn3765UlS1dO9fX2Y+gaqh5ibCpDsqwKLVmOpocR6SI4DqWpUe656ycU yLLy3HNQpEUslEDYOXQcZHaKqfFh1MDGzkziFFzOaF9B26yFGIpFf38/hmGgKAqmaVJVXc3w8DCe 7xMKh0in03h+gBAqoyMj6NEQipSYuoBIiOeee4G3vOVCyuIJLrrgAgLHBVVF6AbIgB1/3MGWV7bh BgpPP/0UBw8c4NTxE1RWVtLW1oZpmtiOzdHjx0mWpRgZGyUUCdHfP8jREyfRtRThiEUmm+fVg6ee 175++72n1rfH+FD4XcTLyjhxrIfVK9qhOIbi2wQ4dBzZRXdPF+s3nsX8M1eD51O08xhSoioKXiiE 4ukkw+WMDhwnGk+RzBXxMyMkQzCam+a6972XU6dOYdtF0uk0xWIRoSoc7OigvLwcu1Ckra2FwHeI JmOMTU2TKq9Ciyk88puHWbVsFbv37GbF6na6u46jqiqu65FMpRgYGcJRAoJSFlW6nBgeZuas2fRO jrNqw3pGRseZKPm4TsCstjm89PwWZs2cybzZs5g7bx533f00TS3lqGpYnjjlCCCsCSEyF65uHlOE WhmOVdDbN8bSxWA4klKuiCYLKFKyYeN5RKsaKBFDGCpaaQgtWY0f6Ai/AIEDlKisqkAoZXgIRkdH yeVy2LbD8PAwM2fO5KGHHqKuro6R4WEaW5oZGholmUwSi0aZMWMGhw7up6HRZHRwiPJkOdue2cfC BauJxSs459zzyBemSdS24Dg2cctC0zRqrBQzY+X0HNlHPFHFZedcxEvb9zHUmyNfPEzJddm79xBr l7eiNNQwp62Riy86j3hZkkLeZ8eOXaxYu4KhoTHxic989hYhRFoDuPiiq344OZX+ujCi6IpNb/8Q M00dAehCZ96iRRBKIDQLSw2T6TlFZnSUWiuOjMXQPBu3lEZ6JQr5DL4fUCgUqK6uJpPL0draimFF 8X0f0zSpra2lvb0d23VYuXwF+XyeqfEJMpkMs2bNYmJinHiinK6uTpJQyOjvAAARkUlEQVRljVRU VhHgoOo6uhEj5yooWoSxqQzRaJRMvsCBowdZuagZzx2jr+84obBDPl8kl5/A8wMuf+tGaitSSAlt bW3s33+ANetWUyj69PaN8a55TXR2jXNsaKr6Ty5BIZv56aEjR/zZC+YTKBJdlxTyaXRDI2tL3JKH m5mmlB4lyI6imwrVrTNRYyE0tUBpMoP0imQyY/T29xKORlEUhY6Ok4yPjyGlxHVdhoaGmDNnDvv2 7WN6eprKykqOHTvO4cOHSaVSOI7DyMgIhUIB0zLZtm07dfUVaLrENMAuuTglg0g4TCIWpzxVhq5q 1FRUMdrTg13Ms337DsrrZ5NMxDAMhbaWRjZvvpBZMxuQRpSVZ21CCycZnsxyz30P0jcwSuvMWoyQ YGx8YmrzuRs/8ydfKRoO5f6w5aWptevWlLu5WnGko495qmROUy2+EsH3ioSSMbxSCac0QSieJPA8 PNeFXIZicRrHy5Mv5CirKGNgsI/yygrmnbGIna+/QWV5DbsPHaRUKNDW2sLG9Wexa9cutm55mXgs SnNLIyMjA5w8eYp5c+bjS59cLo+iaPzsZz/EMFWQ4JR8nFJAvCKMQCGdzWJZFsVckbltTbz+2m5s x2E6O0w2O8HY2Bhz587jkQefwTQMqhsa2PLiq5TsHIlUkosvuYBHHnuc9WvXoSkGO3bt1m2ZDP4E 5qNf/YH31rOXPjXY3XddOBwlLTNUVFSTGxsiZNbgqSbSA0UPYYWj5NNpTMvAzkyRTadJlidJGHEY O/3kHIuFKJYckALLshgeGaCvt48g8GlftIh9e/Zw1upVbHt9N5s3X8zI6CBv7nyD9iVLkJ5gMj1O zCty7Qfej18KUE0TO5vBjIbB84DTLgBCQQYgFAXfLpHJZEjV1ZEZGSFbtKmsrGRiYorLL78CgUDV DRzXpqqpkVI2TU//EM88v5d3v70M35tBV9/EyPPbbnO/+cv7/39f6WjX4LY7vve1z23YsByvWGB6 bBhVK2EYBggoFl1UxUS6Adl0jpHhfgxDRTMgHKrA9yEaTaJpJh46tVX1pKenKDlZTp06RiSSYN3a tdTV1zM6Mk5jUwvnXHQBfd3d1NXW0tLShqpqxONhmlsbsR2b6rp6hO8R+DaqKpF2EdfNg20jAg+h gFcsooZDKEJghUJMT4wTjkQQSoBpaXiei2XpOI6NZoVQVQMhAUXjiSe2YlmSjRtXsGXbLhav2vyt jRdfuf1PhtvBN16mekZLsa48vvLsTatmFfM5MpkpaqvK8T3/dBi7LplMhv27d9LW2kQimThdrY9E Mc04gX/aV5YILNNAVxVGRgbJZNKUV5bRdbKLyvJKXnrpZZpaZ3L7z+6ntSHF3IWL6O7s5tFHHqe/ b5Azlyzh+InjTExM8+bre1i4fBl33X4b0nPZ+eYO5i06A1WodJ3q4uDBQ9TVz+DZp54mCAKeevpp UqkUlmWxd99eXnjxRfLZAqYRIhQKn/awFZVsvsTY2BTf/8EvOPctZ5FMRuSW7cdKP/nN03/qkFYB br/jbv74xAMMjKdHj3Tsu3bBvHlk0xkmJ0epKq/C93w0TeJ4BZziFIoiQKh4noqpJ7DzkwR4BNLH 9z28oIhdyuIHPrpucWDfEZob6glHw9TVNzE6nmbO/FkUC5NEQ2E6O3uQgcKHrr+BfXv3YxgWqbJq pqeLNFRWUFlRxeTEJOXJcmoqKkGz2PraNuaf0U6ASn1TE37gkUgmCYVD7Nu/jxn1rZSnKpkYn0YG gqaGFqQKhWIJoRjc8+vfY4VVmttmMNA/LI4cnfzW8YHxrf8K5k/dDmsufQf//Mt7XzhxZPxkIhyl vrGRgqvRN9BHemoS1w3IFBz6+0fQUSmLxDGlz8TYIIWpMXShk8uUKKQzGL5CenyaQrZAZmqC6poy DveN4Xg+ZRHB7KYyVq04g+aaJkb7h1nR3k4ibJAe7yebHmVqfAScPPGQjybylFVGGJkaJVmZRNVc PHx273qT40eP09vTi25E8H0Nz1PZtu1Nli8/i1dee4UZzc0sX7eWRStXUdIMFCNMoqycklNk55uv cv45K0lYEW779Ws8/sbRf/i3nR9/1mp2/rolL3Z2nbxhafsiFKGIiK6Qimt4bp7pyTwvvrqVP+7Y weTkJNPZDEbYIpmMgmGArpLNTTM8MkC+VMBDoW5GC43Nc5k9ZybRcJjhgQGKxRJVMxooFWyefvY5 hKqRLCunae58hkZGON7RSUV1LYYVxtR0+nqHcFyF+tpajh06wsjoGPv37SdXKFJRUUFFRTnT6XGe ffYpNmxYSyoVJ6zr5LNZjhw5Ql9fD63NjWTzRYRQ+fznvsC5527CtMJ09Y9SVjvz+guveOeuf8vh /9i1uXnt3C23fO7D66dHetSZMypIjx/AUAQySPDCntdZMn8Bv73rYaLxMFL1WTi3hbLqGYSjMYqZ KSrKEgQCzli0DEWJYtsSgjSJeJzHH3uUupoq0tPTbNu5h7POOovxsXGi0QiapnHwyBFmz57N+NgY juOgOi6OVKhraMIplchPjZIp5lm9eg35goMXBOTyBRoaa8nn8wwMDJBKpZgYHGTO/AVsfeU11m88 lzOXLafoCp579hmGh0dpbm5Bt2Lc8u1fFJ94dnsinc64S9a/5S+D+c7f38hn/+lHXHPu/OlP3PCu hF0sMKtWJz3Wj513eXjrS9z08RtJhiPs2rGNrF1gYmSYqXyJbK5AMmIxZ3YbhhUhkarkZEc3CxYt pqmxhnQ6x/D4OG4ui1dMs/DMlTi2TTgR58SRI3R2dlFZVcXs2XPoONlBeVkZhXQGdIu842JpKiEV 9JCFqhokkuUcO36CuhkNHD9+jPKKCkKhENlsFtPQyeZyhKIJ5syZj+MHHD16jC984bt86lPvw7JC 3PvQs3z1xw8ub52/ZNd/5PAXG6C/9/lr/26g/+iPzrvwYtEQM6iIBBw9tIu9J07xyc99gZcfuJ9i MceGt2zCEBInON1ZqUmP/p5efDRqamvRdQUtZKKhM5mz0UJxpkb6KQ8JhK6iqRqmaSKBQqHI3n0H WLdhA06xiKbroEgCxTjdYs9p2xhhoKk6uYKDqumUbI9UWQWe61KyTxe9paqgGSauHzA2NY2mm3z8 +hv54Ifei+u6pKcz8uHfP/X0S51sfujXt3PVe2/4d/r/4izB89sP7CyLhPU5jTXrzWhSFhwpFp7R TtfAKdpXr6WUzTE63MdI7wkqUlUEgY9qGGhWlKzjU1lZQyxZhi8NUMIUCkU8u0QqFUcXCtFUJcKI YMRTpKemURVBplCghKC6vALfDU63jEkDt+QQOA6+44FU8VWLQD2dL6nhOKoRo+QKVEPHlR6+crp1 xLJCICSe63Pz5z/HlVdeiiaKFD0pn3ml4/gz+8fWAjz02NN/pv8vTp8cOnCQp3Z0fPnXDz27v5DL C6dUkAcOn+Tycy9mZN9uLN2lsqqK/pEioXicTL5IPpslPT1BVXkK1ynhOSV0TWCXskQiISLRME6p gB+4OHaB9OQ4dmYaVVWxHZ98toChahAoCM0gny+R9zVyvkYRC9+IE5hxHE/H8zSEauE5ksAPMHTw XBdVUbAMCyEERdsmk8lyyy23cNHFF1NXWYmiJ/npnU+KFes3bvz+V276S/L/csTcdvvtzKw2aaxr /fldd915zZpVy8rH0xmZ1E2RSMbRdIFmhMgXfGpqK1A0jcmJCfr6+6irq0FIH0VVmJ6eYnJ6AqdU wvPc0809QhAEPq5dQlVVVFVHonD42BGWn9mOU3QwQ2GyRRcjWo5QTRTNxEfB8SSqGcEPQFNVLNMi ZOq4bgFdV7BME6TA9T3y2RzfuPVWNl96GVNTU5SKgfzn2+/jJ3c/WvHOD9009vwrO/4imP/WINc/ f+Wz4Tdee6Ljpo9cU9fT1UNNVTnzZzWSnuijubEaHxXPLnDqVAduqciMGbWMDI+j6RpWOAJCJRY+ PeanaRpCCBRFIZ/LYIWjhCMJJqbSvPHGHznvnPWE9SiO1ChIgY+JqqpI+JchDUHJh0QsQjGfRfoO QgYEgUtZWTnp6SyRcITDJ47xy1/ewfkXXUix6CADn1/9biuXXf3hc2780j9t6T+xnxmzF//vwNz0 gUs5++xltffe9ssXPv7J6xf4HmTTkyxf2EREy+MFpwfnE6kykIJsegpkCV03sUsuvh9g/YsDaJkm +UIBz3MxNBNNM/AR+EHAyPAQvlNiQftypiezYJg4gYoQChJBIAMkAtMwgAAZuKgiQNcNDDMBONhO nt/d9ztO9gyz7MzF5HIZfBHj1/c+RlXT+rc+8tKLj2979lHWXXj5f6r5fzT6J7MTqbcsqTlw/Ueu m1FXXy8z0+OiYUYtlZaNYYXRDB3bcYhELIR0SE+niZhhbNshmoiRz+cIh0OUSkWk9InFqshls7iu g+M4pNNpRkZGOHvTeUxOTONLMOPlp61UFLwgwPcDyqMRHLeEokIobJLN5TGtGL19nfzqV3fR2NBG RV09U+PjqHqE2+5+1PnUF7+58bqPfe6P/12t/+Xo37+u8Y79iFj51G0//YfGZ17cueXxhx8RrQ2N 7Nixl47OaXJFhcGRcRCQzWWRwsQIxUAzMENhHNdHN0JIBEJVMawwxVKJAAhFomiGSf2MBoQQ5HNZ VEMnnkwgCJAyQFNAU06XMVzfwfE8Agm+L4hGYvzwu9/g4QcfYN3qDehaAs+RnDiVlrffvWXqYzd9 NXHdxz73xze2PvPfDoL/8dz1lt//nE1v+zCffufGTw12Hvne+6+9CowQQwPdlCVD1NWkUBVBZWUN 5WUJFCVABj6O4yKEQiA9ZOCjqgqqYhIEAUEQUCwWiUYj7N+3hzOXrcDxJEiFcCxJNpfDcVy8QGKY IQzj9F41OjLBfffdj+cGVFXUEmg+rhToZlTe+9ALwoxWPf3CK0evViJKbuhUB7Vts/52YAAmuw9S 1ryIE3u3L/rIe97+u7NWtC1Yv261dAoZofg+pqkRSB/LVKitKaeqqoywFcO2S5RKp8uWpVKRaCRB EPhomo5QBCDp6emkuqYOXQ9juy6+IxFCQdF1irZDNpNjeHyArVteYWoqS0NDM1VV1QxPjBKKpeQb ezrFsY6hzNpz3vqZ7/709l8+9dB9XHLVNf9jjX+Vl178/Jtf+eBdv/jWL95+yXqxYsF8xienSEuX eDSGqWn0dfdihl0WnbGQloYGorHw6e4EYRG4DgQBiqmB6xMEgt6+fqpqa8nl8pRwyGVzdJ06ya7X 38AuFQmXldPWOpvurgFUNUQsFpW+DImf3Pmc37hwxaNbt7981f9W0/8azLYnH2bd5ivZ/sx9iZee fe5jO1577utlyYhYu2YVTU11OMUMyXiE8fFJhARFkafb1QyTTGkS0zg9dWvoOkJKNFVldHSUfNFh anoaM1xGNBIjlUxh2zaqojGRHiOaqEC1kuw/fJLnX3yDdZs2PFlfO+fGb/z4tm6AE92dzG5u/X8H 5j8uKWX5tZetv76no+9q286fMaMmTEW5SXkyKisrykXDjBmEQxZTE2MoZopI2KRUzFPMF4iETQLH w/FchKKhmxbFUpp8voAXCMLROK7jcPLEIG8eGsBGTnpK9MEv3PLF295+9XUH/5o6/upgujv309x6 OnF68J6fXbpwwdyee3997zn33n3PTQ0zjFA+ny+bN6eNGXUzsKIO9XW1DA8NUldbDQiCQJBMptBM g5GRUfIZDyFU9h8+xdETJ+kfcNMVFcnjX/3aV777tvd+9CGAnX/czoo1a//aUv62a2RolEfuf1Dp 2LvLOrJje+1NH/jQx77+mU/OOWvRwpO/+tYt76nSFPnjv//ENxojppwd04I6U5FJgSwTyDgETVFd Xn3eJvmtL31p729+/qv1Tz38WEJK+afjd3cc/Zuc99/kHVX/nSWlNIUQ9j986XPLv/L1b7/58Rs+ cKFdspfGYlEnmUj4NTU1perqamfz2975IJARQvyJRu/JYRpn1vxNz+//AxJkqfZPhY3BAAAAAElF TkSuQmCC "
+ height="40"
+ width="40" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/20 centsoff.svg b/plugins/currency/images/20 centsoff.svg
new file mode 100644
index 0000000..25e77fe
--- /dev/null
+++ b/plugins/currency/images/20 centsoff.svg
@@ -0,0 +1,257 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="70"
+ version="1.1"
+ viewBox="0 0 70 70"
+ width="70"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="20 centsoff.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="1"
+ inkscape:cx="-109.56607"
+ inkscape:cy="101"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" /><image
+ y="0"
+ x="0"
+ id="image3046"
+ xlink:href="
+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
+XodtAAAAAElFTkSuQmCC
+"
+ height="70"
+ width="70" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/20 centssmall.svg b/plugins/currency/images/20 centssmall.svg
new file mode 100644
index 0000000..10d8e80
--- /dev/null
+++ b/plugins/currency/images/20 centssmall.svg
@@ -0,0 +1,54 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="40"
+ version="1.1"
+ viewBox="0 0 40 40"
+ width="40"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="20 centssmall.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="1"
+ inkscape:cx="-479.06607"
+ inkscape:cy="-197"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" /><image
+ y="0"
+ x="0"
+ id="image3046"
+ xlink:href=" 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 XodtAAAAAElFTkSuQmCC "
+ height="40"
+ width="40" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/20 dollarsoff.svg b/plugins/currency/images/20 dollarsoff.svg
new file mode 100644
index 0000000..64eabd7
--- /dev/null
+++ b/plugins/currency/images/20 dollarsoff.svg
@@ -0,0 +1,105 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="55"
+ version="1.1"
+ viewBox="0 0 122 55"
+ width="122"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="20 dollarsoff.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="1"
+ inkscape:cx="-75.566073"
+ inkscape:cy="105"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" /><image
+ y="-4.4480385e-07"
+ x="0"
+ id="image3048"
+ xlink:href="
+HBwgJC4nICIsIxwcKDcpLDAxNDQ0Hyc5PTgyPC4zNDL/2wBDAQkJCQwLDBgNDRgyIRwhMjIyMjIy
+MjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjL/wAARCAA3AHoDASIA
+AhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQA
+AAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3
+ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWm
+p6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/8QAHwEA
+AwEBAQEBAQEBAQAAAAAAAAECAwQFBgcICQoL/8QAtREAAgECBAQDBAcFBAQAAQJ3AAECAxEEBSEx
+BhJBUQdhcRMiMoEIFEKRobHBCSMzUvAVYnLRChYkNOEl8RcYGRomJygpKjU2Nzg5OkNERUZHSElK
+U1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6goOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3
+uLm6wsPExcbHyMnK0tPU1dbX2Nna4uPk5ebn6Onq8vP09fb3+Pn6/9oADAMBAAIRAxEAPwCV7hGw
+vPPFUJri1e4+dJG4HzLnA/Kp3zvUfPjI46Z49ax7uDfcsyqww3J2kknHsPb1/wDrefGKejPqpScF
+eJoH7Ioci3nO3HCgk/lV+3t7KdMmCZT1wx2nnHrWRayeXAqSiZURcfKpIOAO2P5+9atvMuCimaQY
++8ykfl8oq1TjfYwq15qN+YmkuYdNtpZYoiH6kSE4HOeozxyeR+RrN1Dxg9nJGkVkMkHcsucg54xj
+1yOeeoqW+jjhjkmSRlkwC4TP7z0yF5zxjI5+oGKzbG2XctxjeqAiMqdoXJHTtzz93jGcAdK7o01F
+aHzNSu6lR850Wl6nq14ytcadHbQ++S5/A8fnW2zhVB2k1y/nTHnzXLcDIJH/AOqtm20//RyZ3kZi
+Ohc8UnG244u791FTVNSvrJS8VrFIvoXIP4Vm2HiSS91GC2ltFjEsgQ/McjNad1D5ULrDvPGFX736
+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
+"
+ height="55"
+ width="122" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/20 dollarssmall.svg b/plugins/currency/images/20 dollarssmall.svg
new file mode 100644
index 0000000..c5ad6a3
--- /dev/null
+++ b/plugins/currency/images/20 dollarssmall.svg
@@ -0,0 +1,55 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="24.795082"
+ version="1.1"
+ viewBox="0 0 55 24.795082"
+ width="55"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="20 dollarssmall.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="2"
+ inkscape:cx="45.381168"
+ inkscape:cy="24.560276"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" />
+<image
+ y="0"
+ x="0"
+ id="image3048"
+ xlink:href=" HBwgJC4nICIsIxwcKDcpLDAxNDQ0Hyc5PTgyPC4zNDL/2wBDAQkJCQwLDBgNDRgyIRwhMjIyMjIy MjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjL/wAARCAA3AHoDASIA AhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQA AAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3 ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWm p6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/8QAHwEA AwEBAQEBAQEBAQAAAAAAAAECAwQFBgcICQoL/8QAtREAAgECBAQDBAcFBAQAAQJ3AAECAxEEBSEx BhJBUQdhcRMiMoEIFEKRobHBCSMzUvAVYnLRChYkNOEl8RcYGRomJygpKjU2Nzg5OkNERUZHSElK U1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6goOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3 uLm6wsPExcbHyMnK0tPU1dbX2Nna4uPk5ebn6Onq8vP09fb3+Pn6/9oADAMBAAIRAxEAPwCV7hGw vPPFUJri1e4+dJG4HzLnA/Kp3zvUfPjI46Z49ax7uDfcsyqww3J2kknHsPb1/wDrefGKejPqpScF eJoH7Ioci3nO3HCgk/lV+3t7KdMmCZT1wx2nnHrWRayeXAqSiZURcfKpIOAO2P5+9atvMuCimaQY +8ykfl8oq1TjfYwq15qN+YmkuYdNtpZYoiH6kSE4HOeozxyeR+RrN1Dxg9nJGkVkMkHcsucg54xj 1yOeeoqW+jjhjkmSRlkwC4TP7z0yF5zxjI5+oGKzbG2XctxjeqAiMqdoXJHTtzz93jGcAdK7o01F aHzNSu6lR850Wl6nq14ytcadHbQ++S5/A8fnW2zhVB2k1y/nTHnzXLcDIJH/AOqtm20//RyZ3kZi Ohc8UnG244u791FTVNSvrJS8VrFIvoXIP4Vm2HiSS91GC2ltFjEsgQ/McjNad1D5ULrDvPGFX736 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 "
+ height="24.795082"
+ width="55" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/5 centsoff.svg b/plugins/currency/images/5 centsoff.svg
new file mode 100644
index 0000000..94b3ab4
--- /dev/null
+++ b/plugins/currency/images/5 centsoff.svg
@@ -0,0 +1,288 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="70"
+ version="1.1"
+ viewBox="0 0 70 70"
+ width="70"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="1 centoff.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="1"
+ inkscape:cx="-117.06607"
+ inkscape:cy="100"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" /><image
+ y="0"
+ x="0"
+ id="image3235"
+ xlink:href="
+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
+RU5ErkJggg==
+"
+ height="70"
+ width="70" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/5 centssmall.svg b/plugins/currency/images/5 centssmall.svg
new file mode 100644
index 0000000..c59b97a
--- /dev/null
+++ b/plugins/currency/images/5 centssmall.svg
@@ -0,0 +1,54 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="40"
+ version="1.1"
+ viewBox="0 0 40 40"
+ width="40"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="1 centsmall.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="1"
+ inkscape:cx="-111.56607"
+ inkscape:cy="93"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" /><image
+ y="0"
+ x="0"
+ id="image3091"
+ xlink:href=" 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 RU5ErkJggg== "
+ height="40"
+ width="40" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/5 dollarsoff.svg b/plugins/currency/images/5 dollarsoff.svg
new file mode 100644
index 0000000..e16f9a7
--- /dev/null
+++ b/plugins/currency/images/5 dollarsoff.svg
@@ -0,0 +1,95 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="55"
+ version="1.1"
+ viewBox="0 0 110 55"
+ width="110"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="5 dollarsoff.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="2"
+ inkscape:cx="-9.75"
+ inkscape:cy="58.615385"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" /><image
+ y="0"
+ x="0"
+ id="image3048"
+ xlink:href="
+HBwgJC4nICIsIxwcKDcpLDAxNDQ0Hyc5PTgyPC4zNDL/2wBDAQkJCQwLDBgNDRgyIRwhMjIyMjIy
+MjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjL/wAARCAA3AG4DASIA
+AhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQA
+AAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3
+ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWm
+p6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/8QAHwEA
+AwEBAQEBAQEBAQAAAAAAAAECAwQFBgcICQoL/8QAtREAAgECBAQDBAcFBAQAAQJ3AAECAxEEBSEx
+BhJBUQdhcRMiMoEIFEKRobHBCSMzUvAVYnLRChYkNOEl8RcYGRomJygpKjU2Nzg5OkNERUZHSElK
+U1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6goOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3
+uLm6wsPExcbHyMnK0tPU1dbX2Nna4uPk5ebn6Onq8vP09fb3+Pn6/9oADAMBAAIRAxEAPwCWfKqo
+XcMf3TiqcjPLkEuSOQADxVpnJABOc1RtITFqUkZuHEn3lBPyuMdD7jOcZ966Fojaaadya2iyDvEm
+PdSP1q7HaQOBkN+dRW1xNJI8VxCI5U5BU8OPUf59KsKMHPNHNoNSl3EuCbW1xErYHfrjvz+v/wCv
+FPRt0SMepUE1HfsTasAB+PaoLiRY9NchygEPDL1XjgiueW5pG+7KF9re2VobSPzXU4aRjhF/xrNe
+71FGLG8QnIBUAYB/Kk0rSWv0eQy+WiMBx1Zuv+frWl/wi5Kt5dwwz1DDOf8AOaRyzryb0ZBbapKp
+AkdZgeSUGGA/ka6K0uyiCSIgq6gg9ciuOksJrS4aORgNnXackitLRrorI1sCAhBZM9sYzTVupUKr
+l7stTpzqFwD1X8qPt92ULjy9o68c/XGaotMkWDIcAnBY9AaebhVj8sGPLY+bPPTGOvbkfhWvu2HG
+Cb2KGs306yW6xvKrzSHd5EYZiAp4AII64qXTZxNbtmaWV1cq/nIFdDgcEAAe/wCNNvDdHy3tZEV0
+JyjjKuD645FR2UcsLTzTNG087Bn2g7RgAAD8BRZmii76bFqOMFckEnHrVJYWkEqYKXDYmjbrh/4f
+0wp9QCKuXBkitHKrztPJbHb9azry7y5MUpRxCAAwGcjnB9D05HernJXMnzGhZXa3s27yysipwD0K
+tjn8x/nmrrDHtWBZ30UJAUnKsVePcCI052gH2IAAz/Efw047uGR9gbDehBH+etSkn1LXNa7EvPOE
+ZKZ2ng46r7j1+n/6i6e183TZIVXfmLCq3GeOAasAb/lHJHXjOPrUqqVUDqRke+RjOfTr71yzbua3
+ujndKW6jtbX7Njy3fBVm/wBrnIx6d8jp+Fa7i7F42IpGiBBDicgAf7uMHv1rKnEltqzGORkjyHPl
+x78KRgkAe/ce3rW7a3AKZVpXUqR+8Xafb0zyB+XvVo4JKzsZPiGDyXjmIGefM8s/ewM/0x/kVm2V
+yLe7DfPIyOEJXAJjfoc+nGfTmtrV5AtlM8kPm/JjpnHGAfbjisLR9Omur4XUgk8qLBQspwfQDnjt
+Qyqa10Nq6YxTeWGYtgFdqA7eo69Onf2FRiWGZY4mNuWGQoaIDPfscfy71NdLKZvk3YwOhf8ApUBj
+m3Z2vu6ZzJ/jWsUdSsT7WjGMIFHZRihdzjjp61CN5YApIT0P3yPyNX1gZR1FbJJbjlV0tETUA72p
+REVmYhQGGRycVzlzGsjFvMaSUOeF3AH0OOmM81t6hNh4kXGcFixPA6YGO5JxWdLZQ3sPySIJTG2w
+5xk5yMY6jr+VYcrZDfczbiRRfLAAFztaTGTg8YP8vxNXLdoAhuECssT4ZX3fIcnBGPoOcipkso5J
+nmeWOQzx5ZgBlGHtzkdiPpS2Vo9rsjaZFdyWMe4EbiemM/UfUUcrHdMtvdoliZxIzeTKAVPdGPA6
+Z78+nSrkNylzG2whvmBbPY8/4ms6Ky8o3MG0+VPEcDOdpHGM/j1/wq7BAYpY3HdNrgdCQOv6Vm1c
+tJrcZd2iTlZNkbSL03jgj0NVLee+uL57KOGCBYjgtksAMZGOnatW5mhtbd55ztRBkmsI6lLEbm8W
+JY2+VQGznOPu+55BPpjH1lXMK/La/U19RlhsrB0nlKll+U/xMR6e9S2GoQ6lZLLDwR8rqeNprlDp
+93cBru5bc7jd85wcZ7Z4xz0qK2uLjTrv7RCdw4Ei54ZfQ/0NVYypz5dDspcjOP0piM7EKMEniiK4
+hvLdJ4WJjcZGeo9j71X1KS9t7BptOVHuIcsYmTd5q9xxyD6YraMrI6paRvuRSa5Y2sckrpcvAgJ8
+9FBVyB25zz0B/kOa1oZEuLWC4VSqyxK4UnpkZrhP7Wtr/ThYGBoHlGB5oIhidhhnx27ke59zXdxR
+pa2sFur7lijVFYn7wAwDUczZzwblLUyW1DT5ODLnBB+63Y5Hb1phudOgKMgJIGBgsMDAH8gPyoor
+WOxrfmkrjEutPULsiIx0w7D/AD0H5Uq3FgJFkEB3Kcg724Oc/wA+aKKatY15I32NBJI5kWRW27hn
+aQaeGVf4gR9KKK5ZSaZV+hHdJDOqLPHvCsHUE9x3qFrSycozRZMZyu5mOCTknr1J70UUMqMIvdDX
+sbJz80eR67m5qa20W0nRkEShQOhLf40UU7WMqqUYtpGhb6QlomyAqqZzjnrUxtCDzIv5Giiq5nax
+xqpK9yq8rpIyec/y+hNMaVWA3NnHrmiiqex0p2Vz/9k=
+"
+ height="55"
+ width="110" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/5 dollarssmall.svg b/plugins/currency/images/5 dollarssmall.svg
new file mode 100644
index 0000000..91e4b3e
--- /dev/null
+++ b/plugins/currency/images/5 dollarssmall.svg
@@ -0,0 +1,55 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="27.5"
+ version="1.1"
+ viewBox="0 0 55 27.5"
+ width="55"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="5 dollarssmall.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="18.327273"
+ inkscape:cx="29.409723"
+ inkscape:cy="16.205357"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" />
+<image
+ y="0"
+ x="0"
+ id="image3048"
+ xlink:href=" HBwgJC4nICIsIxwcKDcpLDAxNDQ0Hyc5PTgyPC4zNDL/2wBDAQkJCQwLDBgNDRgyIRwhMjIyMjIy MjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjL/wAARCAA3AG4DASIA AhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQA AAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3 ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWm p6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/8QAHwEA AwEBAQEBAQEBAQAAAAAAAAECAwQFBgcICQoL/8QAtREAAgECBAQDBAcFBAQAAQJ3AAECAxEEBSEx BhJBUQdhcRMiMoEIFEKRobHBCSMzUvAVYnLRChYkNOEl8RcYGRomJygpKjU2Nzg5OkNERUZHSElK U1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6goOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3 uLm6wsPExcbHyMnK0tPU1dbX2Nna4uPk5ebn6Onq8vP09fb3+Pn6/9oADAMBAAIRAxEAPwCWfKqo XcMf3TiqcjPLkEuSOQADxVpnJABOc1RtITFqUkZuHEn3lBPyuMdD7jOcZ966Fojaaadya2iyDvEm PdSP1q7HaQOBkN+dRW1xNJI8VxCI5U5BU8OPUf59KsKMHPNHNoNSl3EuCbW1xErYHfrjvz+v/wCv FPRt0SMepUE1HfsTasAB+PaoLiRY9NchygEPDL1XjgiueW5pG+7KF9re2VobSPzXU4aRjhF/xrNe 71FGLG8QnIBUAYB/Kk0rSWv0eQy+WiMBx1Zuv+frWl/wi5Kt5dwwz1DDOf8AOaRyzryb0ZBbapKp AkdZgeSUGGA/ka6K0uyiCSIgq6gg9ciuOksJrS4aORgNnXackitLRrorI1sCAhBZM9sYzTVupUKr l7stTpzqFwD1X8qPt92ULjy9o68c/XGaotMkWDIcAnBY9AaebhVj8sGPLY+bPPTGOvbkfhWvu2HG Cb2KGs306yW6xvKrzSHd5EYZiAp4AII64qXTZxNbtmaWV1cq/nIFdDgcEAAe/wCNNvDdHy3tZEV0 JyjjKuD645FR2UcsLTzTNG087Bn2g7RgAAD8BRZmii76bFqOMFckEnHrVJYWkEqYKXDYmjbrh/4f 0wp9QCKuXBkitHKrztPJbHb9azry7y5MUpRxCAAwGcjnB9D05HernJXMnzGhZXa3s27yysipwD0K tjn8x/nmrrDHtWBZ30UJAUnKsVePcCI052gH2IAAz/Efw047uGR9gbDehBH+etSkn1LXNa7EvPOE ZKZ2ng46r7j1+n/6i6e183TZIVXfmLCq3GeOAasAb/lHJHXjOPrUqqVUDqRke+RjOfTr71yzbua3 ujndKW6jtbX7Njy3fBVm/wBrnIx6d8jp+Fa7i7F42IpGiBBDicgAf7uMHv1rKnEltqzGORkjyHPl x78KRgkAe/ce3rW7a3AKZVpXUqR+8Xafb0zyB+XvVo4JKzsZPiGDyXjmIGefM8s/ewM/0x/kVm2V yLe7DfPIyOEJXAJjfoc+nGfTmtrV5AtlM8kPm/JjpnHGAfbjisLR9Omur4XUgk8qLBQspwfQDnjt Qyqa10Nq6YxTeWGYtgFdqA7eo69Onf2FRiWGZY4mNuWGQoaIDPfscfy71NdLKZvk3YwOhf8ApUBj m3Z2vu6ZzJ/jWsUdSsT7WjGMIFHZRihdzjjp61CN5YApIT0P3yPyNX1gZR1FbJJbjlV0tETUA72p REVmYhQGGRycVzlzGsjFvMaSUOeF3AH0OOmM81t6hNh4kXGcFixPA6YGO5JxWdLZQ3sPySIJTG2w 5xk5yMY6jr+VYcrZDfczbiRRfLAAFztaTGTg8YP8vxNXLdoAhuECssT4ZX3fIcnBGPoOcipkso5J nmeWOQzx5ZgBlGHtzkdiPpS2Vo9rsjaZFdyWMe4EbiemM/UfUUcrHdMtvdoliZxIzeTKAVPdGPA6 Z78+nSrkNylzG2whvmBbPY8/4ms6Ky8o3MG0+VPEcDOdpHGM/j1/wq7BAYpY3HdNrgdCQOv6Vm1c tJrcZd2iTlZNkbSL03jgj0NVLee+uL57KOGCBYjgtksAMZGOnatW5mhtbd55ztRBkmsI6lLEbm8W JY2+VQGznOPu+55BPpjH1lXMK/La/U19RlhsrB0nlKll+U/xMR6e9S2GoQ6lZLLDwR8rqeNprlDp 93cBru5bc7jd85wcZ7Z4xz0qK2uLjTrv7RCdw4Ei54ZfQ/0NVYypz5dDspcjOP0piM7EKMEniiK4 hvLdJ4WJjcZGeo9j71X1KS9t7BptOVHuIcsYmTd5q9xxyD6YraMrI6paRvuRSa5Y2sckrpcvAgJ8 9FBVyB25zz0B/kOa1oZEuLWC4VSqyxK4UnpkZrhP7Wtr/ThYGBoHlGB5oIhidhhnx27ke59zXdxR pa2sFur7lijVFYn7wAwDUczZzwblLUyW1DT5ODLnBB+63Y5Hb1phudOgKMgJIGBgsMDAH8gPyoor WOxrfmkrjEutPULsiIx0w7D/AD0H5Uq3FgJFkEB3Kcg724Oc/wA+aKKatY15I32NBJI5kWRW27hn aQaeGVf4gR9KKK5ZSaZV+hHdJDOqLPHvCsHUE9x3qFrSycozRZMZyu5mOCTknr1J70UUMqMIvdDX sbJz80eR67m5qa20W0nRkEShQOhLf40UU7WMqqUYtpGhb6QlomyAqqZzjnrUxtCDzIv5Giiq5nax xqpK9yq8rpIyec/y+hNMaVWA3NnHrmiiqex0p2Vz/9k= "
+ height="27.5"
+ width="55" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/50 centsoff.svg b/plugins/currency/images/50 centsoff.svg
new file mode 100644
index 0000000..2992ae5
--- /dev/null
+++ b/plugins/currency/images/50 centsoff.svg
@@ -0,0 +1,54 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="80"
+ version="1.1"
+ viewBox="0 0 80 80"
+ width="80"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="50 centsoff.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="1"
+ inkscape:cx="-230.56607"
+ inkscape:cy="136"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" /><image
+ y="0"
+ x="0"
+ id="image3361"
+ xlink:href=" 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 "
+ height="80"
+ width="80" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/50 centssmall.svg b/plugins/currency/images/50 centssmall.svg
new file mode 100644
index 0000000..533e287
--- /dev/null
+++ b/plugins/currency/images/50 centssmall.svg
@@ -0,0 +1,54 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="40"
+ version="1.1"
+ viewBox="0 0 40 40"
+ width="40"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="50 centssmall.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="1"
+ inkscape:cx="-57.06607"
+ inkscape:cy="190"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" /><image
+ y="0"
+ x="0"
+ id="image3046"
+ xlink:href=" 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 "
+ height="40"
+ width="40" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/50 dollarsoff.svg b/plugins/currency/images/50 dollarsoff.svg
new file mode 100644
index 0000000..48169d9
--- /dev/null
+++ b/plugins/currency/images/50 dollarsoff.svg
@@ -0,0 +1,54 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="55"
+ version="1.1"
+ viewBox="0 0 129 55"
+ width="129"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="50 dollarsoff.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="1"
+ inkscape:cx="-320.60686"
+ inkscape:cy="43.999999"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" /><image
+ y="-4.21012e-07"
+ x="1.7763568e-15"
+ id="image3048"
+ xlink:href=" HBwgJC4nICIsIxwcKDcpLDAxNDQ0Hyc5PTgyPC4zNDL/2wBDAQkJCQwLDBgNDRgyIRwhMjIyMjIy MjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjL/wAARCAA3AIEDASIA AhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQA AAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3 ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWm p6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/8QAHwEA AwEBAQEBAQEBAQAAAAAAAAECAwQFBgcICQoL/8QAtREAAgECBAQDBAcFBAQAAQJ3AAECAxEEBSEx BhJBUQdhcRMiMoEIFEKRobHBCSMzUvAVYnLRChYkNOEl8RcYGRomJygpKjU2Nzg5OkNERUZHSElK U1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6goOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3 uLm6wsPExcbHyMnK0tPU1dbX2Nna4uPk5ebn6Onq8vP09fb3+Pn6/9oADAMBAAIRAxEAPwDV8xUf y2JJAUlsccnA/WoHitZHyVyz+uRnIP8AQGrmQT0xUFy5jjJU7WPQ9q+VvrZHZGTWqKxS1bduj6Mw 6ntgn+QqN2s4wSCAqnqMnGDj+bfrVmCWYr/yzZgDg88/hSSTEFjKu0/pWkYu6uDm+W1zJvJrW0jS Ro3ZXbYAg5PGO59BW7a3RklaCKFbdQckyNk5PJHXrnPTNczq0yXNxbWyhtxkD5I4xyK2vI2sxVmM ipz9BycehwD+hr3aMbQTe55l3JttlqHUXudWFlbtGzL/AKyTOR9B61tyI9soLfMoHJ9Pzrg/DkiC 5kupbkRIhyeOSTk4H+Fdiuu2Uts0rTgwAhHYoRyQeMevH61rOmpFqbiYNz4jt7i5LR29yCo2EMg6 8+9IdYXAVYJufVOfyzWTHGyXc0eTIA5w+CM+/wDWp3by84bLd2H9Kn6jTk7lPES2LLa3tlRZEbar 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 "
+ height="55"
+ width="129" /></svg> \ No newline at end of file
diff --git a/plugins/currency/images/50 dollarssmall.svg b/plugins/currency/images/50 dollarssmall.svg
new file mode 100644
index 0000000..4312f4a
--- /dev/null
+++ b/plugins/currency/images/50 dollarssmall.svg
@@ -0,0 +1,105 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ enable-background="new 0 0 55 55"
+ height="23.449612"
+ version="1.1"
+ viewBox="0 0 55 23.449612"
+ width="55"
+ x="0px"
+ xml:space="preserve"
+ y="0px"
+ id="svg2"
+ inkscape:version="0.48.1 r9760"
+ sodipodi:docname="50 dollarssmall.svg"><metadata
+ id="metadata23"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs21" /><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="1280"
+ inkscape:window-height="725"
+ id="namedview19"
+ showgrid="false"
+ inkscape:zoom="1"
+ inkscape:cx="57.883638"
+ inkscape:cy="30.486034"
+ inkscape:window-x="0"
+ inkscape:window-y="25"
+ inkscape:window-maximized="1"
+ inkscape:current-layer="svg2"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" />
+<image
+ y="0"
+ x="0"
+ id="image3048"
+ xlink:href="
+HBwgJC4nICIsIxwcKDcpLDAxNDQ0Hyc5PTgyPC4zNDL/2wBDAQkJCQwLDBgNDRgyIRwhMjIyMjIy
+MjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjL/wAARCAA3AIEDASIA
+AhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQA
+AAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3
+ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWm
+p6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/8QAHwEA
+AwEBAQEBAQEBAQAAAAAAAAECAwQFBgcICQoL/8QAtREAAgECBAQDBAcFBAQAAQJ3AAECAxEEBSEx
+BhJBUQdhcRMiMoEIFEKRobHBCSMzUvAVYnLRChYkNOEl8RcYGRomJygpKjU2Nzg5OkNERUZHSElK
+U1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6goOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3
+uLm6wsPExcbHyMnK0tPU1dbX2Nna4uPk5ebn6Onq8vP09fb3+Pn6/9oADAMBAAIRAxEAPwDV8xUf
+y2JJAUlsccnA/WoHitZHyVyz+uRnIP8AQGrmQT0xUFy5jjJU7WPQ9q+VvrZHZGTWqKxS1bduj6Mw
+6ntgn+QqN2s4wSCAqnqMnGDj+bfrVmCWYr/yzZgDg88/hSSTEFjKu0/pWkYu6uDm+W1zJvJrW0jS
+Ro3ZXbYAg5PGO59BW7a3RklaCKFbdQckyNk5PJHXrnPTNczq0yXNxbWyhtxkD5I4xyK2vI2sxVmM
+ipz9BycehwD+hr3aMbQTe55l3JttlqHUXudWFlbtGzL/AKyTOR9B61tyI9soLfMoHJ9Pzrg/DkiC
+5kupbkRIhyeOSTk4H+Fdiuu2Uts0rTgwAhHYoRyQeMevH61rOmpFqbiYNz4jt7i5LR29yCo2EMg6
+8+9IdYXAVYJufVOfyzWTHGyXc0eTIA5w+CM+/wDWp3by84bLd2H9Kn6jTk7lPES2LLa3tlRZEbar
+DK7eRz9fTFai+KIIokXbPwoxhV/xrk7lXJMqglVbBIHfFXrTSZr6CNhIArruDdMdsY7nPFdMqUVB
+JvYlzbne3Q6KDXv7VaS2t0mZthJygx/Osq1u9Uu7dbi30gvE+SreeBnnHpW/bWEGkaXKI3WNhGS8
+zeoH3j7CspNG+x6GLm21W6MkUBkjdZP3RAGcbem01xTowld/mbe1aVrFuYi3j824Kwp3ZzgZ/Gow
+yTRh4pFYHoykEVRtZU1ie4ub+NGlSOHyomGVUMu4kA+tRRRR2muCO3ARJYS8ka8AEHhsdvSvJxFC
+MJcqetrmkKjauaHlv/z0/SinZorjNeZ/0kLcu4jO1dwwckdR6VV8xpLJcuOWwSzEcZPQ8f57nrVm
+6OIHyOCpHPTp39qq7f8ARIgAMlznK9Dznuf51qtUJE9upDRsZkVcZZRJ144zzzWHqGtgXU8BhMcs
+bFQCQV+pOf0rpbbaw52bgM8DmuYktG1C+v5DbZVSQhcBCT6cD9Tz+ddlJR57z6Gc2+XQzLm63ajA
+2MMhw2D7/p9K1G8Qzx2kkBhj8xwQkoGMAjBOPpXP+SfOCrC6EfeGOnXvVl1d4k3o5ILDAGSSMZz6
+devNezGKsjiRs6BHbyxsFRFlQEvJIgIA65OfpVrSRBK9zEzxywKTcJuAGGB64HC5B79Mj0rM0+Vx
+DcJAAXYpuwc/JznGPw5H9a6TTYwku+OCAzDI3hskYXjsO5zjIPA9aobMm7tfsmqXAABhkYOm3psI
+BwPTHSnvA8ce/DbQ24FfvFCBjJ7cY/OoIbj7RczrG4eNT5KMTkMqjaG9vlqKbUY7bfAqmRlyMnkD
+Pp/nj+eqaSVybXehFdYSRiuF5BAUj5CMd8+hPSu30m2aLTbQPgFYwcKMct1J964mz0+a8vI5pkZI
+S4JLcFsdq9Bgz9mjz12j+VZV5e6rGsF79n2JWiDIVYAgjBBHBrEbw/ZAeQk17JAG/wCPVZj5Y5zg
++nPvWtOWKiJHKtJ8ufQeteY+LdcvLy/mtrbzY9MtZDDiPIV2BwSx75IOK54OUm0nY0lFdTttQ0SS
++uEmEclvIi7FaCQKdvp7iq8OmLpzvkOZn5Z5G3Mw7ZNcVJp1v4o1ILoFj9lWK3BlWR/lLDgYPqeB
+79cdTXW6ErR+HdPRgdyxsCCMHPmP61w42hyU+bmbKpyu7WLv40UZoryTYSd8AoerDCn37DqPbuKl
+gBt9NkeNAJBvIBHfJ9cZ5p5SJ4HDlcHjDY6d+v41HcpnTJre3kxLghSzk4b1ya7KcYqKuS7nNz3G
+oXQZ9SlRLTZnajgKxHTpyT/XFT214b5YmtCFjjkCShy3AA5PH+OfpUsWmXNvfcTb7YIApLDcCO34
+5/Ss3VLuTT5/ssAMTN+8JQ4Az3AHfjr7V2rlqSUYWb/roZu8VdkGutGLiHdteVVUnnAIYE9OD/8A
+rqjDd5LiZBKHYMQTt6emOnU02RNyAkkyM2ST1NRCAn7o5HGBXpRjyqxzI3bfTY78NJp92isF+aGU
+bWX2yM5+tbFk+qRaa1lDBDA8yny5pGJyCB0IHXBGM1iaJYjVA0W9oblR/o8ynb83o3qDzg9R7jir
+Vrf315Hcm4uGaW3iEsKkgDKcEDHB+Ut09KYNEUdjd6ZG8FxGYpHPBJGCO/OcdqTTolGoSu0ZkMfT
+2PrzW59ot9W0owvKnmgZQsQCG7df881iaQfOu5jH87AKw46Y+vp/Ss8RNOlYqmnzGlCqHaEeYb2O
+dsinHvk1sxyqsMciS3EZeNRyyFVwPQ9OnOcZ+tZUqMGiKQZfcRnYpyO46+grdtnkjiQJE/zruYBQ
+D0/qR39RT3pxNXFuq15CQOXugplmkCqvLhMHPf5QOa8svtavBbXujr5f2Z7t5D8g3E7umfw+terJ
+MQBLIDkcsBXIS+CrG4uZJ1v7pWZy5xGvyknPrWFOrGLfM7GtWm9Opx1xG+mQRRPb3drfn53dm2ho
+zgqAOvUfz/D0bSLd7XQ9PgcYdYASPQsS2P8Ax6iXRbSe8XUL+Sa/uIxhPMAVAAcj5R1/Hr3qUXL3
+FypAmVcMXDxEbj9fz/OuTHV41IckNSYRad2SY96KdzRXkmg81nzXpilkQRjC57/7OaKK1pxUm7nT
+h4qTd+w2S9ZCfkB5I6+4H9apzW1rfTCWe3VnOFzuI4yR/SiitYLlXNHRlypxdK7RReyshyLUdN33
+z/d3Vu22i6ZcQCQ2YU5IwHbsfrRRXq05Sulc8uvCMXoWbXSNPguEkitgrqdync3B/OrQ02yW4E4t
+1EoYsCCRyevHvRRRVb5iqexRv4oVvNwjwSozgketRwxxR5KLgnqcmiivPm3zs6NLImyP3P1NbsNs
+rQRt5jKdoOVyCOPWiivXUU6UbnJVm41nYZdWqx2kjCToOm2siGKOPdsyMncfmJyaKK4cTBReh00p
+ylFuRMVDqQc4I6ZqrBp9tbyeZErhsY5kZv5miivLbadkymT496KKKmxFz//Z
+"
+ height="23.449612"
+ width="55" /></svg> \ No newline at end of file
diff --git a/plugins/wedo_plugin/99-lego-WeDo.rules b/plugins/wedo_plugin/99-lego-WeDo.rules
new file mode 100644
index 0000000..7c8beea
--- /dev/null
+++ b/plugins/wedo_plugin/99-lego-WeDo.rules
@@ -0,0 +1 @@
+SYSFS{idVendor}=="0694", SYSFS{idProduct}=="0003", MODE="0666"
diff --git a/plugins/wedo_plugin/WeDoMore.py b/plugins/wedo_plugin/WeDoMore.py
new file mode 100644
index 0000000..719c7af
--- /dev/null
+++ b/plugins/wedo_plugin/WeDoMore.py
@@ -0,0 +1,192 @@
+#Copyright (c) 2011, 2012, Ian Daniher
+#Copyright (c) 2012, Tony Forster, Walter Bender
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+
+import sys
+import os
+sys.path.append(os.path.dirname(__file__))
+import usb.core
+
+import logging
+logger = logging.getLogger('WeDoMore')
+
+
+UNAVAILABLE = None
+TILTSENSOR = [38, 39]
+DISTANCESENSOR = [176, 177, 178, 179]
+MOTOR = [0, 1, 2, 3, 238, 239]
+TILT_FORWARD = 0
+TILT_LEFT = 1
+TILT_RIGHT = 2
+TILT_BACK = 3
+NO_TILT = -1
+
+
+def scan_for_devices():
+ ''' Find all available devices '''
+ return usb.core.find(find_all=True, idVendor=0x0694, idProduct=0x0003)
+
+
+class WeDo:
+ def __init__(self, device=None):
+ """Find a USB device with the VID and PID of the Lego
+ WeDo. If the HID kernel driver is active, detatch
+ it."""
+ self.dev = None
+ self.number = 0
+ self.dev = device
+ if self.dev is None:
+ logging.debug("No Lego WeDo found")
+ else:
+ status = self.init_device()
+ if status is UNAVAILABLE:
+ logging.debug("WARNING: Could not talk to WeDo device.")
+ self.valMotorA = 0
+ self.valMotorB = 0
+
+ def init_device(self):
+ ''' Reinit device associated with the WeDo instance '''
+ if self.dev is not None:
+ try:
+ if self.dev.is_kernel_driver_active(0):
+ try:
+ self.dev.detach_kernel_driver(0)
+ except: # usb.core.USBError as e:
+ e = ''
+ logger.error(
+ "Could not detatch kernel driver: %s" % (str(e)))
+ return UNAVAILABLE
+ except: # usb.core.USBError as e:
+ e = ''
+ logger.error("Could not talk to WeDo device: %s" % (str(e)))
+ return UNAVAILABLE
+ self.endpoint = self.dev[0][(0,0)][0]
+ return True
+
+ def getRawData(self):
+ """Read 64 bytes from the WeDo's endpoint, but only
+ return the last eight."""
+ try:
+ data = list(self.endpoint.read(64)[-8:])
+ except: # usb.core.USBError as e:
+ e = ''
+ logger.error("Could not read from WeDo device: %s" % (str(e)))
+ return UNAVAILABLE
+ return data
+
+ def processMotorValues(self, value):
+ """Check to make sure motor values are sane."""
+ retValue = int(value)
+ if 0 < value < 101:
+ retValue += 27
+ elif -101 < value < 0:
+ retValue -= 27
+ elif value == 0:
+ retValue = 0
+ return retValue
+
+ def setMotors(self, valMotorA, valMotorB):
+ """Arguments should be in form of a number between 0
+ and 100, positive or negative. Magic numbers used for
+ the ctrl_transfer derived from sniffing USB coms."""
+ if self.dev is None:
+ return
+ self.valMotorA = self.processMotorValues(valMotorA)
+ self.valMotorB = self.processMotorValues(valMotorB)
+ data = [64, self.valMotorA&0xFF, self.valMotorB&0xFF,
+ 0x00, 0x00, 0x00, 0x00, 0x00]
+ try:
+ self.dev.ctrl_transfer(bmRequestType = 0x21, bRequest = 0x09,
+ wValue = 0x0200, wIndex = 0,
+ data_or_wLength = data)
+ except: # usb.core.USBError as e:
+ e = ''
+ logger.error("Could not write to driver: %s" % (str(e)))
+
+ def getData(self):
+ """Sensor data is contained in the 2nd and 4th byte, with
+ sensor IDs being contained in the 3rd and 5th byte
+ respectively."""
+ rawData = self.getRawData()
+ if rawData is not None:
+ sensorData = {rawData[3]: rawData[2], rawData[5]: rawData[4]}
+ else:
+ sensorData = {}
+ return sensorData
+
+ def processTilt(self, v):
+ """Use a series of elif/value-checks to process the tilt
+ sensor data."""
+ if v in range(10, 40):
+ return TILT_BACK
+ elif v in range(60, 90):
+ return TILT_RIGHT
+ elif v in range(170, 190):
+ return TILT_FORWARD
+ elif v in range(220, 240):
+ return TILT_LEFT
+ elif v in range(120, 140):
+ return NO_TILT
+ else:
+ return NO_TILT
+
+ def getTilt(self):
+ if self.dev is None:
+ return UNAVAILABLE
+ data = self.getData()
+ for num in data.keys():
+ if num in TILTSENSOR:
+ return self.processTilt(data[num])
+ return UNAVAILABLE
+
+ def getDistance(self):
+ if self.dev is None:
+ return UNAVAILABLE
+ data = self.getData()
+ for num in data.keys():
+ if num in DISTANCESENSOR:
+ return data[num] - 69
+ return UNAVAILABLE
+
+ # TODO: check motor availability
+
+ def setMotorA(self, valMotorA):
+ self.setMotors(valMotorA, self.valMotorB)
+ return self.valMotorA
+
+ def setMotorB(self, valMotorB):
+ self.setMotors(self.valMotorA, valMotorB)
+ return self.valMotorB
+
+ def getMotorA(self):
+ if self.dev is None:
+ return UNAVAILABLE
+ if self.valMotorA == 0:
+ return 0
+ elif self.valMotorA < 0:
+ return self.valMotorA + 27
+ else:
+ return self.valMotorA - 27
+
+ def getMotorB(self):
+ if self.dev is None:
+ return UNAVAILABLE
+ if self.valMotorB == 0:
+ return 0
+ elif self.valMotorB < 0:
+ return self.valMotorB + 27
+ else:
+ return self.valMotorB - 27
diff --git a/plugins/wedo_plugin/__init__.py b/plugins/wedo_plugin/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/plugins/wedo_plugin/__init__.py
diff --git a/plugins/wedo_plugin/icons/WeDooff.svg b/plugins/wedo_plugin/icons/WeDooff.svg
new file mode 100644
index 0000000..cc43d44
--- /dev/null
+++ b/plugins/wedo_plugin/icons/WeDooff.svg
@@ -0,0 +1,71 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ version="1.1"
+ width="55"
+ height="55"
+ viewBox="0 0 55 55"
+ id="svg2"
+ xml:space="preserve"
+ inkscape:version="0.47 r22583"
+ sodipodi:docname="WeDooff.svg"><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="640"
+ inkscape:window-height="504"
+ id="namedview10"
+ showgrid="false"
+ inkscape:zoom="4.2909091"
+ inkscape:cx="27.5"
+ inkscape:cy="27.5"
+ inkscape:window-x="0"
+ inkscape:window-y="24"
+ inkscape:window-maximized="0"
+ inkscape:current-layer="svg2" /><metadata
+ id="metadata15"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs13"><inkscape:perspective
+ sodipodi:type="inkscape:persp3d"
+ inkscape:vp_x="0 : 27.5 : 1"
+ inkscape:vp_y="0 : 1000 : 0"
+ inkscape:vp_z="55 : 27.5 : 1"
+ inkscape:persp3d-origin="27.5 : 18.333333 : 1"
+ id="perspective12" />
+
+
+
+
+ </defs><rect
+ width="55"
+ height="55"
+ x="0"
+ y="0"
+ id="rect3269"
+ style="fill:#282828;fill-opacity:1;fill-rule:nonzero;stroke:none" /><path
+ d="m 11.421095,15.380686 c 0,2.0569 1.66964,3.72654 3.72654,3.72654 2.05489,0 3.72453,-1.66964 3.72453,-3.72654 0,-2.05489 -1.66897,-3.72788 -3.72453,-3.72788 -2.0569,0 -3.72654,1.67299 -3.72654,3.72788 z"
+ id="path7"
+ style="fill:#ffffff;fill-opacity:1" /><path
+ style="fill:#ffffff;fill-opacity:1"
+ id="path2823"
+ d="m 35.421095,15.380686 c 0,2.0569 1.66964,3.72654 3.72654,3.72654 2.05489,0 3.72453,-1.66964 3.72453,-3.72654 0,-2.05489 -1.66897,-3.72788 -3.72453,-3.72788 -2.0569,0 -3.72654,1.67299 -3.72654,3.72788 z" /><path
+ d="m 35.421095,39.380686 c 0,2.0569 1.66964,3.72654 3.72654,3.72654 2.05489,0 3.72453,-1.66964 3.72453,-3.72654 0,-2.05489 -1.66897,-3.72788 -3.72453,-3.72788 -2.0569,0 -3.72654,1.67299 -3.72654,3.72788 z"
+ id="path2825"
+ style="fill:#ffffff;fill-opacity:1" /><path
+ style="fill:#ffffff;fill-opacity:1"
+ id="path2827"
+ d="m 11.421095,39.380686 c 0,2.0569 1.66964,3.72654 3.72654,3.72654 2.05489,0 3.72453,-1.66964 3.72453,-3.72654 0,-2.05489 -1.66897,-3.72788 -3.72453,-3.72788 -2.0569,0 -3.72654,1.67299 -3.72654,3.72788 z" /></svg>
diff --git a/plugins/wedo_plugin/icons/WeDoon.svg b/plugins/wedo_plugin/icons/WeDoon.svg
new file mode 100644
index 0000000..16d54d2
--- /dev/null
+++ b/plugins/wedo_plugin/icons/WeDoon.svg
@@ -0,0 +1,71 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ version="1.1"
+ width="55"
+ height="55"
+ viewBox="0 0 55 55"
+ id="svg2"
+ xml:space="preserve"
+ inkscape:version="0.47 r22583"
+ sodipodi:docname="WeDoon.svg"><sodipodi:namedview
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1"
+ objecttolerance="10"
+ gridtolerance="10"
+ guidetolerance="10"
+ inkscape:pageopacity="0"
+ inkscape:pageshadow="2"
+ inkscape:window-width="640"
+ inkscape:window-height="504"
+ id="namedview10"
+ showgrid="false"
+ inkscape:zoom="4.2909091"
+ inkscape:cx="27.5"
+ inkscape:cy="27.5"
+ inkscape:window-x="0"
+ inkscape:window-y="24"
+ inkscape:window-maximized="0"
+ inkscape:current-layer="svg2" /><metadata
+ id="metadata15"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
+ id="defs13"><inkscape:perspective
+ sodipodi:type="inkscape:persp3d"
+ inkscape:vp_x="0 : 27.5 : 1"
+ inkscape:vp_y="0 : 1000 : 0"
+ inkscape:vp_z="55 : 27.5 : 1"
+ inkscape:persp3d-origin="27.5 : 18.333333 : 1"
+ id="perspective12" />
+
+
+
+
+ </defs><rect
+ width="55"
+ height="55"
+ x="0"
+ y="0"
+ id="rect3269"
+ style="fill:#ffd200;fill-opacity:1;fill-rule:nonzero;stroke:none" /><path
+ d="m 11.421095,15.380686 c 0,2.0569 1.66964,3.72654 3.72654,3.72654 2.05489,0 3.72453,-1.66964 3.72453,-3.72654 0,-2.05489 -1.66897,-3.72788 -3.72453,-3.72788 -2.0569,0 -3.72654,1.67299 -3.72654,3.72788 z"
+ id="path7"
+ style="fill:#ff0000;fill-opacity:1" /><path
+ style="fill:#ff0000;fill-opacity:1"
+ id="path2823"
+ d="m 35.421095,15.380686 c 0,2.0569 1.66964,3.72654 3.72654,3.72654 2.05489,0 3.72453,-1.66964 3.72453,-3.72654 0,-2.05489 -1.66897,-3.72788 -3.72453,-3.72788 -2.0569,0 -3.72654,1.67299 -3.72654,3.72788 z" /><path
+ d="m 35.421095,39.380686 c 0,2.0569 1.66964,3.72654 3.72654,3.72654 2.05489,0 3.72453,-1.66964 3.72453,-3.72654 0,-2.05489 -1.66897,-3.72788 -3.72453,-3.72788 -2.0569,0 -3.72654,1.67299 -3.72654,3.72788 z"
+ id="path2825"
+ style="fill:#ff0000;fill-opacity:1" /><path
+ style="fill:#ff0000;fill-opacity:1"
+ id="path2827"
+ d="m 11.421095,39.380686 c 0,2.0569 1.66964,3.72654 3.72654,3.72654 2.05489,0 3.72453,-1.66964 3.72453,-3.72654 0,-2.05489 -1.66897,-3.72788 -3.72453,-3.72788 -2.0569,0 -3.72654,1.67299 -3.72654,3.72788 z" /></svg> \ No newline at end of file
diff --git a/plugins/wedo_plugin/plugin.info b/plugins/wedo_plugin/plugin.info
new file mode 100644
index 0000000..b66e1fa
--- /dev/null
+++ b/plugins/wedo_plugin/plugin.info
@@ -0,0 +1,5 @@
+[Plugin]
+name=wedo_plugin
+palette=wedo
+version=2.2
+
diff --git a/plugins/wedo_plugin/usb/__init__.py b/plugins/wedo_plugin/usb/__init__.py
new file mode 100644
index 0000000..8909cf2
--- /dev/null
+++ b/plugins/wedo_plugin/usb/__init__.py
@@ -0,0 +1,92 @@
+# Copyright (C) 2009-2011 Wander Lairson Costa
+#
+# The following terms apply to all files associated
+# with the software unless explicitly disclaimed in individual files.
+#
+# The authors hereby grant permission to use, copy, modify, distribute,
+# and license this software and its documentation for any purpose, provided
+# that existing copyright notices are retained in all copies and that this
+# notice is included verbatim in any distributions. No written agreement,
+# license, or royalty fee is required for any of the authorized uses.
+# Modifications to this software may be copyrighted by their authors
+# and need not follow the licensing terms described here, provided that
+# the new terms are clearly indicated on the first page of each file where
+# they apply.
+#
+# IN NO EVENT SHALL THE AUTHORS OR DISTRIBUTORS BE LIABLE TO ANY PARTY
+# FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
+# ARISING OUT OF THE USE OF THIS SOFTWARE, ITS DOCUMENTATION, OR ANY
+# DERIVATIVES THEREOF, EVEN IF THE AUTHORS HAVE BEEN ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+#
+# THE AUTHORS AND DISTRIBUTORS SPECIFICALLY DISCLAIM ANY WARRANTIES,
+# INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT. THIS SOFTWARE
+# IS PROVIDED ON AN "AS IS" BASIS, AND THE AUTHORS AND DISTRIBUTORS HAVE
+# NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR
+# MODIFICATIONS.
+
+r"""PyUSB - Easy USB access in Python
+
+This package exports the following modules and subpackages:
+
+ core - the main USB implementation
+ legacy - the compatibility layer with 0.x version
+ backend - the support for backend implementations.
+
+Since version 1.0, main PyUSB implementation lives in the 'usb.core'
+module. New applications are encouraged to use it.
+"""
+
+import logging
+import os
+
+__author__ = 'Wander Lairson Costa'
+
+__all__ = ['legacy', 'core', 'backend', 'util']
+
+
+def _setup_log():
+ from usb import _debug
+ logger = logging.getLogger('usb')
+ debug_level = os.getenv('PYUSB_DEBUG_LEVEL')
+
+ if debug_level is not None:
+ _debug.enable_tracing(True)
+ filename = os.getenv('PYUSB_LOG_FILENAME')
+
+ LEVELS = {'debug': logging.DEBUG,
+ 'info': logging.INFO,
+ 'warning': logging.WARNING,
+ 'error': logging.ERROR,
+ 'critical': logging.CRITICAL}
+
+ level = LEVELS.get(debug_level, logging.CRITICAL + 10)
+ logger.setLevel(level = level)
+
+ try:
+ handler = logging.FileHandler(filename)
+ except:
+ handler = logging.StreamHandler()
+
+ fmt = logging.Formatter('%(asctime)s %(levelname)s:%(name)s:%(message)s')
+ handler.setFormatter(fmt)
+ logger.addHandler(handler)
+ else:
+ class NullHandler(logging.Handler):
+ def emit(self, record):
+ pass
+
+ # We set the log level to avoid delegation to the
+ # parent log handler (if there is one).
+ # Thanks to Chris Clark to pointing this out.
+ logger.setLevel(logging.CRITICAL + 10)
+
+ logger.addHandler(NullHandler())
+
+
+_setup_log()
+
+# We import all 'legacy' module symbols to provide compatility
+# with applications that use 0.x versions.
+from usb.legacy import *
diff --git a/plugins/wedo_plugin/usb/_debug.py b/plugins/wedo_plugin/usb/_debug.py
new file mode 100644
index 0000000..13b0ced
--- /dev/null
+++ b/plugins/wedo_plugin/usb/_debug.py
@@ -0,0 +1,77 @@
+# Copyright (C) 2009-2011 Wander Lairson Costa
+#
+# The following terms apply to all files associated
+# with the software unless explicitly disclaimed in individual files.
+#
+# The authors hereby grant permission to use, copy, modify, distribute,
+# and license this software and its documentation for any purpose, provided
+# that existing copyright notices are retained in all copies and that this
+# notice is included verbatim in any distributions. No written agreement,
+# license, or royalty fee is required for any of the authorized uses.
+# Modifications to this software may be copyrighted by their authors
+# and need not follow the licensing terms described here, provided that
+# the new terms are clearly indicated on the first page of each file where
+# they apply.
+#
+# IN NO EVENT SHALL THE AUTHORS OR DISTRIBUTORS BE LIABLE TO ANY PARTY
+# FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
+# ARISING OUT OF THE USE OF THIS SOFTWARE, ITS DOCUMENTATION, OR ANY
+# DERIVATIVES THEREOF, EVEN IF THE AUTHORS HAVE BEEN ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+#
+# THE AUTHORS AND DISTRIBUTORS SPECIFICALLY DISCLAIM ANY WARRANTIES,
+# INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT. THIS SOFTWARE
+# IS PROVIDED ON AN "AS IS" BASIS, AND THE AUTHORS AND DISTRIBUTORS HAVE
+# NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR
+# MODIFICATIONS.
+
+__author__ = 'Wander Lairson Costa'
+
+__all__ = ['methodtrace', 'functiontrace']
+
+import logging
+import usb._interop as _interop
+
+_enable_tracing = False
+
+def enable_tracing(enable):
+ global _enable_tracing
+ _enable_tracing = enable
+
+def _trace_function_call(logger, fname, *args, **named_args):
+ logger.debug(
+ # TODO: check if 'f' is a method or a free function
+ fname + '(' + \
+ ', '.join((str(val) for val in args)) + \
+ ', '.join((name + '=' + str(val) for name, val in named_args.items())) + ')'
+ )
+
+# decorator for methods calls tracing
+def methodtrace(logger):
+ def decorator_logging(f):
+ if not _enable_tracing:
+ return f
+ def do_trace(*args, **named_args):
+ # this if is just a optimization to avoid unecessary string formatting
+ if logging.DEBUG >= logger.getEffectiveLevel():
+ fn = type(args[0]).__name__ + '.' + f.__name__
+ _trace_function_call(logger, fn, *args[1:], **named_args)
+ return f(*args, **named_args)
+ _interop._update_wrapper(do_trace, f)
+ return do_trace
+ return decorator_logging
+
+# decorator for methods calls tracing
+def functiontrace(logger):
+ def decorator_logging(f):
+ if not _enable_tracing:
+ return f
+ def do_trace(*args, **named_args):
+ # this if is just a optimization to avoid unecessary string formatting
+ if logging.DEBUG >= logger.getEffectiveLevel():
+ _trace_function_call(logger, f.__name__, *args, **named_args)
+ return f(*args, **named_args)
+ _interop._update_wrapper(do_trace, f)
+ return do_trace
+ return decorator_logging
diff --git a/plugins/wedo_plugin/usb/_interop.py b/plugins/wedo_plugin/usb/_interop.py
new file mode 100644
index 0000000..6069d5e
--- /dev/null
+++ b/plugins/wedo_plugin/usb/_interop.py
@@ -0,0 +1,135 @@
+# Copyright (C) 2009-2011 Wander Lairson Costa
+#
+# The following terms apply to all files associated
+# with the software unless explicitly disclaimed in individual files.
+#
+# The authors hereby grant permission to use, copy, modify, distribute,
+# and license this software and its documentation for any purpose, provided
+# that existing copyright notices are retained in all copies and that this
+# notice is included verbatim in any distributions. No written agreement,
+# license, or royalty fee is required for any of the authorized uses.
+# Modifications to this software may be copyrighted by their authors
+# and need not follow the licensing terms described here, provided that
+# the new terms are clearly indicated on the first page of each file where
+# they apply.
+#
+# IN NO EVENT SHALL THE AUTHORS OR DISTRIBUTORS BE LIABLE TO ANY PARTY
+# FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
+# ARISING OUT OF THE USE OF THIS SOFTWARE, ITS DOCUMENTATION, OR ANY
+# DERIVATIVES THEREOF, EVEN IF THE AUTHORS HAVE BEEN ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+#
+# THE AUTHORS AND DISTRIBUTORS SPECIFICALLY DISCLAIM ANY WARRANTIES,
+# INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT. THIS SOFTWARE
+# IS PROVIDED ON AN "AS IS" BASIS, AND THE AUTHORS AND DISTRIBUTORS HAVE
+# NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR
+# MODIFICATIONS.
+
+# All the hacks necessary to assure compatibility across all
+# supported versions come here.
+# Please, note that there is one version check for each
+# hack we need to do, this makes maintenance easier... ^^
+
+import sys
+import array
+
+__all__ = ['_reduce', '_set', '_next', '_groupby', '_sorted', '_update_wrapper']
+
+# we support Python >= 2.3
+assert sys.hexversion >= 0x020300f0
+
+# On Python 3, reduce became a functools module function
+try:
+ import functools
+ _reduce = functools.reduce
+except (ImportError, AttributeError):
+ _reduce = reduce
+
+# we only have the builtin set type since 2.5 version
+try:
+ _set = set
+except NameError:
+ import sets
+ _set = sets.Set
+
+# On Python >= 2.6, we have the builtin next() function
+# On Python 2.5 and before, we have to call the iterator method next()
+def _next(iter):
+ try:
+ return next(iter)
+ except NameError:
+ return iter.next()
+
+# groupby is available only since 2.4 version
+try:
+ import itertools
+ _groupby = itertools.groupby
+except (ImportError, AttributeError):
+ # stolen from Python docs
+ class _groupby(object):
+ # [k for k, g in groupby('AAAABBBCCDAABBB')] --> A B C D A B
+ # [list(g) for k, g in groupby('AAAABBBCCD')] --> AAAA BBB CC D
+ def __init__(self, iterable, key=None):
+ if key is None:
+ key = lambda x: x
+ self.keyfunc = key
+ self.it = iter(iterable)
+ self.tgtkey = self.currkey = self.currvalue = object()
+ def __iter__(self):
+ return self
+ def next(self):
+ while self.currkey == self.tgtkey:
+ self.currvalue = _next(self.it) # Exit on StopIteration
+ self.currkey = self.keyfunc(self.currvalue)
+ self.tgtkey = self.currkey
+ return (self.currkey, self._grouper(self.tgtkey))
+ def _grouper(self, tgtkey):
+ while self.currkey == tgtkey:
+ yield self.currvalue
+ self.currvalue = _next(self.it) # Exit on StopIteration
+ self.currkey = self.keyfunc(self.currvalue)
+
+# builtin sorted function is only availale since 2.4 version
+try:
+ _sorted = sorted
+except NameError:
+ def _sorted(l, key=None, reverse=False):
+ # sort function on Python 2.3 does not
+ # support 'key' parameter
+ class KeyToCmp(object):
+ def __init__(self, K):
+ self.key = K
+ def __call__(self, x, y):
+ kx = self.key(x)
+ ky = self.key(y)
+ if kx < ky:
+ return reverse and 1 or -1
+ elif kx > ky:
+ return reverse and -1 or 1
+ else:
+ return 0
+ tmp = list(l)
+ tmp.sort(KeyToCmp(key))
+ return tmp
+
+try:
+ import functools
+ _update_wrapper = functools.update_wrapper
+except (ImportError, AttributeError):
+ def _update_wrapper(wrapper, wrapped):
+ wrapper.__name__ = wrapped.__name__
+ wrapper.__module__ = wrapped.__module__
+ wrapper.__doc__ = wrapped.__doc__
+ wrapper.__dict__ = wrapped.__dict__
+
+def as_array(data=None):
+ if data is None:
+ return array.array('B')
+ try:
+ return array.array('B', data)
+ except TypeError:
+ # When you pass a unicode string, you got a TypeError
+ # if first parameter is not 'u'
+ return array.array('u', data)
+
diff --git a/plugins/wedo_plugin/usb/backend/__init__.py b/plugins/wedo_plugin/usb/backend/__init__.py
new file mode 100644
index 0000000..67ee00f
--- /dev/null
+++ b/plugins/wedo_plugin/usb/backend/__init__.py
@@ -0,0 +1,368 @@
+# Copyright (C) 2009-2011 Wander Lairson Costa
+#
+# The following terms apply to all files associated
+# with the software unless explicitly disclaimed in individual files.
+#
+# The authors hereby grant permission to use, copy, modify, distribute,
+# and license this software and its documentation for any purpose, provided
+# that existing copyright notices are retained in all copies and that this
+# notice is included verbatim in any distributions. No written agreement,
+# license, or royalty fee is required for any of the authorized uses.
+# Modifications to this software may be copyrighted by their authors
+# and need not follow the licensing terms described here, provided that
+# the new terms are clearly indicated on the first page of each file where
+# they apply.
+#
+# IN NO EVENT SHALL THE AUTHORS OR DISTRIBUTORS BE LIABLE TO ANY PARTY
+# FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
+# ARISING OUT OF THE USE OF THIS SOFTWARE, ITS DOCUMENTATION, OR ANY
+# DERIVATIVES THEREOF, EVEN IF THE AUTHORS HAVE BEEN ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+#
+# THE AUTHORS AND DISTRIBUTORS SPECIFICALLY DISCLAIM ANY WARRANTIES,
+# INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT. THIS SOFTWARE
+# IS PROVIDED ON AN "AS IS" BASIS, AND THE AUTHORS AND DISTRIBUTORS HAVE
+# NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR
+# MODIFICATIONS.
+
+r"""usb.backend - Backend interface.
+
+This module exports:
+
+IBackend - backend interface.
+
+Backends are Python objects which implement the IBackend interface.
+The easiest way to do so is inherinting from IBackend.
+
+PyUSB already provides backends for libusb versions 0.1 and 1.0,
+and OpenUSB library. Backends modules included with PyUSB are required to
+export the get_backend() function, which returns an instance of a backend
+object. You can provide your own customized backend if you
+want to. Bellow you find a skeleton of a backend implementation module:
+
+import usb.backend
+
+class MyBackend(usb.backend.IBackend):
+ pass
+
+def get_backend():
+ return MyBackend()
+
+You can use your customized backend by passing it as the backend parameter of the
+usb.core.find() function. For example:
+
+import custom_backend
+import usb.core
+
+myidVendor = 0xfffe
+myidProduct = 0x0001
+
+mybackend = custom_backend.get_backend()
+
+dev = usb.core.find(backend = mybackend, idProduct=myidProduct,
+ idVendor=myidVendor)
+
+For custom backends, you are not required to supply the get_backend() function,
+since the application code will instantiate the backend.
+
+If you do not provide a backend to the find() function, it will use one of the
+defaults backend according to its internal rules. For details, consult the
+find() function documentation.
+"""
+
+__author__ = 'Wander Lairson Costa'
+
+__all__ = ['IBackend', 'libusb01', 'libusb10', 'openusb']
+
+def _not_implemented(func):
+ raise NotImplementedError(func.__name__)
+
+class IBackend(object):
+ r"""Backend interface.
+
+ IBackend is the basic interface for backend implementations. By default,
+ the methods of the interface raise a NotImplementedError exception. A
+ backend implementation should replace the methods to provide the funcionality
+ necessary.
+
+ As Python is a dynamic typed language, you are not obligated to inherit from
+ IBackend: everything that bahaves like an IBackend is an IBackend. But you
+ are strongly recommended to do so, inheriting from IBackend provides consistent
+ default behavior.
+ """
+ def enumerate_devices(self):
+ r"""This function is required to return an iterable object which
+ yields an implementation defined device identification for each
+ USB device found in the system.
+
+ The device identification object is used as argument to other methods
+ of the interface.
+ """
+ _not_implemented(self.enumerate_devices)
+
+ def get_device_descriptor(self, dev):
+ r"""Return the device descriptor of the given device.
+
+ The object returned is required to have all the Device Descriptor
+ fields accessible as member variables. They must be convertible (but
+ not required to be equal) to the int type.
+
+ dev is an object yielded by the iterator returned by the enumerate_devices()
+ method.
+ """
+ _not_implemented(self.get_device_descriptor)
+
+ def get_configuration_descriptor(self, dev, config):
+ r"""Return a configuration descriptor of the given device.
+
+ The object returned is required to have all the Configuration Descriptor
+ fields acessible as member variables. They must be convertible (but
+ not required to be equal) to the int type.
+
+ The dev parameter is the already described device identification object.
+ config is the logical index of the configuration (not the bConfigurationValue
+ field). By "logical index" we mean the relative order of the configurations
+ returned by the peripheral as a result of GET_DESCRIPTOR request.
+ """
+ _not_implemented(self.get_configuration_descriptor)
+
+ def get_interface_descriptor(self, dev, intf, alt, config):
+ r"""Return an interface descriptor of the given device.
+
+ The object returned is required to have all the Interface Descriptor
+ fields accessible as member variables. They must be convertible (but
+ not required to be equal) to the int type.
+
+ The dev parameter is the already described device identification object.
+ The intf parameter is the interface logical index (not the bInterfaceNumber field)
+ and alt is the alternate setting logical index (not the bAlternateSetting value).
+ Not every interface has more than one alternate setting. In this case, the alt
+ parameter should be zero. config is the configuration logical index (not the
+ bConfigurationValue field).
+ """
+ _not_implemented(self.get_interface_descriptor)
+
+ def get_endpoint_descriptor(self, dev, ep, intf, alt, config):
+ r"""Return an endpoint descriptor of the given device.
+
+ The object returned is required to have all the Endpoint Descriptor
+ fields acessible as member variables. They must be convertible (but
+ not required to be equal) to the int type.
+
+ The ep parameter is the endpoint logical index (not the bEndpointAddress
+ field) of the endpoint descriptor desired. intf, alt and config are the same
+ values already described in the get_interface_descriptor() method.
+ """
+ _not_implemented(self.get_endpoint_descriptor)
+
+ def open_device(self, dev):
+ r"""Open the device for data exchange.
+
+ This method opens the device identified by the dev parameter for communication.
+ This method must be called before calling any communication related method, such
+ as transfer methods.
+
+ It returns a handle identifying the communication instance. This handle must be
+ passed to the communication methods.
+ """
+ _not_implemented(self.open_device)
+
+ def close_device(self, dev_handle):
+ r"""Close the device handle.
+
+ This method closes the device communication channel and releases any
+ system resources related to it.
+ """
+ _not_implemented(self.close_device)
+
+ def set_configuration(self, dev_handle, config_value):
+ r"""Set the active device configuration.
+
+ This method should be called to set the active configuration
+ of the device. The dev_handle parameter is the value returned
+ by the open_device() method and the config_value parameter is the
+ bConfigurationValue field of the related configuration descriptor.
+ """
+ _not_implemented(self.set_configuration)
+
+ def get_configuration(self, dev_handle):
+ r"""Get the current active device configuration.
+
+ This method returns the bConfigurationValue of the currently
+ active configuration. Depending on the backend and the OS,
+ either a cached value may be returned or a control request may
+ be issued. The dev_handle parameter is the value returned by
+ the open_device method.
+ """
+ _not_implemented(self.get_configuration)
+
+ def set_interface_altsetting(self, dev_handle, intf, altsetting):
+ r"""Set the interface alternate setting.
+
+ This method should only be called when the interface has more than
+ one alternate setting. The dev_handle is the value returned by the
+ open_device() method. intf and altsetting are respectivelly the
+ bInterfaceNumber and bAlternateSetting fields of the related interface.
+ """
+ _not_implemented(self.set_interface_altsetting)
+
+ def claim_interface(self, dev_handle, intf):
+ r"""Claim the given interface.
+
+ Interface claiming is not related to USB spec itself, but it is
+ generally an necessary call of the USB libraries. It requests exclusive
+ access to the interface on the system. This method must be called
+ before using one of the transfer methods.
+
+ dev_handle is the value returned by the open_device() method and
+ intf is the bInterfaceNumber field of the desired interface.
+ """
+ _not_implemented(self.claim_interface)
+
+ def release_interface(self, dev_handle, intf):
+ r"""Release the claimed interface.
+
+ dev_handle and intf are the same parameters of the claim_interface
+ method.
+ """
+ _not_implemented(self.release_interface)
+
+ def bulk_write(self, dev_handle, ep, intf, data, timeout):
+ r"""Perform a bulk write.
+
+ dev_handle is the value returned by the open_device() method.
+ The ep parameter is the bEndpointAddress field whose endpoint
+ the data will be sent to. intf is the bInterfaceNumber field
+ of the interface containing the endpoint. The data parameter
+ is the data to be sent. It must be an instance of the array.array
+ class. The timeout parameter specifies a time limit to the operation
+ in miliseconds.
+
+ The method returns the number of bytes written.
+ """
+ _not_implemented(self.bulk_write)
+
+ def bulk_read(self, dev_handle, ep, intf, size, timeout):
+ r"""Perform a bulk read.
+
+ dev_handle is the value returned by the open_device() method.
+ The ep parameter is the bEndpointAddress field whose endpoint
+ the data will be received from. intf is the bInterfaceNumber field
+ of the interface containing the endpoint. The size parameter
+ is the number of bytes to be read. The timeout parameter specifies
+ a time limit to the operation in miliseconds.
+
+ The method returns an array.array object containing the data read.
+ """
+ _not_implemented(self.bulk_read)
+
+ def intr_write(self, dev_handle, ep, intf, data, timeout):
+ r"""Perform an interrupt write.
+
+ dev_handle is the value returned by the open_device() method.
+ The ep parameter is the bEndpointAddress field whose endpoint
+ the data will be sent to. intf is the bInterfaceNumber field
+ of the interface containing the endpoint. The data parameter
+ is the data to be sent. It must be an instance of the array.array
+ class. The timeout parameter specifies a time limit to the operation
+ in miliseconds.
+
+ The method returns the number of bytes written.
+ """
+ _not_implemented(self.intr_write)
+
+ def intr_read(self, dev_handle, ep, intf, size, timeout):
+ r"""Perform an interrut read.
+
+ dev_handle is the value returned by the open_device() method.
+ The ep parameter is the bEndpointAddress field whose endpoint
+ the data will be received from. intf is the bInterfaceNumber field
+ of the interface containing the endpoint. The size parameter
+ is the number of bytes to be read. The timeout parameter specifies
+ a time limit to the operation in miliseconds.
+
+ The method returns an array.array object containing the data read.
+ """
+ _not_implemented(self.intr_read)
+
+ def iso_write(self, dev_handle, ep, intf, data, timeout):
+ r"""Perform an isochronous write.
+
+ dev_handle is the value returned by the open_device() method.
+ The ep parameter is the bEndpointAddress field whose endpoint
+ the data will be sent to. intf is the bInterfaceNumber field
+ of the interface containing the endpoint. The data parameter
+ is the data to be sent.It must be an instance of the array.array
+ class. The timeout parameter specifies a time limit to the operation
+ in miliseconds.
+
+ The method returns the number of bytes written.
+ """
+ _not_implemented(self.iso_write)
+
+ def iso_read(self, dev_handle, ep, intf, size, timeout):
+ r"""Perform an isochronous read.
+
+ dev_handle is the value returned by the open_device() method.
+ The ep parameter is the bEndpointAddress field whose endpoint
+ the data will be received from. intf is the bInterfaceNumber field
+ of the interface containing the endpoint. The size parameter
+ is the number of bytes to be read. The timeout parameter specifies
+ a time limit to the operation in miliseconds.
+
+ The method returns an array.array object containing the data read.
+ """
+ _not_implemented(self.iso_read)
+
+ def ctrl_transfer(self,
+ dev_handle,
+ bmRequestType,
+ bRequest,
+ wValue,
+ wIndex,
+ data_or_wLength,
+ timeout):
+ r"""Perform a control transfer on the endpoint 0.
+
+ The direction of the transfer is inferred from the bmRequestType
+ field of the setup packet.
+
+ dev_handle is the value returned by the open_device() method.
+ bmRequestType, bRequest, wValue and wIndex are the same fields
+ of the setup packet. data_or_wLength is either the payload to be sent
+ to the device, if any, as an array.array object (None there is no
+ payload) for OUT requests in the data stage or the wLength field
+ specifying the number of bytes to read for IN requests in the data
+ stage. The timeout parameter specifies a time limit to the operation
+ in miliseconds.
+
+ Return the number of bytes written (for OUT transfers) or the data
+ read (for IN transfers), as an array.array object.
+ """
+ _not_implemented(self.ctrl_transfer)
+
+ def reset_device(self, dev_handle):
+ r"""Reset the device."""
+ _not_implemented(self.reset_device)
+
+ def is_kernel_driver_active(self, dev_handle, intf):
+ r"""Determine if a kernel driver is active on an interface.
+
+ If a kernel driver is active, you cannot claim the interface,
+ and the backend will be unable to perform I/O.
+ """
+ _not_implemented(self.is_kernel_driver_active)
+
+ def detach_kernel_driver(self, dev_handle, intf):
+ r"""Detach a kernel driver from an interface.
+
+ If successful, you will then be able to claim the interface
+ and perform I/O.
+ """
+ _not_implemented(self.detach_kernel_driver)
+
+ def attach_kernel_driver(self, dev_handle, intf):
+ r"""Re-attach an interface's kernel driver, which was previously
+ detached using detach_kernel_driver()."""
+ _not_implemented(self.attach_kernel_driver)
diff --git a/plugins/wedo_plugin/usb/backend/libusb01.py b/plugins/wedo_plugin/usb/backend/libusb01.py
new file mode 100644
index 0000000..cf344c0
--- /dev/null
+++ b/plugins/wedo_plugin/usb/backend/libusb01.py
@@ -0,0 +1,582 @@
+# Copyright (C) 2009-2011 Wander Lairson Costa
+#
+# The following terms apply to all files associated
+# with the software unless explicitly disclaimed in individual files.
+#
+# The authors hereby grant permission to use, copy, modify, distribute,
+# and license this software and its documentation for any purpose, provided
+# that existing copyright notices are retained in all copies and that this
+# notice is included verbatim in any distributions. No written agreement,
+# license, or royalty fee is required for any of the authorized uses.
+# Modifications to this software may be copyrighted by their authors
+# and need not follow the licensing terms described here, provided that
+# the new terms are clearly indicated on the first page of each file where
+# they apply.
+#
+# IN NO EVENT SHALL THE AUTHORS OR DISTRIBUTORS BE LIABLE TO ANY PARTY
+# FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
+# ARISING OUT OF THE USE OF THIS SOFTWARE, ITS DOCUMENTATION, OR ANY
+# DERIVATIVES THEREOF, EVEN IF THE AUTHORS HAVE BEEN ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+#
+# THE AUTHORS AND DISTRIBUTORS SPECIFICALLY DISCLAIM ANY WARRANTIES,
+# INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT. THIS SOFTWARE
+# IS PROVIDED ON AN "AS IS" BASIS, AND THE AUTHORS AND DISTRIBUTORS HAVE
+# NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR
+# MODIFICATIONS.
+
+from ctypes import *
+import ctypes.util
+import os
+import usb.backend
+import usb.util
+import sys
+from usb.core import USBError
+from usb._debug import methodtrace
+import usb._interop as _interop
+import logging
+
+__author__ = 'Wander Lairson Costa'
+
+__all__ = ['get_backend']
+
+_logger = logging.getLogger('usb.backend.libusb01')
+
+# usb.h
+
+_PC_PATH_MAX = 4
+
+if sys.platform != 'win32' and sys.platform != 'cygwin':
+ _PATH_MAX = os.pathconf('.', _PC_PATH_MAX)
+else:
+ _PATH_MAX = 511
+
+# libusb-win32 makes all structures packed, while
+# default libusb only does for some structures
+# _PackPolicy defines the structure packing according
+# to the platform.
+class _PackPolicy(object):
+ pass
+
+if sys.platform == 'win32' or sys.platform == 'cygwin':
+ _PackPolicy._pack_ = 1
+
+# Data structures
+
+class _usb_descriptor_header(Structure):
+ _pack_ = 1
+ _fields_ = [('blength', c_uint8),
+ ('bDescriptorType', c_uint8)]
+
+class _usb_string_descriptor(Structure):
+ _pack_ = 1
+ _fields_ = [('bLength', c_uint8),
+ ('bDescriptorType', c_uint8),
+ ('wData', c_uint16)]
+
+class _usb_endpoint_descriptor(Structure, _PackPolicy):
+ _fields_ = [('bLength', c_uint8),
+ ('bDescriptorType', c_uint8),
+ ('bEndpointAddress', c_uint8),
+ ('bmAttributes', c_uint8),
+ ('wMaxPacketSize', c_uint16),
+ ('bInterval', c_uint8),
+ ('bRefresh', c_uint8),
+ ('bSynchAddress', c_uint8),
+ ('extra', POINTER(c_uint8)),
+ ('extralen', c_int)]
+
+class _usb_interface_descriptor(Structure, _PackPolicy):
+ _fields_ = [('bLength', c_uint8),
+ ('bDescriptorType', c_uint8),
+ ('bInterfaceNumber', c_uint8),
+ ('bAlternateSetting', c_uint8),
+ ('bNumEndpoints', c_uint8),
+ ('bInterfaceClass', c_uint8),
+ ('bInterfaceSubClass', c_uint8),
+ ('bInterfaceProtocol', c_uint8),
+ ('iInterface', c_uint8),
+ ('endpoint', POINTER(_usb_endpoint_descriptor)),
+ ('extra', POINTER(c_uint8)),
+ ('extralen', c_int)]
+
+class _usb_interface(Structure, _PackPolicy):
+ _fields_ = [('altsetting', POINTER(_usb_interface_descriptor)),
+ ('num_altsetting', c_int)]
+
+class _usb_config_descriptor(Structure, _PackPolicy):
+ _fields_ = [('bLength', c_uint8),
+ ('bDescriptorType', c_uint8),
+ ('wTotalLength', c_uint16),
+ ('bNumInterfaces', c_uint8),
+ ('bConfigurationValue', c_uint8),
+ ('iConfiguration', c_uint8),
+ ('bmAttributes', c_uint8),
+ ('bMaxPower', c_uint8),
+ ('interface', POINTER(_usb_interface)),
+ ('extra', POINTER(c_uint8)),
+ ('extralen', c_int)]
+
+class _usb_device_descriptor(Structure, _PackPolicy):
+ _pack_ = 1
+ _fields_ = [('bLength', c_uint8),
+ ('bDescriptorType', c_uint8),
+ ('bcdUSB', c_uint16),
+ ('bDeviceClass', c_uint8),
+ ('bDeviceSubClass', c_uint8),
+ ('bDeviceProtocol', c_uint8),
+ ('bMaxPacketSize0', c_uint8),
+ ('idVendor', c_uint16),
+ ('idProduct', c_uint16),
+ ('bcdDevice', c_uint16),
+ ('iManufacturer', c_uint8),
+ ('iProduct', c_uint8),
+ ('iSerialNumber', c_uint8),
+ ('bNumConfigurations', c_uint8)]
+
+class _usb_device(Structure, _PackPolicy):
+ pass
+
+class _usb_bus(Structure, _PackPolicy):
+ pass
+
+_usb_device._fields_ = [('next', POINTER(_usb_device)),
+ ('prev', POINTER(_usb_device)),
+ ('filename', c_int8 * (_PATH_MAX + 1)),
+ ('bus', POINTER(_usb_bus)),
+ ('descriptor', _usb_device_descriptor),
+ ('config', POINTER(_usb_config_descriptor)),
+ ('dev', c_void_p),
+ ('devnum', c_uint8),
+ ('num_children', c_ubyte),
+ ('children', POINTER(POINTER(_usb_device)))]
+
+_usb_bus._fields_ = [('next', POINTER(_usb_bus)),
+ ('prev', POINTER(_usb_bus)),
+ ('dirname', c_char * (_PATH_MAX + 1)),
+ ('devices', POINTER(_usb_device)),
+ ('location', c_uint32),
+ ('root_dev', POINTER(_usb_device))]
+
+_usb_dev_handle = c_void_p
+
+class _DeviceDescriptor:
+ def __init__(self, dev):
+ desc = dev.descriptor
+ self.bLength = desc.bLength
+ self.bDescriptorType = desc.bDescriptorType
+ self.bcdUSB = desc.bcdUSB
+ self.bDeviceClass = desc.bDeviceClass
+ self.bDeviceSubClass = desc.bDeviceSubClass
+ self.bDeviceProtocol = desc.bDeviceProtocol
+ self.bMaxPacketSize0 = desc.bMaxPacketSize0
+ self.idVendor = desc.idVendor
+ self.idProduct = desc.idProduct
+ self.bcdDevice = desc.bcdDevice
+ self.iManufacturer = desc.iManufacturer
+ self.iProduct = desc.iProduct
+ self.iSerialNumber = desc.iSerialNumber
+ self.bNumConfigurations = desc.bNumConfigurations
+ self.address = dev.devnum
+ self.bus = dev.bus[0].location
+
+_lib = None
+
+def _load_library():
+ if sys.platform != 'cygwin':
+ candidates = ('usb-0.1', 'usb', 'libusb0')
+ for candidate in candidates:
+ libname = ctypes.util.find_library(candidate)
+ if libname is not None: break
+ else:
+ # corner cases
+ # cygwin predefines library names with 'cyg' instead of 'lib'
+ try:
+ return CDLL('cygusb0.dll')
+ except:
+ _logger.error('Libusb 0 could not be loaded in cygwin', exc_info=True)
+
+ raise OSError('USB library could not be found')
+ return CDLL(libname)
+
+def _setup_prototypes(lib):
+ # usb_dev_handle *usb_open(struct usb_device *dev);
+ lib.usb_open.argtypes = [POINTER(_usb_device)]
+ lib.usb_open.restype = _usb_dev_handle
+
+ # int usb_close(usb_dev_handle *dev);
+ lib.usb_close.argtypes = [_usb_dev_handle]
+
+ # int usb_get_string(usb_dev_handle *dev,
+ # int index,
+ # int langid,
+ # char *buf,
+ # size_t buflen);
+ lib.usb_get_string.argtypes = [
+ _usb_dev_handle,
+ c_int,
+ c_int,
+ c_char_p,
+ c_size_t
+ ]
+
+ # int usb_get_string_simple(usb_dev_handle *dev,
+ # int index,
+ # char *buf,
+ # size_t buflen);
+ lib.usb_get_string_simple.argtypes = [
+ _usb_dev_handle,
+ c_int,
+ c_char_p,
+ c_size_t
+ ]
+
+ # int usb_get_descriptor_by_endpoint(usb_dev_handle *udev,
+ # int ep,
+ # unsigned char type,
+ # unsigned char index,
+ # void *buf,
+ # int size);
+ lib.usb_get_descriptor_by_endpoint.argtypes = [
+ _usb_dev_handle,
+ c_int,
+ c_ubyte,
+ c_ubyte,
+ c_void_p,
+ c_int
+ ]
+
+ # int usb_get_descriptor(usb_dev_handle *udev,
+ # unsigned char type,
+ # unsigned char index,
+ # void *buf,
+ # int size);
+ lib.usb_get_descriptor.argtypes = [
+ _usb_dev_handle,
+ c_ubyte,
+ c_ubyte,
+ c_void_p,
+ c_int
+ ]
+
+ # int usb_bulk_write(usb_dev_handle *dev,
+ # int ep,
+ # const char *bytes,
+ # int size,
+ # int timeout);
+ lib.usb_bulk_write.argtypes = [
+ _usb_dev_handle,
+ c_int,
+ c_char_p,
+ c_int,
+ c_int
+ ]
+
+ # int usb_bulk_read(usb_dev_handle *dev,
+ # int ep,
+ # char *bytes,
+ # int size,
+ # int timeout);
+ lib.usb_bulk_read.argtypes = [
+ _usb_dev_handle,
+ c_int,
+ c_char_p,
+ c_int,
+ c_int
+ ]
+
+ # int usb_interrupt_write(usb_dev_handle *dev,
+ # int ep,
+ # const char *bytes,
+ # int size,
+ # int timeout);
+ lib.usb_interrupt_write.argtypes = [
+ _usb_dev_handle,
+ c_int,
+ c_char_p,
+ c_int,
+ c_int
+ ]
+
+ # int usb_interrupt_read(usb_dev_handle *dev,
+ # int ep,
+ # char *bytes,
+ # int size,
+ # int timeout);
+ lib.usb_interrupt_read.argtypes = [
+ _usb_dev_handle,
+ c_int,
+ c_char_p,
+ c_int,
+ c_int
+ ]
+
+ # int usb_control_msg(usb_dev_handle *dev,
+ # int requesttype,
+ # int request,
+ # int value,
+ # int index,
+ # char *bytes,
+ # int size,
+ # int timeout);
+ lib.usb_control_msg.argtypes = [
+ _usb_dev_handle,
+ c_int,
+ c_int,
+ c_int,
+ c_int,
+ c_char_p,
+ c_int,
+ c_int
+ ]
+
+ # int usb_set_configuration(usb_dev_handle *dev, int configuration);
+ lib.usb_set_configuration.argtypes = [_usb_dev_handle, c_int]
+
+ # int usb_claim_interface(usb_dev_handle *dev, int interface);
+ lib.usb_claim_interface.argtypes = [_usb_dev_handle, c_int]
+
+ # int usb_release_interface(usb_dev_handle *dev, int interface);
+ lib.usb_release_interface.argtypes = [_usb_dev_handle, c_int]
+
+ # int usb_set_altinterface(usb_dev_handle *dev, int alternate);
+ lib.usb_set_altinterface.argtypes = [_usb_dev_handle, c_int]
+
+ # int usb_resetep(usb_dev_handle *dev, unsigned int ep);
+ lib.usb_resetep.argtypes = [_usb_dev_handle, c_int]
+
+ # int usb_clear_halt(usb_dev_handle *dev, unsigned int ep);
+ lib.usb_clear_halt.argtypes = [_usb_dev_handle, c_int]
+
+ # int usb_reset(usb_dev_handle *dev);
+ lib.usb_reset.argtypes = [_usb_dev_handle]
+
+ # char *usb_strerror(void);
+ lib.usb_strerror.argtypes = []
+ lib.usb_strerror.restype = c_char_p
+
+ # void usb_set_debug(int level);
+ lib.usb_set_debug.argtypes = [c_int]
+
+ # struct usb_device *usb_device(usb_dev_handle *dev);
+ lib.usb_device.argtypes = [_usb_dev_handle]
+ lib.usb_device.restype = POINTER(_usb_device)
+
+ # struct usb_bus *usb_get_busses(void);
+ lib.usb_get_busses.restype = POINTER(_usb_bus)
+
+def _check(retval):
+ if retval is None:
+ errmsg = _lib.usb_strerror()
+ else:
+ ret = int(retval)
+ if ret < 0:
+ errmsg = _lib.usb_strerror()
+ # No error means that we need to get the error
+ # message from the return code
+ # Thanks to Nicholas Wheeler to point out the problem...
+ # Also see issue #2860940
+ if errmsg.lower() == 'no error':
+ errmsg = os.strerror(-ret)
+ else:
+ return ret
+ raise USBError(errmsg, ret)
+
+# implementation of libusb 0.1.x backend
+class _LibUSB(usb.backend.IBackend):
+ @methodtrace(_logger)
+ def enumerate_devices(self):
+ _check(_lib.usb_find_busses())
+ _check(_lib.usb_find_devices())
+ bus = _lib.usb_get_busses()
+ while bool(bus):
+ dev = bus[0].devices
+ while bool(dev):
+ yield dev[0]
+ dev = dev[0].next
+ bus = bus[0].next
+
+ @methodtrace(_logger)
+ def get_device_descriptor(self, dev):
+ return _DeviceDescriptor(dev)
+
+ @methodtrace(_logger)
+ def get_configuration_descriptor(self, dev, config):
+ if config >= dev.descriptor.bNumConfigurations:
+ raise IndexError('Invalid configuration index ' + str(config))
+ return dev.config[config]
+
+ @methodtrace(_logger)
+ def get_interface_descriptor(self, dev, intf, alt, config):
+ cfgdesc = self.get_configuration_descriptor(dev, config)
+ if intf >= cfgdesc.bNumInterfaces:
+ raise IndexError('Invalid interface index ' + str(interface))
+ interface = cfgdesc.interface[intf]
+ if alt >= interface.num_altsetting:
+ raise IndexError('Invalid alternate setting index ' + str(alt))
+ return interface.altsetting[alt]
+
+ @methodtrace(_logger)
+ def get_endpoint_descriptor(self, dev, ep, intf, alt, config):
+ interface = self.get_interface_descriptor(dev, intf, alt, config)
+ if ep >= interface.bNumEndpoints:
+ raise IndexError('Invalid endpoint index ' + str(ep))
+ return interface.endpoint[ep]
+
+ @methodtrace(_logger)
+ def open_device(self, dev):
+ return _check(_lib.usb_open(dev))
+
+ @methodtrace(_logger)
+ def close_device(self, dev_handle):
+ _check(_lib.usb_close(dev_handle))
+
+ @methodtrace(_logger)
+ def set_configuration(self, dev_handle, config_value):
+ _check(_lib.usb_set_configuration(dev_handle, config_value))
+
+ @methodtrace(_logger)
+ def set_interface_altsetting(self, dev_handle, intf, altsetting):
+ _check(_lib.usb_set_altinterface(dev_handle, altsetting))
+
+ @methodtrace(_logger)
+ def get_configuration(self, dev_handle):
+ bmRequestType = usb.util.build_request_type(
+ usb.util.CTRL_IN,
+ usb.util.CTRL_TYPE_STANDARD,
+ usb.util.CTRL_RECIPIENT_DEVICE
+ )
+ return self.ctrl_transfer(dev_handle,
+ bmRequestType,
+ 0x08,
+ 0,
+ 0,
+ 1,
+ 100
+ )[0]
+
+
+ @methodtrace(_logger)
+ def claim_interface(self, dev_handle, intf):
+ _check(_lib.usb_claim_interface(dev_handle, intf))
+
+ @methodtrace(_logger)
+ def release_interface(self, dev_handle, intf):
+ _check(_lib.usb_release_interface(dev_handle, intf))
+
+ @methodtrace(_logger)
+ def bulk_write(self, dev_handle, ep, intf, data, timeout):
+ return self.__write(_lib.usb_bulk_write,
+ dev_handle,
+ ep,
+ intf,
+ data, timeout)
+
+ @methodtrace(_logger)
+ def bulk_read(self, dev_handle, ep, intf, size, timeout):
+ return self.__read(_lib.usb_bulk_read,
+ dev_handle,
+ ep,
+ intf,
+ size,
+ timeout)
+
+ @methodtrace(_logger)
+ def intr_write(self, dev_handle, ep, intf, data, timeout):
+ return self.__write(_lib.usb_interrupt_write,
+ dev_handle,
+ ep,
+ intf,
+ data,
+ timeout)
+
+ @methodtrace(_logger)
+ def intr_read(self, dev_handle, ep, intf, size, timeout):
+ return self.__read(_lib.usb_interrupt_read,
+ dev_handle,
+ ep,
+ intf,
+ size,
+ timeout)
+
+ @methodtrace(_logger)
+ def ctrl_transfer(self,
+ dev_handle,
+ bmRequestType,
+ bRequest,
+ wValue,
+ wIndex,
+ data_or_wLength,
+ timeout):
+ if usb.util.ctrl_direction(bmRequestType) == usb.util.CTRL_OUT:
+ address, length = data_or_wLength.buffer_info()
+ length *= data_or_wLength.itemsize
+ return _check(_lib.usb_control_msg(
+ dev_handle,
+ bmRequestType,
+ bRequest,
+ wValue,
+ wIndex,
+ cast(address, c_char_p),
+ length,
+ timeout
+ ))
+ else:
+ data = _interop.as_array((0,) * data_or_wLength)
+ read = int(_check(_lib.usb_control_msg(
+ dev_handle,
+ bmRequestType,
+ bRequest,
+ wValue,
+ wIndex,
+ cast(data.buffer_info()[0],
+ c_char_p),
+ data_or_wLength,
+ timeout
+ )))
+ return data[:read]
+
+ @methodtrace(_logger)
+ def reset_device(self, dev_handle):
+ _check(_lib.usb_reset(dev_handle))
+
+ @methodtrace(_logger)
+ def detach_kernel_driver(self, dev_handle, intf):
+ _check(_lib.usb_detach_kernel_driver_np(dev_handle, intf))
+
+ def __write(self, fn, dev_handle, ep, intf, data, timeout):
+ address, length = data.buffer_info()
+ length *= data.itemsize
+ return int(_check(fn(
+ dev_handle,
+ ep,
+ cast(address, c_char_p),
+ length,
+ timeout
+ )))
+
+ def __read(self, fn, dev_handle, ep, intf, size, timeout):
+ data = _interop.as_array((0,) * size)
+ address, length = data.buffer_info()
+ length *= data.itemsize
+ ret = int(_check(fn(
+ dev_handle,
+ ep,
+ cast(address, c_char_p),
+ length,
+ timeout
+ )))
+ return data[:ret]
+
+def get_backend():
+ global _lib
+ try:
+ if _lib is None:
+ _lib = _load_library()
+ _setup_prototypes(_lib)
+ _lib.usb_init()
+ return _LibUSB()
+ except Exception:
+ _logger.error('Error loading libusb 0.1 backend', exc_info=True)
+ return None
diff --git a/plugins/wedo_plugin/usb/backend/libusb10.py b/plugins/wedo_plugin/usb/backend/libusb10.py
new file mode 100644
index 0000000..cb2a566
--- /dev/null
+++ b/plugins/wedo_plugin/usb/backend/libusb10.py
@@ -0,0 +1,654 @@
+# Copyright (C) 2009-2011 Wander Lairson Costa
+#
+# The following terms apply to all files associated
+# with the software unless explicitly disclaimed in individual files.
+#
+# The authors hereby grant permission to use, copy, modify, distribute,
+# and license this software and its documentation for any purpose, provided
+# that existing copyright notices are retained in all copies and that this
+# notice is included verbatim in any distributions. No written agreement,
+# license, or royalty fee is required for any of the authorized uses.
+# Modifications to this software may be copyrighted by their authors
+# and need not follow the licensing terms described here, provided that
+# the new terms are clearly indicated on the first page of each file where
+# they apply.
+#
+# IN NO EVENT SHALL THE AUTHORS OR DISTRIBUTORS BE LIABLE TO ANY PARTY
+# FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
+# ARISING OUT OF THE USE OF THIS SOFTWARE, ITS DOCUMENTATION, OR ANY
+# DERIVATIVES THEREOF, EVEN IF THE AUTHORS HAVE BEEN ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+#
+# THE AUTHORS AND DISTRIBUTORS SPECIFICALLY DISCLAIM ANY WARRANTIES,
+# INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT. THIS SOFTWARE
+# IS PROVIDED ON AN "AS IS" BASIS, AND THE AUTHORS AND DISTRIBUTORS HAVE
+# NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR
+# MODIFICATIONS.
+
+from ctypes import *
+import ctypes.util
+import usb.util
+import sys
+import logging
+from usb._debug import methodtrace
+import usb._interop as _interop
+import errno
+
+__author__ = 'Wander Lairson Costa'
+
+__all__ = [
+ 'get_backend',
+ 'LIBUSB_SUCESS',
+ 'LIBUSB_ERROR_IO',
+ 'LIBUSB_ERROR_INVALID_PARAM',
+ 'LIBUSB_ERROR_ACCESS',
+ 'LIBUSB_ERROR_NO_DEVICE',
+ 'LIBUSB_ERROR_NOT_FOUND',
+ 'LIBUSB_ERROR_BUSY',
+ 'LIBUSB_ERROR_TIMEOUT',
+ 'LIBUSB_ERROR_OVERFLOW',
+ 'LIBUSB_ERROR_PIPE',
+ 'LIBUSB_ERROR_INTERRUPTED',
+ 'LIBUSB_ERROR_NO_MEM',
+ 'LIBUSB_ERROR_NOT_SUPPORTED',
+ 'LIBUSB_ERROR_OTHER'
+ ]
+
+_logger = logging.getLogger('usb.backend.libusb10')
+
+# libusb.h
+
+# return codes
+
+LIBUSB_SUCCESS = 0
+LIBUSB_ERROR_IO = -1
+LIBUSB_ERROR_INVALID_PARAM = -2
+LIBUSB_ERROR_ACCESS = -3
+LIBUSB_ERROR_NO_DEVICE = -4
+LIBUSB_ERROR_NOT_FOUND = -5
+LIBUSB_ERROR_BUSY = -6
+LIBUSB_ERROR_TIMEOUT = -7
+LIBUSB_ERROR_OVERFLOW = -8
+LIBUSB_ERROR_PIPE = -9
+LIBUSB_ERROR_INTERRUPTED = -10
+LIBUSB_ERROR_NO_MEM = -11
+LIBUSB_ERROR_NOT_SUPPORTED = -12
+LIBUSB_ERROR_OTHER = -99
+
+# map return codes to strings
+_str_error = {
+ LIBUSB_SUCCESS:'Success (no error)',
+ LIBUSB_ERROR_IO:'Input/output error',
+ LIBUSB_ERROR_INVALID_PARAM:'Invalid parameter',
+ LIBUSB_ERROR_ACCESS:'Access denied (insufficient permissions)',
+ LIBUSB_ERROR_NO_DEVICE:'No such device (it may have been disconnected)',
+ LIBUSB_ERROR_NOT_FOUND:'Entity not found',
+ LIBUSB_ERROR_BUSY:'Resource busy',
+ LIBUSB_ERROR_TIMEOUT:'Operation timed out',
+ LIBUSB_ERROR_OVERFLOW:'Overflow',
+ LIBUSB_ERROR_PIPE:'Pipe error',
+ LIBUSB_ERROR_INTERRUPTED:'System call interrupted (perhaps due to signal)',
+ LIBUSB_ERROR_NO_MEM:'Insufficient memory',
+ LIBUSB_ERROR_NOT_SUPPORTED:'Operation not supported or unimplemented on this platform',
+ LIBUSB_ERROR_OTHER:'Unknown error'
+}
+
+# map return code to errno values
+_libusb_errno = {
+ LIBUSB_SUCCESS:None,
+ LIBUSB_ERROR_IO:errno.__dict__.get('EIO', None),
+ LIBUSB_ERROR_INVALID_PARAM:errno.__dict__.get('EINVAL', None),
+ LIBUSB_ERROR_ACCESS:errno.__dict__.get('EACCES', None),
+ LIBUSB_ERROR_NO_DEVICE:errno.__dict__.get('ENODEV', None),
+ LIBUSB_ERROR_NOT_FOUND:errno.__dict__.get('ENOENT', None),
+ LIBUSB_ERROR_BUSY:errno.__dict__.get('EBUSY', None),
+ LIBUSB_ERROR_TIMEOUT:errno.__dict__.get('ETIMEDOUT', None),
+ LIBUSB_ERROR_OVERFLOW:errno.__dict__.get('EOVERFLOW', None),
+ LIBUSB_ERROR_PIPE:errno.__dict__.get('EPIPE', None),
+ LIBUSB_ERROR_INTERRUPTED:errno.__dict__.get('EINTR', None),
+ LIBUSB_ERROR_NO_MEM:errno.__dict__.get('ENOMEM', None),
+ LIBUSB_ERROR_NOT_SUPPORTED:errno.__dict__.get('ENOSYS', None),
+ LIBUSB_ERROR_OTHER:None
+}
+
+# Data structures
+
+class _libusb_endpoint_descriptor(Structure):
+ _fields_ = [('bLength', c_uint8),
+ ('bDescriptorType', c_uint8),
+ ('bEndpointAddress', c_uint8),
+ ('bmAttributes', c_uint8),
+ ('wMaxPacketSize', c_uint16),
+ ('bInterval', c_uint8),
+ ('bRefresh', c_uint8),
+ ('bSynchAddress', c_uint8),
+ ('extra', POINTER(c_ubyte)),
+ ('extra_length', c_int)]
+
+class _libusb_interface_descriptor(Structure):
+ _fields_ = [('bLength', c_uint8),
+ ('bDescriptorType', c_uint8),
+ ('bInterfaceNumber', c_uint8),
+ ('bAlternateSetting', c_uint8),
+ ('bNumEndpoints', c_uint8),
+ ('bInterfaceClass', c_uint8),
+ ('bInterfaceSubClass', c_uint8),
+ ('bInterfaceProtocol', c_uint8),
+ ('iInterface', c_uint8),
+ ('endpoint', POINTER(_libusb_endpoint_descriptor)),
+ ('extra', POINTER(c_ubyte)),
+ ('extra_length', c_int)]
+
+class _libusb_interface(Structure):
+ _fields_ = [('altsetting', POINTER(_libusb_interface_descriptor)),
+ ('num_altsetting', c_int)]
+
+class _libusb_config_descriptor(Structure):
+ _fields_ = [('bLength', c_uint8),
+ ('bDescriptorType', c_uint8),
+ ('wTotalLength', c_uint16),
+ ('bNumInterfaces', c_uint8),
+ ('bConfigurationValue', c_uint8),
+ ('iConfiguration', c_uint8),
+ ('bmAttributes', c_uint8),
+ ('bMaxPower', c_uint8),
+ ('interface', POINTER(_libusb_interface)),
+ ('extra', POINTER(c_ubyte)),
+ ('extra_length', c_int)]
+
+class _libusb_device_descriptor(Structure):
+ _fields_ = [('bLength', c_uint8),
+ ('bDescriptorType', c_uint8),
+ ('bcdUSB', c_uint16),
+ ('bDeviceClass', c_uint8),
+ ('bDeviceSubClass', c_uint8),
+ ('bDeviceProtocol', c_uint8),
+ ('bMaxPacketSize0', c_uint8),
+ ('idVendor', c_uint16),
+ ('idProduct', c_uint16),
+ ('bcdDevice', c_uint16),
+ ('iManufacturer', c_uint8),
+ ('iProduct', c_uint8),
+ ('iSerialNumber', c_uint8),
+ ('bNumConfigurations', c_uint8)]
+
+_lib = None
+_init = None
+
+_libusb_device_handle = c_void_p
+
+def _load_library():
+ if sys.platform != 'cygwin':
+ candidates = ('usb-1.0', 'libusb-1.0', 'usb')
+ for candidate in candidates:
+ libname = ctypes.util.find_library(candidate)
+ if libname is not None: break
+ else:
+ # corner cases
+ # cygwin predefines library names with 'cyg' instead of 'lib'
+ try:
+ return CDLL('cygusb-1.0.dll')
+ except Exception:
+ _logger.error('Libusb 1.0 could not be loaded in cygwin', exc_info=True)
+
+ raise OSError('USB library could not be found')
+ # Windows backend uses stdcall calling convention
+ if sys.platform == 'win32':
+ l = WinDLL(libname)
+ else:
+ l = CDLL(libname)
+ # On FreeBSD 8/9, libusb 1.0 and libusb 0.1 are in the same shared
+ # object libusb.so, so if we found libusb library name, we must assure
+ # it is 1.0 version. We just try to get some symbol from 1.0 version
+ if not hasattr(l, 'libusb_init'):
+ raise OSError('USB library could not be found')
+ return l
+
+def _setup_prototypes(lib):
+ # void libusb_set_debug (libusb_context *ctx, int level)
+ lib.libusb_set_debug.argtypes = [c_void_p, c_int]
+
+ # int libusb_init (libusb_context **context)
+ lib.libusb_init.argtypes = [POINTER(c_void_p)]
+
+ # void libusb_exit (struct libusb_context *ctx)
+ lib.libusb_exit.argtypes = [c_void_p]
+
+ # ssize_t libusb_get_device_list (libusb_context *ctx,
+ # libusb_device ***list)
+ lib.libusb_get_device_list.argtypes = [
+ c_void_p,
+ POINTER(POINTER(c_void_p))
+ ]
+
+ # void libusb_free_device_list (libusb_device **list,
+ # int unref_devices)
+ lib.libusb_free_device_list.argtypes = [
+ POINTER(c_void_p),
+ c_int
+ ]
+
+ # libusb_device *libusb_ref_device (libusb_device *dev)
+ lib.libusb_ref_device.argtypes = [c_void_p]
+ lib.libusb_ref_device.restype = c_void_p
+
+ # void libusb_unref_device(libusb_device *dev)
+ lib.libusb_unref_device.argtypes = [c_void_p]
+
+ # int libusb_open(libusb_device *dev, libusb_device_handle **handle)
+ lib.libusb_open.argtypes = [c_void_p, POINTER(_libusb_device_handle)]
+
+ # void libusb_close(libusb_device_handle *dev_handle)
+ lib.libusb_close.argtypes = [_libusb_device_handle]
+
+ # int libusb_set_configuration(libusb_device_handle *dev,
+ # int configuration)
+ lib.libusb_set_configuration.argtypes = [_libusb_device_handle, c_int]
+
+ # int libusb_get_configuration(libusb_device_handle *dev,
+ # int *config)
+ lib.libusb_get_configuration.argtypes = [_libusb_device_handle, POINTER(c_int)]
+
+ # int libusb_claim_interface(libusb_device_handle *dev,
+ # int interface_number)
+ lib.libusb_claim_interface.argtypes = [_libusb_device_handle, c_int]
+
+ # int libusb_release_interface(libusb_device_handle *dev,
+ # int interface_number)
+ lib.libusb_release_interface.argtypes = [_libusb_device_handle, c_int]
+
+ # int libusb_set_interface_alt_setting(libusb_device_handle *dev,
+ # int interface_number,
+ # int alternate_setting)
+ lib.libusb_set_interface_alt_setting.argtypes = [
+ _libusb_device_handle,
+ c_int,
+ c_int
+ ]
+
+ # int libusb_reset_device (libusb_device_handle *dev)
+ lib.libusb_reset_device.argtypes = [_libusb_device_handle]
+
+ # int libusb_kernel_driver_active(libusb_device_handle *dev,
+ # int interface)
+ lib.libusb_kernel_driver_active.argtypes = [
+ _libusb_device_handle,
+ c_int
+ ]
+
+ # int libusb_detach_kernel_driver(libusb_device_handle *dev,
+ # int interface)
+ lib.libusb_detach_kernel_driver.argtypes = [
+ _libusb_device_handle,
+ c_int
+ ]
+
+ # int libusb_attach_kernel_driver(libusb_device_handle *dev,
+ # int interface)
+ lib.libusb_attach_kernel_driver.argtypes = [
+ _libusb_device_handle,
+ c_int
+ ]
+
+ # int libusb_get_device_descriptor(
+ # libusb_device *dev,
+ # struct libusb_device_descriptor *desc
+ # )
+ lib.libusb_get_device_descriptor.argtypes = [
+ c_void_p,
+ POINTER(_libusb_device_descriptor)
+ ]
+
+ # int libusb_get_config_descriptor(
+ # libusb_device *dev,
+ # uint8_t config_index,
+ # struct libusb_config_descriptor **config
+ # )
+ lib.libusb_get_config_descriptor.argtypes = [
+ c_void_p,
+ c_uint8,
+ POINTER(POINTER(_libusb_config_descriptor))
+ ]
+
+ # void libusb_free_config_descriptor(
+ # struct libusb_config_descriptor *config
+ # )
+ lib.libusb_free_config_descriptor.argtypes = [
+ POINTER(_libusb_config_descriptor)
+ ]
+
+ # int libusb_get_string_descriptor_ascii(libusb_device_handle *dev,
+ # uint8_t desc_index,
+ # unsigned char *data,
+ # int length)
+ lib.libusb_get_string_descriptor_ascii.argtypes = [
+ _libusb_device_handle,
+ c_uint8,
+ POINTER(c_ubyte),
+ c_int
+ ]
+
+ # int libusb_control_transfer(libusb_device_handle *dev_handle,
+ # uint8_t bmRequestType,
+ # uint8_t bRequest,
+ # uint16_t wValue,
+ # uint16_t wIndex,
+ # unsigned char *data,
+ # uint16_t wLength,
+ # unsigned int timeout)
+ lib.libusb_control_transfer.argtypes = [
+ _libusb_device_handle,
+ c_uint8,
+ c_uint8,
+ c_uint16,
+ c_uint16,
+ POINTER(c_ubyte),
+ c_uint16,
+ c_uint
+ ]
+
+ #int libusb_bulk_transfer(
+ # struct libusb_device_handle *dev_handle,
+ # unsigned char endpoint,
+ # unsigned char *data,
+ # int length,
+ # int *transferred,
+ # unsigned int timeout
+ # )
+ lib.libusb_bulk_transfer.argtypes = [
+ _libusb_device_handle,
+ c_ubyte,
+ POINTER(c_ubyte),
+ c_int,
+ POINTER(c_int),
+ c_uint
+ ]
+
+ # int libusb_interrupt_transfer(
+ # libusb_device_handle *dev_handle,
+ # unsigned char endpoint,
+ # unsigned char *data,
+ # int length,
+ # int *actual_length,
+ # unsigned int timeout
+ # );
+ lib.libusb_interrupt_transfer.argtypes = [
+ _libusb_device_handle,
+ c_ubyte,
+ POINTER(c_ubyte),
+ c_int,
+ POINTER(c_int),
+ c_uint
+ ]
+
+ # uint8_t libusb_get_bus_number(libusb_device *dev)
+ lib.libusb_get_bus_number.argtypes = [c_void_p]
+ lib.libusb_get_bus_number.restype = c_uint8
+
+ # uint8_t libusb_get_device_address(libusb_device *dev)
+ lib.libusb_get_device_address.argtypes = [c_void_p]
+ lib.libusb_get_device_address.restype = c_uint8
+
+
+
+# check a libusb function call
+def _check(retval):
+ if isinstance(retval, int):
+ retval = c_int(retval)
+ if isinstance(retval, c_int):
+ if retval.value < 0:
+ from usb.core import USBError
+ ret = retval.value
+ raise USBError(_str_error[ret], ret, _libusb_errno[ret])
+ return retval
+
+# wrap a device
+class _Device(object):
+ def __init__(self, devid):
+ self.devid = _lib.libusb_ref_device(devid)
+ def __del__(self):
+ _lib.libusb_unref_device(self.devid)
+
+# wrap a descriptor and keep a reference to another object
+# Thanks to Thomas Reitmayr.
+class _WrapDescriptor(object):
+ def __init__(self, desc, obj = None):
+ self.obj = obj
+ self.desc = desc
+ def __getattr__(self, name):
+ return getattr(self.desc, name)
+
+# wrap a configuration descriptor
+class _ConfigDescriptor(object):
+ def __init__(self, desc):
+ self.desc = desc
+ def __del__(self):
+ _lib.libusb_free_config_descriptor(self.desc)
+ def __getattr__(self, name):
+ return getattr(self.desc.contents, name)
+
+# initialize and finalize the library
+class _Initializer(object):
+ def __init__(self):
+ _check(_lib.libusb_init(None))
+ def __del__(self):
+ _lib.libusb_exit(None)
+
+
+# iterator for libusb devices
+class _DevIterator(object):
+ def __init__(self):
+ self.dev_list = POINTER(c_void_p)()
+ self.num_devs = _check(_lib.libusb_get_device_list(
+ None,
+ byref(self.dev_list))
+ ).value
+ def __iter__(self):
+ for i in range(self.num_devs):
+ yield _Device(self.dev_list[i])
+ def __del__(self):
+ _lib.libusb_free_device_list(self.dev_list, 1)
+
+# implementation of libusb 1.0 backend
+class _LibUSB(usb.backend.IBackend):
+ @methodtrace(_logger)
+ def enumerate_devices(self):
+ return _DevIterator()
+
+ @methodtrace(_logger)
+ def get_device_descriptor(self, dev):
+ dev_desc = _libusb_device_descriptor()
+ _check(_lib.libusb_get_device_descriptor(dev.devid, byref(dev_desc)))
+ dev_desc.bus = _lib.libusb_get_bus_number(dev.devid)
+ dev_desc.address = _lib.libusb_get_device_address(dev.devid)
+ return dev_desc
+
+ @methodtrace(_logger)
+ def get_configuration_descriptor(self, dev, config):
+ cfg = POINTER(_libusb_config_descriptor)()
+ _check(_lib.libusb_get_config_descriptor(dev.devid,
+ config, byref(cfg)))
+ return _ConfigDescriptor(cfg)
+
+ @methodtrace(_logger)
+ def get_interface_descriptor(self, dev, intf, alt, config):
+ cfg = self.get_configuration_descriptor(dev, config)
+ if intf >= cfg.bNumInterfaces:
+ raise IndexError('Invalid interface index ' + str(intf))
+ i = cfg.interface[intf]
+ if alt >= i.num_altsetting:
+ raise IndexError('Invalid alternate setting index ' + str(alt))
+ return _WrapDescriptor(i.altsetting[alt], cfg)
+
+ @methodtrace(_logger)
+ def get_endpoint_descriptor(self, dev, ep, intf, alt, config):
+ i = self.get_interface_descriptor(dev, intf, alt, config)
+ if ep > i.bNumEndpoints:
+ raise IndexError('Invalid endpoint index ' + str(ep))
+ return _WrapDescriptor(i.endpoint[ep], i)
+
+ @methodtrace(_logger)
+ def open_device(self, dev):
+ handle = _libusb_device_handle()
+ _check(_lib.libusb_open(dev.devid, byref(handle)))
+ return handle
+
+ @methodtrace(_logger)
+ def close_device(self, dev_handle):
+ _lib.libusb_close(dev_handle)
+
+ @methodtrace(_logger)
+ def set_configuration(self, dev_handle, config_value):
+ _check(_lib.libusb_set_configuration(dev_handle, config_value))
+
+ @methodtrace(_logger)
+ def get_configuration(self, dev_handle):
+ config = c_int()
+ _check(_lib.libusb_get_configuration(dev_handle, byref(config)))
+ return config.value
+
+ @methodtrace(_logger)
+ def set_interface_altsetting(self, dev_handle, intf, altsetting):
+ _check(_lib.libusb_set_interface_alt_setting(dev_handle,
+ intf,
+ altsetting))
+
+ @methodtrace(_logger)
+ def claim_interface(self, dev_handle, intf):
+ _check(_lib.libusb_claim_interface(dev_handle, intf))
+
+ @methodtrace(_logger)
+ def release_interface(self, dev_handle, intf):
+ _check(_lib.libusb_release_interface(dev_handle, intf))
+
+ @methodtrace(_logger)
+ def bulk_write(self, dev_handle, ep, intf, data, timeout):
+ return self.__write(_lib.libusb_bulk_transfer,
+ dev_handle,
+ ep,
+ intf,
+ data,
+ timeout)
+
+ @methodtrace(_logger)
+ def bulk_read(self, dev_handle, ep, intf, size, timeout):
+ return self.__read(_lib.libusb_bulk_transfer,
+ dev_handle,
+ ep,
+ intf,
+ size,
+ timeout)
+
+ @methodtrace(_logger)
+ def intr_write(self, dev_handle, ep, intf, data, timeout):
+ return self.__write(_lib.libusb_interrupt_transfer,
+ dev_handle,
+ ep,
+ intf,
+ data,
+ timeout)
+
+ @methodtrace(_logger)
+ def intr_read(self, dev_handle, ep, intf, size, timeout):
+ return self.__read(_lib.libusb_interrupt_transfer,
+ dev_handle,
+ ep,
+ intf,
+ size,
+ timeout)
+
+# TODO: implement isochronous
+# @methodtrace(_logger)
+# def iso_write(self, dev_handle, ep, intf, data, timeout):
+# pass
+
+
+# @methodtrace(_logger)
+# def iso_read(self, dev_handle, ep, intf, size, timeout):
+# pass
+
+ @methodtrace(_logger)
+ def ctrl_transfer(self,
+ dev_handle,
+ bmRequestType,
+ bRequest,
+ wValue,
+ wIndex,
+ data_or_wLength,
+ timeout):
+ if usb.util.ctrl_direction(bmRequestType) == usb.util.CTRL_OUT:
+ buff = data_or_wLength
+ else:
+ buff = _interop.as_array((0,) * data_or_wLength)
+
+ addr, length = buff.buffer_info()
+ length *= buff.itemsize
+
+ ret = _check(_lib.libusb_control_transfer(dev_handle,
+ bmRequestType,
+ bRequest,
+ wValue,
+ wIndex,
+ cast(addr,
+ POINTER(c_ubyte)),
+ length,
+ timeout))
+
+ if usb.util.ctrl_direction(bmRequestType) == usb.util.CTRL_OUT:
+ return ret.value
+ else:
+ return buff[:ret.value]
+
+ @methodtrace(_logger)
+ def reset_device(self, dev_handle):
+ _check(_lib.libusb_reset_device(dev_handle))
+
+ @methodtrace(_logger)
+ def is_kernel_driver_active(self, dev_handle, intf):
+ return bool(_check(_lib.libusb_kernel_driver_active(dev_handle, intf)))
+
+ @methodtrace(_logger)
+ def detach_kernel_driver(self, dev_handle, intf):
+ _check(_lib.libusb_detach_kernel_driver(dev_handle, intf))
+
+ @methodtrace(_logger)
+ def attach_kernel_driver(self, dev_handle, intf):
+ _check(_lib.libusb_attach_kernel_driver(dev_handle, intf))
+
+ def __write(self, fn, dev_handle, ep, intf, data, timeout):
+ address, length = data.buffer_info()
+ length *= data.itemsize
+ transferred = c_int()
+ _check(fn(dev_handle,
+ ep,
+ cast(address, POINTER(c_ubyte)),
+ length,
+ byref(transferred),
+ timeout))
+ return transferred.value
+
+ def __read(self, fn, dev_handle, ep, intf, size, timeout):
+ data = _interop.as_array((0,) * size)
+ address, length = data.buffer_info()
+ length *= data.itemsize
+ transferred = c_int()
+ _check(fn(dev_handle,
+ ep,
+ cast(address, POINTER(c_ubyte)),
+ length,
+ byref(transferred),
+ timeout))
+ return data[:transferred.value]
+
+def get_backend():
+ global _lib, _init
+ try:
+ if _lib is None:
+ _lib = _load_library()
+ _setup_prototypes(_lib)
+ _init = _Initializer()
+ return _LibUSB()
+ except Exception:
+ _logger.error('Error loading libusb 1.0 backend', exc_info=True)
+ return None
diff --git a/plugins/wedo_plugin/usb/backend/openusb.py b/plugins/wedo_plugin/usb/backend/openusb.py
new file mode 100644
index 0000000..23e4d45
--- /dev/null
+++ b/plugins/wedo_plugin/usb/backend/openusb.py
@@ -0,0 +1,707 @@
+# Copyright (C) 2009-2011 Wander Lairson Costa
+#
+# The following terms apply to all files associated
+# with the software unless explicitly disclaimed in individual files.
+#
+# The authors hereby grant permission to use, copy, modify, distribute,
+# and license this software and its documentation for any purpose, provided
+# that existing copyright notices are retained in all copies and that this
+# notice is included verbatim in any distributions. No written agreement,
+# license, or royalty fee is required for any of the authorized uses.
+# Modifications to this software may be copyrighted by their authors
+# and need not follow the licensing terms described here, provided that
+# the new terms are clearly indicated on the first page of each file where
+# they apply.
+#
+# IN NO EVENT SHALL THE AUTHORS OR DISTRIBUTORS BE LIABLE TO ANY PARTY
+# FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
+# ARISING OUT OF THE USE OF THIS SOFTWARE, ITS DOCUMENTATION, OR ANY
+# DERIVATIVES THEREOF, EVEN IF THE AUTHORS HAVE BEEN ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+#
+# THE AUTHORS AND DISTRIBUTORS SPECIFICALLY DISCLAIM ANY WARRANTIES,
+# INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT. THIS SOFTWARE
+# IS PROVIDED ON AN "AS IS" BASIS, AND THE AUTHORS AND DISTRIBUTORS HAVE
+# NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR
+# MODIFICATIONS.
+
+from ctypes import *
+import ctypes.util
+import usb.util
+from usb._debug import methodtrace
+import logging
+import errno
+
+__author__ = 'Wander Lairson Costa'
+
+__all__ = [
+ 'get_backend'
+ 'OPENUSB_SUCCESS'
+ 'OPENUSB_PLATFORM_FAILURE'
+ 'OPENUSB_NO_RESOURCES'
+ 'OPENUSB_NO_BANDWIDTH'
+ 'OPENUSB_NOT_SUPPORTED'
+ 'OPENUSB_HC_HARDWARE_ERROR'
+ 'OPENUSB_INVALID_PERM'
+ 'OPENUSB_BUSY'
+ 'OPENUSB_BADARG'
+ 'OPENUSB_NOACCESS'
+ 'OPENUSB_PARSE_ERROR'
+ 'OPENUSB_UNKNOWN_DEVICE'
+ 'OPENUSB_INVALID_HANDLE'
+ 'OPENUSB_SYS_FUNC_FAILURE'
+ 'OPENUSB_NULL_LIST'
+ 'OPENUSB_CB_CONTINUE'
+ 'OPENUSB_CB_TERMINATE'
+ 'OPENUSB_IO_STALL'
+ 'OPENUSB_IO_CRC_ERROR'
+ 'OPENUSB_IO_DEVICE_HUNG'
+ 'OPENUSB_IO_REQ_TOO_BIG'
+ 'OPENUSB_IO_BIT_STUFFING'
+ 'OPENUSB_IO_UNEXPECTED_PID'
+ 'OPENUSB_IO_DATA_OVERRUN'
+ 'OPENUSB_IO_DATA_UNDERRUN'
+ 'OPENUSB_IO_BUFFER_OVERRUN'
+ 'OPENUSB_IO_BUFFER_UNDERRUN'
+ 'OPENUSB_IO_PID_CHECK_FAILURE'
+ 'OPENUSB_IO_DATA_TOGGLE_MISMATCH'
+ 'OPENUSB_IO_TIMEOUT'
+ 'OPENUSB_IO_CANCELED'
+ ]
+
+_logger = logging.getLogger('usb.backend.openusb')
+
+OPENUSB_SUCCESS = 0
+OPENUSB_PLATFORM_FAILURE = -1
+OPENUSB_NO_RESOURCES = -2
+OPENUSB_NO_BANDWIDTH = -3
+OPENUSB_NOT_SUPPORTED = -4
+OPENUSB_HC_HARDWARE_ERROR = -5
+OPENUSB_INVALID_PERM = -6
+OPENUSB_BUSY = -7
+OPENUSB_BADARG = -8
+OPENUSB_NOACCESS = -9
+OPENUSB_PARSE_ERROR = -10
+OPENUSB_UNKNOWN_DEVICE = -11
+OPENUSB_INVALID_HANDLE = -12
+OPENUSB_SYS_FUNC_FAILURE = -13
+OPENUSB_NULL_LIST = -14
+OPENUSB_CB_CONTINUE = -20
+OPENUSB_CB_TERMINATE = -21
+OPENUSB_IO_STALL = -50
+OPENUSB_IO_CRC_ERROR = -51
+OPENUSB_IO_DEVICE_HUNG = -52
+OPENUSB_IO_REQ_TOO_BIG = -53
+OPENUSB_IO_BIT_STUFFING = -54
+OPENUSB_IO_UNEXPECTED_PID = -55
+OPENUSB_IO_DATA_OVERRUN = -56
+OPENUSB_IO_DATA_UNDERRUN = -57
+OPENUSB_IO_BUFFER_OVERRUN = -58
+OPENUSB_IO_BUFFER_UNDERRUN = -59
+OPENUSB_IO_PID_CHECK_FAILURE = -60
+OPENUSB_IO_DATA_TOGGLE_MISMATCH = -61
+OPENUSB_IO_TIMEOUT = -62
+OPENUSB_IO_CANCELED = -63
+
+_openusb_errno = {
+ OPENUSB_SUCCESS:None,
+ OPENUSB_PLATFORM_FAILURE:None,
+ OPENUSB_NO_RESOURCES:errno.__dict__.get('ENOMEM', None),
+ OPENUSB_NO_BANDWIDTH:None,
+ OPENUSB_NOT_SUPPORTED:errno.__dict__.get('ENOSYS', None),
+ OPENUSB_HC_HARDWARE_ERROR:errno.__dict__.get('EIO', None),
+ OPENUSB_INVALID_PERM:errno.__dict__.get('EBADF', None),
+ OPENUSB_BUSY:errno.__dict__.get('EBUSY', None),
+ OPENUSB_BADARG:errno.__dict__.get('EINVAL', None),
+ OPENUSB_NOACCESS:errno.__dict__.get('EACCES', None),
+ OPENUSB_PARSE_ERROR:None,
+ OPENUSB_UNKNOWN_DEVICE:errno.__dict__.get('ENODEV', None),
+ OPENUSB_INVALID_HANDLE:errno.__dict__.get('EINVAL', None),
+ OPENUSB_SYS_FUNC_FAILURE:None,
+ OPENUSB_NULL_LIST:None,
+ OPENUSB_CB_CONTINUE:None,
+ OPENUSB_CB_TERMINATE:None,
+ OPENUSB_IO_STALL:errno.__dict__.get('EIO', None),
+ OPENUSB_IO_CRC_ERROR:errno.__dict__.get('EIO', None),
+ OPENUSB_IO_DEVICE_HUNG:errno.__dict__.get('EIO', None),
+ OPENUSB_IO_REQ_TOO_BIG:errno.__dict__.get('E2BIG', None),
+ OPENUSB_IO_BIT_STUFFING:None,
+ OPENUSB_IO_UNEXPECTED_PID:errno.__dict__.get('ESRCH', None),
+ OPENUSB_IO_DATA_OVERRUN:errno.__dict__.get('EOVERFLOW', None),
+ OPENUSB_IO_DATA_UNDERRUN:None,
+ OPENUSB_IO_BUFFER_OVERRUN:errno.__dict__.get('EOVERFLOW', None),
+ OPENUSB_IO_BUFFER_UNDERRUN:None,
+ OPENUSB_IO_PID_CHECK_FAILURE:None,
+ OPENUSB_IO_DATA_TOGGLE_MISMATCH:None,
+ OPENUSB_IO_TIMEOUT:errno.__dict__.get('ETIMEDOUT', None),
+ OPENUSB_IO_CANCELED:errno.__dict__.get('EINTR', None)
+}
+
+class _usb_endpoint_desc(Structure):
+ _fields_ = [('bLength', c_uint8),
+ ('bDescriptorType', c_uint8),
+ ('bEndpointAddress', c_uint8),
+ ('bmAttributes', c_uint8),
+ ('wMaxPacketSize', c_uint16),
+ ('bInterval', c_uint8),
+ ('bRefresh', c_uint8),
+ ('bSynchAddress', c_uint8)]
+
+class _usb_interface_desc(Structure):
+ _fields_ = [('bLength', c_uint8),
+ ('bDescriptorType', c_uint8),
+ ('bInterfaceNumber', c_uint8),
+ ('bAlternateSetting', c_uint8),
+ ('bNumEndpoints', c_uint8),
+ ('bInterfaceClass', c_uint8),
+ ('bInterfaceSubClass', c_uint8),
+ ('bInterfaceProtocol', c_uint8),
+ ('iInterface', c_uint8)]
+
+class _usb_config_desc(Structure):
+ _fields_ = [('bLength', c_uint8),
+ ('bDescriptorType', c_uint8),
+ ('wTotalLength', c_uint16),
+ ('bNumInterfaces', c_uint8),
+ ('bConfigurationValue', c_uint8),
+ ('iConfiguration', c_uint8),
+ ('bmAttributes', c_uint8),
+ ('bMaxPower', c_uint8)]
+
+class _usb_device_desc(Structure):
+ _fields_ = [('bLength', c_uint8),
+ ('bDescriptorType', c_uint8),
+ ('bcdUSB', c_uint16),
+ ('bDeviceClass', c_uint8),
+ ('bDeviceSubClass', c_uint8),
+ ('bDeviceProtocol', c_uint8),
+ ('bMaxPacketSize0', c_uint8),
+ ('idVendor', c_uint16),
+ ('idProduct', c_uint16),
+ ('bcdDevice', c_uint16),
+ ('iManufacturer', c_uint8),
+ ('iProduct', c_uint8),
+ ('iSerialNumber', c_uint8),
+ ('bNumConfigurations', c_uint8)]
+
+class _openusb_request_result(Structure):
+ _fields_ = [('status', c_int32),
+ ('transfered_bytes', c_uint32)]
+
+class _openusb_ctrl_request(Structure):
+ class _openusb_ctrl_setup(Structure):
+ _fields_ = [('bmRequestType', c_uint8),
+ ('bRequest', c_uint8),
+ ('wValue', c_uint16),
+ ('wIndex', c_uint16)]
+ _fields_ = [('payload', POINTER(c_uint8)),
+ ('length', c_uint32),
+ ('timeout', c_uint32),
+ ('flags', c_uint32),
+ ('result', _openusb_request_result),
+ ('next', c_void_p)]
+
+class _openusb_intr_request(Structure):
+ _fields_ = [('interval', c_uint16),
+ ('payload', POINTER(c_uint8)),
+ ('length', c_uint32),
+ ('timeout', c_uint32),
+ ('flags', c_uint32),
+ ('result', _openusb_request_result),
+ ('next', c_void_p)]
+
+class _openusb_bulk_request(Structure):
+ _fields_ = [('payload', POINTER(c_uint8)),
+ ('length', c_uint32),
+ ('timeout', c_uint32),
+ ('flags', c_uint32),
+ ('result', _openusb_request_result),
+ ('next', c_void_p)]
+
+class _openusb_isoc_pkts(Structure):
+ class _openusb_isoc_packet(Structure):
+ _fields_ = [('payload', POINTER(c_uint8)),
+ ('length', c_uint32)]
+ _fields_ = [('num_packets', c_uint32),
+ ('packets', POINTER(_openusb_isoc_packet))]
+
+class _openusb_isoc_request(Structure):
+ _fields_ = [('start_frame', c_uint32),
+ ('flags', c_uint32),
+ ('pkts', _openusb_isoc_pkts),
+ ('isoc_results', POINTER(_openusb_request_result)),
+ ('isoc_status', c_int32),
+ ('next', c_void_p)]
+
+_openusb_devid = c_uint64
+_openusb_busid = c_uint64
+_openusb_handle = c_uint64
+_openusb_dev_handle = c_uint64
+
+_lib = None
+_ctx = None
+
+def _load_library():
+ libname = ctypes.util.find_library('openusb')
+ if libname is None:
+ raise OSError('USB library could not be found')
+ return CDLL(libname)
+
+def _setup_prototypes(lib):
+ # int32_t openusb_init(uint32_t flags , openusb_handle_t *handle);
+ lib.openusb_init.argtypes = [c_uint32, POINTER(_openusb_handle)]
+ lib.openusb_init.restype = c_int32
+
+ # void openusb_fini(openusb_handle_t handle );
+ lib.openusb_fini.argtypes = [_openusb_handle]
+
+ # uint32_t openusb_get_busid_list(openusb_handle_t handle,
+ # openusb_busid_t **busids,
+ # uint32_t *num_busids);
+ lib.openusb_get_busid_list.argtypes = [
+ _openusb_handle,
+ POINTER(POINTER(_openusb_busid)),
+ POINTER(c_uint32)
+ ]
+
+ # void openusb_free_busid_list(openusb_busid_t * busids);
+ lib.openusb_free_busid_list.argtypes = [POINTER(_openusb_busid)]
+
+ # uint32_t openusb_get_devids_by_bus(openusb_handle_t handle,
+ # openusb_busid_t busid,
+ # openusb_devid_t **devids,
+ # uint32_t *num_devids);
+ lib.openusb_get_devids_by_bus.argtypes = [
+ _openusb_handle,
+ _openusb_busid,
+ POINTER(POINTER(_openusb_devid)),
+ POINTER(c_uint32)
+ ]
+
+ lib.openusb_get_devids_by_bus.restype = c_int32
+
+ # void openusb_free_devid_list(openusb_devid_t * devids);
+ lib.openusb_free_devid_list.argtypes = [POINTER(_openusb_devid)]
+
+ # int32_t openusb_open_device(openusb_handle_t handle,
+ # openusb_devid_t devid ,
+ # uint32_t flags,
+ # openusb_dev_handle_t *dev);
+ lib.openusb_open_device.argtypes = [
+ _openusb_handle,
+ _openusb_devid,
+ c_uint32,
+ POINTER(_openusb_dev_handle)
+ ]
+
+ lib.openusb_open_device.restype = c_int32
+
+ # int32_t openusb_close_device(openusb_dev_handle_t dev);
+ lib.openusb_close_device.argtypes = [_openusb_dev_handle]
+ lib.openusb_close_device.restype = c_int32
+
+ # int32_t openusb_set_configuration(openusb_dev_handle_t dev,
+ # uint8_t cfg);
+ lib.openusb_set_configuration.argtypes = [_openusb_dev_handle, c_uint8]
+ lib.openusb_set_configuration.restype = c_int32
+
+ # int32_t openusb_get_configuration(openusb_dev_handle_t dev,
+ # uint8_t *cfg);
+ lib.openusb_get_configuration.argtypes = [_openusb_dev_handle, POINTER(c_uint8)]
+ lib.openusb_get_configuration.restype = c_int32
+
+ # int32_t openusb_claim_interface(openusb_dev_handle_t dev,
+ # uint8_t ifc,
+ # openusb_init_flag_t flags);
+ lib.openusb_claim_interface.argtypes = [
+ _openusb_dev_handle,
+ c_uint8,
+ c_int
+ ]
+
+ lib.openusb_claim_interface.restype = c_int32
+
+ # int32_t openusb_release_interface(openusb_dev_handle_t dev,
+ # uint8_t ifc);
+ lib.openusb_release_interface.argtypes = [
+ _openusb_dev_handle,
+ c_uint8
+ ]
+
+ lib.openusb_release_interface.restype = c_int32
+
+ # int32_topenusb_set_altsetting(openusb_dev_handle_t dev,
+ # uint8_t ifc,
+ # uint8_t alt);
+ lib.openusb_set_altsetting.argtypes = [
+ _openusb_dev_handle,
+ c_uint8,
+ c_uint8
+ ]
+ lib.openusb_set_altsetting.restype = c_int32
+
+ # int32_t openusb_reset(openusb_dev_handle_t dev);
+ lib.openusb_reset.argtypes = [_openusb_dev_handle]
+ lib.openusb_reset.restype = c_int32
+
+ # int32_t openusb_parse_device_desc(openusb_handle_t handle,
+ # openusb_devid_t devid,
+ # uint8_t *buffer,
+ # uint16_t buflen,
+ # usb_device_desc_t *devdesc);
+ lib.openusb_parse_device_desc.argtypes = [
+ _openusb_handle,
+ _openusb_devid,
+ POINTER(c_uint8),
+ c_uint16,
+ POINTER(_usb_device_desc)
+ ]
+
+ lib.openusb_parse_device_desc.restype = c_int32
+
+ # int32_t openusb_parse_config_desc(openusb_handle_t handle,
+ # openusb_devid_t devid,
+ # uint8_t *buffer,
+ # uint16_t buflen,
+ # uint8_t cfgidx,
+ # usb_config_desc_t *cfgdesc);
+ lib.openusb_parse_config_desc.argtypes = [
+ _openusb_handle,
+ _openusb_devid,
+ POINTER(c_uint8),
+ c_uint16,
+ c_uint8,
+ POINTER(_usb_config_desc)
+ ]
+ lib.openusb_parse_config_desc.restype = c_int32
+
+ # int32_t openusb_parse_interface_desc(openusb_handle_t handle,
+ # openusb_devid_t devid,
+ # uint8_t *buffer,
+ # uint16_t buflen,
+ # uint8_t cfgidx,
+ # uint8_t ifcidx,
+ # uint8_t alt,
+ # usb_interface_desc_t *ifcdesc);
+ lib.openusb_parse_interface_desc.argtypes = [
+ _openusb_handle,
+ _openusb_devid,
+ POINTER(c_uint8),
+ c_uint16,
+ c_uint8,
+ c_uint8,
+ c_uint8,
+ POINTER(_usb_interface_desc)
+ ]
+
+ lib.openusb_parse_interface_desc.restype = c_int32
+
+ # int32_t openusb_parse_endpoint_desc(openusb_handle_t handle,
+ # openusb_devid_t devid,
+ # uint8_t *buffer,
+ # uint16_t buflen,
+ # uint8_t cfgidx,
+ # uint8_t ifcidx,
+ # uint8_t alt,
+ # uint8_t eptidx,
+ # usb_endpoint_desc_t *eptdesc);
+ lib.openusb_parse_endpoint_desc.argtypes = [
+ _openusb_handle,
+ _openusb_devid,
+ POINTER(c_uint8),
+ c_uint16,
+ c_uint8,
+ c_uint8,
+ c_uint8,
+ c_uint8,
+ POINTER(_usb_endpoint_desc)
+ ]
+
+ lib.openusb_parse_interface_desc.restype = c_int32
+
+ # const char *openusb_strerror(int32_t error );
+ lib.openusb_strerror.argtypes = [c_int32]
+ lib.openusb_strerror.restype = c_char_p
+
+ # int32_t openusb_ctrl_xfer(openusb_dev_handle_t dev,
+ # uint8_t ifc,
+ # uint8_t ept,
+ # openusb_ctrl_request_t *ctrl);
+ lib.openusb_ctrl_xfer.argtypes = [
+ _openusb_dev_handle,
+ c_uint8,
+ c_uint8,
+ POINTER(_openusb_ctrl_request)
+ ]
+
+ lib.openusb_ctrl_xfer.restype = c_int32
+
+ # int32_t openusb_intr_xfer(openusb_dev_handle_t dev,
+ # uint8_t ifc,
+ # uint8_t ept,
+ # openusb_intr_request_t *intr);
+ lib.openusb_intr_xfer.argtypes = [
+ _openusb_dev_handle,
+ c_uint8,
+ c_uint8,
+ POINTER(_openusb_intr_request)
+ ]
+
+ lib.openusb_bulk_xfer.restype = c_int32
+
+ # int32_t openusb_bulk_xfer(openusb_dev_handle_t dev,
+ # uint8_t ifc,
+ # uint8_t ept,
+ # openusb_bulk_request_t *bulk);
+ lib.openusb_bulk_xfer.argtypes = [
+ _openusb_dev_handle,
+ c_uint8,
+ c_uint8,
+ POINTER(_openusb_bulk_request)
+ ]
+
+ lib.openusb_bulk_xfer.restype = c_int32
+
+ # int32_t openusb_isoc_xfer(openusb_dev_handle_t dev,
+ # uint8_t ifc,
+ # uint8_t ept,
+ # openusb_isoc_request_t *isoc);
+ lib.openusb_isoc_xfer.argtypes = [
+ _openusb_dev_handle,
+ c_uint8,
+ c_uint8,
+ POINTER(_openusb_isoc_request)
+ ]
+
+ lib.openusb_isoc_xfer.restype = c_int32
+
+def _check(retval):
+ ret = retval.value
+ if ret != 0:
+ from usb.core import USBError
+ raise USBError(_lib.openusb_strerror(ret), ret, _openusb_errno[ret])
+ return retval
+
+class _Context(object):
+ def __init__(self):
+ self.handle = _openusb_handle()
+ _check(_lib.openusb_init(0, byref(self.handle)))
+ def __del__(self):
+ _lib.openusb_fini(self.handle)
+
+class _BusIterator(object):
+ def __init__(self):
+ self.buslist = POINTER(openusb_busid)()
+ num_busids = c_uint32()
+ _check(_lib.openusb_get_busid_list(_ctx.handle,
+ byref(self.buslist),
+ byref(num_busids)))
+ self.num_busids = num_busids.value
+ def __iter__(self):
+ for i in range(self.num_busids):
+ yield self.buslist[i]
+ def __del__(self):
+ _lib.openusb_free_busid_list(self.buslist)
+
+class _DevIterator(object):
+ def __init__(self, busid):
+ self.devlist = POINTER(_openusb_devid)()
+ num_devids = c_uint32()
+ _check(_lib.openusb_get_devids_by_bus(_ctx.handle,
+ busid,
+ byref(self.devlist),
+ byref(num_devids)))
+ self.num_devids = num_devids.value
+ def __iter__(self):
+ for i in range(self.num_devids):
+ yield self.devlist[i]
+ def __del__(self):
+ _lib.openusb_free_devid_list(self.devlist)
+
+class _OpenUSB(usb.backend.IBackend):
+ @methodtrace(_logger)
+ def enumerate_devices(self):
+ for bus in _BusIterator():
+ for devid in _DevIterator(bus):
+ yield devid
+
+ @methodtrace(_logger)
+ def get_device_descriptor(self, dev):
+ desc = _usb_device_desc()
+ _check(_lib.openusb_parse_device_desc(_ctx.handle,
+ dev,
+ None,
+ 0,
+ byref(desc)))
+ desc.bus = None
+ desc.address = None
+ return desc
+
+ @methodtrace(_logger)
+ def get_configuration_descriptor(self, dev, config):
+ desc = _usb_config_desc()
+ _check(_lib.openusb_parse_config_desc(_ctx.handle,
+ dev,
+ None,
+ 0,
+ config,
+ byref(desc)))
+ return desc
+
+ @methodtrace(_logger)
+ def get_interface_descriptor(self, dev, intf, alt, config):
+ desc = _usb_interface_desc()
+ _check(_lib.openusb_parse_interface_desc(_ctx.handle,
+ dev,
+ None,
+ 0,
+ config,
+ intf,
+ alt,
+ byref(desc)))
+ return desc
+
+ @methodtrace(_logger)
+ def get_endpoint_descriptor(self, dev, ep, intf, alt, config):
+ desc = _usb_endpoint_desc()
+ _check(_lib.openusb_parse_endpoint_desc(_ctx.handle,
+ dev,
+ None,
+ 0,
+ config,
+ intf,
+ alt,
+ ep,
+ byref(desc)))
+ return desc
+
+ @methodtrace(_logger)
+ def open_device(self, dev):
+ handle = _openusb_dev_handle()
+ _check(_lib.openusb_open_device(_ctx.handle, dev, 0, byref(handle)))
+ return handle
+
+ @methodtrace(_logger)
+ def close_device(self, dev_handle):
+ _lib.openusb_close_device(dev_handle)
+
+ @methodtrace(_logger)
+ def set_configuration(self, dev_handle, config_value):
+ _check(_lib.openusb_set_configuration(dev_handle, config_value))
+
+ @methodtrace(_logger)
+ def get_configuration(self, dev_handle):
+ config = c_uint8()
+ _check(_lib.openusb_get_configuration(dev_handle, byref(config)))
+ return config.value
+
+ @methodtrace(_logger)
+ def set_interface_altsetting(self, dev_handle, intf, altsetting):
+ _check(_lib.set_altsetting(dev_handle, intf, altsetting))
+
+ @methodtrace(_logger)
+ def claim_interface(self, dev_handle, intf):
+ _check(_lib.openusb_claim_interface(dev_handle, intf, 0))
+
+ @methodtrace(_logger)
+ def release_interface(self, dev_handle, intf):
+ _lib.openusb_release_interface(dev_handle, intf)
+
+ @methodtrace(_logger)
+ def bulk_write(self, dev_handle, ep, intf, data, timeout):
+ request = _openusb_bulk_request()
+ memset(byref(request), 0, sizeof(request))
+ request.payload, request.length = data.buffer_info()
+ request.timeout = timeout
+ _check(_lib.openusb_bulk_xfer(dev_handle, intf, ep, byref(request)))
+ return request.transfered_bytes.value
+
+ @methodtrace(_logger)
+ def bulk_read(self, dev_handle, ep, intf, size, timeout):
+ request = _openusb_bulk_request()
+ buffer = array.array('B', '\x00' * size)
+ memset(byref(request), 0, sizeof(request))
+ request.payload, request.length = buffer.buffer_info()
+ request.timeout = timeout
+ _check(_lib.openusb_bulk_xfer(dev_handle, intf, ep, byref(request)))
+ return buffer[:request.transfered_bytes.value]
+
+ @methodtrace(_logger)
+ def intr_write(self, dev_handle, ep, intf, data, timeout):
+ request = _openusb_intr_request()
+ memset(byref(request), 0, sizeof(request))
+ payload, request.length = data.buffer_info()
+ request.payload = cast(payload, POINTER(c_uint8))
+ request.timeout = timeout
+ _check(_lib.openusb_intr_xfer(dev_handle, intf, ep, byref(request)))
+ return request.transfered_bytes.value
+
+ @methodtrace(_logger)
+ def intr_read(self, dev_handle, ep, intf, size, timeout):
+ request = _openusb_intr_request()
+ buffer = array.array('B', '\x00' * size)
+ memset(byref(request), 0, sizeof(request))
+ payload, request.length = buffer.buffer_info()
+ request.payload = cast(payload, POINTER(c_uint8))
+ request.timeout = timeout
+ _check(_lib.openusb_intr_xfer(dev_handle, intf, ep, byref(request)))
+ return buffer[:request.transfered_bytes.value]
+
+# TODO: implement isochronous
+# @methodtrace(_logger)
+# def iso_write(self, dev_handle, ep, intf, data, timeout):
+# pass
+
+# @methodtrace(_logger)
+# def iso_read(self, dev_handle, ep, intf, size, timeout):
+# pass
+
+ @methodtrace(_logger)
+ def ctrl_transfer(self,
+ dev_handle,
+ bmRequestType,
+ bRequest,
+ wValue,
+ wIndex,
+ data_or_wLength,
+ timeout):
+ request = _openusb_ctrl_request()
+ request.setup.bmRequestType = bmRequestType
+ request.setup.bRequest = bRequest
+ request.setup.wValue
+ request.setup.wIndex
+ request.timeout = timeout
+
+ direction = usb.util.ctrl_direction(bmRequestType)
+
+ if direction == ENDPOINT_OUT:
+ buffer = data_or_wLength
+ else:
+ buffer = array.array('B', '\x00' * data_or_wLength)
+
+ payload, request.length = buffer.buffer_info()
+ request.payload = cast(payload, POINTER(c_uint8))
+
+ ret = _check(_lib.openusb_ctrl_xfer(dev_handle, 0, 0, byref(request)))
+
+ if direction == ENDPOINT_OUT:
+ ret
+ else:
+ buffer[:ret]
+
+ @methodtrace(_logger)
+ def reset_device(self, dev_handle):
+ _check(_lib.openusb_reset(dev_handle))
+
+def get_backend():
+ try:
+ global _lib, _ctx
+ if _lib is None:
+ _lib = _load_library()
+ _setup_prototypes(_lib)
+ _ctx = _Context()
+ return _OpenUSB()
+ except Exception:
+ _logger.error('Error loading OpenUSB backend', exc_info=True)
+ return None
diff --git a/plugins/wedo_plugin/usb/control.py b/plugins/wedo_plugin/usb/control.py
new file mode 100644
index 0000000..8647c14
--- /dev/null
+++ b/plugins/wedo_plugin/usb/control.py
@@ -0,0 +1,252 @@
+# Copyright (C) 2009-2011 Wander Lairson Costa
+#
+# The following terms apply to all files associated
+# with the software unless explicitly disclaimed in individual files.
+#
+# The authors hereby grant permission to use, copy, modify, distribute,
+# and license this software and its documentation for any purpose, provided
+# that existing copyright notices are retained in all copies and that this
+# notice is included verbatim in any distributions. No written agreement,
+# license, or royalty fee is required for any of the authorized uses.
+# Modifications to this software may be copyrighted by their authors
+# and need not follow the licensing terms described here, provided that
+# the new terms are clearly indicated on the first page of each file where
+# they apply.
+#
+# IN NO EVENT SHALL THE AUTHORS OR DISTRIBUTORS BE LIABLE TO ANY PARTY
+# FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
+# ARISING OUT OF THE USE OF THIS SOFTWARE, ITS DOCUMENTATION, OR ANY
+# DERIVATIVES THEREOF, EVEN IF THE AUTHORS HAVE BEEN ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+#
+# THE AUTHORS AND DISTRIBUTORS SPECIFICALLY DISCLAIM ANY WARRANTIES,
+# INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT. THIS SOFTWARE
+# IS PROVIDED ON AN "AS IS" BASIS, AND THE AUTHORS AND DISTRIBUTORS HAVE
+# NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR
+# MODIFICATIONS.
+
+r"""usb.control - USB standard control requests
+
+This module exports:
+
+get_status - get recipeint status
+clear_feature - clear a recipient feature
+set_feature - set a recipient feature
+get_descriptor - get a device descriptor
+set_descriptor - set a device descriptor
+get_configuration - get a device configuration
+set_configuration - set a device configuration
+get_interface - get a device interface
+set_interface - set a device interface
+"""
+
+__author__ = 'Wander Lairson Costa'
+
+__all__ = ['get_status',
+ 'clear_feature',
+ 'set_feature',
+ 'get_descriptor',
+ 'set_descriptor',
+ 'get_configuration',
+ 'set_configuration',
+ 'get_interface',
+ 'set_interface',
+ 'ENDPOINT_HALT',
+ 'FUNCTION_SUSPEND',
+ 'DEVICE_REMOTE_WAKEUP',
+ 'U1_ENABLE',
+ 'U2_ENABLE',
+ 'LTM_ENABLE']
+
+import usb.util as util
+import usb.core as core
+
+def _parse_recipient(recipient, direction):
+ if recipient is None:
+ r = util.CTRL_RECIPIENT_DEVICE
+ wIndex = 0
+ elif isinstance(recipient, core.Interface):
+ r = util.CTRL_RECIPIENT_INTERFACE
+ wIndex = recipient.bInterfaceNumber
+ elif isinstance(recipient, core.Endpoint):
+ r = util.CTRL_RECIPIENT_ENDPOINT
+ wIndex = recipient.bEndpointAddress
+ else:
+ raise ValueError('Invalid recipient.')
+ bmRequestType = util.build_request_type(
+ direction,
+ util.CTRL_TYPE_STANDARD,
+ r
+ )
+ return (bmRequestType, wIndex)
+
+# standard feature selectors from USB 2.0/3.0
+ENDPOINT_HALT = 0
+FUNCTION_SUSPEND = 0
+DEVICE_REMOTE_WAKEUP = 1
+U1_ENABLE = 48
+U2_ENABLE = 49
+LTM_ENABLE = 50
+
+def get_status(dev, recipient = None):
+ r"""Return the status for the specified recipient.
+
+ dev is the Device object to which the request will be
+ sent to.
+
+ The recipient can be None (on which the status will be queried
+ on the device), an Interface or Endpoint descriptors.
+
+ The status value is returned as an integer with the lower
+ word being the two bytes status value.
+ """
+ bmRequestType, wIndex = _parse_recipient(recipient, util.CTRL_IN)
+ ret = dev.ctrl_transfer(bmRequestType = bmRequestType,
+ bRequest = 0x00,
+ wIndex = wIndex,
+ data_or_wLength = 2)
+ return ret[0] | (ret[1] << 8)
+
+def clear_feature(dev, feature, recipient = None):
+ r"""Clear/disable a specific feature.
+
+ dev is the Device object to which the request will be
+ sent to.
+
+ feature is the feature you want to disable.
+
+ The recipient can be None (on which the status will be queried
+ on the device), an Interface or Endpoint descriptors.
+ """
+ bmRequestType, wIndex = _parse_recipient(recipient, util.CTRL_OUT)
+ dev.ctrl_transfer(bmRequestType = bmRequestType,
+ bRequest = 0x01,
+ wIndex = wIndex,
+ wValue = feature)
+
+def set_feature(dev, feature, recipient = None):
+ r"""Set/enable a specific feature.
+
+ dev is the Device object to which the request will be
+ sent to.
+
+ feature is the feature you want to enable.
+
+ The recipient can be None (on which the status will be queried
+ on the device), an Interface or Endpoint descriptors.
+ """
+ bmRequestType, wIndex = _parse_recipient(recipient, util.CTRL_OUT)
+ dev.ctrl_transfer(bmRequestType = bmRequestType,
+ bRequest = 0x03,
+ wIndex = wIndex,
+ wValue = feature)
+
+def get_descriptor(dev, desc_size, desc_type, desc_index, wIndex = 0):
+ r"""Return the specified descriptor.
+
+ dev is the Device object to which the request will be
+ sent to.
+
+ desc_size is the descriptor size.
+
+ desc_type and desc_index are the descriptor type and index,
+ respectively. wIndex index is used for string descriptors
+ and represents the Language ID. For other types of descriptors,
+ it is zero.
+ """
+ wValue = desc_index | (desc_type << 8)
+ bmRequestType = util.build_request_type(
+ util.CTRL_IN,
+ util.CTRL_TYPE_STANDARD,
+ util.CTRL_RECIPIENT_DEVICE
+ )
+ return dev.ctrl_transfer(
+ bmRequestType = bmRequestType,
+ bRequest = 0x06,
+ wValue = wValue,
+ wIndex = wIndex,
+ data_or_wLength = desc_size
+ )
+
+def set_descriptor(dev, desc, desc_type, desc_index, wIndex = None):
+ r"""Update an existing descriptor or add a new one.
+
+ dev is the Device object to which the request will be
+ sent to.
+
+ The desc parameter is the descriptor to be sent to the device.
+ desc_type and desc_index are the descriptor type and index,
+ respectively. wIndex index is used for string descriptors
+ and represents the Language ID. For other types of descriptors,
+ it is zero.
+ """
+ wValue = desc_index | (desc_type << 8)
+ bmRequestType = util.build_request_type(
+ util.CTRL_OUT,
+ util.CTRL_TYPE_STANDARD,
+ util.CTRL_RECIPIENT_DEVICE
+ )
+ dev.ctrl_transfer(
+ bmRequestType = bmRequestType,
+ bRequest = 0x07,
+ wValue = wValue,
+ wIndex = wIndex,
+ data_or_wLength = desc
+ )
+
+def get_configuration(dev):
+ r"""Get the current active configuration of the device.
+
+ dev is the Device object to which the request will be
+ sent to.
+
+ This function differs from the Device.get_active_configuration
+ method because the later may use cached data, while this
+ function always does a device request.
+ """
+ bmRequestType = util.build_request_type(
+ util.CTRL_IN,
+ util.CTRL_TYPE_STANDARD,
+ util.CTRL_RECIPIENT_DEVICE
+ )
+ return dev.ctrl_transfer(
+ bmRequestType,
+ bRequest = 0x08,
+ data_or_wLength = 1
+ )[0]
+
+def set_configuration(dev, bConfigurationNumber):
+ r"""Set the current device configuration.
+
+ dev is the Device object to which the request will be
+ sent to.
+ """
+ dev.set_configuration(bConfigurationNumber)
+
+def get_interface(dev, bInterfaceNumber):
+ r"""Get the current alternate setting of the interface.
+
+ dev is the Device object to which the request will be
+ sent to.
+ """
+ bmRequestType = util.build_request_type(
+ util.CTRL_IN,
+ util.CTRL_TYPE_STANDARD,
+ util.CTRL_RECIPIENT_INTERFACE
+ )
+ return dev.ctrl_transfer(
+ bmRequestType = bmRequestType,
+ bRequest = 0x0a,
+ wIndex = bInterfaceNumber,
+ data_or_wLength = 1
+ )[0]
+
+def set_interface(dev, bInterfaceNumber, bAlternateSetting):
+ r"""Set the alternate setting of the interface.
+
+ dev is the Device object to which the request will be
+ sent to.
+ """
+ dev.set_interface_altsetting(bInterfaceNumber, bAlternateSetting)
+
diff --git a/plugins/wedo_plugin/usb/core.py b/plugins/wedo_plugin/usb/core.py
new file mode 100644
index 0000000..c90d011
--- /dev/null
+++ b/plugins/wedo_plugin/usb/core.py
@@ -0,0 +1,856 @@
+# Copyright (C) 2009-2011 Wander Lairson Costa
+#
+# The following terms apply to all files associated
+# with the software unless explicitly disclaimed in individual files.
+#
+# The authors hereby grant permission to use, copy, modify, distribute,
+# and license this software and its documentation for any purpose, provided
+# that existing copyright notices are retained in all copies and that this
+# notice is included verbatim in any distributions. No written agreement,
+# license, or royalty fee is required for any of the authorized uses.
+# Modifications to this software may be copyrighted by their authors
+# and need not follow the licensing terms described here, provided that
+# the new terms are clearly indicated on the first page of each file where
+# they apply.
+#
+# IN NO EVENT SHALL THE AUTHORS OR DISTRIBUTORS BE LIABLE TO ANY PARTY
+# FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
+# ARISING OUT OF THE USE OF THIS SOFTWARE, ITS DOCUMENTATION, OR ANY
+# DERIVATIVES THEREOF, EVEN IF THE AUTHORS HAVE BEEN ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+#
+# THE AUTHORS AND DISTRIBUTORS SPECIFICALLY DISCLAIM ANY WARRANTIES,
+# INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT. THIS SOFTWARE
+# IS PROVIDED ON AN "AS IS" BASIS, AND THE AUTHORS AND DISTRIBUTORS HAVE
+# NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR
+# MODIFICATIONS.
+
+r"""usb.core - Core USB features.
+
+This module exports:
+
+Device - a class representing a USB device.
+Configuration - a class representing a configuration descriptor.
+Interface - a class representing an interface descriptor.
+Endpoint - a class representing an endpoint descriptor.
+find() - a function to find USB devices.
+"""
+
+__author__ = 'Wander Lairson Costa'
+
+__all__ = ['Device', 'Configuration', 'Interface', 'Endpoint', 'find']
+
+import usb.util as util
+import copy
+import operator
+import usb._interop as _interop
+import logging
+
+_logger = logging.getLogger('usb.core')
+
+_DEFAULT_TIMEOUT = 1000
+
+def _set_attr(input, output, fields):
+ for f in fields:
+ setattr(output, f, int(getattr(input, f)))
+
+class _ResourceManager(object):
+ def __init__(self, dev, backend):
+ self.backend = backend
+ self._active_cfg_index = None
+ self.dev = dev
+ self.handle = None
+ self._claimed_intf = _interop._set()
+ self._alt_set = {}
+ self._ep_type_map = {}
+
+ def managed_open(self):
+ if self.handle is None:
+ self.handle = self.backend.open_device(self.dev)
+ return self.handle
+
+ def managed_close(self):
+ if self.handle is not None:
+ self.backend.close_device(self.handle)
+ self.handle = None
+
+ def managed_set_configuration(self, device, config):
+ if config is None:
+ cfg = device[0]
+ elif isinstance(config, Configuration):
+ cfg = config
+ elif config == 0: # unconfigured state
+ class FakeConfiguration(object):
+ def __init__(self):
+ self.index = None
+ self.bConfigurationValue = 0
+ cfg = FakeConfiguration()
+ else:
+ cfg = util.find_descriptor(device, bConfigurationValue=config)
+ self.managed_open()
+ self.backend.set_configuration(self.handle, cfg.bConfigurationValue)
+ # cache the index instead of the object to avoid cyclic references
+ # of the device and Configuration (Device tracks the _ResourceManager,
+ # which tracks the Configuration, which tracks the Device)
+ self._active_cfg_index = cfg.index
+ # after changing configuration, our alternate setting and endpoint type caches
+ # are not valid anymore
+ self._ep_type_map.clear()
+ self._alt_set.clear()
+
+ def managed_claim_interface(self, device, intf):
+ self.managed_open()
+ if intf is None:
+ cfg = self.get_active_configuration(device)
+ i = cfg[(0,0)].bInterfaceNumber
+ elif isinstance(intf, Interface):
+ i = intf.bInterfaceNumber
+ else:
+ i = intf
+ if i not in self._claimed_intf:
+ self.backend.claim_interface(self.handle, i)
+ self._claimed_intf.add(i)
+
+ def managed_release_interface(self, device, intf):
+ if intf is None:
+ cfg = self.get_active_configuration(device)
+ i = cfg[(0,0)].bInterfaceNumber
+ elif isinstance(intf, Interface):
+ i = intf.bInterfaceNumber
+ else:
+ i = intf
+ if i in self._claimed_intf:
+ self.backend.release_interface(self.handle, i)
+ self._claimed_intf.remove(i)
+
+ def managed_set_interface(self, device, intf, alt):
+ if intf is None:
+ i = self.get_interface(device, intf)
+ elif isinstance(intf, Interface):
+ i = intf
+ else:
+ cfg = self.get_active_configuration(device)
+ if alt is not None:
+ i = util.find_descriptor(cfg, bInterfaceNumber=intf, bAlternateSetting=alt)
+ else:
+ i = util.find_descriptor(cfg, bInterfaceNumber=intf)
+ self.managed_claim_interface(device, i)
+ if alt is None:
+ alt = i.bAlternateSetting
+ self.backend.set_interface_altsetting(self.handle, i.bInterfaceNumber, alt)
+ self._alt_set[i.bInterfaceNumber] = alt
+
+ def get_interface(self, device, intf):
+ # TODO: check the viability of issuing a GET_INTERFACE
+ # request when we don't have a alternate setting cached
+ if intf is None:
+ cfg = self.get_active_configuration(device)
+ return cfg[(0,0)]
+ elif isinstance(intf, Interface):
+ return intf
+ else:
+ cfg = self.get_active_configuration(device)
+ if intf in self._alt_set:
+ return util.find_descriptor(cfg,
+ bInterfaceNumber=intf,
+ bAlternateSetting=self._alt_set[intf])
+ else:
+ return util.find_descriptor(cfg, bInterfaceNumber=intf)
+
+ def get_active_configuration(self, device):
+ if self._active_cfg_index is None:
+ self.managed_open()
+ cfg = util.find_descriptor(
+ device,
+ bConfigurationValue=self.backend.get_configuration(self.handle)
+ )
+ if cfg is None:
+ raise USBError('Configuration not set')
+ self._active_cfg_index = cfg.index
+ return cfg
+ return device[self._active_cfg_index]
+
+ def get_endpoint_type(self, device, address, intf):
+ intf = self.get_interface(device, intf)
+ key = (address, intf.bInterfaceNumber, intf.bAlternateSetting)
+ try:
+ return self._ep_type_map[key]
+ except KeyError:
+ e = util.find_descriptor(intf, bEndpointAddress=address)
+ etype = util.endpoint_type(e.bmAttributes)
+ self._ep_type_map[key] = etype
+ return etype
+
+ def release_all_interfaces(self, device):
+ claimed = copy.copy(self._claimed_intf)
+ for i in claimed:
+ self.managed_release_interface(device, i)
+
+ def dispose(self, device, close_handle = True):
+ self.release_all_interfaces(device)
+ if close_handle:
+ self.managed_close()
+ self._ep_type_map.clear()
+ self._alt_set.clear()
+ self._active_cfg_index = None
+
+class USBError(IOError):
+ r"""Exception class for USB errors.
+
+ Backends must raise this exception when USB related errors occur.
+ The backend specific error code is available through the
+ 'backend_error_code' member variable.
+ """
+
+ def __init__(self, strerror, error_code = None, errno = None):
+ r"""Initialize the object.
+
+ This initializes the USBError object. The strerror and errno are passed
+ to the parent object. The error_code parameter is attributed to the
+ backend_error_code member variable.
+ """
+ IOError.__init__(self, errno, strerror)
+ self.backend_error_code = error_code
+
+class Endpoint(object):
+ r"""Represent an endpoint object.
+
+ This class contains all fields of the Endpoint Descriptor
+ according to the USB Specification. You may access them as class
+ properties. For example, to access the field bEndpointAddress
+ of the endpoint descriptor:
+
+ >>> import usb.core
+ >>> dev = usb.core.find()
+ >>> for cfg in dev:
+ >>> for i in cfg:
+ >>> for e in i:
+ >>> print e.bEndpointAddress
+ """
+
+ def __init__(self, device, endpoint, interface = 0,
+ alternate_setting = 0, configuration = 0):
+ r"""Initialize the Endpoint object.
+
+ The device parameter is the device object returned by the find()
+ function. endpoint is the endpoint logical index (not the endpoint address).
+ The configuration parameter is the logical index of the
+ configuration (not the bConfigurationValue field). The interface
+ parameter is the interface logical index (not the bInterfaceNumber field)
+ and alternate_setting is the alternate setting logical index (not the
+ bAlternateSetting value). Not every interface has more than one alternate
+ setting. In this case, the alternate_setting parameter should be zero.
+ By "logical index" we mean the relative order of the configurations returned by the
+ peripheral as a result of GET_DESCRIPTOR request.
+ """
+ self.device = device
+ intf = Interface(device, interface, alternate_setting, configuration)
+ self.interface = intf.bInterfaceNumber
+ self.index = endpoint
+
+ backend = device._ctx.backend
+
+ desc = backend.get_endpoint_descriptor(
+ device._ctx.dev,
+ endpoint,
+ interface,
+ alternate_setting,
+ configuration
+ )
+
+ _set_attr(
+ desc,
+ self,
+ (
+ 'bLength',
+ 'bDescriptorType',
+ 'bEndpointAddress',
+ 'bmAttributes',
+ 'wMaxPacketSize',
+ 'bInterval',
+ 'bRefresh',
+ 'bSynchAddress'
+ )
+ )
+
+ def write(self, data, timeout = None):
+ r"""Write data to the endpoint.
+
+ The parameter data contains the data to be sent to the endpoint and
+ timeout is the time limit of the operation. The transfer type and
+ endpoint address are automatically inferred.
+
+ The method returns the number of bytes written.
+
+ For details, see the Device.write() method.
+ """
+ return self.device.write(self.bEndpointAddress, data, self.interface, timeout)
+
+ def read(self, size, timeout = None):
+ r"""Read data from the endpoint.
+
+ The parameter size is the number of bytes to read and timeout is the
+ time limit of the operation.The transfer type and endpoint address
+ are automatically inferred.
+
+ The method returns an array.array object with the data read.
+
+ For details, see the Device.read() method.
+ """
+ return self.device.read(self.bEndpointAddress, size, self.interface, timeout)
+
+class Interface(object):
+ r"""Represent an interface object.
+
+ This class contains all fields of the Interface Descriptor
+ according to the USB Specification. You may access them as class
+ properties. For example, to access the field bInterfaceNumber
+ of the interface descriptor:
+
+ >>> import usb.core
+ >>> dev = usb.core.find()
+ >>> for cfg in dev:
+ >>> for i in cfg:
+ >>> print i.bInterfaceNumber
+ """
+
+ def __init__(self, device, interface = 0,
+ alternate_setting = 0, configuration = 0):
+ r"""Initialize the interface object.
+
+ The device parameter is the device object returned by the find()
+ function. The configuration parameter is the logical index of the
+ configuration (not the bConfigurationValue field). The interface
+ parameter is the interface logical index (not the bInterfaceNumber field)
+ and alternate_setting is the alternate setting logical index (not the
+ bAlternateSetting value). Not every interface has more than one alternate
+ setting. In this case, the alternate_setting parameter should be zero.
+ By "logical index" we mean the relative order of the configurations returned by the
+ peripheral as a result of GET_DESCRIPTOR request.
+ """
+ self.device = device
+ self.alternate_index = alternate_setting
+ self.index = interface
+ self.configuration = configuration
+
+ backend = device._ctx.backend
+
+ desc = backend.get_interface_descriptor(
+ self.device._ctx.dev,
+ interface,
+ alternate_setting,
+ configuration
+ )
+
+ _set_attr(
+ desc,
+ self,
+ (
+ 'bLength',
+ 'bDescriptorType',
+ 'bInterfaceNumber',
+ 'bAlternateSetting',
+ 'bNumEndpoints',
+ 'bInterfaceClass',
+ 'bInterfaceSubClass',
+ 'bInterfaceProtocol',
+ 'iInterface',
+ )
+ )
+
+ def set_altsetting(self):
+ r"""Set the interface alternate setting."""
+ self.device.set_interface_altsetting(
+ self.bInterfaceNumber,
+ self.bAlternateSetting
+ )
+
+ def __iter__(self):
+ r"""Iterate over all endpoints of the interface."""
+ for i in range(self.bNumEndpoints):
+ yield Endpoint(
+ self.device,
+ i,
+ self.index,
+ self.alternate_index,
+ self.configuration
+ )
+ def __getitem__(self, index):
+ r"""Return the Endpoint object in the given position."""
+ return Endpoint(
+ self.device,
+ index,
+ self.index,
+ self.alternate_index,
+ self.configuration
+ )
+
+class Configuration(object):
+ r"""Represent a configuration object.
+
+ This class contains all fields of the Configuration Descriptor
+ according to the USB Specification. You may access them as class
+ properties. For example, to access the field bConfigurationValue
+ of the configuration descriptor:
+
+ >>> import usb.core
+ >>> dev = usb.core.find()
+ >>> for cfg in dev:
+ >>> print cfg.bConfigurationValue
+ """
+
+ def __init__(self, device, configuration = 0):
+ r"""Initialize the configuration object.
+
+ The device parameter is the device object returned by the find()
+ function. The configuration parameter is the logical index of the
+ configuration (not the bConfigurationValue field). By "logical index"
+ we mean the relative order of the configurations returned by the
+ peripheral as a result of GET_DESCRIPTOR request.
+ """
+ self.device = device
+ self.index = configuration
+
+ backend = device._ctx.backend
+
+ desc = backend.get_configuration_descriptor(
+ self.device._ctx.dev,
+ configuration
+ )
+
+ _set_attr(
+ desc,
+ self,
+ (
+ 'bLength',
+ 'bDescriptorType',
+ 'wTotalLength',
+ 'bNumInterfaces',
+ 'bConfigurationValue',
+ 'iConfiguration',
+ 'bmAttributes',
+ 'bMaxPower'
+ )
+ )
+
+ def set(self):
+ r"""Set this configuration as the active one."""
+ self.device.set_configuration(self.bConfigurationValue)
+
+ def __iter__(self):
+ r"""Iterate over all interfaces of the configuration."""
+ for i in range(self.bNumInterfaces):
+ alt = 0
+ try:
+ while True:
+ yield Interface(self.device, i, alt, self.index)
+ alt += 1
+ except (USBError, IndexError):
+ pass
+ def __getitem__(self, index):
+ r"""Return the Interface object in the given position.
+
+ index is a tuple of two values with interface index and
+ alternate setting index, respectivally. Example:
+
+ >>> interface = config[(0, 0)]
+ """
+ return Interface(self.device, index[0], index[1], self.index)
+
+
+class Device(object):
+ r"""Device object.
+
+ This class contains all fields of the Device Descriptor according
+ to the USB Specification. You may access them as class properties.
+ For example, to access the field bDescriptorType of the device
+ descriptor:
+
+ >>> import usb.core
+ >>> dev = usb.core.find()
+ >>> dev.bDescriptorType
+
+ Additionally, the class provides methods to communicate with
+ the hardware. Typically, an application will first call the
+ set_configuration() method to put the device in a known configured
+ state, optionally call the set_interface_altsetting() to select the
+ alternate setting (if there is more than one) of the interface used,
+ and call the write() and read() method to send and receive data.
+
+ When working in a new hardware, one first try would be like this:
+
+ >>> import usb.core
+ >>> dev = usb.core.find(idVendor=myVendorId, idProduct=myProductId)
+ >>> dev.set_configuration()
+ >>> dev.write(1, 'test')
+
+ This sample finds the device of interest (myVendorId and myProductId should be
+ replaced by the corresponding values of your device), then configures the device
+ (by default, the configuration value is 1, which is a typical value for most
+ devices) and then writes some data to the endpoint 0x01.
+
+ Timeout values for the write, read and ctrl_transfer methods are specified in
+ miliseconds. If the parameter is omitted, Device.default_timeout value will
+ be used instead. This property can be set by the user at anytime.
+ """
+
+ def __init__(self, dev, backend):
+ r"""Initialize the Device object.
+
+ Library users should normally get a Device instance through
+ the find function. The dev parameter is the identification
+ of a device to the backend and its meaning is opaque outside
+ of it. The backend parameter is a instance of a backend
+ object.
+ """
+ self._ctx = _ResourceManager(dev, backend)
+ self.__default_timeout = _DEFAULT_TIMEOUT
+
+ desc = backend.get_device_descriptor(dev)
+
+ _set_attr(
+ desc,
+ self,
+ (
+ 'bLength',
+ 'bDescriptorType',
+ 'bcdUSB',
+ 'bDeviceClass',
+ 'bDeviceSubClass',
+ 'bDeviceProtocol',
+ 'bMaxPacketSize0',
+ 'idVendor',
+ 'idProduct',
+ 'bcdDevice',
+ 'iManufacturer',
+ 'iProduct',
+ 'iSerialNumber',
+ 'bNumConfigurations',
+ 'address',
+ 'bus'
+ )
+ )
+
+ self.bus = int(desc.bus) if desc.bus is not None else None
+ self.address = int(desc.address) if desc.address is not None else None
+
+ def set_configuration(self, configuration = None):
+ r"""Set the active configuration.
+
+ The configuration parameter is the bConfigurationValue field of the
+ configuration you want to set as active. If you call this method
+ without parameter, it will use the first configuration found.
+ As a device hardly ever has more than one configuration, calling
+ the method without parameter is enough to get the device ready.
+ """
+ self._ctx.managed_set_configuration(self, configuration)
+
+ def get_active_configuration(self):
+ r"""Return a Configuration object representing the current configuration set."""
+ return self._ctx.get_active_configuration(self)
+
+ def set_interface_altsetting(self, interface = None, alternate_setting = None):
+ r"""Set the alternate setting for an interface.
+
+ When you want to use an interface and it has more than one alternate setting,
+ you should call this method to select the alternate setting you would like
+ to use. If you call the method without one or the two parameters, it will
+ be selected the first one found in the Device in the same way of set_configuration
+ method.
+
+ Commonly, an interface has only one alternate setting and this call is
+ not necessary. For most of the devices, either it has more than one alternate
+ setting or not, it is not harmful to make a call to this method with no arguments,
+ as devices will silently ignore the request when there is only one alternate
+ setting, though the USB Spec allows devices with no additional alternate setting
+ return an error to the Host in response to a SET_INTERFACE request.
+
+ If you are in doubt, you may want to call it with no arguments wrapped by
+ a try/except clause:
+
+ >>> try:
+ >>> dev.set_interface_altsetting()
+ >>> except usb.core.USBError:
+ >>> pass
+ """
+ self._ctx.managed_set_interface(self, interface, alternate_setting)
+
+ def reset(self):
+ r"""Reset the device."""
+ self._ctx.dispose(self, False)
+ self._ctx.backend.reset_device(self._ctx.handle)
+ self._ctx.dispose(self, True)
+
+ def write(self, endpoint, data, interface = None, timeout = None):
+ r"""Write data to the endpoint.
+
+ This method is used to send data to the device. The endpoint parameter
+ corresponds to the bEndpointAddress member whose endpoint you want to
+ communicate with. The interface parameter is the bInterfaceNumber field
+ of the interface descriptor which contains the endpoint. If you do not
+ provide one, the first one found will be used, as explained in the
+ set_interface_altsetting() method.
+
+ The data parameter should be a sequence like type convertible to
+ array type (see array module).
+
+ The timeout is specified in miliseconds.
+
+ The method returns the number of bytes written.
+ """
+ backend = self._ctx.backend
+
+ fn_map = {
+ util.ENDPOINT_TYPE_BULK:backend.bulk_write,
+ util.ENDPOINT_TYPE_INTR:backend.intr_write,
+ util.ENDPOINT_TYPE_ISO:backend.iso_write
+ }
+
+ intf = self._ctx.get_interface(self, interface)
+ fn = fn_map[self._ctx.get_endpoint_type(self, endpoint, intf)]
+ self._ctx.managed_claim_interface(self, intf)
+
+ return fn(
+ self._ctx.handle,
+ endpoint,
+ intf.bInterfaceNumber,
+ _interop.as_array(data),
+ self.__get_timeout(timeout)
+ )
+
+ def read(self, endpoint, size, interface = None, timeout = None):
+ r"""Read data from the endpoint.
+
+ This method is used to receive data from the device. The endpoint parameter
+ corresponds to the bEndpointAddress member whose endpoint you want to
+ communicate with. The interface parameter is the bInterfaceNumber field
+ of the interface descriptor which contains the endpoint. If you do not
+ provide one, the first one found will be used, as explained in the
+ set_interface_altsetting() method. The size parameters tells how many
+ bytes you want to read.
+
+ The timeout is specified in miliseconds.
+
+ The method returns an array object with the data read.
+ """
+ backend = self._ctx.backend
+
+ fn_map = {
+ util.ENDPOINT_TYPE_BULK:backend.bulk_read,
+ util.ENDPOINT_TYPE_INTR:backend.intr_read,
+ util.ENDPOINT_TYPE_ISO:backend.iso_read
+ }
+
+ intf = self._ctx.get_interface(self, interface)
+ fn = fn_map[self._ctx.get_endpoint_type(self, endpoint, intf)]
+ self._ctx.managed_claim_interface(self, intf)
+
+ return fn(
+ self._ctx.handle,
+ endpoint,
+ intf.bInterfaceNumber,
+ size,
+ self.__get_timeout(timeout)
+ )
+
+
+ def ctrl_transfer(self, bmRequestType, bRequest, wValue=0, wIndex=0,
+ data_or_wLength = None, timeout = None):
+ r"""Do a control transfer on the endpoint 0.
+
+ This method is used to issue a control transfer over the
+ endpoint 0(endpoint 0 is required to always be a control endpoint).
+
+ The parameters bmRequestType, bRequest, wValue and wIndex are the
+ same of the USB Standard Control Request format.
+
+ Control requests may or may not have a data payload to write/read.
+ In cases which it has, the direction bit of the bmRequestType
+ field is used to infere the desired request direction. For
+ host to device requests (OUT), data_or_wLength parameter is
+ the data payload to send, and it must be a sequence type convertible
+ to an array object. In this case, the return value is the number of data
+ payload written. For device to host requests (IN), data_or_wLength
+ is the wLength parameter of the control request specifying the
+ number of bytes to read in data payload. In this case, the return
+ value is the data payload read, as an array object.
+ """
+ if util.ctrl_direction(bmRequestType) == util.CTRL_OUT:
+ a = _interop.as_array(data_or_wLength)
+ elif data_or_wLength is None:
+ a = 0
+ else:
+ a = data_or_wLength
+
+ self._ctx.managed_open()
+
+ return self._ctx.backend.ctrl_transfer(
+ self._ctx.handle,
+ bmRequestType,
+ bRequest,
+ wValue,
+ wIndex,
+ a,
+ self.__get_timeout(timeout)
+ )
+
+ def is_kernel_driver_active(self, interface):
+ r"""Determine if there is kernel driver associated with the interface.
+
+ If a kernel driver is active, and the object will be unable to perform I/O.
+ """
+ self._ctx.managed_open()
+ return self._ctx.backend.is_kernel_driver_active(self._ctx.handle, interface)
+
+ def detach_kernel_driver(self, interface):
+ r"""Detach a kernel driver.
+
+ If successful, you will then be able to perform I/O.
+ """
+ self._ctx.managed_open()
+ self._ctx.backend.detach_kernel_driver(self._ctx.handle, interface)
+
+ def attach_kernel_driver(self, interface):
+ r"""Re-attach an interface's kernel driver, which was previously
+ detached using detach_kernel_driver()."""
+ self._ctx.managed_open()
+ self._ctx.backend.attach_kernel_driver(self._ctx.handle, interface)
+
+ def __iter__(self):
+ r"""Iterate over all configurations of the device."""
+ for i in range(self.bNumConfigurations):
+ yield Configuration(self, i)
+
+ def __getitem__(self, index):
+ r"""Return the Configuration object in the given position."""
+ return Configuration(self, index)
+
+ def __del__(self):
+ self._ctx.dispose(self)
+
+ def __get_timeout(self, timeout):
+ if timeout is not None:
+ return timeout
+ return self.__default_timeout
+
+ def __set_def_tmo(self, tmo):
+ if tmo < 0:
+ raise ValueError('Timeout cannot be a negative value')
+ self.__default_timeout = tmo
+
+ def __get_def_tmo(self):
+ return self.__default_timeout
+
+ default_timeout = property(
+ __get_def_tmo,
+ __set_def_tmo,
+ doc = 'Default timeout for transfer I/O functions'
+ )
+
+def find(find_all=False, backend = None, custom_match = None, **args):
+ r"""Find an USB device and return it.
+
+ find() is the function used to discover USB devices.
+ You can pass as arguments any combination of the
+ USB Device Descriptor fields to match a device. For example:
+
+ find(idVendor=0x3f4, idProduct=0x2009)
+
+ will return the Device object for the device with
+ idVendor Device descriptor field equals to 0x3f4 and
+ idProduct equals to 0x2009.
+
+ If there is more than one device which matchs the criteria,
+ the first one found will be returned. If a matching device cannot
+ be found the function returns None. If you want to get all
+ devices, you can set the parameter find_all to True, then find
+ will return an list with all matched devices. If no matching device
+ is found, it will return an empty list. Example:
+
+ printers = find(find_all=True, bDeviceClass=7)
+
+ This call will get all the USB printers connected to the system.
+ (actually may be not, because some devices put their class
+ information in the Interface Descriptor).
+
+ You can also use a customized match criteria:
+
+ dev = find(custom_match = lambda d: d.idProduct=0x3f4 and d.idvendor=0x2009)
+
+ A more accurate printer finder using a customized match would be like
+ so:
+
+ def is_printer(dev):
+ import usb.util
+ if dev.bDeviceClass == 7:
+ return True
+ for cfg in dev:
+ if usb.util.find_descriptor(cfg, bInterfaceClass=7) is not None:
+ return True
+
+ printers = find(find_all=True, custom_match = is_printer)
+
+ Now even if the device class code is in the interface descriptor the
+ printer will be found.
+
+ You can combine a customized match with device descriptor fields. In this
+ case, the fields must match and the custom_match must return True. In the our
+ previous example, if we would like to get all printers belonging to the
+ manufacturer 0x3f4, the code would be like so:
+
+ printers = find(find_all=True, idVendor=0x3f4, custom_match=is_printer)
+
+ If you want to use find as a 'list all devices' function, just call
+ it with find_all = True:
+
+ devices = find(find_all=True)
+
+ Finally, you may pass a custom backend to the find function:
+
+ find(backend = MyBackend())
+
+ PyUSB has builtin backends for libusb 0.1, libusb 1.0 and OpenUSB.
+ If you do not supply a backend explicitly, find() function will select
+ one of the predefineds backends according to system availability.
+
+ Backends are explained in the usb.backend module.
+ """
+
+ def device_iter(k, v):
+ for dev in backend.enumerate_devices():
+ d = Device(dev, backend)
+ if (custom_match is None or custom_match(d)) and \
+ _interop._reduce(
+ lambda a, b: a and b,
+ map(
+ operator.eq,
+ v,
+ map(lambda i: getattr(d, i), k)
+ ),
+ True
+ ):
+ yield d
+
+ if backend is None:
+ import usb.backend.libusb10 as libusb10
+ import usb.backend.libusb01 as libusb01
+ import usb.backend.openusb as openusb
+
+ for m in (libusb10, openusb, libusb01):
+ backend = m.get_backend()
+ if backend is not None:
+ _logger.info('find(): using backend "%s"', m.__name__)
+ break
+ else:
+ raise ValueError('No backend available')
+
+ k, v = args.keys(), args.values()
+
+ if find_all:
+ return [d for d in device_iter(k, v)]
+ else:
+ try:
+ return _interop._next(device_iter(k, v))
+ except StopIteration:
+ return None
diff --git a/plugins/wedo_plugin/usb/legacy.py b/plugins/wedo_plugin/usb/legacy.py
new file mode 100644
index 0000000..0c9c52c
--- /dev/null
+++ b/plugins/wedo_plugin/usb/legacy.py
@@ -0,0 +1,334 @@
+# Copyright (C) 2009-2011 Wander Lairson Costa
+#
+# The following terms apply to all files associated
+# with the software unless explicitly disclaimed in individual files.
+#
+# The authors hereby grant permission to use, copy, modify, distribute,
+# and license this software and its documentation for any purpose, provided
+# that existing copyright notices are retained in all copies and that this
+# notice is included verbatim in any distributions. No written agreement,
+# license, or royalty fee is required for any of the authorized uses.
+# Modifications to this software may be copyrighted by their authors
+# and need not follow the licensing terms described here, provided that
+# the new terms are clearly indicated on the first page of each file where
+# they apply.
+#
+# IN NO EVENT SHALL THE AUTHORS OR DISTRIBUTORS BE LIABLE TO ANY PARTY
+# FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
+# ARISING OUT OF THE USE OF THIS SOFTWARE, ITS DOCUMENTATION, OR ANY
+# DERIVATIVES THEREOF, EVEN IF THE AUTHORS HAVE BEEN ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+#
+# THE AUTHORS AND DISTRIBUTORS SPECIFICALLY DISCLAIM ANY WARRANTIES,
+# INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT. THIS SOFTWARE
+# IS PROVIDED ON AN "AS IS" BASIS, AND THE AUTHORS AND DISTRIBUTORS HAVE
+# NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR
+# MODIFICATIONS.
+
+import usb.core as core
+import usb.util as util
+import usb._interop as _interop
+import usb.control as control
+
+__author__ = 'Wander Lairson Costa'
+
+USBError = core.USBError
+
+CLASS_AUDIO = 1
+CLASS_COMM = 2
+CLASS_DATA = 10
+CLASS_HID = 3
+CLASS_HUB = 9
+CLASS_MASS_STORAGE = 8
+CLASS_PER_INTERFACE = 0
+CLASS_PRINTER = 7
+CLASS_VENDOR_SPEC = 255
+DT_CONFIG = 2
+DT_CONFIG_SIZE = 9
+DT_DEVICE = 1
+DT_DEVICE_SIZE = 18
+DT_ENDPOINT = 5
+DT_ENDPOINT_AUDIO_SIZE = 9
+DT_ENDPOINT_SIZE = 7
+DT_HID = 33
+DT_HUB = 41
+DT_HUB_NONVAR_SIZE = 7
+DT_INTERFACE = 4
+DT_INTERFACE_SIZE = 9
+DT_PHYSICAL = 35
+DT_REPORT = 34
+DT_STRING = 3
+ENDPOINT_ADDRESS_MASK = 15
+ENDPOINT_DIR_MASK = 128
+ENDPOINT_IN = 128
+ENDPOINT_OUT = 0
+ENDPOINT_TYPE_BULK = 2
+ENDPOINT_TYPE_CONTROL = 0
+ENDPOINT_TYPE_INTERRUPT = 3
+ENDPOINT_TYPE_ISOCHRONOUS = 1
+ENDPOINT_TYPE_MASK = 3
+ERROR_BEGIN = 500000
+MAXALTSETTING = 128
+MAXCONFIG = 8
+MAXENDPOINTS = 32
+MAXINTERFACES = 32
+RECIP_DEVICE = 0
+RECIP_ENDPOINT = 2
+RECIP_INTERFACE = 1
+RECIP_OTHER = 3
+REQ_CLEAR_FEATURE = 1
+REQ_GET_CONFIGURATION = 8
+REQ_GET_DESCRIPTOR = 6
+REQ_GET_INTERFACE = 10
+REQ_GET_STATUS = 0
+REQ_SET_ADDRESS = 5
+REQ_SET_CONFIGURATION = 9
+REQ_SET_DESCRIPTOR = 7
+REQ_SET_FEATURE = 3
+REQ_SET_INTERFACE = 11
+REQ_SYNCH_FRAME = 12
+TYPE_CLASS = 32
+TYPE_RESERVED = 96
+TYPE_STANDARD = 0
+TYPE_VENDOR = 64
+
+class Endpoint(object):
+ r"""Endpoint descriptor object."""
+ def __init__(self, ep):
+ self.address = ep.bEndpointAddress
+ self.interval = ep.bInterval
+ self.maxPacketSize = ep.wMaxPacketSize
+ self.type = util.endpoint_type(ep.bmAttributes)
+
+class Interface(object):
+ r"""Interface descriptor object."""
+ def __init__(self, intf):
+ self.alternateSetting = intf.bAlternateSetting
+ self.interfaceNumber = intf.bInterfaceNumber
+ self.iInterface = intf.iInterface
+ self.interfaceClass = intf.bInterfaceClass
+ self.interfaceSubClass = intf.bInterfaceSubClass
+ self.interfaceProtocol = intf.bInterfaceProtocol
+ self.endpoints = [Endpoint(e) for e in intf]
+
+class Configuration(object):
+ r"""Configuration descriptor object."""
+ def __init__(self, cfg):
+ self.iConfiguration = cfg.iConfiguration
+ self.maxPower = cfg.bMaxPower << 2
+ self.remoteWakeup = (cfg.bmAttributes >> 5) & 1
+ self.selfPowered = (cfg.bmAttributes >> 6) & 1
+ self.totalLength = cfg.wTotalLength
+ self.value = cfg.bConfigurationValue
+ self.interfaces = [
+ list(g) for k, g in _interop._groupby(
+ _interop._sorted(
+ [Interface(i) for i in cfg],
+ key=lambda i: i.interfaceNumber
+ ),
+ lambda i: i.alternateSetting)
+ ]
+
+class DeviceHandle(object):
+ def __init__(self, dev):
+ self.dev = dev
+ self.__claimed_interface = -1
+
+ def bulkWrite(self, endpoint, buffer, timeout = 100):
+ r"""Perform a bulk write request to the endpoint specified.
+
+ Arguments:
+ endpoint: endpoint number.
+ buffer: sequence data buffer to write.
+ This parameter can be any sequence type.
+ timeout: operation timeout in miliseconds. (default: 100)
+ Returns the number of bytes written.
+ """
+ return self.dev.write(endpoint, buffer, self.__claimed_interface, timeout)
+
+ def bulkRead(self, endpoint, size, timeout = 100):
+ r"""Performs a bulk read request to the endpoint specified.
+
+ Arguments:
+ endpoint: endpoint number.
+ size: number of bytes to read.
+ timeout: operation timeout in miliseconds. (default: 100)
+ Return a tuple with the data read.
+ """
+ return self.dev.read(endpoint, size, self.__claimed_interface, timeout)
+
+ def interruptWrite(self, endpoint, buffer, timeout = 100):
+ r"""Perform a interrupt write request to the endpoint specified.
+
+ Arguments:
+ endpoint: endpoint number.
+ buffer: sequence data buffer to write.
+ This parameter can be any sequence type.
+ timeout: operation timeout in miliseconds. (default: 100)
+ Returns the number of bytes written.
+ """
+ return self.dev.write(endpoint, buffer, self.__claimed_interface, timeout)
+
+ def interruptRead(self, endpoint, size, timeout = 100):
+ r"""Performs a interrupt read request to the endpoint specified.
+
+ Arguments:
+ endpoint: endpoint number.
+ size: number of bytes to read.
+ timeout: operation timeout in miliseconds. (default: 100)
+ Return a tuple with the data read.
+ """
+ return self.dev.read(endpoint, size, self.__claimed_interface, timeout)
+
+ def controlMsg(self, requestType, request, buffer, value = 0, index = 0, timeout = 100):
+ r"""Perform a control request to the default control pipe on a device.
+
+ Arguments:
+ requestType: specifies the direction of data flow, the type
+ of request, and the recipient.
+ request: specifies the request.
+ buffer: if the transfer is a write transfer, buffer is a sequence
+ with the transfer data, otherwise, buffer is the number of
+ bytes to read.
+ value: specific information to pass to the device. (default: 0)
+ index: specific information to pass to the device. (default: 0)
+ timeout: operation timeout in miliseconds. (default: 100)
+ Return the number of bytes written.
+ """
+ return self.dev.ctrl_transfer(
+ requestType,
+ request,
+ wValue = value,
+ wIndex = index,
+ data_or_wLength = buffer,
+ timeout = timeout
+ )
+
+ def clearHalt(self, endpoint):
+ r"""Clears any halt status on the specified endpoint.
+
+ Arguments:
+ endpoint: endpoint number.
+ """
+ cfg = self.dev.get_active_configuration()
+ intf = util.find_descriptor(cfg, bInterfaceNumber = self.__claimed_interface)
+ e = util.find_descriptor(intf, bEndpointAddress = endpoint)
+ control.clear_feature(self.dev, control.ENDPOINT_HALT, e)
+
+ def claimInterface(self, interface):
+ r"""Claims the interface with the Operating System.
+
+ Arguments:
+ interface: interface number or an Interface object.
+ """
+ if_num = interface.interfaceNumber \
+ if isinstance(interface, Interface) else interface
+
+ util.claim_interface(self.dev, if_num)
+ self.__claimed_interface = if_num
+
+ def releaseInterface(self):
+ r"""Release an interface previously claimed with claimInterface."""
+ util.release_interface(self.dev, self.__claimed_interface)
+ self.__claimed_interface = -1
+
+ def reset(self):
+ r"""Reset the specified device by sending a RESET
+ down the port it is connected to."""
+ self.dev.reset()
+
+ def resetEndpoint(self, endpoint):
+ r"""Reset all states for the specified endpoint.
+
+ Arguments:
+ endpoint: endpoint number.
+ """
+ self.clearHalt(endpoint)
+
+ def setConfiguration(self, configuration):
+ r"""Set the active configuration of a device.
+
+ Arguments:
+ configuration: a configuration value or a Configuration object.
+ """
+ self.dev.set_configuration(configuration)
+
+ def setAltInterface(self, alternate):
+ r"""Sets the active alternate setting of the current interface.
+
+ Arguments:
+ alternate: an alternate setting number or an Interface object.
+ """
+ self.dev.set_interface_altsetting(self.__claimed_interface, alternate)
+
+ def getString(self, index, length, langid = None):
+ r"""Retrieve the string descriptor specified by index
+ and langid from a device.
+
+ Arguments:
+ index: index of descriptor in the device.
+ length: number of bytes of the string
+ langid: Language ID. If it is omittedi, will be
+ used the first language.
+ """
+ return util.get_string(self.dev, length, index, langid).encode('ascii')
+
+ def getDescriptor(self, desc_type, desc_index, length, endpoint = -1):
+ r"""Retrieves a descriptor from the device identified by the type
+ and index of the descriptor.
+
+ Arguments:
+ desc_type: descriptor type.
+ desc_index: index of the descriptor.
+ len: descriptor length.
+ endpoint: ignored.
+ """
+ return control.get_descriptor(self.dev, length, desc_type, desc_index)
+
+ def detachKernelDriver(self, interface):
+ r"""Detach a kernel driver from the interface (if one is attached,
+ we have permission and the operation is supported by the OS)
+
+ Arguments:
+ interface: interface number or an Interface object.
+ """
+ self.dev.detach_kernel_driver(interface)
+
+class Device(object):
+ r"""Device descriptor object"""
+ def __init__(self, dev):
+ self.deviceClass = dev.bDeviceClass
+ self.deviceSubClass = dev.bDeviceSubClass
+ self.deviceProtocol = dev.bDeviceProtocol
+ self.deviceVersion = dev.bcdDevice
+ self.devnum = None
+ self.filename = ''
+ self.iManufacturer = dev.iManufacturer
+ self.iProduct = dev.iProduct
+ self.iSerialNumber = dev.iSerialNumber
+ self.idProduct = dev.idProduct
+ self.idVendor = dev.idVendor
+ self.maxPacketSize = dev.bMaxPacketSize0
+ self.usbVersion = dev.bcdUSB
+ self.configurations = [Configuration(c) for c in dev]
+ self.dev = dev
+
+ def open(self):
+ r"""Open the device for use.
+
+ Return a DeviceHandle object
+ """
+ return DeviceHandle(self.dev)
+
+class Bus(object):
+ r"""Bus object."""
+ def __init__(self):
+ self.dirname = ''
+ self.localtion = 0
+ self.devices = [Device(d) for d in core.find(find_all=True)]
+
+def busses():
+ r"""Return a tuple with the usb busses."""
+ return (Bus(),)
+
diff --git a/plugins/wedo_plugin/usb/util.py b/plugins/wedo_plugin/usb/util.py
new file mode 100644
index 0000000..1f8cee3
--- /dev/null
+++ b/plugins/wedo_plugin/usb/util.py
@@ -0,0 +1,260 @@
+# Copyright (C) 2009-2011 Wander Lairson Costa
+#
+# The following terms apply to all files associated
+# with the software unless explicitly disclaimed in individual files.
+#
+# The authors hereby grant permission to use, copy, modify, distribute,
+# and license this software and its documentation for any purpose, provided
+# that existing copyright notices are retained in all copies and that this
+# notice is included verbatim in any distributions. No written agreement,
+# license, or royalty fee is required for any of the authorized uses.
+# Modifications to this software may be copyrighted by their authors
+# and need not follow the licensing terms described here, provided that
+# the new terms are clearly indicated on the first page of each file where
+# they apply.
+#
+# IN NO EVENT SHALL THE AUTHORS OR DISTRIBUTORS BE LIABLE TO ANY PARTY
+# FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
+# ARISING OUT OF THE USE OF THIS SOFTWARE, ITS DOCUMENTATION, OR ANY
+# DERIVATIVES THEREOF, EVEN IF THE AUTHORS HAVE BEEN ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+#
+# THE AUTHORS AND DISTRIBUTORS SPECIFICALLY DISCLAIM ANY WARRANTIES,
+# INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT. THIS SOFTWARE
+# IS PROVIDED ON AN "AS IS" BASIS, AND THE AUTHORS AND DISTRIBUTORS HAVE
+# NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR
+# MODIFICATIONS.
+
+r"""usb.util - Utility functions.
+
+This module exports:
+
+endpoint_address - return the endpoint absolute address.
+endpoint_direction - return the endpoint transfer direction.
+endpoint_type - return the endpoint type
+ctrl_direction - return the direction of a control transfer
+build_request_type - build a bmRequestType field of a control transfer.
+find_descriptor - find an inner descriptor.
+claim_interface - explicitly claim an interface.
+release_interface - explicitly release an interface.
+dispose_resources - release internal resources allocated by the object.
+get_string - retrieve a string descriptor from the device.
+"""
+
+__author__ = 'Wander Lairson Costa'
+
+import operator
+import usb._interop as _interop
+
+# descriptor type
+DESC_TYPE_DEVICE = 0x01
+DESC_TYPE_CONFIG = 0x02
+DESC_TYPE_STRING = 0x03
+DESC_TYPE_INTERFACE = 0x04
+DESC_TYPE_ENDPOINT = 0x05
+
+# endpoint direction
+ENDPOINT_IN = 0x80
+ENDPOINT_OUT = 0x00
+
+# endpoint type
+ENDPOINT_TYPE_CTRL = 0x00
+ENDPOINT_TYPE_ISO = 0x01
+ENDPOINT_TYPE_BULK = 0x02
+ENDPOINT_TYPE_INTR = 0x03
+
+# control request type
+CTRL_TYPE_STANDARD = (0 << 5)
+CTRL_TYPE_CLASS = (1 << 5)
+CTRL_TYPE_VENDOR = (2 << 5)
+CTRL_TYPE_RESERVED = (3 << 5)
+
+# control request recipient
+CTRL_RECIPIENT_DEVICE = 0
+CTRL_RECIPIENT_INTERFACE = 1
+CTRL_RECIPIENT_ENDPOINT = 2
+CTRL_RECIPIENT_OTHER = 3
+
+# control request direction
+CTRL_OUT = 0x00
+CTRL_IN = 0x80
+
+_ENDPOINT_ADDR_MASK = 0x0f
+_ENDPOINT_DIR_MASK = 0x80
+_ENDPOINT_TRANSFER_TYPE_MASK = 0x03
+_CTRL_DIR_MASK = 0x80
+
+def endpoint_address(address):
+ r"""Return the endpoint absolute address.
+
+ The address parameter is the bEndpointAddress field
+ of the endpoint descriptor.
+ """
+ return address & _ENDPOINT_ADDR_MASK
+
+def endpoint_direction(address):
+ r"""Return the endpoint direction.
+
+ The address parameter is the bEndpointAddress field
+ of the endpoint descriptor.
+ The possible return values are ENDPOINT_OUT or ENDPOINT_IN.
+ """
+ return address & _ENDPOINT_DIR_MASK
+
+def endpoint_type(bmAttributes):
+ r"""Return the transfer type of the endpoint.
+
+ The bmAttributes parameter is the bmAttributes field
+ of the endpoint descriptor.
+ The possible return values are: ENDPOINT_TYPE_CTRL,
+ ENDPOINT_TYPE_ISO, ENDPOINT_TYPE_BULK or ENDPOINT_TYPE_INTR.
+ """
+ return bmAttributes & _ENDPOINT_TRANSFER_TYPE_MASK
+
+def ctrl_direction(bmRequestType):
+ r"""Return the direction of a control request.
+
+ The bmRequestType parameter is the value of the
+ bmRequestType field of a control transfer.
+ The possible return values are CTRL_OUT or CTRL_IN.
+ """
+ return bmRequestType & _CTRL_DIR_MASK
+
+def build_request_type(direction, type, recipient):
+ r"""Build a bmRequestType field for control requests.
+
+ These is a conventional function to build a bmRequestType
+ for a control request.
+
+ The direction parameter can be CTRL_OUT or CTRL_IN.
+ The type parameter can be CTRL_TYPE_STANDARD, CTRL_TYPE_CLASS,
+ CTRL_TYPE_VENDOR or CTRL_TYPE_RESERVED values.
+ The recipient can be CTRL_RECIPIENT_DEVICE, CTRL_RECIPIENT_INTERFACE,
+ CTRL_RECIPIENT_ENDPOINT or CTRL_RECIPIENT_OTHER.
+
+ Return the bmRequestType value.
+ """
+ return recipient | type | direction
+
+def find_descriptor(desc, find_all=False, custom_match=None, **args):
+ r"""Find an inner descriptor.
+
+ find_descriptor works in the same way the core.find() function does,
+ but it acts on general descriptor objects. For example, suppose you
+ have a Device object called dev and want a Configuration of this
+ object with its bConfigurationValue equals to 1, the code would
+ be like so:
+
+ >>> cfg = util.find_descriptor(dev, bConfigurationValue=1)
+
+ You can use any field of the Descriptor as a match criteria, and you
+ can supply a customized match just like core.find() does. The
+ find_descriptor function also accepts the find_all parameter to get
+ a list of descriptor instead of just one.
+ """
+ def desc_iter(k, v):
+ for d in desc:
+ if (custom_match is None or custom_match(d)) and \
+ _interop._reduce(
+ lambda a, b: a and b,
+ map(
+ operator.eq,
+ v,
+ map(lambda i: getattr(d, i), k)
+ ),
+ True
+ ):
+ yield d
+
+ k, v = args.keys(), args.values()
+
+ if find_all:
+ return [d for d in desc_iter(k, v)]
+ else:
+ try:
+ return _interop._next(desc_iter(k, v))
+ except StopIteration:
+ return None
+
+def claim_interface(device, interface):
+ r"""Explicitly claim an interface.
+
+ PyUSB users normally do not have to worry about interface claiming,
+ as the library takes care of it automatically. But there are situations
+ where you need deterministic interface claiming. For these uncommon
+ cases, you can use claim_interface.
+
+ If the interface is already claimed, either through a previously call
+ to claim_interface or internally by the device object, nothing happens.
+ """
+ device._ctx.managed_claim_interface(device, interface)
+
+def release_interface(device, interface):
+ r"""Explicitly release an interface.
+
+ This function is used to release an interface previously claimed,
+ either through a call to claim_interface or internally by the
+ device object.
+
+ Normally, you do not need to worry about claiming policies, as
+ the device object takes care of it automatically.
+ """
+ device._ctx.managed_release_interface(device, interface)
+
+def dispose_resources(device):
+ r"""Release internal resources allocated by the object.
+
+ Sometimes you need to provide deterministic resources
+ freeing, for example to allow another application to
+ talk to the device. As Python does not provide deterministic
+ destruction, this function releases all internal resources
+ allocated by the device, like device handle and interface
+ policy.
+
+ After calling this function, you can continue using the device
+ object normally. If the resources will be necessary again, it
+ will allocate them automatically.
+ """
+ device._ctx.dispose(device)
+
+def get_string(dev, length, index, langid = None):
+ r"""Retrieve a string descriptor from the device.
+
+ dev is the Device object to which the request will be
+ sent to.
+
+ length is the length of string in number of characters.
+
+ index is the string descriptor index and langid is the Language
+ ID of the descriptor. If langid is omitted, the string descriptor
+ of the first Language ID will be returned.
+
+ The return value is the unicode string present in the descriptor.
+ """
+ from usb.control import get_descriptor
+ if langid is None:
+ # Asking for the zero'th index is special - it returns a string
+ # descriptor that contains all the language IDs supported by the device.
+ # Typically there aren't many - often only one. The language IDs are 16
+ # bit numbers, and they start at the third byte in the descriptor. See
+ # USB 2.0 specification section 9.6.7 for more information.
+ #
+ # Note from libusb 1.0 sources (descriptor.c)
+ buf = get_descriptor(
+ dev,
+ 1024,
+ DESC_TYPE_STRING,
+ 0
+ )
+ assert len(buf) >= 4
+ langid = buf[2] | (buf[3] << 8)
+
+ buf = get_descriptor(
+ dev,
+ length * 2 + 2, # string is utf16 + 2 bytes of the descriptor
+ DESC_TYPE_STRING,
+ index,
+ langid
+ )
+ return buf[2:].tostring().decode('utf-16-le')
diff --git a/plugins/wedo_plugin/wedo_plugin.py b/plugins/wedo_plugin/wedo_plugin.py
new file mode 100644
index 0000000..c0cbe12
--- /dev/null
+++ b/plugins/wedo_plugin/wedo_plugin.py
@@ -0,0 +1,304 @@
+#Copyright (c) 2012, Tony Forster, Ian Daniher, Walter Bender
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+
+from gettext import gettext as _
+
+from plugins.plugin import Plugin
+from WeDoMore import WeDo, scan_for_devices, UNAVAILABLE
+
+from TurtleArt.tapalette import make_palette
+from TurtleArt.taconstants import XO1, XO15
+from TurtleArt.talogo import primitive_dictionary
+
+import logging
+_logger = logging.getLogger('turtleart-activity WeDo plugin')
+
+
+class Wedo_plugin(Plugin):
+
+ def __init__(self, parent):
+ ''' Scan for WeDo devices '''
+ self.WeDos = []
+ device_list = scan_for_devices()
+ for i, dev in enumerate(device_list):
+ self.WeDos.append(WeDo(device=dev))
+ self.WeDos[-1].number = i
+ self._parent = parent
+ if len(self.WeDos) == 0:
+ self._status = False # no WeDo devices found
+ self.active_wedo = None
+ else:
+ self._status = True
+ self.active_wedo = 0
+
+ def setup(self):
+ ''' Setup palettes '''
+ palette = make_palette('WeDo', colors=["#FF6060", "#A06060"],
+ help_string=_('Palette of WeDo blocks'))
+
+ primitive_dictionary['wedoselect'] = self.wedo_select
+ palette.add_block('wedoselect',
+ style='basic-style-1arg',
+ default = 1,
+ label=_('WeDo'),
+ help_string=_('set current WeDo device'),
+ prim_name = 'wedoselect')
+
+ self._parent.lc.def_prim(
+ 'wedoselect', 1,
+ lambda self, n: primitive_dictionary['wedoselect'](n))
+
+ primitive_dictionary['wedocount'] = self.wedo_count
+ palette.add_block('wedogetcount',
+ style='box-style',
+ label=_('number of WeDos'),
+ help_string=_('number of WeDo devices'),
+ prim_name = 'wedocount')
+
+ self._parent.lc.def_prim(
+ 'wedocount', 0, lambda self: primitive_dictionary['wedocount']())
+
+ primitive_dictionary['wedotilt'] = self.wedo_gettilt
+ palette.add_block('tilt',
+ style='box-style',
+ label=_('tilt'),
+ help_string=_('tilt sensor output: (-1 == no tilt,\
+ 0 == tilt forward, 3 == tilt back, 1 == tilt left, 2 == tilt right)'),
+ value_block=True,
+ prim_name = 'wedotilt')
+ self._parent.lc.def_prim(
+ 'wedotilt', 0, lambda self: primitive_dictionary['wedotilt']())
+
+ primitive_dictionary['wedodistance'] = self.wedo_getdistance
+ palette.add_block('wedodistance',
+ style='box-style',
+ label=_('distance'),
+ help_string=_('distance sensor output'),
+ value_block=True,
+ prim_name = 'wedodistance')
+ self._parent.lc.def_prim(
+ 'wedodistance', 0,
+ lambda self: primitive_dictionary['wedodistance']())
+
+ primitive_dictionary['wedogetMotorA'] = self.wedo_getmotora
+ palette.add_block('wedogetMotorA',
+ style='box-style',
+ label=_('Motor A'),
+ help_string=_('returns the current value of Motor A'),
+ value_block=True,
+ prim_name = 'wedogetMotorA')
+
+ self._parent.lc.def_prim(
+ 'wedogetMotorA', 0,
+ lambda self: primitive_dictionary['wedogetMotorA']())
+
+ primitive_dictionary['wedogetMotorB'] = self.wedo_getmotorb
+ palette.add_block('wedogetMotorB',
+ style='box-style',
+ label=_('Motor B'),
+ help_string=_('returns the current value of Motor B'),
+ value_block=True,
+ prim_name = 'wedogetMotorB')
+ self._parent.lc.def_prim(
+ 'wedogetMotorB', 0,
+ lambda self: primitive_dictionary['wedogetMotorB']())
+
+ primitive_dictionary['wedosetMotorA'] = self.wedo_setmotora
+ palette.add_block('wedosetMotorA',
+ style = 'basic-style-1arg',
+ label = _('Motor A'),
+ default = 30,
+ prim_name = 'wedosetMotorA',
+ help_string = _('set the value for Motor A'))
+ self._parent.lc.def_prim(
+ 'wedosetMotorA', 1,
+ lambda self, a: primitive_dictionary['wedosetMotorA'](a))
+
+ primitive_dictionary['wedosetMotorB'] = self.wedo_setmotorb
+ palette.add_block('wedosetMotorB',
+ style = 'basic-style-1arg',
+ label = _('Motor B'),
+ default = 30,
+ prim_name = 'wedosetMotorB',
+ help_string = _('set the value for Motor B'))
+ self._parent.lc.def_prim(
+ 'wedosetMotorB', 1,
+ lambda self, b: primitive_dictionary['wedosetMotorB'](b))
+
+ def wedo_select(self, i):
+ ''' Select current device '''
+ if self.wedo_count() == 0:
+ self.active_wedo = None
+ self._parent.showlabel(
+ 'status', _('WeDo is unavailable'))
+ return
+ if type(i) == unicode:
+ i = str(i.encode('ascii', 'replace'))
+ if type(i) == float or type(i) == str:
+ i = int(i)
+ if type(i) != int:
+ i = 1
+ if i < 0:
+ i = -i
+ if i < 0 or i > self.wedo_count() - 1:
+ self._parent.showlabel(
+ 'status', _('WeDo %d is unavailable; defaulting to 1') % (i))
+ i -= 1 # Userspace counts from 1; internally, we count from 0
+ if i > self.wedo_count() - 1:
+ i = 0
+ self.active_wedo = i
+
+ def wedo_count(self):
+ ''' How many devices are available? '''
+ n = len(self.WeDos)
+ for wedo in self.WeDos:
+ if wedo.dev is None:
+ n -= 1
+ return n
+
+ def wedo_find(self):
+ ''' Find an available device '''
+ for wedo in self.WeDos:
+ if wedo.dev is not None:
+ return self.WeDos.index(wedo)
+ return None
+
+ def wedo_gettilt(self):
+ if self.active_wedo is None:
+ self.active_wedo = self.wedo_find()
+ if self.active_wedo is None:
+ self._parent.showlabel('status', _('WeDo is unavailable'))
+ return -1
+ tilt = self.WeDos[self.active_wedo].getTilt()
+ if tilt == UNAVAILABLE:
+ # Should we look for tilt on another WeDo?
+ self._parent.showlabel(
+ 'status', _('%s is unavailable on WeDo %d') % (
+ _('tilt'), self.active_wedo + 1))
+ return -1
+ else:
+ return tilt
+
+ def wedo_getdistance(self):
+ if self.active_wedo is None:
+ self.active_wedo = self.wedo_find()
+ if self.active_wedo is None:
+ self._parent.showlabel('status', _('WeDo is unavailable'))
+ return 0
+ distance = self.WeDos[self.active_wedo].getDistance()
+ if distance == UNAVAILABLE:
+ # Should we look for distance on another WeDo?
+ self._parent.showlabel(
+ 'status', _('%s is unavailable on WeDo %d') % (
+ _('distance'), self.active_wedo + 1))
+ return 0
+ else:
+ return distance
+
+ def wedo_getmotora(self):
+ if self.active_wedo is None:
+ self.active_wedo = self.wedo_find()
+ if self.active_wedo is None:
+ self._parent.showlabel('status', _('WeDo is unavailable'))
+ return 0
+ speed = self.WeDos[self.active_wedo].getMotorA()
+ if speed == UNAVAILABLE:
+ self._parent.showlabel(
+ 'status', _('%s is unavailable on WeDo %d') % (
+ _('Motor A'), self.active_wedo + 1))
+ return 0
+ else:
+ return speed
+
+ def wedo_getmotorb(self):
+ if self.active_wedo is None:
+ self.active_wedo = self.wedo_find()
+ if self.active_wedo is None:
+ self._parent.showlabel('status', _('WeDo is unavailable'))
+ return 0
+ speed = self.WeDos[self.active_wedo].getMotorB()
+ if speed == UNAVAILABLE:
+ self._parent.showlabel(
+ 'status', _('%s is unavailable on WeDo %d') % (
+ _('Motor B'), self.active_wedo + 1))
+ return 0
+ else:
+ return speed
+
+ def wedo_setmotora(self, speed):
+ if self.active_wedo is None:
+ self.active_wedo = self.wedo_find()
+ if self.active_wedo is None:
+ self._parent.showlabel('status', _('WeDo is unavailable'))
+ return
+ status = self.WeDos[self.active_wedo].setMotorA(speed)
+ if status == UNAVAILABLE:
+ self._parent.showlabel(
+ 'status', _('%s is unavailable on WeDo %d') % (
+ _('Motor A'), self.active_wedo + 1))
+
+ def wedo_setmotorb(self, speed):
+ if self.active_wedo is None:
+ self.active_wedo = self.wedo_find()
+ if self.active_wedo is None:
+ self._parent.showlabel('status', _('WeDo is unavailable'))
+ return
+ status = self.WeDos[self.active_wedo].setMotorB(speed)
+ if status == UNAVAILABLE:
+ self._parent.showlabel(
+ 'status', _('%s is unavailable on WeDo %d') % (
+ _('Motor B'), self.active_wedo + 1))
+
+ def start(self):
+ ''' Each time program starts, scan for devices and reset status '''
+ for wedo in self.WeDos:
+ wedo.dev = None
+ self.active_wedo = None
+ device_list = scan_for_devices()
+ if len(device_list) > 0:
+ self.status = True
+ if self.active_wedo is None:
+ self.active_wedo = 0
+ else:
+ self.status = False
+ for i, dev in enumerate(device_list):
+ if i < len(self.WeDos):
+ self.WeDos[i].dev = dev
+ self.WeDos[i].number = i
+ status = self.WeDos[i].init_device() # Reinitial device
+ if status == UNAVAILABLE:
+ self._parent.showlabel('status', _('WeDo is unavailable'))
+ else:
+ self.WeDos.append(WeDo(device=dev))
+ self.WeDos[i].number = i
+
+ def stop(self):
+ if self._status:
+ for wedo in self.WeDos:
+ if wedo.dev is not None:
+ wedo.setMotors(0, 0)
+
+ def goto_background(self):
+ pass
+
+ def return_to_foreground(self):
+ pass
+
+ def quit(self):
+ if self._status:
+ for wedo in self.WeDos:
+ if wedo.dev is not None:
+ wedo.setMotors(0, 0)
diff --git a/po/af.po b/po/af.po
index b686ae1..e185cde 100644
--- a/po/af.po
+++ b/po/af.po
@@ -2,8 +2,33 @@
# Copyright (C) YEAR THE PACKAGE'S COPYRIGHT HOLDER
# This file is distributed under the same license as the PACKAGE package.
# FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
+#, fuzzy
msgid ""
msgstr ""
+"#-#-#-#-# af.po (PACKAGE VERSION) #-#-#-#-#\n"
+"Project-Id-Version: PACKAGE VERSION\n"
+"Report-Msgid-Bugs-To: \n"
+"POT-Creation-Date: 2012-11-02 00:32-0400\n"
+"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
+"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
+"Language-Team: LANGUAGE <LL@li.org>\n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
+"X-Generator: Translate Toolkit 1.7.0\n"
+"#-#-#-#-# af.po (PACKAGE VERSION) #-#-#-#-#\n"
+"#-#-#-#-# af.po (PACKAGE VERSION) #-#-#-#-#\n"
+"Project-Id-Version: PACKAGE VERSION\n"
+"Report-Msgid-Bugs-To: \n"
+"POT-Creation-Date: 2012-11-02 00:32-0400\n"
+"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
+"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
+"Language-Team: LANGUAGE <LL@li.org>\n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
+"X-Generator: Translate Toolkit 1.7.0\n"
+"#-#-#-#-# af.po (TURTLEART) #-#-#-#-#\n"
"Project-Id-Version: TURTLEART\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2013-02-24 00:31-0500\n"
@@ -18,585 +43,1895 @@ msgstr ""
"X-Generator: Pootle 2.0.5\n"
#. TRANS: "name" option from activity.info file
-msgid "TurtleBlocks"
-msgstr ""
-
#. TRANS: "summary" option from activity.info file
#. TRANS: "description" option from activity.info file
+msgid "turtleart-extras (master)"
+msgstr ""
+
+#: taextras.py:36
+msgid "Turtle Art Mini"
+msgstr ""
+
+#: taextras.py:40
+msgid "Turtle Confusion"
+msgstr ""
+
+#: taextras.py:41 taextras.py:46
+msgid "Select a challenge"
+msgstr ""
+
+#: taextras.py:45
+msgid "Amazonas Tortuga"
+msgstr ""
+
+#: taextras.py:52
+msgid "Palette of Mexican pesos"
+msgstr ""
+
+#: taextras.py:53
+msgid "Palette of Colombian pesos"
+msgstr ""
+
+#: taextras.py:54
+msgid "Palette of Rwandan francs"
+msgstr ""
+
+#: taextras.py:55
+msgid "Palette of US dollars"
+msgstr ""
+
+#: taextras.py:56
+msgid "Palette of Australian dollars"
+msgstr ""
+
+#: taextras.py:57
+msgid "Palette of Paraguayan Guaranies"
+msgstr ""
+
+#: taextras.py:58
+msgid "Palette of Peruvian Nuevo Soles"
+msgstr ""
+
+#: taextras.py:59
+msgid "Palette of Uruguayan Pesos"
+msgstr ""
+
+#. TRANS: Butia is the Arduino Robot Project from Uruguay
+#. (http://www.fing.edu.uy/inco/proyectos/butia/)
+#: taextras.py:65
+msgid "TurtleBots"
+msgstr ""
+
+#: taextras.py:66
+msgid "adjust LED intensity between 0 and 255"
+msgstr ""
+
+#: taextras.py:67
+msgid "returns the object gray level as a number between 0 and 1023"
+msgstr ""
+
+#: taextras.py:68
+msgid "returns 1 when the button is press and 0 otherwise"
+msgstr ""
+
+#: taextras.py:69
+msgid "returns the ambient light level as a number between 0 and 1023"
+msgstr ""
+
+#: taextras.py:70
+msgid "returns the ambient temperature as a number between 0 and 255"
+msgstr ""
+
+#: taextras.py:71
msgid ""
-"A Logo-inspired turtle that draws colorful pictures with snap-together "
-"visual programming blocks"
+"returns the distance from the object in front of the sensor as a number "
+"between 0 and 255"
msgstr ""
-#: TurtleArt/tabasics.py:123
-#, fuzzy
-msgid "Palette of turtle commands"
-msgstr "palet van skilpadbevele"
+#: taextras.py:73
+msgid "returns 0 or 1 depending on the sensor inclination"
+msgstr ""
-#: TurtleArt/tabasics.py:128
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:723
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:734
-msgid "forward"
-msgstr "vorentoe"
+#: taextras.py:74
+msgid "returns 1 when the sensors detects a magnetic field, 0 otherwise"
+msgstr ""
-#: TurtleArt/tabasics.py:132
-#, fuzzy
-msgid "moves turtle forward"
-msgstr "skuif die skilpad vorentoe"
+#: taextras.py:75
+msgid "switches from 0 to 1, the frequency depends on the vibration"
+msgstr ""
-#: TurtleArt/tabasics.py:139
-msgid "back"
-msgstr "agtertoe"
+#: taextras.py:76
+msgid "returns the value of the resistance"
+msgstr ""
-#: TurtleArt/tabasics.py:143
-#, fuzzy
-msgid "moves turtle backward"
-msgstr "skuif die skilpad agtertoe"
+#: taextras.py:77
+msgid "LED"
+msgstr ""
-#: TurtleArt/tabasics.py:151
-msgid "clean"
-msgstr "maak skoon"
+#: taextras.py:78
+msgid "button"
+msgstr ""
-#: TurtleArt/tabasics.py:154
-#, fuzzy
-msgid "clears the screen and reset the turtle"
-msgstr "maak die skerm skoon en herstel die skilpad"
+#: taextras.py:79
+msgid "grayscale"
+msgstr ""
-#: TurtleArt/tabasics.py:162
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:854
-msgid "left"
-msgstr "links"
+#: taextras.py:80
+msgid "ambient light"
+msgstr ""
-#: TurtleArt/tabasics.py:166
-#, fuzzy
-msgid "turns turtle counterclockwise (angle in degrees)"
-msgstr "draai die skilpad anti-kloksgewys (gee die hoek in grade)"
+#: taextras.py:81
+msgid "temperature"
+msgstr ""
-#: TurtleArt/tabasics.py:174
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:878
-msgid "right"
-msgstr "regs"
+#: taextras.py:82 taextras.py:291
+msgid "distance"
+msgstr ""
-#: TurtleArt/tabasics.py:178
-#, fuzzy
-msgid "turns turtle clockwise (angle in degrees)"
-msgstr "draai die skilpad kloksgewys (gee die hoek in grade)"
+#: taextras.py:83 taextras.py:288
+msgid "tilt"
+msgstr ""
-#: TurtleArt/tabasics.py:186
-msgid "arc"
-msgstr "boog"
+#: taextras.py:84
+msgid "magnetic induction"
+msgstr ""
-#: TurtleArt/tabasics.py:186
-msgid "angle"
-msgstr "hoek"
+#: taextras.py:85
+msgid "vibration"
+msgstr ""
-#: TurtleArt/tabasics.py:186
-msgid "radius"
-msgstr "radius"
+#: taextras.py:86 plugins/audio_sensors/audio_sensors.py:151
+#: plugins/audio_sensors/audio_sensors.py:165
+#: plugins/audio_sensors/audio_sensors.py:179
+#: plugins/audio_sensors/audio_sensors.py:193
+msgid "resistance"
+msgstr ""
-#: TurtleArt/tabasics.py:190
-#, fuzzy
-msgid "moves turtle along an arc"
-msgstr "skuif die skilpad in 'n boog"
+#: taextras.py:87
+msgid "Butia Robot"
+msgstr ""
-#: TurtleArt/tabasics.py:199 TurtleArt/tabasics.py:265
-msgid "set xy"
-msgstr "stel xy"
+#: taextras.py:88
+msgid "refresh Butia"
+msgstr ""
-#: TurtleArt/tabasics.py:199 TurtleArt/tabasics.py:265
+#: taextras.py:89
+msgid "refresh the state of the Butia palette and blocks"
+msgstr ""
+
+#. TRANS: This string is shorthand for "battery charge of Butia"
+#: taextras.py:91
+msgid "battery charge Butia"
+msgstr ""
+
+#: taextras.py:92
+msgid "returns the battery charge as a number between 0 and 255"
+msgstr ""
+
+#. TRANS: This string is shorthand for "speed of Butia"
+#: taextras.py:94
+msgid "speed Butia"
+msgstr ""
+
+#: taextras.py:95
+msgid "set the speed of the Butia motors"
+msgstr ""
+
+#: taextras.py:96
+msgid "the speed must be a value between 0 and 1023"
+msgstr ""
+
+#. TRANS: This string is shorthand for "move Butia forward"
+#: taextras.py:98
+msgid "forward Butia"
+msgstr ""
+
+#: taextras.py:99
+msgid "move the Butia robot forward"
+msgstr ""
+
+#: taextras.py:100
+msgid "move the Butia robot forward a predefined distance"
+msgstr ""
+
+#. TRANS: This string is shorthand for "turn Butia left"
+#: taextras.py:102
+msgid "left Butia"
+msgstr ""
+
+#: taextras.py:103
+msgid "turn the Butia robot at left"
+msgstr ""
+
+#. TRANS: This string is shorthand for "move Butia backward"
+#: taextras.py:105
+msgid "backward Butia"
+msgstr ""
+
+#: taextras.py:106
+msgid "move the Butia robot backward"
+msgstr ""
+
+#: taextras.py:107
+msgid "move the Butia robot backward a predefined distance"
+msgstr ""
+
+#. TRANS: This string is shorthand for "turn Butia right"
+#: taextras.py:109
+msgid "right Butia"
+msgstr ""
+
+#: taextras.py:110
+msgid "turn the Butia robot at right"
+msgstr ""
+
+#: taextras.py:111
+msgid "turn Butia"
+msgstr ""
+
+#: taextras.py:112
+msgid "turn the Butia robot x degrees"
+msgstr ""
+
+#: taextras.py:113
+msgid "stop Butia"
+msgstr ""
+
+#: taextras.py:114
+msgid "stop the Butia robot"
+msgstr ""
+
+#: taextras.py:115
+msgid "Butia"
+msgstr ""
+
+#: taextras.py:119
+msgid "Error importing Pygame. This plugin require Pygame 1.9"
+msgstr ""
+
+#: taextras.py:120
+msgid "Error on initialization of the camera"
+msgstr ""
+
+#: taextras.py:121
+msgid "No camera was found"
+msgstr ""
+
+#: taextras.py:122
+msgid "Error stopping camera"
+msgstr ""
+
+#: taextras.py:123
+msgid "Error starting camera"
+msgstr ""
+
+#. TRANS: The "mask" is used to restrict processing to a region in the image
+#: taextras.py:125
+msgid "Error in get mask"
+msgstr ""
+
+#: taextras.py:126
+msgid "FollowMe"
+msgstr ""
+
+#: taextras.py:127
+msgid "refresh FollowMe"
+msgstr ""
+
+#: taextras.py:128
+msgid "Search for a connected camera."
+msgstr ""
+
+#. TRANS: the calibration is used to match an RGB color to a target
+#: taextras.py:130
+msgid "calibration"
+msgstr ""
+
+#: taextras.py:131
+msgid "store a personalized calibration"
+msgstr ""
+
+#: taextras.py:132
+msgid "return a personalized calibration"
+msgstr ""
+
+#: taextras.py:133
+msgid "follow"
+msgstr ""
+
+#: taextras.py:134
+msgid "follow a color or calibration"
+msgstr ""
+
+#: taextras.py:135 plugins/camera_sensor/camera_sensor.py:80
+#: plugins/camera_sensor/camera_sensor.py:93
+#: plugins/camera_sensor/camera_sensor.py:128
+#: plugins/camera_sensor/camera_sensor.py:141
+#: plugins/light_sensor/light_sensor.py:56
+#: plugins/light_sensor/light_sensor.py:63
+msgid "brightness"
+msgstr ""
+
+#: taextras.py:136
+msgid "set the camera brightness as a value between 0 to 255."
+msgstr ""
+
+#: taextras.py:137
+msgid "minimum pixels"
+msgstr ""
+
+#: taextras.py:138
+msgid "set the minimal number of pixels to follow"
+msgstr ""
+
+#: taextras.py:139
+msgid "threshold"
+msgstr ""
+
+#. TRANS: RGB color space (red, green, blue)
+#: taextras.py:141
+msgid "set a threshold for a RGB color"
+msgstr ""
+
+#: taextras.py:142
+msgid "camera mode"
+msgstr ""
+
+#. TRANS: RGB, YUV, and HSV are color spaces
+#: taextras.py:144
+msgid "set the color mode of the camera: RGB; YUV or HSV"
+msgstr ""
+
+#: taextras.py:145
+msgid "get brightness"
+msgstr ""
+
+#: taextras.py:146
+msgid "get the brightness of the ambient light"
+msgstr ""
+
+#: taextras.py:147
+msgid "average color"
+msgstr ""
+
+#: taextras.py:148
+msgid ""
+"if set to 0 then color averaging is off during calibration; for other values "
+"it is on"
+msgstr ""
+
+#: taextras.py:149
+msgid "x position"
+msgstr ""
+
+#: taextras.py:150
+msgid "return x position"
+msgstr ""
+
+#: taextras.py:151
+msgid "y position"
+msgstr ""
+
+#: taextras.py:152
+msgid "return y position"
+msgstr ""
+
+#: taextras.py:153
+msgid "pixels"
+msgstr ""
+
+#: taextras.py:154
+msgid "return the number of pixels of the biggest blob"
+msgstr ""
+
+#. TRANS: RGB color space (red, green, blue)
+#: taextras.py:156
+msgid "set the color mode of the camera to RGB"
+msgstr ""
+
+#. TRANS: YUV color space (luminance, chrominance)
+#: taextras.py:158
+msgid "set the color mode of the camera to YUV"
+msgstr ""
+
+#. TRANS: HSV color space (hue, saturation, value)
+#: taextras.py:160
+msgid "set the color mode of the camera to HSV"
+msgstr ""
+
+#: taextras.py:161
+msgid "empty calibration"
+msgstr ""
+
+#: taextras.py:162
+msgid "error in string conversion"
+msgstr ""
+
+#. TRANS: SumBot is a robot programmed for "Sumo wrestling"
+#: taextras.py:167
+msgid "SumBot"
+msgstr ""
+
+#: taextras.py:168
+msgid "speed SumBot"
+msgstr ""
+
+#: taextras.py:169
+msgid "submit the speed to the SumBot"
+msgstr ""
+
+#: taextras.py:170
+msgid "set the default speed for the movement commands"
+msgstr ""
+
+#. TRANS: This string is shorthand for "move SumBot forward"
+#: taextras.py:172
+msgid "forward SumBot"
+msgstr ""
+
+#: taextras.py:173
+msgid "move SumBot forward"
+msgstr ""
+
+#. TRANS: This string is shorthand for "move SumBot backward"
+#: taextras.py:175
+msgid "backward SumBot"
+msgstr ""
+
+#: taextras.py:176
+msgid "move SumBot backward"
+msgstr ""
+
+#: taextras.py:177
+msgid "stop SumBot"
+msgstr ""
+
+#: taextras.py:178
+msgid "stop the SumBot"
+msgstr ""
+
+#. TRANS: This string is shorthand for "turn SumBot left"
+#: taextras.py:180
+msgid "left SumBot"
+msgstr ""
+
+#: taextras.py:181
+msgid "turn left the SumBot"
+msgstr ""
+
+#. TRANS: This string is shorthand for "move SumBot right"
+#: taextras.py:183
+msgid "right SumBot"
+msgstr ""
+
+#: taextras.py:184
+msgid "turn right the SumBot"
+msgstr ""
+
+#. TRANS: The angle to the center is the angle SumBot must turn to
+#. face the center of the playing field
+#: taextras.py:187
+msgid "angle to center"
+msgstr ""
+
+#. TRANS: dohyo is the playing field
+#: taextras.py:189
+msgid "get the angle to the center of the dohyo"
+msgstr ""
+
+#. TRANS: The angle to the center is the angle SumBot must turn to
+#. face the Enemy (opponent)
+#: taextras.py:192
+msgid "angle to Enemy"
+msgstr ""
+
+#: taextras.py:193
+msgid "get the angle to the Enemy"
+msgstr ""
+
+#. TRANS: This string is shorthand for "x coordinate of SumBot"
+#: taextras.py:195
+msgid "x coor. SumBot"
+msgstr ""
+
+#: taextras.py:196
+msgid "get the x coordinate of the SumBot"
+msgstr ""
+
+#. TRANS: This string is shorthand for "y coordinate of SumBot"
+#: taextras.py:198
+msgid "y coor. SumBot"
+msgstr ""
+
+#: taextras.py:199
+msgid "get the y coordinate of the SumBot"
+msgstr ""
+
+#. TRANS: This string is shorthand for "x coordinate of SumBot's enemy"
+#: taextras.py:201
+msgid "x coor. Enemy"
+msgstr ""
+
+#: taextras.py:202
+msgid "get the x coordinate of the Enemy"
+msgstr ""
+
+#. TRANS: This string is shorthand for "y coordinate of SumBot's enemy"
+#: taextras.py:204
+msgid "y coor. Enemy"
+msgstr ""
+
+#: taextras.py:205
+msgid "get the y coordinate of the Enemy"
+msgstr ""
+
+#. TRANS: This string is shorthand for "rotation of SumBot"
+#: taextras.py:207
+msgid "rotation SumBot"
+msgstr ""
+
+#: taextras.py:208
+msgid "get the rotation of the Sumbot"
+msgstr ""
+
+#. TRANS: This string is shorthand for "rotation of SumBot's enemy"
+#: taextras.py:210
+msgid "rotation Enemy"
+msgstr ""
+
+#: taextras.py:211
+msgid "get the rotation of the Enemy"
+msgstr ""
+
+#: taextras.py:212
+msgid "distance to center"
+msgstr ""
+
+#. TRANS: dohyo is the playing field
+#: taextras.py:214
+msgid "get the distance to the center of the dohyo"
+msgstr ""
+
+#: taextras.py:215
+msgid "distance to Enemy"
+msgstr ""
+
+#: taextras.py:216
+msgid "get the distance to the Enemy"
+msgstr ""
+
+#: taextras.py:217
+msgid "update information"
+msgstr ""
+
+#: taextras.py:218
+msgid "update information from the server"
+msgstr ""
+
+#. TRANS: Please use similar terms to those used in the Physics Activity
+#: taextras.py:223
+msgid "Palette of physics blocks"
+msgstr ""
+
+#: taextras.py:224
+msgid "start polygon"
+msgstr ""
+
+#: taextras.py:225
+msgid "Begin defining a new polygon based on the current Turtle xy position."
+msgstr ""
+
+#: taextras.py:227
+msgid "add point"
+msgstr ""
+
+#: taextras.py:228
+msgid ""
+"Add a new point to the current polygon based on the current Turtle xy "
+"position."
+msgstr ""
+
+#: taextras.py:230
+msgid "end polygon"
+msgstr ""
+
+#: taextras.py:231
+msgid "Define a new polygon."
+msgstr ""
+
+#: taextras.py:232
+msgid "end filled polygon"
+msgstr ""
+
+#: taextras.py:233
+msgid "Not a simple polygon"
+msgstr ""
+
+#: taextras.py:234
+msgid "Define a new filled polygon."
+msgstr ""
+
+#: taextras.py:235
+msgid "triangle"
+msgstr ""
+
+#. TRANS: base of a triangle
+#: taextras.py:237
+msgid "base"
+msgstr ""
+
+#: taextras.py:238 taextras.py:244
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:894
+msgid "height"
+msgstr "hoogte"
+
+#: taextras.py:239
+msgid "Add a triangle object to the project."
+msgstr ""
+
+#: taextras.py:240
+msgid "circle"
+msgstr ""
+
+#: taextras.py:241
+msgid "Add a circle object to the project."
+msgstr ""
+
+#: taextras.py:242
+msgid "rectangle"
+msgstr ""
+
+#: taextras.py:243 plugins/turtle_blocks_extras/turtle_blocks_extras.py:870
+msgid "width"
+msgstr "wydte"
+
+#: taextras.py:245
+msgid "Add a rectangle object to the project."
+msgstr ""
+
+#: taextras.py:246
+msgid "reset"
+msgstr ""
+
+#: taextras.py:247
+msgid "Reset the project; clear the object list."
+msgstr ""
+
+#: taextras.py:248
+msgid "motor"
+msgstr ""
+
+#. TRANS: torque as in engine torque
+#: taextras.py:250
+msgid "torque"
+msgstr ""
+
+#: taextras.py:251
+msgid "speed"
+msgstr ""
+
+#: taextras.py:252
+msgid ""
+"Motor torque and speed range from 0 (off) to positive numbers; motor is "
+"placed on the most recent object created."
+msgstr ""
+
+#: taextras.py:254 taextras.py:417
+msgid "pin"
+msgstr ""
+
+#: taextras.py:255
+msgid "Pin an object down so that it cannot fall."
+msgstr ""
+
+#: taextras.py:256
+msgid "joint"
+msgstr ""
+
+#: taextras.py:257 TurtleArt/tabasics.py:199 TurtleArt/tabasics.py:265
msgid "x"
msgstr "x"
-#: TurtleArt/tabasics.py:199 TurtleArt/tabasics.py:265
+#: taextras.py:258 TurtleArt/tabasics.py:199 TurtleArt/tabasics.py:265
msgid "y"
msgstr "y"
-#: TurtleArt/tabasics.py:203 TurtleArt/tabasics.py:269
-#, fuzzy
+#: taextras.py:259
msgid ""
-"moves turtle to position xcor, ycor; (0, 0) is in the center of the screen."
-msgstr "skuif die skilpad na posisie x, y; (0,0) is in die middel van die skem."
+"Join two objects together (the most recent object created and the object at "
+"point x, y)."
+msgstr ""
-#
-#: TurtleArt/tabasics.py:213
-msgid "set heading"
-msgstr "stel rigting"
+#: taextras.py:261
+msgid "save as Physics activity"
+msgstr ""
-#: TurtleArt/tabasics.py:217
-#, fuzzy
-msgid "sets the heading of the turtle (0 is towards the top of the screen.)"
-msgstr "stel die rigting van die skilpad (0 is na die bokant van die skerm.)"
+#: taextras.py:262
+msgid "Save the project to the Journal as a Physics activity."
+msgstr ""
-#: TurtleArt/tabasics.py:225 TurtleArt/tawindow.py:3862
-#: TurtleArt/tawindow.py:3868 TurtleArtActivity.py:604
-msgid "xcor"
-msgstr "x-koord"
+#. TRANS: Here, gear means a toothed wheel, as in a clock-works
+#: taextras.py:264
+msgid "gear"
+msgstr ""
-#: TurtleArt/tabasics.py:226
+#: taextras.py:265
+msgid "Add a gear object to the project."
+msgstr ""
+
+#: taextras.py:266
+msgid "density"
+msgstr ""
+
+#: taextras.py:267
msgid ""
-"holds current x-coordinate value of the turtle (can be used in place of a "
-"number block)"
+"Set the density property for objects (density can be any positive number)."
msgstr ""
-"hou die huidige x-koordinaat van die skilpad (kan gebruik word i.p.v. 'n "
-"nommerblok)"
-#: TurtleArt/tabasics.py:236 TurtleArt/tawindow.py:3862
-#: TurtleArt/tawindow.py:3868 TurtleArtActivity.py:605
-msgid "ycor"
-msgstr "y-koord"
+#: taextras.py:269
+msgid "friction"
+msgstr ""
-#: TurtleArt/tabasics.py:237
+#: taextras.py:270
msgid ""
-"holds current y-coordinate value of the turtle (can be used in place of a "
-"number block)"
+"Set the friction property for objects (value from 0 to 1, where 0 turns "
+"friction off and 1 is strong friction)."
msgstr ""
-"hou die huidige y-koordinaat van die skilpad (kan gebruik word i.p.v. 'n "
-"nommerblok)"
-#: TurtleArt/tabasics.py:247 TurtleArt/tawindow.py:3863
-#: TurtleArt/tawindow.py:3869 TurtleArtActivity.py:605
-msgid "heading"
-msgstr "rigting"
+#. TRANS: bounciness is coefficient of restitution
+#: taextras.py:273
+msgid "bounciness"
+msgstr ""
-#: TurtleArt/tabasics.py:248
+#: taextras.py:274
msgid ""
-"holds current heading value of the turtle (can be used in place of a number "
-"block)"
+"Set the bounciness property for objects (a value from 0 to 1, where 0 means "
+"no bounce and 1 is very bouncy)."
msgstr ""
-"hou die huidige rigting van die skilpad (kan gebruik word i.p.v. 'n "
-"nommerblok)"
-#: TurtleArt/tabasics.py:282
-#, fuzzy
-msgid "Palette of pen commands"
-msgstr "palet van penbevele"
+#. TRANS: dynamic here means moving vs in a fixed position
+#: taextras.py:277
+msgid "dynamic"
+msgstr ""
-#: TurtleArt/tabasics.py:287 TurtleArt/tabasics.py:298
-msgid "fill screen"
-msgstr "vul skerm"
+#: taextras.py:278
+msgid ""
+"If dynamic = 1, the object can move; if dynamic = 0, it is fixed in position."
+msgstr ""
-#: TurtleArt/tabasics.py:287 TurtleArt/tabasics.py:298
+#. TRANS: WeDo is a robotics product of the LEGO company
+#: taextras.py:284
+msgid "Palette of WeDo blocks"
+msgstr ""
+
+#: taextras.py:285
+msgid "WeDo"
+msgstr ""
+
+#: taextras.py:286
+msgid "set current WeDo device"
+msgstr ""
+
+#: taextras.py:287
+msgid "number of WeDo devices"
+msgstr ""
+
+#: taextras.py:289
+msgid ""
+"tilt sensor output: (-1 == no tilt, 0 == tilt forward, 3 == tilt back, 1 == "
+"tilt left, 2 == tilt right)"
+msgstr ""
+
+#. TRANS: This string is shorthand for "output of the distance sensor"
+#: taextras.py:293
+msgid "distance sensor output"
+msgstr ""
+
+#: taextras.py:294
+msgid "Motor A"
+msgstr ""
+
+#: taextras.py:295
+msgid "returns the current value of Motor A"
+msgstr ""
+
+#: taextras.py:296
+msgid "Motor B"
+msgstr ""
+
+#: taextras.py:297
+msgid "returns the current value of Motor B"
+msgstr ""
+
+#: taextras.py:298
+msgid "set the value for Motor A"
+msgstr ""
+
+#: taextras.py:299
+msgid "set the value for Motor B"
+msgstr ""
+
+#: taextras.py:300
+msgid "WeDo is unavailable"
+msgstr ""
+
+#. TRANS: e.g., Wedo 2 is unavailable, defaulting to 1
+#: taextras.py:302
+#, python-format
+msgid "WeDo %d is unavailable; defaulting to 1"
+msgstr ""
+
+#. TRANS: %(device)s and %(wedo_number)d are substitution strings;
+#. please leave untranslated
+#: taextras.py:305
+#, python-format
+msgid "%(device)s is unavailable on WeDo %(wedo_number)d"
+msgstr ""
+
+#. TRANS: Lego NXT is a robotics product of the LEGO company
+#: taextras.py:311
+msgid "Palette of LEGO NXT blocks of motors"
+msgstr ""
+
+#: taextras.py:312
+msgid "Palette of LEGO NXT blocks of sensors"
+msgstr ""
+
+#. TRANS: touch sensor (implemented as a button)
+#: taextras.py:314
+msgid "touch"
+msgstr ""
+
+#. TRANS: distance sensor (implemented using ultrasonics)
+#: taextras.py:316
+msgid "ultrasonic"
+msgstr ""
+
+#: taextras.py:317 TurtleArt/tabasics.py:287 TurtleArt/tabasics.py:298
#: TurtleArt/tabasics.py:348
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1158
msgid "color"
msgstr "kleur"
-#: TurtleArt/tabasics.py:287 TurtleArt/tabasics.py:299
-#: TurtleArt/tabasics.py:358
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1154
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1159
-msgid "shade"
-msgstr "skadu"
+#: taextras.py:318
+#, fuzzy
+msgid "light"
+msgstr "regs"
-#: TurtleArt/tabasics.py:291 TurtleArt/tabasics.py:303
-msgid "fills the background with (color, shade)"
-msgstr "vul die agtergrond met (kleur, skadu)"
+#: taextras.py:319 plugins/audio_sensors/audio_sensors.py:83
+#: plugins/audio_sensors/audio_sensors.py:98 pysamples/grecord.py:205
+msgid "sound"
+msgstr "klank"
-#: TurtleArt/tabasics.py:299 TurtleArt/tabasics.py:367
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1155
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1160
-msgid "gray"
+#: taextras.py:320
+msgid "grey"
msgstr ""
-#: TurtleArt/tabasics.py:313
-msgid "set color"
-msgstr "stel kleur"
+#. TRANS: The brick is the NXT controller
+#: taextras.py:322
+msgid "Please check the connection with the brick"
+msgstr ""
-#: TurtleArt/tabasics.py:317
-#, fuzzy
-msgid "sets color of the line drawn by the turtle"
-msgstr "stel die"
+#: taextras.py:323
+#, python-format
+msgid "Invalid port '%s'. Port must be: PORT A, B or C"
+msgstr ""
-#: TurtleArt/tabasics.py:325
-msgid "set shade"
-msgstr "stel skadu"
+#: taextras.py:324
+#, python-format
+msgid "Invalid port '%s'. Port must be: PORT 1, 2, 3 or 4"
+msgstr ""
-#: TurtleArt/tabasics.py:329
-#, fuzzy
-msgid "sets shade of the line drawn by the turtle"
-msgstr "stel die skadu van die lyn wat die skilpad teken"
+#: taextras.py:325
+msgid "The value of power must be between -127 to 127"
+msgstr ""
-#: TurtleArt/tabasics.py:337
-msgid "set gray"
+#: taextras.py:326
+#, python-format
+msgid "The parameter must be a integer, not '%s'"
msgstr ""
-#: TurtleArt/tabasics.py:340
-#, fuzzy
-msgid "sets gray level of the line drawn by the turtle"
-msgstr "stel die skadu van die lyn wat die skilpad teken"
+#: taextras.py:327
+msgid "An error has occurred: check all connections and try to reconnect"
+msgstr ""
-#: TurtleArt/tabasics.py:349
-msgid "holds current pen color (can be used in place of a number block)"
+#: taextras.py:328
+#, python-format
+msgid "NXT found %s bricks"
msgstr ""
-"hou die huidige kleur van die pen (kan gebruk word i.p.v. 'n nommerblok)"
-#: TurtleArt/tabasics.py:359
-msgid "holds current pen shade"
+#: taextras.py:329
+msgid "NXT not found"
msgstr ""
-#: TurtleArt/tabasics.py:368
-#, fuzzy
-msgid "holds current gray level (can be used in place of a number block)"
-msgstr "hou die huidige skaal (kan gebruik word i.p.v. 'n nommerblok)"
+#: taextras.py:330
+#, python-format
+msgid "Brick number %s was not found"
+msgstr ""
-#: TurtleArt/tabasics.py:376
-msgid "pen up"
-msgstr "pen op"
+#: taextras.py:331
+msgid "refresh NXT"
+msgstr ""
-#: TurtleArt/tabasics.py:379
-#, fuzzy
-msgid "Turtle will not draw when moved."
-msgstr "skilpad sal nie teken wanneer hy geskuif word nie."
+#: taextras.py:332
+msgid "Search for a connected NXT brick."
+msgstr ""
-#: TurtleArt/tabasics.py:385
-msgid "pen down"
-msgstr "pen af"
+#: taextras.py:333
+msgid "NXT"
+msgstr ""
-#: TurtleArt/tabasics.py:388
-#, fuzzy
-msgid "Turtle will draw when moved."
-msgstr "skilpad sal teken wanneer hy geskuif word."
+#: taextras.py:334
+msgid "set current NXT device"
+msgstr ""
-#: TurtleArt/tabasics.py:394
-msgid "set pen size"
-msgstr "stel pengrootte"
+#: taextras.py:335
+msgid "number of NXT devices"
+msgstr ""
-#: TurtleArt/tabasics.py:398
-#, fuzzy
-msgid "sets size of the line drawn by the turtle"
-msgstr "stel die grootte van die lyn wat die skilpad teken"
+#: taextras.py:336
+msgid "brick name"
+msgstr ""
-#: TurtleArt/tabasics.py:408
-msgid "start fill"
+#: taextras.py:337
+msgid "Get the name of a brick."
msgstr ""
-#: TurtleArt/tabasics.py:410
-msgid "starts filled polygon (used with end fill block)"
+#: taextras.py:338
+msgid "play tone"
msgstr ""
-#: TurtleArt/tabasics.py:417
-msgid "end fill"
+#: taextras.py:339
+msgid "frequency"
msgstr ""
-#: TurtleArt/tabasics.py:419
-msgid "completes filled polygon (used with start fill block)"
+#: taextras.py:340 plugins/turtle_blocks_extras/turtle_blocks_extras.py:445
+msgid "time"
msgstr ""
-#: TurtleArt/tabasics.py:426
-msgid "pen size"
-msgstr "pengrootte"
+#: taextras.py:341
+msgid "Play a tone at frequency for time."
+msgstr ""
-#: TurtleArt/tabasics.py:427
-msgid "holds current pen size (can be used in place of a number block)"
-msgstr "hou die huidige pengrootte (kan gebruk word i.p.v. 'n nommerblok)"
+#. TRANS: turn is the action
+#: taextras.py:343
+msgid ""
+"turn motor\n"
+"\n"
+msgstr ""
-#: TurtleArt/tabasics.py:441
-#, fuzzy
-msgid "Palette of pen colors"
-msgstr "palet van penbevele"
+#: taextras.py:344
+msgid "port"
+msgstr ""
-#: TurtleArt/tabasics.py:443
+#: taextras.py:345
+msgid "power"
+msgstr ""
+
+#. TRANS: rotations is quantity of turns
+#: taextras.py:347
+msgid "rotations"
+msgstr ""
+
+#: taextras.py:348
+msgid "turn a motor"
+msgstr ""
+
+#: taextras.py:349
+msgid ""
+"synchronize\n"
+"\n"
+"motors"
+msgstr ""
+
+#: taextras.py:350
+msgid "steering"
+msgstr ""
+
+#: taextras.py:351
+msgid "synchronize two motors connected in PORT B and PORT C"
+msgstr ""
+
+#: taextras.py:352
+msgid "PORT A"
+msgstr ""
+
+#: taextras.py:353
+msgid "PORT A of the brick"
+msgstr ""
+
+#: taextras.py:354
+msgid "PORT B"
+msgstr ""
+
+#: taextras.py:355
+msgid "PORT B of the brick"
+msgstr ""
+
+#: taextras.py:356
+msgid "PORT C"
+msgstr ""
+
+#: taextras.py:357
+msgid "PORT C of the brick"
+msgstr ""
+
+#: taextras.py:358
+msgid "start motor"
+msgstr ""
+
+#: taextras.py:359
+msgid "Run a motor forever."
+msgstr ""
+
+#: taextras.py:360
+msgid "brake motor"
+msgstr ""
+
+#: taextras.py:361
+msgid "Stop a specified motor."
+msgstr ""
+
+#. TRANS: reset is used to reset the counter associated with the motor
+#: taextras.py:363
+msgid "reset motor"
+msgstr ""
+
+#: taextras.py:364
+msgid "Reset the motor counter."
+msgstr ""
+
+#: taextras.py:365
+msgid "motor position"
+msgstr ""
+
+#: taextras.py:366
+msgid "Get the motor position."
+msgstr ""
+
+#: taextras.py:367
+msgid "PORT 1"
+msgstr ""
+
+#: taextras.py:368
+msgid "PORT 1 of the brick"
+msgstr ""
+
+#: taextras.py:369
#, fuzzy
-msgid "red"
+msgid "read"
msgstr "rooi"
-#: TurtleArt/tabasics.py:444
-#, fuzzy
-msgid "orange"
-msgstr "oranje"
+#: taextras.py:370
+msgid "sensor"
+msgstr ""
-#: TurtleArt/tabasics.py:446
-#, fuzzy
-msgid "yellow"
-msgstr "geel"
+#: taextras.py:371
+msgid "Read sensor output."
+msgstr ""
-#: TurtleArt/tabasics.py:448
-msgid "green"
+#: taextras.py:372
+msgid "PORT 2"
msgstr ""
-#: TurtleArt/tabasics.py:449
-msgid "cyan"
+#: taextras.py:373
+msgid "PORT 2 of the brick"
msgstr ""
-#: TurtleArt/tabasics.py:450
-msgid "blue"
+#: taextras.py:374
+msgid "light sensor"
msgstr ""
-#: TurtleArt/tabasics.py:451
-msgid "purple"
+#: taextras.py:375
+msgid "grey sensor"
msgstr ""
-#: TurtleArt/tabasics.py:453
-msgid "white"
+#: taextras.py:376
+msgid "PORT 3"
msgstr ""
-#: TurtleArt/tabasics.py:454
-#, fuzzy
-msgid "black"
-msgstr "agtertoe"
+#: taextras.py:377
+msgid "PORT 3 of the brick"
+msgstr ""
-#: TurtleArt/tabasics.py:460
-msgid "set text color"
-msgstr "stel tekskleur"
+#: taextras.py:378
+msgid "touch sensor"
+msgstr ""
-#: TurtleArt/tabasics.py:463
-#, fuzzy
-msgid "sets color of text drawn by the turtle"
-msgstr "stel die kleur van die lyn wat die skilpad teken"
+#: taextras.py:379
+msgid "distance sensor"
+msgstr ""
-#: TurtleArt/tabasics.py:471
-msgid "set text size"
-msgstr "stel teksgrootte"
+#: taextras.py:380
+msgid "PORT 4"
+msgstr ""
-#: TurtleArt/tabasics.py:474
-#, fuzzy
-msgid "sets size of text drawn by the turtle"
-msgstr "stel die grootte van die teks wat die skilpad teken"
+#: taextras.py:381
+msgid "PORT 4 of the brick"
+msgstr ""
-#: TurtleArt/tabasics.py:557
-#, fuzzy
-msgid "Palette of numeric operators"
-msgstr "palet van numeriese bewerkers"
+#: taextras.py:382
+msgid "sound sensor"
+msgstr ""
-#: TurtleArt/tabasics.py:563
-msgid "plus"
+#: taextras.py:383
+msgid "color sensor"
msgstr ""
-#: TurtleArt/tabasics.py:567
+#. TRANS: set light is used to set the light level associated with
+#. the color sensor (which can emit light as well as sense it)
+#: taextras.py:386
+msgid "set light"
+msgstr ""
+
+#: taextras.py:387
+msgid "Set color sensor light."
+msgstr ""
+
+#. TRANS: the battery level is the charge level of the brick
+#: taextras.py:389
+msgid "battery level"
+msgstr ""
+
+#: taextras.py:390
+msgid "Get battery level of the brick"
+msgstr ""
+
+#. TRANS: Arduino plugin to control an Arduino board
+#: taextras.py:395
+msgid "HIGH"
+msgstr ""
+
+#: taextras.py:396
+msgid "LOW"
+msgstr ""
+
+#: taextras.py:397
+msgid "INPUT"
+msgstr ""
+
+#: taextras.py:398
+msgid "OUTPUT"
+msgstr ""
+
+#. TRANS: PWM is pulse-width modulation
+#: taextras.py:400
+msgid "PWM"
+msgstr ""
+
+#: taextras.py:401
+msgid "SERVO"
+msgstr ""
+
+#: taextras.py:402
+msgid "ERROR: Check the Arduino and the number of port."
+msgstr ""
+
+#: taextras.py:403
+msgid "ERROR: Value must be a number from 0 to 255."
+msgstr ""
+
+#: taextras.py:404
+msgid "ERROR: Value must be either HIGH or LOW."
+msgstr ""
+
+#: taextras.py:405
+msgid "ERROR: The mode must be either INPUT, OUTPUT, PWM or SERVO."
+msgstr ""
+
+#: taextras.py:406
+msgid "refresh Arduino"
+msgstr ""
+
+#: taextras.py:407
+msgid "Search for connected Arduinos."
+msgstr ""
+
+#: taextras.py:408
+msgid "Arduino"
+msgstr ""
+
+#: taextras.py:409
+msgid "set current Arduino board"
+msgstr ""
+
+#: taextras.py:410
+msgid "number of Arduinos"
+msgstr ""
+
+#: taextras.py:411
+msgid "number of Arduino boards"
+msgstr ""
+
+#: taextras.py:412
+msgid "Arduino name"
+msgstr ""
+
+#: taextras.py:413
+msgid "Get the name of an Arduino."
+msgstr ""
+
+#. TRANS: pin mode is used to specify the mode (INPUT, OUTPUT, etc)
+#. in which an I/O pin is being used.
+#: taextras.py:416
+msgid "pin mode"
+msgstr ""
+
+#: taextras.py:418
#, fuzzy
-msgid "adds two alphanumeric inputs"
-msgstr "tel twee numeriese insetwaardes bymekaar"
+msgid "mode"
+msgstr "modulo"
-#: TurtleArt/tabasics.py:575
-msgid "minus"
+#: taextras.py:419
+msgid "Select the pin function (INPUT, OUTPUT, PWM, SERVO)."
msgstr ""
-#: TurtleArt/tabasics.py:578
-msgid "subtracts bottom numeric input from top numeric input"
-msgstr "trek die onderste numeriese insetwaarde van die boonste een af"
+#: taextras.py:420
+msgid "analog write"
+msgstr ""
-#: TurtleArt/tabasics.py:589
-msgid "multiply"
+#: taextras.py:421 TurtleArt/tabasics.py:928 TurtleArt/tawindow.py:4189
+msgid "value"
msgstr ""
-#: TurtleArt/tabasics.py:592
-msgid "multiplies two numeric inputs"
-msgstr "vermenigvuldig twee numeriese insetwaardes"
+#: taextras.py:422
+msgid "Write analog value in specified port."
+msgstr ""
-#: TurtleArt/tabasics.py:601
-msgid "divide"
+#: taextras.py:423
+msgid "analog read"
msgstr ""
-#: TurtleArt/tabasics.py:604
+#: taextras.py:424
msgid ""
-"divides top numeric input (numerator) by bottom numeric input (denominator)"
+"Read value from analog port. Value may be between 0 and 1023. Use Vref to "
+"determine voltage. For USB, volt=((read)*5)/1024) approximately."
msgstr ""
-"deel die boonste numeriese insetwaarde (teller) deur die onderste een "
-"(noemer)"
-#: TurtleArt/tabasics.py:614
-msgid "identity"
+#: taextras.py:426
+msgid "digital write"
msgstr ""
-#: TurtleArt/tabasics.py:616
-msgid "identity operator used for extending blocks"
-msgstr "identitietsbewerker om blokke uit te brei"
+#: taextras.py:427
+msgid "Write digital value to specified port."
+msgstr ""
-#: TurtleArt/tabasics.py:624 TurtleArt/tabasics.py:625
-msgid "mod"
-msgstr "modulo"
+#: taextras.py:428
+msgid "digital read"
+msgstr ""
-#: TurtleArt/tabasics.py:628
-msgid "modular (remainder) operator"
-msgstr "modulêre (reswaarde) operateur"
+#: taextras.py:429
+msgid "Read value from digital port."
+msgstr ""
-#: TurtleArt/tabasics.py:635
-msgid "√"
+#: taextras.py:430
+msgid "Set HIGH value for digital port."
msgstr ""
-#: TurtleArt/tabasics.py:636
-msgid "square root"
+#: taextras.py:431
+msgid "Configure Arduino port for digital input."
msgstr ""
-#: TurtleArt/tabasics.py:639
-#, fuzzy
-msgid "calculates square root"
-msgstr "werk die vierkantswortel uit"
+#: taextras.py:432
+msgid "Configure Arduino port to drive a servo."
+msgstr ""
-#: TurtleArt/tabasics.py:646
-msgid "random"
-msgstr "ewekansig"
+#: taextras.py:433
+msgid "Set LOW value for digital port."
+msgstr ""
-#: TurtleArt/tabasics.py:646
-msgid "min"
-msgstr "min"
+#: taextras.py:434
+msgid "Configure Arduino port for digital output."
+msgstr ""
-#: TurtleArt/tabasics.py:646
-msgid "max"
-msgstr "maks"
+#: taextras.py:435
+msgid "Configure Arduino port for PWM (pulse-width modulation)."
+msgstr ""
-#: TurtleArt/tabasics.py:650
-#, fuzzy
-msgid "returns random number between minimum (top) and maximum (bottom) values"
+#. TRANS: plugin to control an ExpEyes device
+#: taextras.py:440
+msgid "Palette of Expeyes blocks"
msgstr ""
-"gee 'n ewekansige nommerwaarde tussen minimum- (links) en maksimumwaardes "
-"(regs)"
-#: TurtleArt/tabasics.py:662
-msgid "number"
-msgstr "syfer"
+#. TRANS: Programmable voltage output
+#: taextras.py:442
+msgid "set PVS"
+msgstr ""
-#: TurtleArt/tabasics.py:663
-msgid "used as numeric input in mathematic operators"
-msgstr "gebruik as numeriese insetwaarde in wiskundige operateurs"
+#: taextras.py:443
+msgid "set programmable voltage output"
+msgstr ""
-#: TurtleArt/tabasics.py:671
-msgid "greater than"
+#. TRANS: Square wave 1 voltage output
+#: taextras.py:445
+msgid "set SQR1 voltage"
msgstr ""
-#: TurtleArt/tabasics.py:674
-msgid "logical greater-than operator"
-msgstr "logiese groter-as bewerker"
+#: taextras.py:446
+msgid "set square wave 1 voltage output"
+msgstr ""
-#: TurtleArt/tabasics.py:683
-msgid "less than"
+#. TRANS: Square wave 2 voltage output
+#: taextras.py:448
+msgid "set SQR2 voltage"
msgstr ""
-#: TurtleArt/tabasics.py:687
-msgid "logical less-than operator"
-msgstr "logiese kleiner-as bewerker"
+#: taextras.py:449
+msgid "set square wave 2 voltage output"
+msgstr ""
-#: TurtleArt/tabasics.py:695
-msgid "equal"
+#. TRANS: Digital output level
+#: taextras.py:451
+msgid "set OD1"
msgstr ""
-#: TurtleArt/tabasics.py:699
-msgid "logical equal-to operator"
-msgstr "logiese gelyk-aan bewerker"
+#: taextras.py:452
+msgid "set digital output level (OD1) low (0) or high (1)"
+msgstr ""
-#: TurtleArt/tabasics.py:705
-msgid "not"
-msgstr "NIE"
+#. TRANS: Input 1 voltage level
+#: taextras.py:454
+msgid "IN1 level"
+msgstr ""
-#: TurtleArt/tabasics.py:708
-msgid "logical NOT operator"
-msgstr "logiese NIE-bewerker"
+#: taextras.py:455
+msgid ""
+"returns 1 if IN1 voltage level >2.5 volts, 0 if IN1 voltage level <= 2.5 "
+"volts"
+msgstr ""
-#: TurtleArt/tabasics.py:714 TurtleArt/tabasics.py:717
-msgid "and"
-msgstr "EN"
+#. TRANS: Input 2 voltage level
+#: taextras.py:458
+msgid "IN2 level"
+msgstr ""
-#: TurtleArt/tabasics.py:718
-msgid "logical AND operator"
-msgstr "logiese EN-bewerker"
+#: taextras.py:459
+msgid ""
+"returns 1 if IN2 voltage level >2.5 volts, 0 if IN2 voltage level <= 2.5 "
+"volts"
+msgstr ""
-#: TurtleArt/tabasics.py:725 TurtleArt/tabasics.py:728
-msgid "or"
-msgstr "OF"
+#. TRANS: Resistive sensor voltage level
+#: taextras.py:462
+msgid "SEN level"
+msgstr ""
-#: TurtleArt/tabasics.py:729
-msgid "logical OR operator"
-msgstr "logiese OF-bewerker"
+#: taextras.py:463
+msgid ""
+"returns 1 if resistive sensor (SEN) voltage level > 2.5 volts, 0 if SEN "
+"voltage level <= 2.5 volts"
+msgstr ""
-#: TurtleArt/tabasics.py:738
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:98
+#: taextras.py:465
+msgid "capture"
+msgstr ""
+
+#: taextras.py:466
+msgid "input"
+msgstr ""
+
+#: taextras.py:467
#, fuzzy
-msgid "Palette of flow operators"
-msgstr "palet van vloeibewerkers"
+msgid "samples"
+msgstr ""
+"#-#-#-#-# af.po (PACKAGE VERSION) #-#-#-#-#\n"
+"#-#-#-#-# af.po (PACKAGE VERSION) #-#-#-#-#\n"
+"#-#-#-#-# af.po (PACKAGE VERSION) #-#-#-#-#\n"
+"#-#-#-#-# af.po (TURTLEART) #-#-#-#-#\n"
+"Voorbeelde"
-#: TurtleArt/tabasics.py:743
-msgid "wait"
-msgstr "wag"
+#: taextras.py:468
+msgid "interval"
+msgstr ""
-#: TurtleArt/tabasics.py:747
-msgid "pauses program execution a specified number of seconds"
+#. TRANS: MS is microseconds
+#: taextras.py:470
+msgid ""
+"capture multiple samples from input at interval (MS); results pushed to FIFO"
msgstr ""
-#: TurtleArt/tabasics.py:754
-msgid "forever"
-msgstr "vir altyd"
+#. TRANS: Analog input 1 voltage level
+#: taextras.py:473
+msgid "A1"
+msgstr ""
-#: TurtleArt/tabasics.py:758
-#, fuzzy
-msgid "loops forever"
-msgstr "gaan vir altyd in 'n lus in"
+#: taextras.py:474
+msgid "read analog input 1 voltage"
+msgstr ""
-#: TurtleArt/tabasics.py:765 TurtleArt/tabasics.py:769
-msgid "repeat"
-msgstr "herhaal"
+#. TRANS: Analog input 2 voltage level
+#: taextras.py:476
+msgid "A2"
+msgstr ""
-#: TurtleArt/tabasics.py:770
-#, fuzzy
-msgid "loops specified number of times"
-msgstr "gaan 'n gespesifiseerde hoeveelheid kere in 'n lus in"
+#: taextras.py:477
+msgid "read analog input 2 voltage"
+msgstr ""
-#: TurtleArt/tabasics.py:776 TurtleArt/tabasics.py:789
-msgid "if"
-msgstr "as"
+#. TRANS: Read input 1 voltage
+#: taextras.py:479
+msgid "IN1"
+msgstr ""
-#: TurtleArt/tabasics.py:776 TurtleArt/tabasics.py:789
-msgid "then"
-msgstr "dan"
+#: taextras.py:480
+msgid "read input 1 voltage"
+msgstr ""
-#: TurtleArt/tabasics.py:779
-msgid "if then"
+#. TRANS: Read input 2 voltage
+#: taextras.py:482
+msgid "IN2"
msgstr ""
-#: TurtleArt/tabasics.py:781
-msgid "if-then operator that uses boolean operators from Numbers palette"
-msgstr "AS-DAN-bewerker wat boolse bewerkers van die Syferpalet gebruik"
+#: taextras.py:483
+msgid "read input 2 voltage"
+msgstr ""
-#: TurtleArt/tabasics.py:789
-msgid "else"
-msgstr "andersins"
+#. TRANS: Read analog sensor input voltage
+#: taextras.py:485
+msgid "SEN"
+msgstr ""
-#: TurtleArt/tabasics.py:793 TurtleArt/tabasics.py:801
-msgid "if then else"
+#: taextras.py:486
+msgid "read analog sensor input voltage"
msgstr ""
-#: TurtleArt/tabasics.py:794 TurtleArt/tabasics.py:802
-msgid "if-then-else operator that uses boolean operators from Numbers palette"
-msgstr "AS-DAN-ANDERS-bewerker wat boolse bewerkers van die Syferpalet gebruik"
+#. TRANS: Read square wave 1 input voltage
+#: taextras.py:488
+msgid "SQR1"
+msgstr ""
-#: TurtleArt/tabasics.py:811
-msgid "horizontal space"
+#: taextras.py:489
+msgid "read square wave 1 voltage"
msgstr ""
+#. TRANS: Read square wave 2 input voltage
+#: taextras.py:491
+msgid "SQR2"
+msgstr ""
+
+#: taextras.py:492
+msgid "read square wave 2 voltage"
+msgstr ""
+
+#. TRANS: Read programmable voltage
+#: taextras.py:494
+msgid "PVS"
+msgstr ""
+
+#: taextras.py:495
+msgid "read programmable voltage"
+msgstr ""
+
+#: taextras.py:496
+msgid "Expeyes device not found"
+msgstr ""
+
+#: TurtleArt/taconstants.py:209 TurtleArt/taconstants.py:231
+#: TurtleArt/taconstants.py:252 TurtleArt/taconstants.py:294
+#: TurtleArt/taconstants.py:336 TurtleArt/taconstants.py:378
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:963
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:978
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:993
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1008
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1023
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1038
+#, fuzzy
+msgid "Title"
+msgstr "titel"
+
+#: TurtleArt/tabasics.py:446
+#, fuzzy
+msgid "yellow"
+msgstr "geel"
+
+#: TurtleArt/tabasics.py:781
+msgid "if-then operator that uses boolean operators from Numbers palette"
+msgstr "AS-DAN-bewerker wat boolse bewerkers van die Syferpalet gebruik"
+
#: TurtleArt/tabasics.py:812
#, fuzzy
msgid "jogs stack right"
msgstr "skuif stapel regs"
-#: TurtleArt/tabasics.py:819
-msgid "vertical space"
-msgstr ""
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:141
+msgid "Sugar Journal media object"
+msgstr "Sugar Joernaal media-objek"
+
+#: TurtleArt/tabasics.py:919
+msgid "box 2"
+msgstr "hokkie 2"
+
+#: TurtleArt/tabasics.py:909
+msgid "box 1"
+msgstr "hokkie 1"
+
+#: TurtleArtActivity.py:682 TurtleArtActivity.py:892 turtleblocks.py:401
+msgid "Step"
+msgstr "Stap"
+
+#: TurtleArt/tabasics.py:592
+msgid "multiplies two numeric inputs"
+msgstr "vermenigvuldig twee numeriese insetwaardes"
+
+#: TurtleArtActivity.py:280 TurtleArtActivity.py:882 turtleblocks.py:392
+msgid "Hide palette"
+msgstr "Versteek palet"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:165
+msgid "Sugar Journal video object"
+msgstr "Sugar Joernaal video-objek"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:881
+msgid "xcor of right of screen"
+msgstr "x-koordinaat van die regterkant van die skerm"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:457
+#, fuzzy
+msgid "Palette of extra options"
+msgstr "palet van ekstra opsies"
+
+#: TurtleArt/tabasics.py:247 TurtleArt/tawindow.py:3863
+#: TurtleArt/tawindow.py:3869 TurtleArtActivity.py:605
+msgid "heading"
+msgstr "rigting"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:198
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:211
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:226
+#, fuzzy
+msgid "draws text or show media from the Journal"
+msgstr "teken teks of wys media van die Joernaal"
#: TurtleArt/tabasics.py:820
#, fuzzy
msgid "jogs stack down"
msgstr "skuif stapel af"
+#: TurtleArt/tabasics.py:628
+msgid "modular (remainder) operator"
+msgstr "modulêre (reswaarde) operateur"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:949
+#, fuzzy
+msgid "bottom y"
+msgstr "onderkant"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:624
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:640
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:656
+msgid "runs code found in the tamyblock.py module found in the Journal"
+msgstr ""
+"voer die kode uit wat in die tamyblock.py module onder die Joernaal gevind "
+"word"
+
+#: TurtleArt/tabasics.py:385
+msgid "pen down"
+msgstr "pen af"
+
+#: TurtleArt/tabasics.py:743
+msgid "wait"
+msgstr "wag"
+
+#: TurtleArt/tabasics.py:928 TurtleArt/tabasics.py:942
+msgid "box"
+msgstr "hokkie"
+
+#: TurtleArt/tabasics.py:876 TurtleArt/tawindow.py:4139
+#, fuzzy
+msgid "invokes named action stack"
+msgstr "roep die beoemde aksiestapel in"
+
+#: TurtleArt/tabasics.py:860 TurtleArt/tabasics.py:863
+#: TurtleArt/tabasics.py:871 TurtleArt/tabasics.py:875
+#: TurtleArt/tawindow.py:1292 TurtleArt/tawindow.py:1371
+#: TurtleArt/tawindow.py:1384 TurtleArt/tawindow.py:1854
+#: TurtleArt/tawindow.py:4125
+msgid "action"
+msgstr "aksie"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:117
+#, fuzzy
+msgid "do-until-True operator that uses boolean operators from Numbers palette"
+msgstr "AS-DAN-ANDERS-bewerker wat boolse bewerkers van die Syferpalet gebruik"
+
+#: TurtleArt/tabasics.py:922
+#, fuzzy
+msgid "Variable 2 (numeric value)"
+msgstr "veranderlike 2"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:873
+msgid "the canvas width"
+msgstr "wydte van die werksoppervlak"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:519
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:529
+#, fuzzy
+msgid "empty heap?"
+msgstr "maak hoop skoon"
+
+#: TurtleArt/tabasics.py:948 TurtleArt/tawindow.py:4166
+msgid "named variable (numeric value)"
+msgstr "benoemde veranderlike"
+
+#: TurtleArt/tawindow.py:1000 TurtleArt/tawindow.py:1470
+#, fuzzy
+msgid "next"
+msgstr "teks"
+
+#: TurtleArt/tabasics.py:394
+msgid "set pen size"
+msgstr "stel pengrootte"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:819
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:981
+msgid "presentation template: select Journal object (no description)"
+msgstr "voorleggingstemplaat: Kies 'n Joernaalobjek (sonder beskrywing)"
+
+#: TurtleArt/tabasics.py:958
+#, fuzzy
+msgid "top of Action 1 stack"
+msgstr "bokant van aksie 1 stapel"
+
+#: TurtleArt/tabasics.py:738
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:98
+#, fuzzy
+msgid "Palette of flow operators"
+msgstr "palet van vloeibewerkers"
+
+#: TurtleArt/tabasics.py:794 TurtleArt/tabasics.py:802
+msgid "if-then-else operator that uses boolean operators from Numbers palette"
+msgstr "AS-DAN-ANDERS-bewerker wat boolse bewerkers van die Syferpalet gebruik"
+
+#
+#: TurtleArt/tabasics.py:213
+msgid "set heading"
+msgstr "stel rigting"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:774
+#, fuzzy
+msgid "declutters canvas by hiding blocks"
+msgstr "maak werksoppervlak skoon deur blokke te versteek"
+
+#: TurtleArt/tabasics.py:856
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:189
+msgid "string value"
+msgstr "stringwaarde"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:175
+msgid "description"
+msgstr "beskrywing"
+
+#: TurtleArt/tabasics.py:471
+msgid "set text size"
+msgstr "stel teksgrootte"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:833
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1026
+msgid "presentation template: select four Journal objects"
+msgstr "voorleggingstemplaat: Kies vier Joernaalobjekte"
+
+#: TurtleArt/tabasics.py:340
+#, fuzzy
+msgid "sets gray level of the line drawn by the turtle"
+msgstr "stel die skadu van die lyn wat die skilpad teken"
+
#: TurtleArt/tabasics.py:826
msgid "stop action"
msgstr "stop aksie"
-#: TurtleArt/tabasics.py:829
-msgid "stops current action"
+#: TurtleArt/tabasics.py:287 TurtleArt/tabasics.py:299
+#: TurtleArt/tabasics.py:358
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1154
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1159
+msgid "shade"
+msgstr "skadu"
+
+#: TurtleArt/tabasics.py:291 TurtleArt/tabasics.py:303
+msgid "fills the background with (color, shade)"
+msgstr "vul die agtergrond met (kleur, skadu)"
+
+#: TurtleArt/tabasics.py:376
+msgid "pen up"
+msgstr "pen op"
+
+#: TurtleArt/tabasics.py:444
+#, fuzzy
+msgid "orange"
+msgstr "oranje"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:467
+#, fuzzy
+msgid "pushes value onto FILO (first-in last-out heap)"
+msgstr "druk die waarde op die EILU (eerste-in-laaste-uit) stapel"
+
+#: TurtleArt/tabasics.py:776 TurtleArt/tabasics.py:789
+msgid "then"
+msgstr "dan"
+
+#: TurtleArt/tabasics.py:705
+msgid "not"
+msgstr "NIE"
+
+#: TurtleArt/tabasics.py:178
+#, fuzzy
+msgid "turns turtle clockwise (angle in degrees)"
+msgstr "draai die skilpad kloksgewys (gee die hoek in grade)"
+
+#: TurtleArt/tabasics.py:368
+#, fuzzy
+msgid "holds current gray level (can be used in place of a number block)"
+msgstr "hou die huidige skaal (kan gebruik word i.p.v. 'n nommerblok)"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:857
+msgid "xcor of left of screen"
+msgstr "x-koordinaat van die linkerkant van die skerm"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:685
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:756
+#, fuzzy
+msgid "turtle"
+msgstr "Skilpad"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:772
+msgid "hide blocks"
+msgstr "versteek blokke"
+
+#: TurtleArt/tabasics.py:687
+msgid "logical less-than operator"
+msgstr "logiese kleiner-as bewerker"
+
+#: TurtleArt/tabasics.py:883
+msgid "store in box 1"
+msgstr "stoor in hokkie 1"
+
+#: TurtleArt/tabasics.py:896
+msgid "store in box 2"
+msgstr "stoor in hokkie 2"
+
+#: TurtleArt/tabasics.py:226
+msgid ""
+"holds current x-coordinate value of the turtle (can be used in place of a "
+"number block)"
msgstr ""
+"hou die huidige x-koordinaat van die skilpad (kan gebruik word i.p.v. 'n "
+"nommerblok)"
-#: TurtleArt/tabasics.py:838
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:549
+msgid "print"
+msgstr "druk"
+
+#: TurtleArtActivity.py:166 TurtleArtActivity.py:709 TurtleArtActivity.py:823
+#: TurtleArtActivity.py:853 turtleblocks.py:360
+msgid "Save as Logo"
+msgstr "Stoor as Logo"
+
+#: TurtleArt/tabasics.py:317
#, fuzzy
-msgid "Palette of variable blocks"
-msgstr "palet van veranderlike blokke"
+msgid "sets color of the line drawn by the turtle"
+msgstr "stel die"
-#: TurtleArt/tabasics.py:843 pysamples/grecord.py:213
-msgid "start"
-msgstr "begin"
+#: TurtleArt/tabasics.py:460
+msgid "set text color"
+msgstr "stel tekskleur"
+
+#: TurtleArt/tabasics.py:662
+msgid "number"
+msgstr "syfer"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:124
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:715
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:886
+msgid "top"
+msgstr "bokant"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:234
+msgid "set scale"
+msgstr "stel skaal"
#: TurtleArt/tabasics.py:846
msgid "connects action to toolbar run buttons"
msgstr "koppel die aksie aan die die nutsbalk se uitvoerknoppies"
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:897
+msgid "the canvas height"
+msgstr "hoogte van die werksoppervlak"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:994
+#, fuzzy
+msgid "presentation 2x1"
+msgstr "voorlegging"
+
+#: TurtleArt/tabasics.py:714 TurtleArt/tabasics.py:717
+msgid "and"
+msgstr "EN"
+
+#: TurtleArt/tabasics.py:427
+msgid "holds current pen size (can be used in place of a number block)"
+msgstr "hou die huidige pengrootte (kan gebruk word i.p.v. 'n nommerblok)"
+
+#: TurtleArt/tabasics.py:313
+msgid "set color"
+msgstr "stel kleur"
+
+#: TurtleArt/tabasics.py:646
+msgid "min"
+msgstr "min"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:724
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:735
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:746
+#, fuzzy
+msgid "loads a block"
+msgstr "laai my blok"
+
+#: TurtleArt/tabasics.py:282
+#, fuzzy
+msgid "Palette of pen commands"
+msgstr "palet van penbevele"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:480
+#, fuzzy
+msgid "shows values in FILO (first-in last-out heap)"
+msgstr "druk die waarde op die EILU (eerste-in-laaste-uit) stapel"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:107
+#, fuzzy
+msgid "do-while-True operator that uses boolean operators from Numbers palette"
+msgstr "AS-DAN-ANDERS-bewerker wat boolse bewerkers van die Syferpalet gebruik"
+
+#: TurtleArt/tabasics.py:708
+msgid "logical NOT operator"
+msgstr "logiese NIE-bewerker"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:865
+msgid "ycor of bottom of screen"
+msgstr "y-koordinaat van die onderkant van die skerm"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:826
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:966
+msgid "presentation template: select Journal object (with description)"
+msgstr "voorleggingstemplaat: Kies 'n Joernaalobjek (met beskrywing)"
+
+#: TurtleArt/tabasics.py:557
+#, fuzzy
+msgid "Palette of numeric operators"
+msgstr "palet van numeriese bewerkers"
+
+#: TurtleArt/tabasics.py:754
+msgid "forever"
+msgstr "vir altyd"
+
+#: TurtleArt/tabasics.py:329
+#, fuzzy
+msgid "sets shade of the line drawn by the turtle"
+msgstr "stel die skadu van die lyn wat die skilpad teken"
+
+#: TurtleArt/tabasics.py:151
+msgid "clean"
+msgstr "maak skoon"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:840
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:847
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:996
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1011
+msgid "presentation template: select two Journal objects"
+msgstr "voorleggingstemplaat: Kies twee Joernaalobjekte"
+
+#: TurtleArtActivity.py:611 TurtleArtActivity.py:757 turtleblocks.py:372
+#, fuzzy
+msgid "Grow blocks"
+msgstr "Wys blokke"
+
+#: TurtleArtActivity.py:594 TurtleArtActivity.py:748
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:789
+msgid "Fullscreen"
+msgstr "Volskerm"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:194
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:222
+msgid "show"
+msgstr "wys"
+
#: TurtleArt/tabasics.py:853 TurtleArt/tabasics.py:854
#: TurtleArt/tabasics.py:855
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:186
@@ -608,121 +1943,655 @@ msgstr "koppel die aksie aan die die nutsbalk se uitvoerknoppies"
msgid "text"
msgstr "teks"
-#: TurtleArt/tabasics.py:856
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:189
-msgid "string value"
-msgstr "stringwaarde"
+#: TurtleArt/tabasics.py:646
+msgid "random"
+msgstr "ewekansig"
-#: TurtleArt/tabasics.py:860 TurtleArt/tabasics.py:863
-#: TurtleArt/tabasics.py:871 TurtleArt/tabasics.py:875
-#: TurtleArt/tawindow.py:1292 TurtleArt/tawindow.py:1371
-#: TurtleArt/tawindow.py:1384 TurtleArt/tawindow.py:1854
-#: TurtleArt/tawindow.py:4125
-msgid "action"
-msgstr "aksie"
+#: TurtleArt/tabasics.py:674
+msgid "logical greater-than operator"
+msgstr "logiese groter-as bewerker"
-#: TurtleArt/tabasics.py:865
-msgid "top of nameable action stack"
-msgstr "bokant van benoembare aksiestapel"
+#: TurtleArt/tabasics.py:166
+#, fuzzy
+msgid "turns turtle counterclockwise (angle in degrees)"
+msgstr "draai die skilpad anti-kloksgewys (gee die hoek in grade)"
-#: TurtleArt/tabasics.py:876 TurtleArt/tawindow.py:4139
+#: TurtleArt/tabasics.py:454
#, fuzzy
-msgid "invokes named action stack"
-msgstr "roep die beoemde aksiestapel in"
+msgid "black"
+msgstr "agtertoe"
-#: TurtleArt/tabasics.py:883
-msgid "store in box 1"
-msgstr "stoor in hokkie 1"
+#: TurtleArt/tabasics.py:639
+#, fuzzy
+msgid "calculates square root"
+msgstr "werk die vierkantswortel uit"
+
+#: TurtleArt/tabasics.py:237
+msgid ""
+"holds current y-coordinate value of the turtle (can be used in place of a "
+"number block)"
+msgstr ""
+"hou die huidige y-koordinaat van die skilpad (kan gebruik word i.p.v. 'n "
+"nommerblok)"
+
+#: pysamples/grecord.py:215
+#, fuzzy
+msgid "stop"
+msgstr "bokant"
+
+#: TurtleArt/tabasics.py:225 TurtleArt/tawindow.py:3862
+#: TurtleArt/tawindow.py:3868 TurtleArtActivity.py:604
+msgid "xcor"
+msgstr "x-koord"
+
+#: TurtleArtActivity.py:687 turtleblocks.py:408 util/helpbutton.py:45
+msgid "Help"
+msgstr "Hulp"
+
+#: TurtleArt/tabasics.py:463
+#, fuzzy
+msgid "sets color of text drawn by the turtle"
+msgstr "stel die kleur van die lyn wat die skilpad teken"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:388
+msgid "keyboard"
+msgstr "sleutelbord"
+
+#: TurtleArt/tabasics.py:186
+msgid "arc"
+msgstr "boog"
+
+#: TurtleArt/tabasics.py:186
+msgid "radius"
+msgstr "radius"
+
+#: TurtleArt/tabasics.py:325
+msgid "set shade"
+msgstr "stel skadu"
+
+#: TurtleArt/tabasics.py:718
+msgid "logical AND operator"
+msgstr "logiese EN-bewerker"
+
+#: TurtleArtActivity.py:681 TurtleArtActivity.py:890 turtleblocks.py:400
+msgid "Run"
+msgstr "Voer uit"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:477
+msgid "show heap"
+msgstr "wys die hoop"
+
+#: TurtleArt/tabasics.py:217
+#, fuzzy
+msgid "sets the heading of the turtle (0 is towards the top of the screen.)"
+msgstr "stel die rigting van die skilpad (0 is na die bokant van die skerm.)"
+
+#: gnome_plugins/uploader_plugin.py:120
+#, fuzzy
+msgid "Title:"
+msgstr "Titel:"
+
+#: TurtleArt/tabasics.py:838
+#, fuzzy
+msgid "Palette of variable blocks"
+msgstr "palet van veranderlike blokke"
+
+#: TurtleArt/tabasics.py:663
+msgid "used as numeric input in mathematic operators"
+msgstr "gebruik as numeriese insetwaarde in wiskundige operateurs"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1024
+#, fuzzy
+msgid "presentation 2x2"
+msgstr "voorlegging"
+
+#: TurtleArt/tabasics.py:912
+#, fuzzy
+msgid "Variable 1 (numeric value)"
+msgstr "veranderlike 1"
+
+#: TurtleArt/tabasics.py:567
+#, fuzzy
+msgid "adds two alphanumeric inputs"
+msgstr "tel twee numeriese insetwaardes bymekaar"
+
+#: TurtleArt/tabasics.py:789
+msgid "else"
+msgstr "andersins"
+
+#: TurtleArt/tabasics.py:379
+#, fuzzy
+msgid "Turtle will not draw when moved."
+msgstr "skilpad sal nie teken wanneer hy geskuif word nie."
+
+#. #-#-#-#-# af.po (PACKAGE VERSION) #-#-#-#-#
+#. #-#-#-#-# af.po (TURTLEART) #-#-#-#-#
+#. TRANS: pop removes a new item from the program stack
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:504
+msgid "pop"
+msgstr "haal af"
+
+#: TurtleArt/tabasics.py:426
+msgid "pen size"
+msgstr "pengrootte"
+
+#: TurtleArt/tabasics.py:190
+#, fuzzy
+msgid "moves turtle along an arc"
+msgstr "skuif die skilpad in 'n boog"
+
+#: TurtleArt/tabasics.py:699
+msgid "logical equal-to operator"
+msgstr "logiese gelyk-aan bewerker"
+
+#: TurtleArt/tabasics.py:441
+#, fuzzy
+msgid "Palette of pen colors"
+msgstr "palet van penbevele"
#: TurtleArt/tabasics.py:888
#, fuzzy
msgid "stores numeric value in Variable 1"
msgstr "stoor die numeriese waarde in veranderlike 1"
-#: TurtleArt/tabasics.py:896
-msgid "store in box 2"
-msgstr "stoor in hokkie 2"
-
#: TurtleArt/tabasics.py:901
#, fuzzy
msgid "stores numeric value in Variable 2"
msgstr "stoor die numeriese waarde in veranderlike 2"
-#: TurtleArt/tabasics.py:909
-msgid "box 1"
-msgstr "hokkie 1"
+#: TurtleArt/tabasics.py:143
+#, fuzzy
+msgid "moves turtle backward"
+msgstr "skuif die skilpad agtertoe"
-#: TurtleArt/tabasics.py:912
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:889
+msgid "ycor of top of screen"
+msgstr "y-koordinaat van die bokant van die skerm"
+
+#: TurtleArt/talogo.py:384 TurtleArtActivity.py:322 TurtleArtActivity.py:684
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1485
+msgid "Show blocks"
+msgstr "Wys blokke"
+
+#: gnome_plugins/collaboration_plugin.py:304
#, fuzzy
-msgid "Variable 1 (numeric value)"
-msgstr "veranderlike 1"
+msgid "Colors"
+msgstr "kleur"
-#: TurtleArt/tabasics.py:919
-msgid "box 2"
-msgstr "hokkie 2"
+#: TurtleArt/tabasics.py:398
+#, fuzzy
+msgid "sets size of the line drawn by the turtle"
+msgstr "stel die grootte van die lyn wat die skilpad teken"
-#: TurtleArt/tabasics.py:922
+#: TurtleArt/tawindow.py:989 TurtleArt/tawindow.py:990
#, fuzzy
-msgid "Variable 2 (numeric value)"
-msgstr "veranderlike 2"
+msgid "orientation"
+msgstr "voorlegging"
+
+#: TurtleArt/tabasics.py:236 TurtleArt/tawindow.py:3862
+#: TurtleArt/tawindow.py:3868 TurtleArtActivity.py:605
+msgid "ycor"
+msgstr "y-koord"
+
+#: TurtleArt/tabasics.py:776 TurtleArt/tabasics.py:789
+msgid "if"
+msgstr "as"
+
+#: TurtleArt/tabasics.py:203 TurtleArt/tabasics.py:269
+#, fuzzy
+msgid ""
+"moves turtle to position xcor, ycor; (0, 0) is in the center of the screen."
+msgstr ""
+"skuif die skilpad na posisie x, y; (0,0) is in die middel van die skem."
+
+#: TurtleArtActivity.py:688 turtleblocks.py:403
+#, fuzzy
+msgid "Stop"
+msgstr "bokant"
+
+#: TurtleArt/tabasics.py:964 TurtleArt/tabasics.py:984
+#, fuzzy
+msgid "action 2"
+msgstr "aksie"
+
+#: TurtleArt/tabasics.py:955 TurtleArt/tabasics.py:974
+#, fuzzy
+msgid "action 1"
+msgstr "aksie"
+
+#: TurtleArtActivity.py:587 TurtleArtActivity.py:731 turtleblocks.py:385
+msgid "Copy"
+msgstr "Kopieer"
+
+#: TurtleArtActivity.py:589 TurtleArtActivity.py:732 turtleblocks.py:386
+msgid "Paste"
+msgstr "Plak"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:490
+msgid "empty heap"
+msgstr "maak hoop skoon"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:508
+#, fuzzy
+msgid "pops value off FILO (first-in last-out heap)"
+msgstr "druk die waarde op die EILU (eerste-in-laaste-uit) stapel"
+
+#: TurtleArtActivity.py:680 TurtleArtActivity.py:888 turtleblocks.py:399
+msgid "Clean"
+msgstr "Maak skoon"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:765
+#, fuzzy
+msgid "Palette of presentation templates"
+msgstr "palet van voorleggingstemplate"
+
+#: TurtleArt/tabasics.py:186
+msgid "angle"
+msgstr "hoek"
+
+#: TurtleArt/tabasics.py:162
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:854
+msgid "left"
+msgstr "links"
+
+#: TurtleArt/tabasics.py:578
+msgid "subtracts bottom numeric input from top numeric input"
+msgstr "trek die onderste numeriese insetwaarde van die boonste een af"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:381
+msgid "query for keyboard input (results stored in keyboard block)"
+msgstr "vra vir inset van die sleutelbord (word in sleutelbord-blok gestoor)"
+
+#: TurtleArt/tabasics.py:154
+#, fuzzy
+msgid "clears the screen and reset the turtle"
+msgstr "maak die skerm skoon en herstel die skilpad"
+
+#: TurtleArt/tabasics.py:977
+#, fuzzy
+msgid "invokes Action 1 stack"
+msgstr "roep aksie 1 stapel in"
+
+#: TurtleArt/tabasics.py:123
+#, fuzzy
+msgid "Palette of turtle commands"
+msgstr "palet van skilpadbevele"
+
+#: TurtleArt/tabasics.py:758
+#, fuzzy
+msgid "loops forever"
+msgstr "gaan vir altyd in 'n lus in"
+
+#: TurtleArt/tawindow.py:3868 pysamples/grecord.py:205
+msgid "Turtle Art"
+msgstr "Turtle Art"
+
+#: TurtleArtActivity.py:573 TurtleArtActivity.py:679
+msgid "Project"
+msgstr "Projek"
+
+#: turtleblocks.py:402
+msgid "Debug"
+msgstr "Ontfout"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:781
+#, fuzzy
+msgid "show blocks"
+msgstr "Wys blokke"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:177
+msgid "Sugar Journal description field"
+msgstr "Sugar Journal beskrywingsveld"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:266
+msgid "scale"
+msgstr "skaal"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:862
+msgid "bottom"
+msgstr "onderkant"
+
+#: gnome_plugins/uploader_plugin.py:130
+msgid "Description:"
+msgstr "Beskrywing:"
+
+#: TurtleArt/tabasics.py:388
+#, fuzzy
+msgid "Turtle will draw when moved."
+msgstr "skilpad sal teken wanneer hy geskuif word."
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:153
+msgid "Sugar Journal audio object"
+msgstr "Sugar Joernaal oudio-objek"
+
+#: TurtleArt/talogo.py:374 TurtleArtActivity.py:683
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1492
+msgid "Stop turtle"
+msgstr "Stop die skilpad"
+
+#: turtleblocks.py:404
+msgid "Turtle"
+msgstr "Skilpad"
#: TurtleArt/tabasics.py:928 TurtleArt/tawindow.py:4189
msgid "store in"
msgstr "stoor in"
-#: TurtleArt/tabasics.py:928 TurtleArt/tabasics.py:942
-msgid "box"
-msgstr "hokkie"
+#: TurtleArt/talogo.py:388 TurtleArtActivity.py:326 TurtleArtActivity.py:894
+msgid "Hide blocks"
+msgstr "Versteek blokke"
-#: TurtleArt/tabasics.py:928 TurtleArt/tawindow.py:4189
-msgid "value"
+#: TurtleArt/tabasics.py:725 TurtleArt/tabasics.py:728
+msgid "or"
+msgstr "OF"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:812
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1041
+#, fuzzy
+msgid "presentation template: list of bullets"
+msgstr "voorleggingstemplaat: Kollys met sewe kolle"
+
+#: TurtleArt/tabasics.py:616
+msgid "identity operator used for extending blocks"
+msgstr "identitietsbewerker om blokke uit te brei"
+
+#: TurtleArt/tabasics.py:474
+#, fuzzy
+msgid "sets size of text drawn by the turtle"
+msgstr "stel die grootte van die teks wat die skilpad teken"
+
+#: TurtleArt/tabasics.py:248
+msgid ""
+"holds current heading value of the turtle (can be used in place of a number "
+"block)"
msgstr ""
+"hou die huidige rigting van die skilpad (kan gebruik word i.p.v. 'n "
+"nommerblok)"
-#: TurtleArt/tabasics.py:932 TurtleArt/tabasics.py:945
-#: TurtleArt/tawindow.py:1296 TurtleArt/tawindow.py:1409
-#: TurtleArt/tawindow.py:1858 TurtleArt/tawindow.py:4152
-#: TurtleArt/tawindow.py:4180
-msgid "my box"
+#: TurtleArt/tabasics.py:650
+#, fuzzy
+msgid "returns random number between minimum (top) and maximum (bottom) values"
+msgstr ""
+"gee 'n ewekansige nommerwaarde tussen minimum- (links) en maksimumwaardes "
+"(regs)"
+
+#: TurtleArt/tabasics.py:349
+msgid "holds current pen color (can be used in place of a number block)"
msgstr ""
+"hou die huidige kleur van die pen (kan gebruk word i.p.v. 'n nommerblok)"
+
+#: TurtleArtActivity.py:274 turtleblocks.py:390
+msgid "Show palette"
+msgstr "Wys palet"
+
+#: TurtleArtActivity.py:219 TurtleArtActivity.py:643 TurtleArtActivity.py:685
+#: TurtleArtActivity.py:829 TurtleArtActivity.py:856
+msgid "Save snapshot"
+msgstr "Stoor flitsbeeld"
+
+#: TurtleArt/tabasics.py:843 pysamples/grecord.py:213
+msgid "start"
+msgstr "begin"
+
+#: TurtleArt/tabasics.py:132
+#, fuzzy
+msgid "moves turtle forward"
+msgstr "skuif die skilpad vorentoe"
+
+#: TurtleArt/tabasics.py:128
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:723
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:734
+msgid "forward"
+msgstr "vorentoe"
+
+#: TurtleArt/tabasics.py:139
+msgid "back"
+msgstr "agtertoe"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:238
+#, fuzzy
+msgid "sets the scale of media"
+msgstr "stel die skaal van die media"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:964
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:979
+#, fuzzy
+msgid "presentation 1x1"
+msgstr "voorlegging"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1009
+#, fuzzy
+msgid "presentation 1x2"
+msgstr "voorlegging"
+
+#: TurtleArt/tabasics.py:865
+msgid "top of nameable action stack"
+msgstr "bokant van benoembare aksiestapel"
#: TurtleArt/tabasics.py:933 TurtleArt/tawindow.py:4194
#, fuzzy
msgid "stores numeric value in named variable"
msgstr "stoor numeriese waarde in benoemde veranderlike"
-#: TurtleArt/tabasics.py:948 TurtleArt/tawindow.py:4166
-msgid "named variable (numeric value)"
-msgstr "benoemde veranderlike"
+#: TurtleArt/tabasics.py:729
+msgid "logical OR operator"
+msgstr "logiese OF-bewerker"
-#: TurtleArt/tabasics.py:955 TurtleArt/tabasics.py:974
+#: TurtleArt/tabasics.py:770
#, fuzzy
-msgid "action 1"
-msgstr "aksie"
+msgid "loops specified number of times"
+msgstr "gaan 'n gespesifiseerde hoeveelheid kere in 'n lus in"
-#: TurtleArt/tabasics.py:958
+#: TurtleArt/tabasics.py:987
#, fuzzy
-msgid "top of Action 1 stack"
-msgstr "bokant van aksie 1 stapel"
+msgid "invokes Action 2 stack"
+msgstr "roep aksie 2 stapel in"
-#: TurtleArt/tabasics.py:964 TurtleArt/tabasics.py:984
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:745
#, fuzzy
-msgid "action 2"
-msgstr "aksie"
+msgid "setxy"
+msgstr "stel xy"
+
+#: TurtleArt/tabasics.py:287 TurtleArt/tabasics.py:298
+msgid "fill screen"
+msgstr "vul skerm"
+
+#: TurtleArt/tabasics.py:199 TurtleArt/tabasics.py:265
+msgid "set xy"
+msgstr "stel xy"
+
+#: TurtleArt/tabasics.py:765 TurtleArt/tabasics.py:769
+msgid "repeat"
+msgstr "herhaal"
+
+#: TurtleArtActivity.py:203 TurtleArtActivity.py:708 TurtleArtActivity.py:820
+#: TurtleArtActivity.py:850 turtleblocks.py:358
+msgid "Save as image"
+msgstr "Stoor as prent"
+
+#: TurtleArtActivity.py:541 TurtleArtActivity.py:577 TurtleArtActivity.py:677
+#: TurtleArtActivity.py:730 turtleblocks.py:387
+msgid "Edit"
+msgstr "Redigeer"
#: TurtleArt/tabasics.py:967
#, fuzzy
msgid "top of Action 2 stack"
msgstr "bokant van aksie 2 stapel"
-#: TurtleArt/tabasics.py:977
+#: TurtleArt/tabasics.py:604
+msgid ""
+"divides top numeric input (numerator) by bottom numeric input (denominator)"
+msgstr ""
+"deel die boonste numeriese insetwaarde (teller) deur die onderste een "
+"(noemer)"
+
+#: TurtleArt/tabasics.py:646
+msgid "max"
+msgstr "maks"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:553
+msgid "prints value in status block at bottom of the screen"
+msgstr ""
+"vertoon die waarde in die statusblokkie aan die onderkant van die skerm"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:392
#, fuzzy
-msgid "invokes Action 1 stack"
-msgstr "roep aksie 1 stapel in"
+msgid "holds results of query-keyboard block as ASCII"
+msgstr "hou die resultaat van die sleutelbord-navraagblok"
-#: TurtleArt/tabasics.py:987
+#. #-#-#-#-# af.po (PACKAGE VERSION) #-#-#-#-#
+#. #-#-#-#-# af.po (TURTLEART) #-#-#-#-#
+#. TRANS: push adds a new item to the program stack
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:464
+msgid "push"
+msgstr "druk"
+
+#. TRANS: "name" option from activity.info file
+msgid "TurtleBlocks"
+msgstr ""
+
+#. TRANS: "summary" option from activity.info file
+#. TRANS: "description" option from activity.info file
+msgid ""
+"A Logo-inspired turtle that draws colorful pictures with snap-together "
+"visual programming blocks"
+msgstr ""
+
+#: TurtleArt/tabasics.py:174
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:878
+msgid "right"
+msgstr "regs"
+
+#: TurtleArt/tabasics.py:299 TurtleArt/tabasics.py:367
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1155
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1160
+msgid "gray"
+msgstr ""
+
+#: TurtleArt/tabasics.py:337
+msgid "set gray"
+msgstr ""
+
+#: TurtleArt/tabasics.py:359
+msgid "holds current pen shade"
+msgstr ""
+
+#: TurtleArt/tabasics.py:408
+msgid "start fill"
+msgstr ""
+
+#: TurtleArt/tabasics.py:410
+msgid "starts filled polygon (used with end fill block)"
+msgstr ""
+
+#: TurtleArt/tabasics.py:417
+msgid "end fill"
+msgstr ""
+
+#: TurtleArt/tabasics.py:419
+msgid "completes filled polygon (used with start fill block)"
+msgstr ""
+
+#: TurtleArt/tabasics.py:443
#, fuzzy
-msgid "invokes Action 2 stack"
-msgstr "roep aksie 2 stapel in"
+msgid "red"
+msgstr "rooi"
+
+#: TurtleArt/tabasics.py:448
+msgid "green"
+msgstr ""
+
+#: TurtleArt/tabasics.py:449
+msgid "cyan"
+msgstr ""
+
+#: TurtleArt/tabasics.py:450
+msgid "blue"
+msgstr ""
+
+#: TurtleArt/tabasics.py:451
+msgid "purple"
+msgstr ""
+
+#: TurtleArt/tabasics.py:453
+msgid "white"
+msgstr ""
+
+#: TurtleArt/tabasics.py:563
+msgid "plus"
+msgstr ""
+
+#: TurtleArt/tabasics.py:575
+msgid "minus"
+msgstr ""
+
+#: TurtleArt/tabasics.py:589
+msgid "multiply"
+msgstr ""
+
+#: TurtleArt/tabasics.py:601
+msgid "divide"
+msgstr ""
+
+#: TurtleArt/tabasics.py:614
+msgid "identity"
+msgstr ""
+
+#: TurtleArt/tabasics.py:624 TurtleArt/tabasics.py:625
+msgid "mod"
+msgstr "modulo"
+
+#: TurtleArt/tabasics.py:635
+msgid "√"
+msgstr ""
+
+#: TurtleArt/tabasics.py:636
+msgid "square root"
+msgstr ""
+
+#: TurtleArt/tabasics.py:671
+msgid "greater than"
+msgstr ""
+
+#: TurtleArt/tabasics.py:683
+msgid "less than"
+msgstr ""
+
+#: TurtleArt/tabasics.py:695
+msgid "equal"
+msgstr ""
+
+#: TurtleArt/tabasics.py:747
+msgid "pauses program execution a specified number of seconds"
+msgstr ""
+
+#: TurtleArt/tabasics.py:779
+msgid "if then"
+msgstr ""
+
+#: TurtleArt/tabasics.py:793 TurtleArt/tabasics.py:801
+msgid "if then else"
+msgstr ""
+
+#: TurtleArt/tabasics.py:811
+msgid "horizontal space"
+msgstr ""
+
+#: TurtleArt/tabasics.py:819
+msgid "vertical space"
+msgstr ""
+
+#: TurtleArt/tabasics.py:829
+msgid "stops current action"
+msgstr ""
+
+#: TurtleArt/tabasics.py:932 TurtleArt/tabasics.py:945
+#: TurtleArt/tawindow.py:1296 TurtleArt/tawindow.py:1409
+#: TurtleArt/tawindow.py:1858 TurtleArt/tawindow.py:4152
+#: TurtleArt/tawindow.py:4180
+msgid "my box"
+msgstr ""
#: TurtleArt/tabasics.py:995
msgid "trash"
@@ -757,33 +2626,6 @@ msgstr ""
msgid "Share selected blocks"
msgstr ""
-#: TurtleArt/taconstants.py:209 TurtleArt/taconstants.py:231
-#: TurtleArt/taconstants.py:252 TurtleArt/taconstants.py:294
-#: TurtleArt/taconstants.py:336 TurtleArt/taconstants.py:378
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:963
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:978
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:993
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1008
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1023
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1038
-#, fuzzy
-msgid "Title"
-msgstr "titel"
-
-#: TurtleArt/talogo.py:374 TurtleArtActivity.py:683
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1492
-msgid "Stop turtle"
-msgstr "Stop die skilpad"
-
-#: TurtleArt/talogo.py:384 TurtleArtActivity.py:322 TurtleArtActivity.py:684
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1485
-msgid "Show blocks"
-msgstr "Wys blokke"
-
-#: TurtleArt/talogo.py:388 TurtleArtActivity.py:326 TurtleArtActivity.py:894
-msgid "Hide blocks"
-msgstr "Versteek blokke"
-
#: TurtleArt/talogo.py:511
msgid "did not output to"
msgstr ""
@@ -821,16 +2663,6 @@ msgstr ""
msgid "click to open"
msgstr ""
-#: TurtleArt/tawindow.py:989 TurtleArt/tawindow.py:990
-#, fuzzy
-msgid "orientation"
-msgstr "voorlegging"
-
-#: TurtleArt/tawindow.py:1000 TurtleArt/tawindow.py:1470
-#, fuzzy
-msgid "next"
-msgstr "teks"
-
#: TurtleArt/tawindow.py:1012 TurtleArt/tawindow.py:1013
#: TurtleArt/tawindow.py:1490
msgid "shift"
@@ -846,33 +2678,14 @@ msgstr ""
msgid "Select blocks to share"
msgstr ""
-#: TurtleArt/tawindow.py:3868 pysamples/grecord.py:205
-msgid "Turtle Art"
-msgstr "Turtle Art"
-
#: TurtleArt/tawindow.py:3977
msgid "image"
msgstr ""
-#: TurtleArtActivity.py:166 TurtleArtActivity.py:709 TurtleArtActivity.py:823
-#: TurtleArtActivity.py:853 turtleblocks.py:360
-msgid "Save as Logo"
-msgstr "Stoor as Logo"
-
-#: TurtleArtActivity.py:203 TurtleArtActivity.py:708 TurtleArtActivity.py:820
-#: TurtleArtActivity.py:850 turtleblocks.py:358
-msgid "Save as image"
-msgstr "Stoor as prent"
-
#: TurtleArtActivity.py:211
msgid "snapshot"
msgstr ""
-#: TurtleArtActivity.py:219 TurtleArtActivity.py:643 TurtleArtActivity.py:685
-#: TurtleArtActivity.py:829 TurtleArtActivity.py:856
-msgid "Save snapshot"
-msgstr "Stoor flitsbeeld"
-
#: TurtleArtActivity.py:260 TurtleArtActivity.py:616 TurtleArtActivity.py:759
#: turtleblocks.py:378
msgid "Turn off hover help"
@@ -882,14 +2695,6 @@ msgstr ""
msgid "Turn on hover help"
msgstr ""
-#: TurtleArtActivity.py:274 turtleblocks.py:390
-msgid "Show palette"
-msgstr "Wys palet"
-
-#: TurtleArtActivity.py:280 TurtleArtActivity.py:882 turtleblocks.py:392
-msgid "Hide palette"
-msgstr "Versteek palet"
-
#: TurtleArtActivity.py:447
msgid "Rescale coordinates down"
msgstr ""
@@ -898,42 +2703,20 @@ msgstr ""
msgid "Rescale coordinates up"
msgstr ""
-#: TurtleArtActivity.py:541 TurtleArtActivity.py:577 TurtleArtActivity.py:677
-#: TurtleArtActivity.py:730 turtleblocks.py:387
-msgid "Edit"
-msgstr "Redigeer"
-
#: TurtleArtActivity.py:546 TurtleArtActivity.py:575 TurtleArtActivity.py:678
#: TurtleArtActivity.py:747 turtleblocks.py:382
msgid "View"
msgstr ""
-#: TurtleArtActivity.py:573 TurtleArtActivity.py:679
-msgid "Project"
-msgstr "Projek"
-
#: TurtleArtActivity.py:579 TurtleArtActivity.py:676 TurtleArtActivity.py:705
#: TurtleArtActivity.py:707 TurtleArtActivity.py:815
msgid "Save/Load"
msgstr ""
-#: TurtleArtActivity.py:587 TurtleArtActivity.py:731 turtleblocks.py:385
-msgid "Copy"
-msgstr "Kopieer"
-
-#: TurtleArtActivity.py:589 TurtleArtActivity.py:732 turtleblocks.py:386
-msgid "Paste"
-msgstr "Plak"
-
#: TurtleArtActivity.py:591
msgid "Restore blocks from trash"
msgstr ""
-#: TurtleArtActivity.py:594 TurtleArtActivity.py:748
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:789
-msgid "Fullscreen"
-msgstr "Volskerm"
-
#: TurtleArtActivity.py:596 TurtleArtActivity.py:749 turtleblocks.py:366
msgid "Cartesian coordinates"
msgstr ""
@@ -946,11 +2729,6 @@ msgstr ""
msgid "Metric coordinates"
msgstr ""
-#: TurtleArtActivity.py:611 TurtleArtActivity.py:757 turtleblocks.py:372
-#, fuzzy
-msgid "Grow blocks"
-msgstr "Wys blokke"
-
#: TurtleArtActivity.py:613 TurtleArtActivity.py:758 turtleblocks.py:374
msgid "Shrink blocks"
msgstr ""
@@ -960,27 +2738,6 @@ msgstr ""
msgid "Load example"
msgstr ""
-#: TurtleArtActivity.py:680 TurtleArtActivity.py:888 turtleblocks.py:399
-msgid "Clean"
-msgstr "Maak skoon"
-
-#: TurtleArtActivity.py:681 TurtleArtActivity.py:890 turtleblocks.py:400
-msgid "Run"
-msgstr "Voer uit"
-
-#: TurtleArtActivity.py:682 TurtleArtActivity.py:892 turtleblocks.py:401
-msgid "Step"
-msgstr "Stap"
-
-#: TurtleArtActivity.py:687 turtleblocks.py:408 util/helpbutton.py:45
-msgid "Help"
-msgstr "Hulp"
-
-#: TurtleArtActivity.py:688 turtleblocks.py:403
-#, fuzzy
-msgid "Stop"
-msgstr "bokant"
-
#: TurtleArtActivity.py:710 TurtleArtActivity.py:836 TurtleArtActivity.py:858
msgid "Load project"
msgstr ""
@@ -1092,11 +2849,6 @@ msgstr ""
msgid "Register"
msgstr ""
-#: gnome_plugins/collaboration_plugin.py:304
-#, fuzzy
-msgid "Colors"
-msgstr "kleur"
-
#: gnome_plugins/fb_plugin.py:82 gnome_plugins/fb_plugin.py:83
#: gnome_plugins/fb_plugin.py:92 gnome_plugins/uploader_plugin.py:63
#: gnome_plugins/uploader_plugin.py:64 gnome_plugins/uploader_plugin.py:73
@@ -1125,15 +2877,6 @@ msgstr ""
msgid "Password:"
msgstr ""
-#: gnome_plugins/uploader_plugin.py:120
-#, fuzzy
-msgid "Title:"
-msgstr "Titel:"
-
-#: gnome_plugins/uploader_plugin.py:130
-msgid "Description:"
-msgstr "Beskrywing:"
-
#: gnome_plugins/uploader_plugin.py:140
msgid "Submit to Web"
msgstr ""
@@ -1168,11 +2911,6 @@ msgstr ""
msgid "push acceleration in x, y, z to heap"
msgstr ""
-#: plugins/audio_sensors/audio_sensors.py:83
-#: plugins/audio_sensors/audio_sensors.py:98 pysamples/grecord.py:205
-msgid "sound"
-msgstr "klank"
-
#: plugins/audio_sensors/audio_sensors.py:84
#: plugins/audio_sensors/audio_sensors.py:99
msgid "raw microphone input signal"
@@ -1199,13 +2937,6 @@ msgstr ""
msgid "microphone input pitch"
msgstr ""
-#: plugins/audio_sensors/audio_sensors.py:151
-#: plugins/audio_sensors/audio_sensors.py:165
-#: plugins/audio_sensors/audio_sensors.py:179
-#: plugins/audio_sensors/audio_sensors.py:193
-msgid "resistance"
-msgstr ""
-
#: plugins/audio_sensors/audio_sensors.py:152
#: plugins/audio_sensors/audio_sensors.py:166
#: plugins/audio_sensors/audio_sensors.py:180
@@ -1232,15 +2963,6 @@ msgstr ""
msgid "Palette of media objects"
msgstr ""
-#: plugins/camera_sensor/camera_sensor.py:80
-#: plugins/camera_sensor/camera_sensor.py:93
-#: plugins/camera_sensor/camera_sensor.py:128
-#: plugins/camera_sensor/camera_sensor.py:141
-#: plugins/light_sensor/light_sensor.py:56
-#: plugins/light_sensor/light_sensor.py:63
-msgid "brightness"
-msgstr ""
-
#: plugins/camera_sensor/camera_sensor.py:82
#: plugins/camera_sensor/camera_sensor.py:130
msgid "light level detected by camera"
@@ -1277,27 +2999,11 @@ msgstr ""
msgid "while"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:107
-#, fuzzy
-msgid "do-while-True operator that uses boolean operators from Numbers palette"
-msgstr "AS-DAN-ANDERS-bewerker wat boolse bewerkers van die Syferpalet gebruik"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:113
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:116
msgid "until"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:117
-#, fuzzy
-msgid "do-until-True operator that uses boolean operators from Numbers palette"
-msgstr "AS-DAN-ANDERS-bewerker wat boolse bewerkers van die Syferpalet gebruik"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:124
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:715
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:886
-msgid "top"
-msgstr "bokant"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:126
msgid "top of a collapsible stack"
msgstr ""
@@ -1306,59 +3012,18 @@ msgstr ""
msgid "journal"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:141
-msgid "Sugar Journal media object"
-msgstr "Sugar Joernaal media-objek"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:151
msgid "audio"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:153
-msgid "Sugar Journal audio object"
-msgstr "Sugar Joernaal oudio-objek"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:163
msgid "video"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:165
-msgid "Sugar Journal video object"
-msgstr "Sugar Joernaal video-objek"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:175
-msgid "description"
-msgstr "beskrywing"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:177
-msgid "Sugar Journal description field"
-msgstr "Sugar Journal beskrywingsveld"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:194
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:222
-msgid "show"
-msgstr "wys"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:198
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:211
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:226
-#, fuzzy
-msgid "draws text or show media from the Journal"
-msgstr "teken teks of wys media van die Joernaal"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:207
msgid "show aligned"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:234
-msgid "set scale"
-msgstr "stel skaal"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:238
-#, fuzzy
-msgid "sets the scale of media"
-msgstr "stel die skaal van die media"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:245
msgid "save picture"
msgstr ""
@@ -1380,10 +3045,6 @@ msgstr ""
msgid "saves turtle graphics as an SVG file in the Sugar Journal"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:266
-msgid "scale"
-msgstr "skaal"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:270
msgid "holds current scale value"
msgstr ""
@@ -1482,19 +3143,6 @@ msgstr ""
msgid "query keyboard"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:381
-msgid "query for keyboard input (results stored in keyboard block)"
-msgstr "vra vir inset van die sleutelbord (word in sleutelbord-blok gestoor)"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:388
-msgid "keyboard"
-msgstr "sleutelbord"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:392
-#, fuzzy
-msgid "holds results of query-keyboard block as ASCII"
-msgstr "hou die resultaat van die sleutelbord-navraagblok"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:424
msgid "read pixel"
msgstr ""
@@ -1511,62 +3159,14 @@ msgstr ""
msgid "returns the color that the turtle \"sees\""
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:445
-msgid "time"
-msgstr ""
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:448
msgid "elapsed time (in seconds) since program started"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:457
-#, fuzzy
-msgid "Palette of extra options"
-msgstr "palet van ekstra opsies"
-
-#. TRANS: push adds a new item to the program stack
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:464
-msgid "push"
-msgstr "druk"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:467
-#, fuzzy
-msgid "pushes value onto FILO (first-in last-out heap)"
-msgstr "druk die waarde op die EILU (eerste-in-laaste-uit) stapel"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:477
-msgid "show heap"
-msgstr "wys die hoop"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:480
-#, fuzzy
-msgid "shows values in FILO (first-in last-out heap)"
-msgstr "druk die waarde op die EILU (eerste-in-laaste-uit) stapel"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:490
-msgid "empty heap"
-msgstr "maak hoop skoon"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:493
msgid "emptys FILO (first-in-last-out heap)"
msgstr ""
-#. TRANS: pop removes a new item from the program stack
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:504
-msgid "pop"
-msgstr "haal af"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:508
-#, fuzzy
-msgid "pops value off FILO (first-in last-out heap)"
-msgstr "druk die waarde op die EILU (eerste-in-laaste-uit) stapel"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:519
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:529
-#, fuzzy
-msgid "empty heap?"
-msgstr "maak hoop skoon"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:522
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:532
msgid "returns True if heap is empty"
@@ -1581,14 +3181,6 @@ msgstr ""
msgid "places a comment in your code"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:549
-msgid "print"
-msgstr "druk"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:553
-msgid "prints value in status block at bottom of the screen"
-msgstr "vertoon die waarde in die statusblokkie aan die onderkant van die skerm"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:563
msgid "Python chr operator"
msgstr ""
@@ -1627,14 +3219,6 @@ msgstr ""
msgid "Python block"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:624
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:640
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:656
-msgid "runs code found in the tamyblock.py module found in the Journal"
-msgstr ""
-"voer die kode uit wat in die tamyblock.py module onder die Joernaal gevind "
-"word"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:669
msgid "Cartesian"
msgstr ""
@@ -1651,12 +3235,6 @@ msgstr ""
msgid "displays polar coordinates"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:685
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:756
-#, fuzzy
-msgid "turtle"
-msgstr "Skilpad"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:689
msgid "chooses which turtle to command"
msgstr ""
@@ -1681,18 +3259,6 @@ msgstr ""
msgid "load"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:724
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:735
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:746
-#, fuzzy
-msgid "loads a block"
-msgstr "laai my blok"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:745
-#, fuzzy
-msgid "setxy"
-msgstr "stel xy"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:754
msgid "palette"
msgstr ""
@@ -1701,25 +3267,6 @@ msgstr ""
msgid "selects a palette"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:765
-#, fuzzy
-msgid "Palette of presentation templates"
-msgstr "palet van voorleggingstemplate"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:772
-msgid "hide blocks"
-msgstr "versteek blokke"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:774
-#, fuzzy
-msgid "declutters canvas by hiding blocks"
-msgstr "maak werksoppervlak skoon deur blokke te versteek"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:781
-#, fuzzy
-msgid "show blocks"
-msgstr "Wys blokke"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:783
msgid "restores hidden blocks"
msgstr ""
@@ -1737,70 +3284,6 @@ msgstr ""
msgid "presentation bulleted list"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:812
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1041
-#, fuzzy
-msgid "presentation template: list of bullets"
-msgstr "voorleggingstemplaat: Kollys met sewe kolle"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:819
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:981
-msgid "presentation template: select Journal object (no description)"
-msgstr "voorleggingstemplaat: Kies 'n Joernaalobjek (sonder beskrywing)"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:826
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:966
-msgid "presentation template: select Journal object (with description)"
-msgstr "voorleggingstemplaat: Kies 'n Joernaalobjek (met beskrywing)"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:833
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1026
-msgid "presentation template: select four Journal objects"
-msgstr "voorleggingstemplaat: Kies vier Joernaalobjekte"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:840
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:847
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:996
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1011
-msgid "presentation template: select two Journal objects"
-msgstr "voorleggingstemplaat: Kies twee Joernaalobjekte"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:857
-msgid "xcor of left of screen"
-msgstr "x-koordinaat van die linkerkant van die skerm"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:862
-msgid "bottom"
-msgstr "onderkant"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:865
-msgid "ycor of bottom of screen"
-msgstr "y-koordinaat van die onderkant van die skerm"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:870
-msgid "width"
-msgstr "wydte"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:873
-msgid "the canvas width"
-msgstr "wydte van die werksoppervlak"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:881
-msgid "xcor of right of screen"
-msgstr "x-koordinaat van die regterkant van die skerm"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:889
-msgid "ycor of top of screen"
-msgstr "y-koordinaat van die bokant van die skerm"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:894
-msgid "height"
-msgstr "hoogte"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:897
-msgid "the canvas height"
-msgstr "hoogte van die werksoppervlak"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:904
msgid "title x"
msgstr ""
@@ -1821,32 +3304,6 @@ msgstr ""
msgid "right x"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:949
-#, fuzzy
-msgid "bottom y"
-msgstr "onderkant"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:964
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:979
-#, fuzzy
-msgid "presentation 1x1"
-msgstr "voorlegging"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:994
-#, fuzzy
-msgid "presentation 2x1"
-msgstr "voorlegging"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1009
-#, fuzzy
-msgid "presentation 1x2"
-msgstr "voorlegging"
-
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1024
-#, fuzzy
-msgid "presentation 2x2"
-msgstr "voorlegging"
-
#: pysamples/brain.py:43
msgid "Please install the Speak Activity and try again."
msgstr ""
@@ -1874,11 +3331,6 @@ msgstr ""
msgid "push destination rgb value to heap"
msgstr ""
-#: pysamples/grecord.py:215
-#, fuzzy
-msgid "stop"
-msgstr "bokant"
-
#: pysamples/grecord.py:217
msgid "play"
msgstr ""
@@ -1956,14 +3408,6 @@ msgstr ""
msgid "Tools"
msgstr ""
-#: turtleblocks.py:402
-msgid "Debug"
-msgstr "Ontfout"
-
-#: turtleblocks.py:404
-msgid "Turtle"
-msgstr "Skilpad"
-
#: turtleblocks.py:407
msgid "About..."
msgstr ""
@@ -1976,22 +3420,6 @@ msgstr ""
msgid "Save project?"
msgstr ""
-#, fuzzy
-#~ msgid "light"
-#~ msgstr "regs"
-
-#, fuzzy
-#~ msgid "read"
-#~ msgstr "rooi"
-
-#, fuzzy
-#~ msgid "mode"
-#~ msgstr "modulo"
-
-#, fuzzy
-#~ msgid "samples"
-#~ msgstr "Voorbeelde"
-
#~ msgid "Save as HTML"
#~ msgstr "Stoor as HTML"
@@ -2050,7 +3478,8 @@ msgstr ""
#~ "hou die huidige skadu van die pen (kan gebruk word i.p.v. 'n nommerblok)"
#~ msgid ""
-#~ "a programmable block: add your own math equation in the block, e.g., sin(x)"
+#~ "a programmable block: add your own math equation in the block, e.g., sin"
+#~ "(x)"
#~ msgstr ""
#~ "'n programmeerbare blok: voeg jou eie wiskundige vergelyking in die blok, "
#~ "bv. sin(x)"
diff --git a/po/am.po b/po/am.po
index e0170b1..4e30350 100644
--- a/po/am.po
+++ b/po/am.po
@@ -2,8 +2,33 @@
# Copyright (C) YEAR THE PACKAGE'S COPYRIGHT HOLDER
# This file is distributed under the same license as the PACKAGE package.
# FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
+#, fuzzy
msgid ""
msgstr ""
+"#-#-#-#-# am.po (PACKAGE VERSION) #-#-#-#-#\n"
+"Project-Id-Version: PACKAGE VERSION\n"
+"Report-Msgid-Bugs-To: \n"
+"POT-Creation-Date: 2012-11-02 00:32-0400\n"
+"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
+"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
+"Language-Team: LANGUAGE <LL@li.org>\n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
+"X-Generator: Translate Toolkit 1.7.0\n"
+"#-#-#-#-# am.po (PACKAGE VERSION) #-#-#-#-#\n"
+"#-#-#-#-# am.po (PACKAGE VERSION) #-#-#-#-#\n"
+"Project-Id-Version: PACKAGE VERSION\n"
+"Report-Msgid-Bugs-To: \n"
+"POT-Creation-Date: 2012-11-02 00:32-0400\n"
+"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
+"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
+"Language-Team: LANGUAGE <LL@li.org>\n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
+"X-Generator: Translate Toolkit 1.7.0\n"
+"#-#-#-#-# am.po (PACKAGE VERSION) #-#-#-#-#\n"
"Project-Id-Version: PACKAGE VERSION\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2013-02-24 00:31-0500\n"
@@ -18,6 +43,1604 @@ msgstr ""
"X-Generator: Pootle 2.0.1\n"
#. TRANS: "name" option from activity.info file
+#. TRANS: "summary" option from activity.info file
+#. TRANS: "description" option from activity.info file
+msgid "turtleart-extras (master)"
+msgstr ""
+
+#: taextras.py:36
+msgid "Turtle Art Mini"
+msgstr ""
+
+#: taextras.py:40
+msgid "Turtle Confusion"
+msgstr ""
+
+#: taextras.py:41 taextras.py:46
+msgid "Select a challenge"
+msgstr ""
+
+#: taextras.py:45
+msgid "Amazonas Tortuga"
+msgstr ""
+
+#: taextras.py:52
+msgid "Palette of Mexican pesos"
+msgstr ""
+
+#: taextras.py:53
+msgid "Palette of Colombian pesos"
+msgstr ""
+
+#: taextras.py:54
+msgid "Palette of Rwandan francs"
+msgstr ""
+
+#: taextras.py:55
+msgid "Palette of US dollars"
+msgstr ""
+
+#: taextras.py:56
+msgid "Palette of Australian dollars"
+msgstr ""
+
+#: taextras.py:57
+msgid "Palette of Paraguayan Guaranies"
+msgstr ""
+
+#: taextras.py:58
+msgid "Palette of Peruvian Nuevo Soles"
+msgstr ""
+
+#: taextras.py:59
+msgid "Palette of Uruguayan Pesos"
+msgstr ""
+
+#. TRANS: Butia is the Arduino Robot Project from Uruguay
+#. (http://www.fing.edu.uy/inco/proyectos/butia/)
+#: taextras.py:65
+msgid "TurtleBots"
+msgstr ""
+
+#: taextras.py:66
+msgid "adjust LED intensity between 0 and 255"
+msgstr ""
+
+#: taextras.py:67
+msgid "returns the object gray level as a number between 0 and 1023"
+msgstr ""
+
+#: taextras.py:68
+msgid "returns 1 when the button is press and 0 otherwise"
+msgstr ""
+
+#: taextras.py:69
+msgid "returns the ambient light level as a number between 0 and 1023"
+msgstr ""
+
+#: taextras.py:70
+msgid "returns the ambient temperature as a number between 0 and 255"
+msgstr ""
+
+#: taextras.py:71
+msgid ""
+"returns the distance from the object in front of the sensor as a number "
+"between 0 and 255"
+msgstr ""
+
+#: taextras.py:73
+msgid "returns 0 or 1 depending on the sensor inclination"
+msgstr ""
+
+#: taextras.py:74
+msgid "returns 1 when the sensors detects a magnetic field, 0 otherwise"
+msgstr ""
+
+#: taextras.py:75
+msgid "switches from 0 to 1, the frequency depends on the vibration"
+msgstr ""
+
+#: taextras.py:76
+msgid "returns the value of the resistance"
+msgstr ""
+
+#: taextras.py:77
+msgid "LED"
+msgstr ""
+
+#: taextras.py:78
+msgid "button"
+msgstr ""
+
+#: taextras.py:79
+msgid "grayscale"
+msgstr ""
+
+#: taextras.py:80
+msgid "ambient light"
+msgstr ""
+
+#: taextras.py:81
+msgid "temperature"
+msgstr ""
+
+#: taextras.py:82 taextras.py:291
+msgid "distance"
+msgstr ""
+
+#: taextras.py:83 taextras.py:288
+msgid "tilt"
+msgstr ""
+
+#: taextras.py:84
+msgid "magnetic induction"
+msgstr ""
+
+#: taextras.py:85
+msgid "vibration"
+msgstr ""
+
+#: taextras.py:86 plugins/audio_sensors/audio_sensors.py:151
+#: plugins/audio_sensors/audio_sensors.py:165
+#: plugins/audio_sensors/audio_sensors.py:179
+#: plugins/audio_sensors/audio_sensors.py:193
+msgid "resistance"
+msgstr ""
+
+#: taextras.py:87
+msgid "Butia Robot"
+msgstr ""
+
+#: taextras.py:88
+msgid "refresh Butia"
+msgstr ""
+
+#: taextras.py:89
+msgid "refresh the state of the Butia palette and blocks"
+msgstr ""
+
+#. TRANS: This string is shorthand for "battery charge of Butia"
+#: taextras.py:91
+msgid "battery charge Butia"
+msgstr ""
+
+#: taextras.py:92
+msgid "returns the battery charge as a number between 0 and 255"
+msgstr ""
+
+#. TRANS: This string is shorthand for "speed of Butia"
+#: taextras.py:94
+msgid "speed Butia"
+msgstr ""
+
+#: taextras.py:95
+msgid "set the speed of the Butia motors"
+msgstr ""
+
+#: taextras.py:96
+msgid "the speed must be a value between 0 and 1023"
+msgstr ""
+
+#. TRANS: This string is shorthand for "move Butia forward"
+#: taextras.py:98
+msgid "forward Butia"
+msgstr ""
+
+#: taextras.py:99
+msgid "move the Butia robot forward"
+msgstr ""
+
+#: taextras.py:100
+msgid "move the Butia robot forward a predefined distance"
+msgstr ""
+
+#. TRANS: This string is shorthand for "turn Butia left"
+#: taextras.py:102
+msgid "left Butia"
+msgstr ""
+
+#: taextras.py:103
+msgid "turn the Butia robot at left"
+msgstr ""
+
+#. TRANS: This string is shorthand for "move Butia backward"
+#: taextras.py:105
+msgid "backward Butia"
+msgstr ""
+
+#: taextras.py:106
+msgid "move the Butia robot backward"
+msgstr ""
+
+#: taextras.py:107
+msgid "move the Butia robot backward a predefined distance"
+msgstr ""
+
+#. TRANS: This string is shorthand for "turn Butia right"
+#: taextras.py:109
+msgid "right Butia"
+msgstr ""
+
+#: taextras.py:110
+msgid "turn the Butia robot at right"
+msgstr ""
+
+#: taextras.py:111
+msgid "turn Butia"
+msgstr ""
+
+#: taextras.py:112
+msgid "turn the Butia robot x degrees"
+msgstr ""
+
+#: taextras.py:113
+msgid "stop Butia"
+msgstr ""
+
+#: taextras.py:114
+msgid "stop the Butia robot"
+msgstr ""
+
+#: taextras.py:115
+msgid "Butia"
+msgstr ""
+
+#: taextras.py:119
+msgid "Error importing Pygame. This plugin require Pygame 1.9"
+msgstr ""
+
+#: taextras.py:120
+msgid "Error on initialization of the camera"
+msgstr ""
+
+#: taextras.py:121
+msgid "No camera was found"
+msgstr ""
+
+#: taextras.py:122
+msgid "Error stopping camera"
+msgstr ""
+
+#: taextras.py:123
+msgid "Error starting camera"
+msgstr ""
+
+#. TRANS: The "mask" is used to restrict processing to a region in the image
+#: taextras.py:125
+msgid "Error in get mask"
+msgstr ""
+
+#: taextras.py:126
+msgid "FollowMe"
+msgstr ""
+
+#: taextras.py:127
+msgid "refresh FollowMe"
+msgstr ""
+
+#: taextras.py:128
+msgid "Search for a connected camera."
+msgstr ""
+
+#. TRANS: the calibration is used to match an RGB color to a target
+#: taextras.py:130
+msgid "calibration"
+msgstr ""
+
+#: taextras.py:131
+msgid "store a personalized calibration"
+msgstr ""
+
+#: taextras.py:132
+msgid "return a personalized calibration"
+msgstr ""
+
+#: taextras.py:133
+msgid "follow"
+msgstr ""
+
+#: taextras.py:134
+msgid "follow a color or calibration"
+msgstr ""
+
+#: taextras.py:135 plugins/camera_sensor/camera_sensor.py:80
+#: plugins/camera_sensor/camera_sensor.py:93
+#: plugins/camera_sensor/camera_sensor.py:128
+#: plugins/camera_sensor/camera_sensor.py:141
+#: plugins/light_sensor/light_sensor.py:56
+#: plugins/light_sensor/light_sensor.py:63
+msgid "brightness"
+msgstr ""
+
+#: taextras.py:136
+msgid "set the camera brightness as a value between 0 to 255."
+msgstr ""
+
+#: taextras.py:137
+msgid "minimum pixels"
+msgstr ""
+
+#: taextras.py:138
+msgid "set the minimal number of pixels to follow"
+msgstr ""
+
+#: taextras.py:139
+msgid "threshold"
+msgstr ""
+
+#. TRANS: RGB color space (red, green, blue)
+#: taextras.py:141
+msgid "set a threshold for a RGB color"
+msgstr ""
+
+#: taextras.py:142
+msgid "camera mode"
+msgstr ""
+
+#. TRANS: RGB, YUV, and HSV are color spaces
+#: taextras.py:144
+msgid "set the color mode of the camera: RGB; YUV or HSV"
+msgstr ""
+
+#: taextras.py:145
+msgid "get brightness"
+msgstr ""
+
+#: taextras.py:146
+msgid "get the brightness of the ambient light"
+msgstr ""
+
+#: taextras.py:147
+msgid "average color"
+msgstr ""
+
+#: taextras.py:148
+msgid ""
+"if set to 0 then color averaging is off during calibration; for other values "
+"it is on"
+msgstr ""
+
+#: taextras.py:149
+msgid "x position"
+msgstr ""
+
+#: taextras.py:150
+msgid "return x position"
+msgstr ""
+
+#: taextras.py:151
+msgid "y position"
+msgstr ""
+
+#: taextras.py:152
+msgid "return y position"
+msgstr ""
+
+#: taextras.py:153
+msgid "pixels"
+msgstr ""
+
+#: taextras.py:154
+msgid "return the number of pixels of the biggest blob"
+msgstr ""
+
+#. TRANS: RGB color space (red, green, blue)
+#: taextras.py:156
+msgid "set the color mode of the camera to RGB"
+msgstr ""
+
+#. TRANS: YUV color space (luminance, chrominance)
+#: taextras.py:158
+msgid "set the color mode of the camera to YUV"
+msgstr ""
+
+#. TRANS: HSV color space (hue, saturation, value)
+#: taextras.py:160
+msgid "set the color mode of the camera to HSV"
+msgstr ""
+
+#: taextras.py:161
+msgid "empty calibration"
+msgstr ""
+
+#: taextras.py:162
+msgid "error in string conversion"
+msgstr ""
+
+#. TRANS: SumBot is a robot programmed for "Sumo wrestling"
+#: taextras.py:167
+msgid "SumBot"
+msgstr ""
+
+#: taextras.py:168
+msgid "speed SumBot"
+msgstr ""
+
+#: taextras.py:169
+msgid "submit the speed to the SumBot"
+msgstr ""
+
+#: taextras.py:170
+msgid "set the default speed for the movement commands"
+msgstr ""
+
+#. TRANS: This string is shorthand for "move SumBot forward"
+#: taextras.py:172
+msgid "forward SumBot"
+msgstr ""
+
+#: taextras.py:173
+msgid "move SumBot forward"
+msgstr ""
+
+#. TRANS: This string is shorthand for "move SumBot backward"
+#: taextras.py:175
+msgid "backward SumBot"
+msgstr ""
+
+#: taextras.py:176
+msgid "move SumBot backward"
+msgstr ""
+
+#: taextras.py:177
+msgid "stop SumBot"
+msgstr ""
+
+#: taextras.py:178
+msgid "stop the SumBot"
+msgstr ""
+
+#. TRANS: This string is shorthand for "turn SumBot left"
+#: taextras.py:180
+msgid "left SumBot"
+msgstr ""
+
+#: taextras.py:181
+msgid "turn left the SumBot"
+msgstr ""
+
+#. TRANS: This string is shorthand for "move SumBot right"
+#: taextras.py:183
+msgid "right SumBot"
+msgstr ""
+
+#: taextras.py:184
+msgid "turn right the SumBot"
+msgstr ""
+
+#. TRANS: The angle to the center is the angle SumBot must turn to
+#. face the center of the playing field
+#: taextras.py:187
+msgid "angle to center"
+msgstr ""
+
+#. TRANS: dohyo is the playing field
+#: taextras.py:189
+msgid "get the angle to the center of the dohyo"
+msgstr ""
+
+#. TRANS: The angle to the center is the angle SumBot must turn to
+#. face the Enemy (opponent)
+#: taextras.py:192
+msgid "angle to Enemy"
+msgstr ""
+
+#: taextras.py:193
+msgid "get the angle to the Enemy"
+msgstr ""
+
+#. TRANS: This string is shorthand for "x coordinate of SumBot"
+#: taextras.py:195
+msgid "x coor. SumBot"
+msgstr ""
+
+#: taextras.py:196
+msgid "get the x coordinate of the SumBot"
+msgstr ""
+
+#. TRANS: This string is shorthand for "y coordinate of SumBot"
+#: taextras.py:198
+msgid "y coor. SumBot"
+msgstr ""
+
+#: taextras.py:199
+msgid "get the y coordinate of the SumBot"
+msgstr ""
+
+#. TRANS: This string is shorthand for "x coordinate of SumBot's enemy"
+#: taextras.py:201
+msgid "x coor. Enemy"
+msgstr ""
+
+#: taextras.py:202
+msgid "get the x coordinate of the Enemy"
+msgstr ""
+
+#. TRANS: This string is shorthand for "y coordinate of SumBot's enemy"
+#: taextras.py:204
+msgid "y coor. Enemy"
+msgstr ""
+
+#: taextras.py:205
+msgid "get the y coordinate of the Enemy"
+msgstr ""
+
+#. TRANS: This string is shorthand for "rotation of SumBot"
+#: taextras.py:207
+msgid "rotation SumBot"
+msgstr ""
+
+#: taextras.py:208
+msgid "get the rotation of the Sumbot"
+msgstr ""
+
+#. TRANS: This string is shorthand for "rotation of SumBot's enemy"
+#: taextras.py:210
+msgid "rotation Enemy"
+msgstr ""
+
+#: taextras.py:211
+msgid "get the rotation of the Enemy"
+msgstr ""
+
+#: taextras.py:212
+msgid "distance to center"
+msgstr ""
+
+#. TRANS: dohyo is the playing field
+#: taextras.py:214
+msgid "get the distance to the center of the dohyo"
+msgstr ""
+
+#: taextras.py:215
+msgid "distance to Enemy"
+msgstr ""
+
+#: taextras.py:216
+msgid "get the distance to the Enemy"
+msgstr ""
+
+#: taextras.py:217
+msgid "update information"
+msgstr ""
+
+#: taextras.py:218
+msgid "update information from the server"
+msgstr ""
+
+#. TRANS: Please use similar terms to those used in the Physics Activity
+#: taextras.py:223
+msgid "Palette of physics blocks"
+msgstr ""
+
+#: taextras.py:224
+msgid "start polygon"
+msgstr ""
+
+#: taextras.py:225
+msgid "Begin defining a new polygon based on the current Turtle xy position."
+msgstr ""
+
+#: taextras.py:227
+msgid "add point"
+msgstr ""
+
+#: taextras.py:228
+msgid ""
+"Add a new point to the current polygon based on the current Turtle xy "
+"position."
+msgstr ""
+
+#: taextras.py:230
+msgid "end polygon"
+msgstr ""
+
+#: taextras.py:231
+msgid "Define a new polygon."
+msgstr ""
+
+#: taextras.py:232
+msgid "end filled polygon"
+msgstr ""
+
+#: taextras.py:233
+msgid "Not a simple polygon"
+msgstr ""
+
+#: taextras.py:234
+msgid "Define a new filled polygon."
+msgstr ""
+
+#: taextras.py:235
+msgid "triangle"
+msgstr ""
+
+#. TRANS: base of a triangle
+#: taextras.py:237
+msgid "base"
+msgstr ""
+
+#: taextras.py:238 taextras.py:244
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:894
+msgid "height"
+msgstr ""
+
+#: taextras.py:239
+msgid "Add a triangle object to the project."
+msgstr ""
+
+#: taextras.py:240
+msgid "circle"
+msgstr ""
+
+#: taextras.py:241
+msgid "Add a circle object to the project."
+msgstr ""
+
+#: taextras.py:242
+msgid "rectangle"
+msgstr ""
+
+#: taextras.py:243 plugins/turtle_blocks_extras/turtle_blocks_extras.py:870
+msgid "width"
+msgstr ""
+
+#: taextras.py:245
+msgid "Add a rectangle object to the project."
+msgstr ""
+
+#: taextras.py:246
+msgid "reset"
+msgstr ""
+
+#: taextras.py:247
+msgid "Reset the project; clear the object list."
+msgstr ""
+
+#: taextras.py:248
+msgid "motor"
+msgstr ""
+
+#. TRANS: torque as in engine torque
+#: taextras.py:250
+msgid "torque"
+msgstr ""
+
+#: taextras.py:251
+msgid "speed"
+msgstr ""
+
+#: taextras.py:252
+msgid ""
+"Motor torque and speed range from 0 (off) to positive numbers; motor is "
+"placed on the most recent object created."
+msgstr ""
+
+#: taextras.py:254 taextras.py:417
+msgid "pin"
+msgstr ""
+
+#: taextras.py:255
+msgid "Pin an object down so that it cannot fall."
+msgstr ""
+
+#: taextras.py:256
+msgid "joint"
+msgstr ""
+
+#: taextras.py:257 TurtleArt/tabasics.py:199 TurtleArt/tabasics.py:265
+msgid "x"
+msgstr ""
+
+#: taextras.py:258 TurtleArt/tabasics.py:199 TurtleArt/tabasics.py:265
+msgid "y"
+msgstr ""
+
+#: taextras.py:259
+msgid ""
+"Join two objects together (the most recent object created and the object at "
+"point x, y)."
+msgstr ""
+
+#: taextras.py:261
+msgid "save as Physics activity"
+msgstr ""
+
+#: taextras.py:262
+msgid "Save the project to the Journal as a Physics activity."
+msgstr ""
+
+#. TRANS: Here, gear means a toothed wheel, as in a clock-works
+#: taextras.py:264
+msgid "gear"
+msgstr ""
+
+#: taextras.py:265
+msgid "Add a gear object to the project."
+msgstr ""
+
+#: taextras.py:266
+msgid "density"
+msgstr ""
+
+#: taextras.py:267
+msgid ""
+"Set the density property for objects (density can be any positive number)."
+msgstr ""
+
+#: taextras.py:269
+msgid "friction"
+msgstr ""
+
+#: taextras.py:270
+msgid ""
+"Set the friction property for objects (value from 0 to 1, where 0 turns "
+"friction off and 1 is strong friction)."
+msgstr ""
+
+#. TRANS: bounciness is coefficient of restitution
+#: taextras.py:273
+msgid "bounciness"
+msgstr ""
+
+#: taextras.py:274
+msgid ""
+"Set the bounciness property for objects (a value from 0 to 1, where 0 means "
+"no bounce and 1 is very bouncy)."
+msgstr ""
+
+#. TRANS: dynamic here means moving vs in a fixed position
+#: taextras.py:277
+msgid "dynamic"
+msgstr ""
+
+#: taextras.py:278
+msgid ""
+"If dynamic = 1, the object can move; if dynamic = 0, it is fixed in position."
+msgstr ""
+
+#. TRANS: WeDo is a robotics product of the LEGO company
+#: taextras.py:284
+msgid "Palette of WeDo blocks"
+msgstr ""
+
+#: taextras.py:285
+msgid "WeDo"
+msgstr ""
+
+#: taextras.py:286
+msgid "set current WeDo device"
+msgstr ""
+
+#: taextras.py:287
+msgid "number of WeDo devices"
+msgstr ""
+
+#: taextras.py:289
+msgid ""
+"tilt sensor output: (-1 == no tilt, 0 == tilt forward, 3 == tilt back, 1 == "
+"tilt left, 2 == tilt right)"
+msgstr ""
+
+#. TRANS: This string is shorthand for "output of the distance sensor"
+#: taextras.py:293
+msgid "distance sensor output"
+msgstr ""
+
+#: taextras.py:294
+msgid "Motor A"
+msgstr ""
+
+#: taextras.py:295
+msgid "returns the current value of Motor A"
+msgstr ""
+
+#: taextras.py:296
+msgid "Motor B"
+msgstr ""
+
+#: taextras.py:297
+msgid "returns the current value of Motor B"
+msgstr ""
+
+#: taextras.py:298
+msgid "set the value for Motor A"
+msgstr ""
+
+#: taextras.py:299
+msgid "set the value for Motor B"
+msgstr ""
+
+#: taextras.py:300
+msgid "WeDo is unavailable"
+msgstr ""
+
+#. TRANS: e.g., Wedo 2 is unavailable, defaulting to 1
+#: taextras.py:302
+#, python-format
+msgid "WeDo %d is unavailable; defaulting to 1"
+msgstr ""
+
+#. TRANS: %(device)s and %(wedo_number)d are substitution strings;
+#. please leave untranslated
+#: taextras.py:305
+#, python-format
+msgid "%(device)s is unavailable on WeDo %(wedo_number)d"
+msgstr ""
+
+#. TRANS: Lego NXT is a robotics product of the LEGO company
+#: taextras.py:311
+msgid "Palette of LEGO NXT blocks of motors"
+msgstr ""
+
+#: taextras.py:312
+msgid "Palette of LEGO NXT blocks of sensors"
+msgstr ""
+
+#. TRANS: touch sensor (implemented as a button)
+#: taextras.py:314
+msgid "touch"
+msgstr ""
+
+#. TRANS: distance sensor (implemented using ultrasonics)
+#: taextras.py:316
+msgid "ultrasonic"
+msgstr ""
+
+#: taextras.py:317 TurtleArt/tabasics.py:287 TurtleArt/tabasics.py:298
+#: TurtleArt/tabasics.py:348
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1158
+msgid "color"
+msgstr "ቀለም"
+
+#: taextras.py:318
+#, fuzzy
+msgid "light"
+msgstr "ቀኝ"
+
+#: taextras.py:319 plugins/audio_sensors/audio_sensors.py:83
+#: plugins/audio_sensors/audio_sensors.py:98 pysamples/grecord.py:205
+msgid "sound"
+msgstr ""
+
+#: taextras.py:320
+msgid "grey"
+msgstr ""
+
+#. TRANS: The brick is the NXT controller
+#: taextras.py:322
+msgid "Please check the connection with the brick"
+msgstr ""
+
+#: taextras.py:323
+#, python-format
+msgid "Invalid port '%s'. Port must be: PORT A, B or C"
+msgstr ""
+
+#: taextras.py:324
+#, python-format
+msgid "Invalid port '%s'. Port must be: PORT 1, 2, 3 or 4"
+msgstr ""
+
+#: taextras.py:325
+msgid "The value of power must be between -127 to 127"
+msgstr ""
+
+#: taextras.py:326
+#, python-format
+msgid "The parameter must be a integer, not '%s'"
+msgstr ""
+
+#: taextras.py:327
+msgid "An error has occurred: check all connections and try to reconnect"
+msgstr ""
+
+#: taextras.py:328
+#, python-format
+msgid "NXT found %s bricks"
+msgstr ""
+
+#: taextras.py:329
+msgid "NXT not found"
+msgstr ""
+
+#: taextras.py:330
+#, python-format
+msgid "Brick number %s was not found"
+msgstr ""
+
+#: taextras.py:331
+msgid "refresh NXT"
+msgstr ""
+
+#: taextras.py:332
+msgid "Search for a connected NXT brick."
+msgstr ""
+
+#: taextras.py:333
+msgid "NXT"
+msgstr ""
+
+#: taextras.py:334
+msgid "set current NXT device"
+msgstr ""
+
+#: taextras.py:335
+msgid "number of NXT devices"
+msgstr ""
+
+#: taextras.py:336
+msgid "brick name"
+msgstr ""
+
+#: taextras.py:337
+msgid "Get the name of a brick."
+msgstr ""
+
+#: taextras.py:338
+msgid "play tone"
+msgstr ""
+
+#: taextras.py:339
+msgid "frequency"
+msgstr ""
+
+#: taextras.py:340 plugins/turtle_blocks_extras/turtle_blocks_extras.py:445
+msgid "time"
+msgstr ""
+
+#: taextras.py:341
+msgid "Play a tone at frequency for time."
+msgstr ""
+
+#. TRANS: turn is the action
+#: taextras.py:343
+msgid ""
+"turn motor\n"
+"\n"
+msgstr ""
+
+#: taextras.py:344
+msgid "port"
+msgstr ""
+
+#: taextras.py:345
+msgid "power"
+msgstr ""
+
+#. TRANS: rotations is quantity of turns
+#: taextras.py:347
+msgid "rotations"
+msgstr ""
+
+#: taextras.py:348
+msgid "turn a motor"
+msgstr ""
+
+#: taextras.py:349
+msgid ""
+"synchronize\n"
+"\n"
+"motors"
+msgstr ""
+
+#: taextras.py:350
+msgid "steering"
+msgstr ""
+
+#: taextras.py:351
+msgid "synchronize two motors connected in PORT B and PORT C"
+msgstr ""
+
+#: taextras.py:352
+msgid "PORT A"
+msgstr ""
+
+#: taextras.py:353
+msgid "PORT A of the brick"
+msgstr ""
+
+#: taextras.py:354
+msgid "PORT B"
+msgstr ""
+
+#: taextras.py:355
+msgid "PORT B of the brick"
+msgstr ""
+
+#: taextras.py:356
+msgid "PORT C"
+msgstr ""
+
+#: taextras.py:357
+msgid "PORT C of the brick"
+msgstr ""
+
+#: taextras.py:358
+msgid "start motor"
+msgstr ""
+
+#: taextras.py:359
+msgid "Run a motor forever."
+msgstr ""
+
+#: taextras.py:360
+msgid "brake motor"
+msgstr ""
+
+#: taextras.py:361
+msgid "Stop a specified motor."
+msgstr ""
+
+#. TRANS: reset is used to reset the counter associated with the motor
+#: taextras.py:363
+msgid "reset motor"
+msgstr ""
+
+#: taextras.py:364
+msgid "Reset the motor counter."
+msgstr ""
+
+#: taextras.py:365
+msgid "motor position"
+msgstr ""
+
+#: taextras.py:366
+msgid "Get the motor position."
+msgstr ""
+
+#: taextras.py:367
+msgid "PORT 1"
+msgstr ""
+
+#: taextras.py:368
+msgid "PORT 1 of the brick"
+msgstr ""
+
+#: taextras.py:369
+msgid "read"
+msgstr ""
+
+#: taextras.py:370
+msgid "sensor"
+msgstr ""
+
+#: taextras.py:371
+msgid "Read sensor output."
+msgstr ""
+
+#: taextras.py:372
+msgid "PORT 2"
+msgstr ""
+
+#: taextras.py:373
+msgid "PORT 2 of the brick"
+msgstr ""
+
+#: taextras.py:374
+msgid "light sensor"
+msgstr ""
+
+#: taextras.py:375
+msgid "grey sensor"
+msgstr ""
+
+#: taextras.py:376
+msgid "PORT 3"
+msgstr ""
+
+#: taextras.py:377
+msgid "PORT 3 of the brick"
+msgstr ""
+
+#: taextras.py:378
+msgid "touch sensor"
+msgstr ""
+
+#: taextras.py:379
+msgid "distance sensor"
+msgstr ""
+
+#: taextras.py:380
+msgid "PORT 4"
+msgstr ""
+
+#: taextras.py:381
+msgid "PORT 4 of the brick"
+msgstr ""
+
+#: taextras.py:382
+msgid "sound sensor"
+msgstr ""
+
+#: taextras.py:383
+msgid "color sensor"
+msgstr ""
+
+#. TRANS: set light is used to set the light level associated with
+#. the color sensor (which can emit light as well as sense it)
+#: taextras.py:386
+msgid "set light"
+msgstr ""
+
+#: taextras.py:387
+msgid "Set color sensor light."
+msgstr ""
+
+#. TRANS: the battery level is the charge level of the brick
+#: taextras.py:389
+msgid "battery level"
+msgstr ""
+
+#: taextras.py:390
+msgid "Get battery level of the brick"
+msgstr ""
+
+#. TRANS: Arduino plugin to control an Arduino board
+#: taextras.py:395
+msgid "HIGH"
+msgstr ""
+
+#: taextras.py:396
+msgid "LOW"
+msgstr ""
+
+#: taextras.py:397
+msgid "INPUT"
+msgstr ""
+
+#: taextras.py:398
+msgid "OUTPUT"
+msgstr ""
+
+#. TRANS: PWM is pulse-width modulation
+#: taextras.py:400
+msgid "PWM"
+msgstr ""
+
+#: taextras.py:401
+msgid "SERVO"
+msgstr ""
+
+#: taextras.py:402
+msgid "ERROR: Check the Arduino and the number of port."
+msgstr ""
+
+#: taextras.py:403
+msgid "ERROR: Value must be a number from 0 to 255."
+msgstr ""
+
+#: taextras.py:404
+msgid "ERROR: Value must be either HIGH or LOW."
+msgstr ""
+
+#: taextras.py:405
+msgid "ERROR: The mode must be either INPUT, OUTPUT, PWM or SERVO."
+msgstr ""
+
+#: taextras.py:406
+msgid "refresh Arduino"
+msgstr ""
+
+#: taextras.py:407
+msgid "Search for connected Arduinos."
+msgstr ""
+
+#: taextras.py:408
+msgid "Arduino"
+msgstr ""
+
+#: taextras.py:409
+msgid "set current Arduino board"
+msgstr ""
+
+#: taextras.py:410
+msgid "number of Arduinos"
+msgstr ""
+
+#: taextras.py:411
+msgid "number of Arduino boards"
+msgstr ""
+
+#: taextras.py:412
+msgid "Arduino name"
+msgstr ""
+
+#: taextras.py:413
+msgid "Get the name of an Arduino."
+msgstr ""
+
+#. TRANS: pin mode is used to specify the mode (INPUT, OUTPUT, etc)
+#. in which an I/O pin is being used.
+#: taextras.py:416
+msgid "pin mode"
+msgstr ""
+
+#: taextras.py:418
+msgid "mode"
+msgstr ""
+
+#: taextras.py:419
+msgid "Select the pin function (INPUT, OUTPUT, PWM, SERVO)."
+msgstr ""
+
+#: taextras.py:420
+msgid "analog write"
+msgstr ""
+
+#: taextras.py:421 TurtleArt/tabasics.py:928 TurtleArt/tawindow.py:4189
+msgid "value"
+msgstr ""
+
+#: taextras.py:422
+msgid "Write analog value in specified port."
+msgstr ""
+
+#: taextras.py:423
+msgid "analog read"
+msgstr ""
+
+#: taextras.py:424
+msgid ""
+"Read value from analog port. Value may be between 0 and 1023. Use Vref to "
+"determine voltage. For USB, volt=((read)*5)/1024) approximately."
+msgstr ""
+
+#: taextras.py:426
+msgid "digital write"
+msgstr ""
+
+#: taextras.py:427
+msgid "Write digital value to specified port."
+msgstr ""
+
+#: taextras.py:428
+msgid "digital read"
+msgstr ""
+
+#: taextras.py:429
+msgid "Read value from digital port."
+msgstr ""
+
+#: taextras.py:430
+msgid "Set HIGH value for digital port."
+msgstr ""
+
+#: taextras.py:431
+msgid "Configure Arduino port for digital input."
+msgstr ""
+
+#: taextras.py:432
+msgid "Configure Arduino port to drive a servo."
+msgstr ""
+
+#: taextras.py:433
+msgid "Set LOW value for digital port."
+msgstr ""
+
+#: taextras.py:434
+msgid "Configure Arduino port for digital output."
+msgstr ""
+
+#: taextras.py:435
+msgid "Configure Arduino port for PWM (pulse-width modulation)."
+msgstr ""
+
+#. TRANS: plugin to control an ExpEyes device
+#: taextras.py:440
+msgid "Palette of Expeyes blocks"
+msgstr ""
+
+#. TRANS: Programmable voltage output
+#: taextras.py:442
+msgid "set PVS"
+msgstr ""
+
+#: taextras.py:443
+msgid "set programmable voltage output"
+msgstr ""
+
+#. TRANS: Square wave 1 voltage output
+#: taextras.py:445
+msgid "set SQR1 voltage"
+msgstr ""
+
+#: taextras.py:446
+msgid "set square wave 1 voltage output"
+msgstr ""
+
+#. TRANS: Square wave 2 voltage output
+#: taextras.py:448
+msgid "set SQR2 voltage"
+msgstr ""
+
+#: taextras.py:449
+msgid "set square wave 2 voltage output"
+msgstr ""
+
+#. TRANS: Digital output level
+#: taextras.py:451
+msgid "set OD1"
+msgstr ""
+
+#: taextras.py:452
+msgid "set digital output level (OD1) low (0) or high (1)"
+msgstr ""
+
+#. TRANS: Input 1 voltage level
+#: taextras.py:454
+msgid "IN1 level"
+msgstr ""
+
+#: taextras.py:455
+msgid ""
+"returns 1 if IN1 voltage level >2.5 volts, 0 if IN1 voltage level <= 2.5 "
+"volts"
+msgstr ""
+
+#. TRANS: Input 2 voltage level
+#: taextras.py:458
+msgid "IN2 level"
+msgstr ""
+
+#: taextras.py:459
+msgid ""
+"returns 1 if IN2 voltage level >2.5 volts, 0 if IN2 voltage level <= 2.5 "
+"volts"
+msgstr ""
+
+#. TRANS: Resistive sensor voltage level
+#: taextras.py:462
+msgid "SEN level"
+msgstr ""
+
+#: taextras.py:463
+msgid ""
+"returns 1 if resistive sensor (SEN) voltage level > 2.5 volts, 0 if SEN "
+"voltage level <= 2.5 volts"
+msgstr ""
+
+#: taextras.py:465
+msgid "capture"
+msgstr ""
+
+#: taextras.py:466
+msgid "input"
+msgstr ""
+
+#: taextras.py:467
+msgid "samples"
+msgstr ""
+
+#: taextras.py:468
+msgid "interval"
+msgstr ""
+
+#. TRANS: MS is microseconds
+#: taextras.py:470
+msgid ""
+"capture multiple samples from input at interval (MS); results pushed to FIFO"
+msgstr ""
+
+#. TRANS: Analog input 1 voltage level
+#: taextras.py:473
+msgid "A1"
+msgstr ""
+
+#: taextras.py:474
+msgid "read analog input 1 voltage"
+msgstr ""
+
+#. TRANS: Analog input 2 voltage level
+#: taextras.py:476
+msgid "A2"
+msgstr ""
+
+#: taextras.py:477
+msgid "read analog input 2 voltage"
+msgstr ""
+
+#. TRANS: Read input 1 voltage
+#: taextras.py:479
+msgid "IN1"
+msgstr ""
+
+#: taextras.py:480
+msgid "read input 1 voltage"
+msgstr ""
+
+#. TRANS: Read input 2 voltage
+#: taextras.py:482
+msgid "IN2"
+msgstr ""
+
+#: taextras.py:483
+msgid "read input 2 voltage"
+msgstr ""
+
+#. TRANS: Read analog sensor input voltage
+#: taextras.py:485
+msgid "SEN"
+msgstr ""
+
+#: taextras.py:486
+msgid "read analog sensor input voltage"
+msgstr ""
+
+#. TRANS: Read square wave 1 input voltage
+#: taextras.py:488
+msgid "SQR1"
+msgstr ""
+
+#: taextras.py:489
+msgid "read square wave 1 voltage"
+msgstr ""
+
+#. TRANS: Read square wave 2 input voltage
+#: taextras.py:491
+msgid "SQR2"
+msgstr ""
+
+#: taextras.py:492
+msgid "read square wave 2 voltage"
+msgstr ""
+
+#. TRANS: Read programmable voltage
+#: taextras.py:494
+msgid "PVS"
+msgstr ""
+
+#: taextras.py:495
+msgid "read programmable voltage"
+msgstr ""
+
+#: taextras.py:496
+msgid "Expeyes device not found"
+msgstr ""
+
+#: TurtleArt/taconstants.py:209 TurtleArt/taconstants.py:231
+#: TurtleArt/taconstants.py:252 TurtleArt/taconstants.py:294
+#: TurtleArt/taconstants.py:336 TurtleArt/taconstants.py:378
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:963
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:978
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:993
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1008
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1023
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1038
+msgid "Title"
+msgstr " አርእስት"
+
+#: TurtleArtActivity.py:682 TurtleArtActivity.py:892 turtleblocks.py:401
+msgid "Step"
+msgstr "እርምጃ"
+
+#: TurtleArt/tawindow.py:1000 TurtleArt/tawindow.py:1470
+msgid "next"
+msgstr "ቀጥል"
+
+#: gnome_plugins/uploader_plugin.py:109
+msgid "Password:"
+msgstr "ሚስጢራዊ ቃል፦"
+
+#: plugins/audio_sensors/audio_sensors.py:119
+#: plugins/audio_sensors/audio_sensors.py:127
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:316
+msgid "pitch"
+msgstr "አጣጣል"
+
+#: TurtleArt/tabasics.py:705
+msgid "not"
+msgstr "እንጂ"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:549
+msgid "print"
+msgstr "አትም"
+
+#: TurtleArt/tabasics.py:662
+msgid "number"
+msgstr "ቁጥር"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:124
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:715
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:886
+msgid "top"
+msgstr "ላይኛ"
+
+#: gnome_plugins/uploader_plugin.py:144
+msgid "Cancel"
+msgstr "ተወው ሻር"
+
+#: TurtleArtActivity.py:594 TurtleArtActivity.py:748
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:789
+msgid "Fullscreen"
+msgstr "ሙሉ እስክሪን"
+
+#: TurtleArt/tabasics.py:853 TurtleArt/tabasics.py:854
+#: TurtleArt/tabasics.py:855
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:186
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:187
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:188
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:195
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:208
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:223
+msgid "text"
+msgstr "ጽሑፍ"
+
+#: TurtleArt/tabasics.py:454
+#, fuzzy
+msgid "black"
+msgstr "ኋላ"
+
+#: pysamples/grecord.py:215
+#, fuzzy
+msgid "stop"
+msgstr "ላይኛ"
+
+#: gnome_plugins/uploader_plugin.py:120
+msgid "Title:"
+msgstr " አርእስት፦"
+
+#: gnome_plugins/collaboration_plugin.py:304
+#, fuzzy
+msgid "Colors"
+msgstr "ቀለም"
+
+#: turtleblocks.py:355
+msgid "Open"
+msgstr "ክፈት"
+
+#: TurtleArtActivity.py:688 turtleblocks.py:403
+msgid "Stop"
+msgstr "ቁም ቁሚ አቁም አቁሚ"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:151
+msgid "audio"
+msgstr "ድምፅ"
+
+#: turtleblocks.py:396
+msgid "Tools"
+msgstr "መሣሪያዎች"
+
+#: TurtleArt/tabasics.py:162
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:854
+msgid "left"
+msgstr "ግራ"
+
+#: gnome_plugins/collaboration_plugin.py:300
+#, fuzzy
+msgid "Password"
+msgstr "ሚስጢራዊ ቃል፦"
+
+#: turtleblocks.py:362
+msgid "Quit"
+msgstr "ውጣ"
+
+#: turtleblocks.py:354
+msgid "New"
+msgstr "አዲስ"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:266
+msgid "scale"
+msgstr "ሚዛን"
+
+#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:140
+msgid "journal"
+msgstr "መጽሔት"
+
+#: TurtleArt/tabasics.py:843 pysamples/grecord.py:213
+msgid "start"
+msgstr "ጀምር"
+
+#: TurtleArt/tabasics.py:139
+msgid "back"
+msgstr "ኋላ"
+
+#: TurtleArt/tabasics.py:287 TurtleArt/tabasics.py:298
+#, fuzzy
+msgid "fill screen"
+msgstr "ሙሉ እስክሪን"
+
+#. TRANS: "name" option from activity.info file
msgid "TurtleBlocks"
msgstr ""
@@ -42,10 +1665,6 @@ msgstr ""
msgid "moves turtle forward"
msgstr ""
-#: TurtleArt/tabasics.py:139
-msgid "back"
-msgstr "ኋላ"
-
#: TurtleArt/tabasics.py:143
msgid "moves turtle backward"
msgstr ""
@@ -58,11 +1677,6 @@ msgstr ""
msgid "clears the screen and reset the turtle"
msgstr ""
-#: TurtleArt/tabasics.py:162
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:854
-msgid "left"
-msgstr "ግራ"
-
#: TurtleArt/tabasics.py:166
msgid "turns turtle counterclockwise (angle in degrees)"
msgstr ""
@@ -96,14 +1710,6 @@ msgstr ""
msgid "set xy"
msgstr ""
-#: TurtleArt/tabasics.py:199 TurtleArt/tabasics.py:265
-msgid "x"
-msgstr ""
-
-#: TurtleArt/tabasics.py:199 TurtleArt/tabasics.py:265
-msgid "y"
-msgstr ""
-
#: TurtleArt/tabasics.py:203 TurtleArt/tabasics.py:269
msgid ""
"moves turtle to position xcor, ycor; (0, 0) is in the center of the screen."
@@ -154,17 +1760,6 @@ msgstr ""
msgid "Palette of pen commands"
msgstr ""
-#: TurtleArt/tabasics.py:287 TurtleArt/tabasics.py:298
-#, fuzzy
-msgid "fill screen"
-msgstr "ሙሉ እስክሪን"
-
-#: TurtleArt/tabasics.py:287 TurtleArt/tabasics.py:298
-#: TurtleArt/tabasics.py:348
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1158
-msgid "color"
-msgstr "ቀለም"
-
#: TurtleArt/tabasics.py:287 TurtleArt/tabasics.py:299
#: TurtleArt/tabasics.py:358
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1154
@@ -302,11 +1897,6 @@ msgstr ""
msgid "white"
msgstr ""
-#: TurtleArt/tabasics.py:454
-#, fuzzy
-msgid "black"
-msgstr "ኋላ"
-
#: TurtleArt/tabasics.py:460
msgid "set text color"
msgstr ""
@@ -404,10 +1994,6 @@ msgstr ""
msgid "returns random number between minimum (top) and maximum (bottom) values"
msgstr ""
-#: TurtleArt/tabasics.py:662
-msgid "number"
-msgstr "ቁጥር"
-
#: TurtleArt/tabasics.py:663
msgid "used as numeric input in mathematic operators"
msgstr ""
@@ -436,10 +2022,6 @@ msgstr ""
msgid "logical equal-to operator"
msgstr ""
-#: TurtleArt/tabasics.py:705
-msgid "not"
-msgstr "እንጂ"
-
#: TurtleArt/tabasics.py:708
msgid "logical NOT operator"
msgstr ""
@@ -545,25 +2127,10 @@ msgstr ""
msgid "Palette of variable blocks"
msgstr ""
-#: TurtleArt/tabasics.py:843 pysamples/grecord.py:213
-msgid "start"
-msgstr "ጀምር"
-
#: TurtleArt/tabasics.py:846
msgid "connects action to toolbar run buttons"
msgstr ""
-#: TurtleArt/tabasics.py:853 TurtleArt/tabasics.py:854
-#: TurtleArt/tabasics.py:855
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:186
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:187
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:188
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:195
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:208
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:223
-msgid "text"
-msgstr "ጽሑፍ"
-
#: TurtleArt/tabasics.py:856
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:189
msgid "string value"
@@ -625,10 +2192,6 @@ msgstr ""
msgid "box"
msgstr ""
-#: TurtleArt/tabasics.py:928 TurtleArt/tawindow.py:4189
-msgid "value"
-msgstr ""
-
#: TurtleArt/tabasics.py:932 TurtleArt/tabasics.py:945
#: TurtleArt/tawindow.py:1296 TurtleArt/tawindow.py:1409
#: TurtleArt/tawindow.py:1858 TurtleArt/tawindow.py:4152
@@ -701,18 +2264,6 @@ msgstr ""
msgid "Share selected blocks"
msgstr ""
-#: TurtleArt/taconstants.py:209 TurtleArt/taconstants.py:231
-#: TurtleArt/taconstants.py:252 TurtleArt/taconstants.py:294
-#: TurtleArt/taconstants.py:336 TurtleArt/taconstants.py:378
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:963
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:978
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:993
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1008
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1023
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1038
-msgid "Title"
-msgstr " አርእስት"
-
#: TurtleArt/talogo.py:374 TurtleArtActivity.py:683
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:1492
msgid "Stop turtle"
@@ -768,10 +2319,6 @@ msgstr ""
msgid "orientation"
msgstr ""
-#: TurtleArt/tawindow.py:1000 TurtleArt/tawindow.py:1470
-msgid "next"
-msgstr "ቀጥል"
-
#: TurtleArt/tawindow.py:1012 TurtleArt/tawindow.py:1013
#: TurtleArt/tawindow.py:1490
msgid "shift"
@@ -870,11 +2417,6 @@ msgstr ""
msgid "Restore blocks from trash"
msgstr ""
-#: TurtleArtActivity.py:594 TurtleArtActivity.py:748
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:789
-msgid "Fullscreen"
-msgstr "ሙሉ እስክሪን"
-
#: TurtleArtActivity.py:596 TurtleArtActivity.py:749 turtleblocks.py:366
msgid "Cartesian coordinates"
msgstr ""
@@ -908,18 +2450,10 @@ msgstr ""
msgid "Run"
msgstr ""
-#: TurtleArtActivity.py:682 TurtleArtActivity.py:892 turtleblocks.py:401
-msgid "Step"
-msgstr "እርምጃ"
-
#: TurtleArtActivity.py:687 turtleblocks.py:408 util/helpbutton.py:45
msgid "Help"
msgstr ""
-#: TurtleArtActivity.py:688 turtleblocks.py:403
-msgid "Stop"
-msgstr "ቁም ቁሚ አቁም አቁሚ"
-
#: TurtleArtActivity.py:710 TurtleArtActivity.py:836 TurtleArtActivity.py:858
msgid "Load project"
msgstr ""
@@ -1023,20 +2557,10 @@ msgstr ""
msgid "Port"
msgstr ""
-#: gnome_plugins/collaboration_plugin.py:300
-#, fuzzy
-msgid "Password"
-msgstr "ሚስጢራዊ ቃል፦"
-
#: gnome_plugins/collaboration_plugin.py:302
msgid "Register"
msgstr ""
-#: gnome_plugins/collaboration_plugin.py:304
-#, fuzzy
-msgid "Colors"
-msgstr "ቀለም"
-
#: gnome_plugins/fb_plugin.py:82 gnome_plugins/fb_plugin.py:83
#: gnome_plugins/fb_plugin.py:92 gnome_plugins/uploader_plugin.py:63
#: gnome_plugins/uploader_plugin.py:64 gnome_plugins/uploader_plugin.py:73
@@ -1061,14 +2585,6 @@ msgstr ""
msgid "Username:"
msgstr ""
-#: gnome_plugins/uploader_plugin.py:109
-msgid "Password:"
-msgstr "ሚስጢራዊ ቃል፦"
-
-#: gnome_plugins/uploader_plugin.py:120
-msgid "Title:"
-msgstr " አርእስት፦"
-
#: gnome_plugins/uploader_plugin.py:130
msgid "Description:"
msgstr ""
@@ -1077,10 +2593,6 @@ msgstr ""
msgid "Submit to Web"
msgstr ""
-#: gnome_plugins/uploader_plugin.py:144
-msgid "Cancel"
-msgstr "ተወው ሻር"
-
#: gnome_plugins/uploader_plugin.py:166
msgid "Login failed"
msgstr ""
@@ -1107,11 +2619,6 @@ msgstr ""
msgid "push acceleration in x, y, z to heap"
msgstr ""
-#: plugins/audio_sensors/audio_sensors.py:83
-#: plugins/audio_sensors/audio_sensors.py:98 pysamples/grecord.py:205
-msgid "sound"
-msgstr ""
-
#: plugins/audio_sensors/audio_sensors.py:84
#: plugins/audio_sensors/audio_sensors.py:99
msgid "raw microphone input signal"
@@ -1127,24 +2634,11 @@ msgstr ""
msgid "microphone input volume"
msgstr ""
-#: plugins/audio_sensors/audio_sensors.py:119
-#: plugins/audio_sensors/audio_sensors.py:127
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:316
-msgid "pitch"
-msgstr "አጣጣል"
-
#: plugins/audio_sensors/audio_sensors.py:120
#: plugins/audio_sensors/audio_sensors.py:128
msgid "microphone input pitch"
msgstr ""
-#: plugins/audio_sensors/audio_sensors.py:151
-#: plugins/audio_sensors/audio_sensors.py:165
-#: plugins/audio_sensors/audio_sensors.py:179
-#: plugins/audio_sensors/audio_sensors.py:193
-msgid "resistance"
-msgstr ""
-
#: plugins/audio_sensors/audio_sensors.py:152
#: plugins/audio_sensors/audio_sensors.py:166
#: plugins/audio_sensors/audio_sensors.py:180
@@ -1171,15 +2665,6 @@ msgstr ""
msgid "Palette of media objects"
msgstr ""
-#: plugins/camera_sensor/camera_sensor.py:80
-#: plugins/camera_sensor/camera_sensor.py:93
-#: plugins/camera_sensor/camera_sensor.py:128
-#: plugins/camera_sensor/camera_sensor.py:141
-#: plugins/light_sensor/light_sensor.py:56
-#: plugins/light_sensor/light_sensor.py:63
-msgid "brightness"
-msgstr ""
-
#: plugins/camera_sensor/camera_sensor.py:82
#: plugins/camera_sensor/camera_sensor.py:130
msgid "light level detected by camera"
@@ -1229,28 +2714,14 @@ msgstr ""
msgid "do-until-True operator that uses boolean operators from Numbers palette"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:124
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:715
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:886
-msgid "top"
-msgstr "ላይኛ"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:126
msgid "top of a collapsible stack"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:140
-msgid "journal"
-msgstr "መጽሔት"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:141
msgid "Sugar Journal media object"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:151
-msgid "audio"
-msgstr "ድምፅ"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:153
msgid "Sugar Journal audio object"
msgstr ""
@@ -1315,10 +2786,6 @@ msgstr ""
msgid "saves turtle graphics as an SVG file in the Sugar Journal"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:266
-msgid "scale"
-msgstr "ሚዛን"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:270
msgid "holds current scale value"
msgstr ""
@@ -1445,10 +2912,6 @@ msgstr ""
msgid "returns the color that the turtle \"sees\""
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:445
-msgid "time"
-msgstr ""
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:448
msgid "elapsed time (in seconds) since program started"
msgstr ""
@@ -1510,10 +2973,6 @@ msgstr ""
msgid "places a comment in your code"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:549
-msgid "print"
-msgstr "አትም"
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:553
msgid "prints value in status block at bottom of the screen"
msgstr ""
@@ -1697,10 +3156,6 @@ msgstr ""
msgid "ycor of bottom of screen"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:870
-msgid "width"
-msgstr ""
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:873
msgid "the canvas width"
msgstr ""
@@ -1713,10 +3168,6 @@ msgstr ""
msgid "ycor of top of screen"
msgstr ""
-#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:894
-msgid "height"
-msgstr ""
-
#: plugins/turtle_blocks_extras/turtle_blocks_extras.py:897
msgid "the canvas height"
msgstr ""
@@ -1789,11 +3240,6 @@ msgstr ""
msgid "push destination rgb value to heap"
msgstr ""
-#: pysamples/grecord.py:215
-#, fuzzy
-msgid "stop"
-msgstr "ላይኛ"
-
#: pysamples/grecord.py:217
msgid "play"
msgstr ""
@@ -1831,14 +3277,6 @@ msgstr ""
msgid "Configuration directory not writable: %s"
msgstr ""
-#: turtleblocks.py:354
-msgid "New"
-msgstr "አዲስ"
-
-#: turtleblocks.py:355
-msgid "Open"
-msgstr "ክፈት"
-
#: turtleblocks.py:356
msgid "Save"
msgstr ""
@@ -1847,10 +3285,6 @@ msgstr ""
msgid "Save as"
msgstr ""
-#: turtleblocks.py:362
-msgid "Quit"
-msgstr "ውጣ"
-
#: turtleblocks.py:363
msgid "File"
msgstr ""
@@ -1867,10 +3301,6 @@ msgstr ""
msgid "Show/hide blocks"
msgstr ""
-#: turtleblocks.py:396
-msgid "Tools"
-msgstr "መሣሪያዎች"
-
#: turtleblocks.py:402
msgid "Debug"
msgstr ""
@@ -1891,10 +3321,6 @@ msgstr ""
msgid "Save project?"
msgstr ""
-#, fuzzy
-#~ msgid "light"
-#~ msgstr "ቀኝ"
-
#~ msgid "full screen"
#~ msgstr "ሙሉ እስክሪን"
diff --git a/po/ar.po b/po/ar.po
index ce803b1..11d23ba 100644
--- a/po/ar.po
+++ b/po/ar.po
@@ -2,8 +2,33 @@
# Copyright (C) YEAR THE PACKAGE'S COPYRIGHT HOLDER
# This file is distributed under the same license as the PACKAGE package.
# FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
+#, fuzzy
msgid ""
msgstr ""
+"#-#-#-#-# ar.po (PACKAGE VERSION) #-#-#-#-#\n"
+"Project-Id-Version: PACKAGE VERSION\n"
+"Report-Msgid-Bugs-To: \n"
+"POT-Creation-Date: 2012-11-02 00:32-0400\n"
+"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
+"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
+"Language-Team: LANGUAGE <LL@li.org>\n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
+"X-Generator: Translate Toolkit 1.7.0\n"
+"#-#-#-#-# ar.po (PACKAGE VERSION) #-#-#-#-#\n"
+"#-#-#-#-# ar.po (PACKAGE VERSION) #-#-#-#-#\n"
+"Project-Id-Version: PACKAGE VERSION\n"
+"Report-Msgid-Bugs-To: \n"
+"POT-Creation-Date: 2012-11-02 00:32-0400\n"
+"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
+"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
+"Language-Team: LANGUAGE <LL@li.org>\n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
+"X-Generator: Translate Toolkit 1.7.0\n"
+"#-#-#-#-# ar.po (PACKAGE VERSION) #-#-#-#-#\n"
"Project-Id-Version: PACKAGE VERSION\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2013-02-24 00:31-0500\n"
@@ -19,6 +44,1675 @@ msgstr ""
"X-Generator: Pootle 2.0.3\n"
#. TRANS: "name" option from activity.info file
+#. TRANS: "summary" option from activity.info file
+#. TRANS: "description" option from activity.info file
+msgid "turtleart-extras (master)"
+msgstr ""
+
+#: taextras.py:36
+msgid "Turtle Art Mini"
+msgstr ""
+
+#: taextras.py:40
+msgid "Turtle Confusion"
+msgstr ""
+
+#: taextras.py:41 taextras.py:46
+msgid "Select a challenge"
+msgstr ""
+
+#: taextras.py:45
+msgid "Amazonas Tortuga"
+msgstr ""
+
+#: taextras.py:52
+msgid "Palette of Mexican pesos"
+msgstr ""
+
+#: taextras.py:53
+msgid "Palette of Colombian pesos"
+msgstr ""
+
+#: taextras.py:54
+msgid "Palette of Rwandan francs"
+msgstr ""
+
+#: taextras.py:55
+msgid "Palette of US dollars"
+msgstr ""
+
+#: taextras.py:56
+msgid "Palette of Australian dollars"
+msgstr ""
+
+#: taextras.py:57
+msgid "Palette of Paraguayan Guaranies"
+msgstr ""
+
+#: taextras.py:58
+msgid "Palette of Peruvian Nuevo Soles"
+msgstr ""
+
+#: taextras.py:59
+msgid "Palette of Uruguayan Pesos"
+msgstr ""
+
+#. TRANS: Butia is the Arduino Robot Project from Uruguay
+#. (http://www.fing.edu.uy/inco/proyectos/butia/)
+#: taextras.py:65
+msgid "TurtleBots"
+msgstr ""
+
+#: taextras.py:66
+msgid "adjust LED intensity between 0 and 255"
+msgstr ""
+
+#: taextras.py:67
+msgid "returns the object gray level as a number between 0 and 1023"
+msgstr ""
+
+#: taextras.py:68
+msgid "returns 1 when the button is press and 0 otherwise"
+msgstr ""
+
+#: taextras.py:69
+msgid "returns the ambient light level as a number between 0 and 1023"
+msgstr ""
+
+#: taextras.py:70
+msgid "returns the ambient temperature as a number between 0 and 255"
+msgstr ""
+
+#: taextras.py:71
+msgid ""
+"returns the distance from the object in front of the sensor as a number "
+"between 0 and 255"
+msgstr ""
+
+#: taextras.py:73
+msgid "returns 0 or 1 depending on the sensor inclination"
+msgstr ""
+
+#: taextras.py:74
+msgid "returns 1 when the sensors detects a magnetic field, 0 otherwise"
+msgstr ""
+
+#: taextras.py:75
+msgid "switches from 0 to 1, the frequency depends on the vibration"
+msgstr ""
+
+#: taextras.py:76
+msgid "returns the value of the resistance"
+msgstr ""
+
+#: taextras.py:77
+msgid "LED"
+msgstr ""
+
+#: taextras.py:78
+msgid "button"
+msgstr ""
+
+#: taextras.py:79
+msgid "grayscale"
+msgstr ""
+
+#: taextras.py:80
+msgid "ambient light"
+msgstr ""
+
+#: taextras.py:81
+msgid "temperature"
+msgstr ""
+
+#: taextras.py:82 taextras.py:291
+msgid "distance"
+msgstr ""
+
+#: taextras.py:83 taextras.py:288
+msgid "tilt"
+msgstr ""
+
+#: taextras.py:84
+msgid "magnetic induction"
+msgstr ""
+
+#: taextras.py:85
+msgid "vibration"
+msgstr ""
+
+#: taextras.py:86 plugins/audio_sensors/audio_sensors.py:151
+#: plugins/audio_sensors/audio_sensors.py:165
+#: plugins/audio_sensors/audio_sensors.py:179
+#: plugins/audio_sensors/audio_sensors.py:193
+msgid "resistance"
+msgstr ""
+
+#: taextras.py:87
+msgid "Butia Robot"
+msgstr ""
+
+#: taextras.py:88
+msgid "refresh Butia"
+msgstr ""
+
+#: taextras.py:89
+msgid "refresh the state of the Butia palette and blocks"
+msgstr ""
+
+#. TRANS: This string is shorthand for "battery charge of Butia"
+#: taextras.py:91
+msgid "battery charge Butia"
+msgstr ""
+
+#: taextras.py:92
+msgid "returns the battery charge as a number between 0 and 255"
+msgstr ""
+
+#. TRANS: This string is shorthand for "speed of Butia"
+#: taextras.py:94
+msgid "speed Butia"
+msgstr ""
+
+#: taextras.py:95
+msgid "set the speed of the Butia motors"
+msgstr ""
+
+#: taextras.py:96
+msgid "the speed must be a value between 0 and 1023"
+msgstr ""
+
+#. TRANS: This string is shorthand for "move Butia forward"
+#: taextras.py:98
+msgid "forward Butia"
+msgstr ""
+
+#: taextras.py:99
+msgid "move the Butia robot forward"
+msgstr ""
+
+#: taextras.py:100
+msgid "move the Butia robot forward a predefined distance"
+msgstr ""
+
+#. TRANS: This string is shorthand for "turn Butia left"
+#: taextras.py:102
+msgid "left Butia"
+msgstr ""
+
+#: taextras.py:103
+msgid "turn the Butia robot at left"
+msgstr ""
+
+#. TRANS: This string is shorthand for "move Butia backward"
+#: taextras.py:105
+msgid "backward Butia"
+msgstr ""
+
+#: taextras.py:106
+msgid "move the Butia robot backward"
+msgstr ""
+
+#: taextras.py:107
+msgid "move the Butia robot backward a predefined distance"
+msgstr ""
+
+#. TRANS: This string is shorthand for "turn Butia right"
+#: taextras.py:109
+msgid "right Butia"
+msgstr ""
+
+#: taextras.py:110
+msgid "turn the Butia robot at right"
+msgstr ""
+
+#: taextras.py:111
+msgid "turn Butia"
+msgstr ""
+
+#: taextras.py:112
+msgid "turn the Butia robot x degrees"
+msgstr ""
+
+#: taextras.py:113
+msgid "stop Butia"
+msgstr ""
+
+#: taextras.py:114
+msgid "stop the Butia robot"
+msgstr ""
+
+#: taextras.py:115
+msgid "Butia"
+msgstr ""
+
+#: taextras.py:119
+msgid "Error importing Pygame. This pl