summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPatrick Monnerat <[email protected]>2019-02-11 19:50:38 +0100
committermonsta <[email protected]>2019-02-20 17:11:10 +0300
commit7842b86e8deac7b6cae3bea3d27b26ae7a399db0 (patch)
tree3c98d5854e72567dc58252340d484686d3bd13df
parent05c5dd58ebf03b1366a43cbcfd135079e6d4455d (diff)
downloadpython-caja-7842b86e8deac7b6cae3bea3d27b26ae7a399db0.tar.bz2
python-caja-7842b86e8deac7b6cae3bea3d27b26ae7a399db0.tar.xz
Examples: remove use of Python 2/3 incompatible urllib/urlparse.
Plus some other rewriting to improve lisibility.
-rw-r--r--examples/background-image.py25
-rw-r--r--examples/block-size-column.py9
-rw-r--r--examples/md5sum-property-page.py9
-rw-r--r--examples/mixed.py28
-rw-r--r--examples/open-terminal.py13
5 files changed, 15 insertions, 69 deletions
diff --git a/examples/background-image.py b/examples/background-image.py
index 450b985..127dd15 100644
--- a/examples/background-image.py
+++ b/examples/background-image.py
@@ -2,14 +2,6 @@ SUPPORTED_FORMATS = 'image/jpeg', 'image/png'
BACKGROUND_SCHEMA = 'org.mate.background'
BACKGROUND_KEY = 'picture-filename'
-try:
- # Python 3.
- from urllib.parse import unquote, urlparse
-except:
- # Python 2.
- from urllib import unquote
- from urlparse import urlparse
-
from gi.repository import Caja, GObject, Gio
@@ -17,21 +9,12 @@ class BackgroundImageExtension(GObject.GObject, Caja.MenuProvider):
def __init__(self):
self.bgsettings = Gio.Settings.new(BACKGROUND_SCHEMA)
- def _filepath(self, file):
- try:
- file = file.get_uri()
- except:
- pass
- (scheme, netloc, path, parameters, query, fragment) = urlparse(file)
- if scheme and unquote(scheme) != 'file':
- return None
- return unquote(path)
-
def menu_activate_cb(self, menu, file):
if file.is_gone():
return
-
- self.bgsettings[BACKGROUND_KEY] = self._filepath(file)
+
+ if file.get_uri_scheme() == 'file':
+ self.bgsettings[BACKGROUND_KEY] = file.get_location().get_path()
def get_file_items(self, window, files):
if len(files) != 1:
@@ -52,7 +35,7 @@ class BackgroundImageExtension(GObject.GObject, Caja.MenuProvider):
label='Use as background image',
tip='Set the current image as a background image')
item.connect('activate', self.menu_activate_cb, file)
- return item,
+ return [item]
def get_background_items(self, window, file):
return []
diff --git a/examples/block-size-column.py b/examples/block-size-column.py
index c59d3e6..d3ce2b4 100644
--- a/examples/block-size-column.py
+++ b/examples/block-size-column.py
@@ -1,12 +1,5 @@
import os
-try:
- # Python 3.
- from urllib.parse import unquote
-except:
- # Python 2.
- from urllib import unquote
-
from gi.repository import GObject, Caja
class ColumnExtension(GObject.GObject, Caja.ColumnProvider, Caja.InfoProvider):
@@ -23,6 +16,6 @@ class ColumnExtension(GObject.GObject, Caja.ColumnProvider, Caja.InfoProvider):
if file.get_uri_scheme() != 'file':
return
- filename = unquote(file.get_uri()[7:])
+ filename = file.get_location().get_path()
file.add_string_attribute('block_size', str(os.stat(filename).st_blksize))
diff --git a/examples/md5sum-property-page.py b/examples/md5sum-property-page.py
index 6f3f345..0557058 100644
--- a/examples/md5sum-property-page.py
+++ b/examples/md5sum-property-page.py
@@ -1,12 +1,5 @@
import hashlib
-try:
- # Python 3.
- from urllib.parse import unquote
-except:
- # Python 2.
- from urllib import unquote
-
from gi.repository import Caja, Gtk, GObject
class MD5SumPropertyPage(GObject.GObject, Caja.PropertyPageProvider):
@@ -24,7 +17,7 @@ class MD5SumPropertyPage(GObject.GObject, Caja.PropertyPageProvider):
if file.is_directory():
return
- filename = unquote(file.get_uri()[7:])
+ filename = file.get_location().get_path()
self.property_label = Gtk.Label('MD5Sum')
self.property_label.show()
diff --git a/examples/mixed.py b/examples/mixed.py
index 0b1c079..8ed67f6 100644
--- a/examples/mixed.py
+++ b/examples/mixed.py
@@ -8,14 +8,6 @@
import os
-try:
- # Python 3.
- from urllib.parse import unquote, urlparse
-except:
- # Python 2.
- from urllib import unquote
- from urlparse import urlparse
-
from gi.repository import Caja, GObject, Gtk
@@ -30,16 +22,8 @@ class Mixed(GObject.GObject,
# Private methods.
- def _basename(self, uri):
- try:
- uri = uri.get_uri() # In case a CajaFile is given.
- except:
- pass
- (scheme, netloc, path, parameters, query, fragment) = urlparse(uri)
- return os.path.basename(unquote(path))
-
def _file_has_mixed_name(self, cajafile):
- name = self._basename(cajafile)
+ name = cajafile.get_name()
if name.upper() != name and name.lower() != name:
return 'mixed'
return ''
@@ -72,7 +56,7 @@ class Mixed(GObject.GObject,
for cajafile in cajafiles:
mixed = cajafile.get_string_attribute('mixed')
if mixed:
- filename = self._basename(cajafile)
+ filename = cajafile.get_name()
menuitem = Caja.MenuItem(
name = 'Mixed::FileMenu',
label = 'Mixed: %s has a mixed case name' % filename,
@@ -107,7 +91,7 @@ class Mixed(GObject.GObject,
page_label.show()
hbox = Gtk.HBox(homogeneous = False, spacing = 4)
hbox.show()
- name_label = Gtk.Label(self._basename(cajafile))
+ name_label = Gtk.Label(cajafile.get_name())
name_label.show()
comment_label = Gtk.Label('has a mixed-case name')
comment_label.show()
@@ -126,9 +110,9 @@ class Mixed(GObject.GObject,
# Caja.LocationWidgetProvider implementation.
def get_widget(self, uri, window):
- filename = self._basename(uri)
- if not self._file_has_mixed_name(filename):
+ cajafile = Caja.FileInfo.create_for_uri(uri)
+ if not self._file_has_mixed_name(cajafile):
return None
- label = Gtk.Label('In mixed-case directory %s' % filename)
+ label = Gtk.Label('In mixed-case directory ' + cajafile.get_name())
label.show()
return label
diff --git a/examples/open-terminal.py b/examples/open-terminal.py
index c80552a..935d894 100644
--- a/examples/open-terminal.py
+++ b/examples/open-terminal.py
@@ -1,13 +1,6 @@
# This example is contributed by Martin Enlund
import os
-try:
- # Python 3.
- from urllib.parse import unquote
-except:
- # Python 2.
- from urllib import unquote
-
from gi.repository import Caja, GObject, Gio
TERMINAL_SCHEMA = 'org.mate.applications-terminal'
@@ -18,7 +11,7 @@ class OpenTerminalExtension(Caja.MenuProvider, GObject.GObject):
self.gsettings = Gio.Settings.new(TERMINAL_SCHEMA)
def _open_terminal(self, file):
- filename = unquote(file.get_uri()[7:])
+ filename = file.get_location().get_path()
terminal = self.gsettings[TERMINAL_KEY]
os.chdir(filename)
@@ -42,11 +35,11 @@ class OpenTerminalExtension(Caja.MenuProvider, GObject.GObject):
label='Open Terminal' ,
tip='Open Terminal In %s' % file.get_name())
item.connect('activate', self.menu_activate_cb, file)
- return item,
+ return [item]
def get_background_items(self, window, file):
item = Caja.MenuItem(name='CajaPython::openterminal_item',
label='Open Terminal Here',
tip='Open Terminal In This Directory')
item.connect('activate', self.menu_background_activate_cb, file)
- return item,
+ return [item]