/usr/share/pyshared/translate/lang/fr.py is in translate-toolkit 1.10.0-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 | #!/usr/bin/env python
# -*- coding: utf-8 -*-
#
# Copyright 2007-2009 Zuza Software Foundation
#
# This file is part of the Translate Toolkit.
#
# 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, see <http://www.gnu.org/licenses/>.
"""This module represents the French language.
.. seealso:: http://en.wikipedia.org/wiki/French_language
"""
import re
from translate.lang import common
def guillemets(text):
def convertquotation(match):
prefix = match.group(1)
# Let's see that we didn't perhaps match an XML tag property like
# <a href="something">
if prefix == u"=":
return match.group(0)
return u"%s«\u00a0%s\u00a0»" % (prefix, match.group(2)) # \u00a0 is NBSP
# Check that there is an even number of double quotes, otherwise it is
# probably not safe to convert them.
if text.count(u'"') % 2 == 0:
text = re.sub('(.|^)"([^"]+)"', convertquotation, text)
singlecount = text.count(u"'")
if singlecount:
if singlecount == text.count(u'`'):
text = re.sub("(.|^)`([^']+)'", convertquotation, text)
elif singlecount % 2 == 0:
text = re.sub("(.|^)'([^']+)'", convertquotation, text)
text = re.sub(u'(.|^)“([^”]+)”', convertquotation, text)
return text
class fr(common.Common):
"""This class represents French."""
validaccel = u"abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ" + \
u"1234567890" + \
u"éÉ"
# According to http://french.about.com/library/writing/bl-punctuation.htm,
# in French, a space is required both before and after all two- (or more)
# part punctuation marks and symbols, including : ; « » ! ? % $ # etc.
puncdict = {}
for c in u":;!?#":
puncdict[c] = u"\u00a0%s" % c
# TODO: consider adding % and $, but think about the consequences of how
# they could be part of variables
def punctranslate(cls, text):
"""Implement some extra features for quotation marks.
Known shortcomings:
- % and $ are not touched yet for fear of variables
- Double spaces might be introduced
"""
text = super(cls, cls).punctranslate(text)
# We might get problems where we got a space in URIs such as
# http ://
text = text.replace(u"\u00a0://", "://")
return guillemets(text)
punctranslate = classmethod(punctranslate)
|