aboutsummaryrefslogtreecommitdiffstats
path: root/mediagoblin/tools/url.py
diff options
context:
space:
mode:
authorAaron Williamson <aaron@copiesofcopies.org>2011-10-01 09:31:42 -0400
committerAaron Williamson <aaron@copiesofcopies.org>2011-10-01 09:31:42 -0400
commitae3bc7fabf8e0abb5f3d8b6534ca451890bbe90b (patch)
treeed9fa698dbde1aa33c3464f71dbd946fe50b6527 /mediagoblin/tools/url.py
parent9122a9d047765574bb0d11436522a6c868da86cc (diff)
downloadmediagoblin-ae3bc7fabf8e0abb5f3d8b6534ca451890bbe90b.tar.lz
mediagoblin-ae3bc7fabf8e0abb5f3d8b6534ca451890bbe90b.tar.xz
mediagoblin-ae3bc7fabf8e0abb5f3d8b6534ca451890bbe90b.zip
Moved common, translation, template, and url code out of util.py and into tools/[file].py
Diffstat (limited to 'mediagoblin/tools/url.py')
-rw-r--r--mediagoblin/tools/url.py31
1 files changed, 31 insertions, 0 deletions
diff --git a/mediagoblin/tools/url.py b/mediagoblin/tools/url.py
new file mode 100644
index 00000000..458ef2c8
--- /dev/null
+++ b/mediagoblin/tools/url.py
@@ -0,0 +1,31 @@
+# GNU MediaGoblin -- federated, autonomous media hosting
+# Copyright (C) 2011 Free Software Foundation, Inc
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 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 Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+import re
+import translitcodec
+
+_punct_re = re.compile(r'[\t !"#$%&\'()*\-/<=>?@\[\\\]^_`{|},.]+')
+
+def slugify(text, delim=u'-'):
+ """
+ Generates an ASCII-only slug. Taken from http://flask.pocoo.org/snippets/5/
+ """
+ result = []
+ for word in _punct_re.split(text.lower()):
+ word = word.encode('translit/long')
+ if word:
+ result.append(word)
+ return unicode(delim.join(result))