Accepting request 526328 from GNOME:Factory

- Rebase gvfs-nds.patch for gvfs 1.34.0, including identations and
  warnings fixes. (forwarded request 526315 from fcrozat)

OBS-URL: https://build.opensuse.org/request/show/526328
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/gvfs?expand=0&rev=136
This commit is contained in:
Dominique Leuenberger 2017-09-15 19:07:40 +00:00 committed by Git OBS Bridge
commit 12bc9cba46
2 changed files with 235 additions and 235 deletions

View File

@ -1,8 +1,9 @@
Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
Index: gvfs-1.34.0/daemon/gvfsbackendnds.c
===================================================================
--- /dev/null
+++ gvfs-1.9.0/daemon/gvfsbackendnds.c
@@ -0,0 +1,753 @@
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
+++ gvfs-1.34.0/daemon/gvfsbackendnds.c 2017-09-15 10:53:24.564258329 +0200
@@ -0,0 +1,747 @@
+/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
+/* GIO - GLib Input, Output and Streaming Library
+ *
+ * Copyright (C) 2006-2007 Red Hat, Inc.
@ -33,13 +34,13 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
+#include <unistd.h>
+#include <fcntl.h>
+#include <string.h>
+#include<stdlib.h>
+#include<stdio.h>
+#include <stdlib.h>
+#include <stdio.h>
+
+#include <glib/gstdio.h>
+#include <glib/gi18n.h>
+#include <gio/gio.h>
+#include<dlfcn.h>
+#include <dlfcn.h>
+#include <sys/utsname.h>
+
+#include "gvfsbackendnds.h"
@ -68,7 +69,7 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
+ char *server;
+ char *mounted_server;
+
+ GMutex *entries_lock;
+ GMutex entries_lock;
+ GList *entries;
+ int entry_errno;
+};
@ -121,9 +122,9 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
+
+ string = g_string_sized_new (remaining_bytes);
+ while (remaining_bytes != 0)
+ {
+ {
+ if (g_utf8_validate (remainder, remaining_bytes, &invalid))
+ break;
+ break;
+ valid_utf8 = FALSE;
+
+ valid_bytes = invalid - remainder;
@ -134,7 +135,7 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
+
+ remaining_bytes -= valid_bytes + 1;
+ remainder = invalid + 1;
+ }
+ }
+
+ g_string_append (string, remainder);
+
@ -147,10 +148,10 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
+static void
+browse_entry_free (BrowseEntry *entry)
+{
+if(entry->name != NULL)
+ g_free (entry->name);
+if(entry != NULL)
+ g_free (entry);
+ if(entry->name != NULL)
+ g_free (entry->name);
+ if(entry != NULL)
+ g_free (entry);
+}
+
+
@ -161,42 +162,40 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
+
+ backend = G_VFS_BACKEND_NDS (object);
+
+if(backend->mounted_server != NULL)
+ g_free (backend->mounted_server);
+if(backend->server != NULL)
+ g_free (backend->server);
+ if(backend->mounted_server != NULL)
+ g_free (backend->mounted_server);
+ if(backend->server != NULL)
+ g_free (backend->server);
+
+ g_mutex_free (backend->entries_lock);
+ g_mutex_clear (&backend->entries_lock);
+
+ g_list_foreach (backend->entries, (GFunc)browse_entry_free, NULL);
+if(backend->entries != NULL)
+ g_list_free (backend->entries);
+ if(backend->entries != NULL)
+ g_list_free (backend->entries);
+
+ if (G_OBJECT_CLASS (g_vfs_backend_nds_parent_class)->finalize)
+ (*G_OBJECT_CLASS (g_vfs_backend_nds_parent_class)->finalize) (object);
+ (*G_OBJECT_CLASS (g_vfs_backend_nds_parent_class)->finalize) (object);
+}
+
+static void
+g_vfs_backend_nds_init (GVfsBackendNds *backend)
+{
+ backend->entries_lock = g_mutex_new ();
+ g_mutex_init(&backend->entries_lock);
+
+ if (mount_tracker == NULL)
+ mount_tracker = g_mount_tracker_new (NULL);
+ mount_tracker = g_mount_tracker_new (NULL, FALSE);
+}
+
+
+static void
+update_cache (GVfsBackendNds *backend,const char *filename)
+{
+ GString *uri;
+ GList *entries;
+ int entry_errno;
+ char *objectname=NULL;
+ char *treename=NULL;
+ GList *objectlist=NULL;
+ GList *object=NULL;
+ GList *l;
+ FILE *fptr=NULL;
+ void *handle=NULL; //handle for dlopen
+ int res;
@ -212,92 +211,92 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
+ entries = NULL;
+ entry_errno = 0;
+
+if(backend->server != NULL)
+{
+ server_name = g_strdup(backend->server);
+ if((ptr = strchr(server_name,'%')) != NULL)
+ *ptr = '\0';
+ if(backend->server != NULL)
+ {
+ server_name = g_strdup(backend->server);
+ if((ptr = strchr(server_name,'%')) != NULL)
+ *ptr = '\0';
+
+}
+ }
+
+if(backend->server == NULL) //retrieve Tree names
+{
+ treename = (char *)malloc(sizeof(char) * 80);
+ system("/opt/novell/ncl/bin/retrieve_trees.pl");
+ fptr = fopen("/tmp/ndstrees.txt","r");
+ if(fptr == NULL)
+ {
+ entry_errno = -1;
+ goto out;
+ }
+ while (fgets(treename,80,fptr) != NULL)
+ {
+ objectlist = g_list_append(objectlist,g_strdup(treename));
+ memset(treename,'\0',80);
+ }
+ fclose(fptr);
+ free(treename);
+}
+ if(backend->server == NULL) //retrieve Tree names
+ {
+ treename = (char *)malloc(sizeof(char) * 80);
+ system("/opt/novell/ncl/bin/retrieve_trees.pl");
+ fptr = fopen("/tmp/ndstrees.txt","r");
+ if(fptr == NULL)
+ {
+ entry_errno = -1;
+ goto out;
+ }
+ while (fgets(treename,80,fptr) != NULL)
+ {
+ objectlist = g_list_append(objectlist,g_strdup(treename));
+ memset(treename,'\0',80);
+ }
+ fclose(fptr);
+ free(treename);
+ }
+
+else //retrieve object names
+{
+ uname(&utsbuf);
+ if(!strcmp(utsbuf.machine,"x86_64"))
+ handle = dlopen("/usr/lib64/libinterface.so",RTLD_NOW | RTLD_DEEPBIND);
+ else
+ handle = dlopen("/usr/lib/libinterface.so",RTLD_NOW | RTLD_DEEPBIND);
+ else //retrieve object names
+ {
+ uname(&utsbuf);
+ if(!strcmp(utsbuf.machine,"x86_64"))
+ handle = dlopen("/usr/lib64/libinterface.so",RTLD_NOW | RTLD_DEEPBIND);
+ else
+ handle = dlopen("/usr/lib/libinterface.so",RTLD_NOW | RTLD_DEEPBIND);
+
+ if(handle == NULL)
+ {
+ return;
+ }
+ *(void **)(&retrieve_children) = dlsym(handle,"retrieve_children");
+ if(handle == NULL)
+ {
+ return;
+ }
+ *(void **)(&retrieve_children) = dlsym(handle,"retrieve_children");
+
+ if(retrieve_children != NULL)
+ {
+ res = (*retrieve_children)(server_name,&object_list_array,&num_objects);
+ if(res == 0)
+ {
+ for(i=0;i < num_objects; i++)
+ {
+ objectlist = g_list_append(objectlist,g_strdup(*(object_list_array+ i)));
+ }
+ }
+ }
+ else
+ {
+ return;
+ }
+ dlclose(handle);
+}
+ if(retrieve_children != NULL)
+ {
+ res = (*retrieve_children)(server_name,&object_list_array,&num_objects);
+ if(res == 0)
+ {
+ for(i=0;i < num_objects; i++)
+ {
+ objectlist = g_list_append(objectlist,g_strdup(*(object_list_array+ i)));
+ }
+ }
+ }
+ else
+ {
+ return;
+ }
+ dlclose(handle);
+ }
+
+
+ gboolean valid_utf8;
+ BrowseEntry *entry;
+ gboolean valid_utf8;
+ BrowseEntry *entry;
+
+for(object = objectlist;object != NULL;object = object->next)
+{
+ entry = g_new (BrowseEntry, 1);
+ objectname = object->data;
+ entry->name = g_strdup (objectname);
+ entry->name_utf8 = nds_name_to_utf8 (objectname, &valid_utf8);
+ entry->name_normalized = normalize_nds_name_helper (objectname, -1, valid_utf8);
+ for(object = objectlist;object != NULL;object = object->next)
+ {
+ entry = g_new (BrowseEntry, 1);
+ objectname = object->data;
+ entry->name = g_strdup (objectname);
+ entry->name_utf8 = nds_name_to_utf8 (objectname, &valid_utf8);
+ entry->name_normalized = normalize_nds_name_helper (objectname, -1, valid_utf8);
+
+ entries = g_list_append (entries, entry);
+}
+ entries = g_list_append (entries, entry);
+ }
+
+//if(objectlist != NULL)
+//g_list_free(objectlist);
+ //if(objectlist != NULL)
+ //g_list_free(objectlist);
+
+ out:
+out:
+
+ if(entry_errno == 0)
+ {
+ g_mutex_lock (backend->entries_lock);
+ backend->entries = entries;
+ g_mutex_unlock (backend->entries_lock);
+ }
+ backend->entry_errno = entry_errno;
+ if(entry_errno == 0)
+ {
+ g_mutex_lock (&backend->entries_lock);
+ backend->entries = entries;
+ g_mutex_unlock (&backend->entries_lock);
+ }
+ backend->entry_errno = entry_errno;
+
+}
+
@ -305,63 +304,63 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
+find_entry_unlocked (GVfsBackendNds *backend,
+ const char *filename)
+{
+ BrowseEntry *entry, *found;
+ GList *l;
+ char *end;
+ int len;
+ char *normalized;
+ BrowseEntry *entry, *found;
+ GList *l;
+ char *end;
+ int len;
+
+ while (*filename == '/')
+ filename++;
+ while (*filename == '/')
+ filename++;
+
+ end = strchr (filename, '/');
+ if (end)
+ end = strchr (filename, '/');
+ if (end)
+ {
+ len = end - filename;
+ len = end - filename;
+
+ while (*end == '/')
+ end++;
+ while (*end == '/')
+ end++;
+
+ if (*end != 0)
+ return NULL;
+ if (*end != 0)
+ return NULL;
+ }
+ else
+ len = strlen (filename);
+ else
+ len = strlen (filename);
+
+ /* First look for an exact filename match */
+ found = NULL;
+ for (l = backend->entries; l != NULL; l = l->next)
+ /* First look for an exact filename match */
+ found = NULL;
+ for (l = backend->entries; l != NULL; l = l->next)
+ {
+ entry = l->data;
+ entry = l->data;
+
+ if (strncmp (filename, entry->name, len) == 0 &&
+ strlen (entry->name) == len)
+ {
+ found = entry;
+ break;
+ }
+ if (strncmp (filename, entry->name, len) == 0 &&
+ strlen (entry->name) == len)
+ {
+ found = entry;
+ break;
+ }
+ }
+
+ if (found == NULL)
+ if (found == NULL)
+ {
+ /* That failed, try normalizing the filename */
+ normalized = normalize_nds_name (filename, len);
+ char *normalized;
+ /* That failed, try normalizing the filename */
+ normalized = normalize_nds_name (filename, len);
+
+ for (l = backend->entries; l != NULL; l = l->next)
+ {
+ entry = l->data;
+ for (l = backend->entries; l != NULL; l = l->next)
+ {
+ entry = l->data;
+
+ if (strcmp (normalized, entry->name_normalized) == 0)
+ {
+ found = entry;
+ break;
+ }
+ }
+if(normalized != NULL)
+ g_free (normalized);
+ if (strcmp (normalized, entry->name_normalized) == 0)
+ {
+ found = entry;
+ break;
+ }
+ }
+ if(normalized != NULL)
+ g_free (normalized);
+ }
+
+ return found;
+ return found;
+}
+
+static GMountSpec *
@ -390,7 +389,6 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
+ char *display_name;
+ char *icon;
+ GMountSpec *browse_mount_spec;
+ char *ptr = NULL;
+
+
+ icon = NULL;
@ -428,8 +426,7 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
+ gboolean is_automount)
+{
+ GVfsBackendNds *op_backend = G_VFS_BACKEND_NDS (backend);
+ char *server;
+ char *share;
+ const char *server;
+
+ server = g_mount_spec_get (mount_spec, "host");
+ if (server)
@ -452,20 +449,18 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
+ const char *filename,
+ GMountSource *mount_source)
+{
+ BrowseEntry *entry;
+ GError *error = NULL;
+ GMountSpec *mount_spec;
+
+ g_mutex_lock (backend->entries_lock);
+ g_mutex_lock (&backend->entries_lock);
+
+backend->server = g_strdup(filename);
+ backend->server = g_strdup(filename);
+
+ mount_spec = get_mount_spec_for_share (backend->server, filename);
+ g_vfs_job_mount_mountable_set_target (job, mount_spec, "/", TRUE);
+ g_mount_spec_unref (mount_spec);
+ g_mutex_unlock (backend->entries_lock);
+ mount_spec = get_mount_spec_for_share (backend->server, filename);
+ g_vfs_job_mount_mountable_set_target (job, mount_spec, "/", TRUE);
+ g_mount_spec_unref (mount_spec);
+ g_mutex_unlock (&backend->entries_lock);
+
+ g_vfs_job_succeeded (G_VFS_JOB (job));
+ g_vfs_job_succeeded (G_VFS_JOB (job));
+}
+
+
@ -475,15 +470,15 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
+ const char *filename,
+ GMountSource *mount_source)
+{
+ GVfsBackendNds *op_backend = G_VFS_BACKEND_NDS (backend);
+ GVfsBackendNds *op_backend = G_VFS_BACKEND_NDS (backend);
+
+update_cache (op_backend,filename);
+ update_cache (op_backend,filename);
+
+ run_mount_mountable (op_backend,
+ job,
+ filename,
+ mount_source);
+ return TRUE;
+ run_mount_mountable (op_backend,
+ job,
+ filename,
+ mount_source);
+ return TRUE;
+}
+
+static gboolean
@ -563,7 +558,6 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
+static void
+get_file_info_from_entry (GVfsBackendNds *backend, BrowseEntry *entry, GFileInfo *info)
+{
+ GMountSpec *mount_spec;
+ GString *uri;
+ GIcon *icon;
+
@ -573,27 +567,25 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
+ g_file_info_set_attribute_boolean (info, G_FILE_ATTRIBUTE_STANDARD_IS_VIRTUAL, TRUE);
+
+ if(backend->server == NULL) //NDS-Tree icon
+ icon = g_themed_icon_new ("ncl-ndstree");
+ icon = g_themed_icon_new ("ncl-ndstree");
+ else
+ icon = g_themed_icon_new ("ncl-nwcontext");
+ icon = g_themed_icon_new ("ncl-nwcontext");
+
+ if (icon)
+ {
+ {
+ g_file_info_set_icon (info, icon);
+ g_object_unref (icon);
+ }
+ }
+
+ mount_spec = NULL;
+ g_file_info_set_file_type (info, G_FILE_TYPE_SHORTCUT);
+
+ g_file_info_set_file_type (info, G_FILE_TYPE_SHORTCUT);
+ uri = g_string_new ("nds://");
+ g_string_append_encoded (uri, entry->name, NULL, NULL);
+ g_string_append_c (uri, '/');
+
+ uri = g_string_new ("nds://");
+ g_string_append_encoded (uri, entry->name, NULL, NULL);
+ g_string_append_c (uri, '/');
+ g_file_info_set_attribute_string (info, G_FILE_ATTRIBUTE_STANDARD_TARGET_URI, uri->str);
+
+ g_file_info_set_attribute_string (info, G_FILE_ATTRIBUTE_STANDARD_TARGET_URI, uri->str);
+
+ g_string_free (uri, TRUE);
+ g_string_free (uri, TRUE);
+
+}
+
@ -606,14 +598,14 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
+{
+ BrowseEntry *entry;
+
+ g_mutex_lock (backend->entries_lock);
+ g_mutex_lock (&backend->entries_lock);
+
+ entry = find_entry_unlocked (backend, filename);
+
+ if (entry)
+ get_file_info_from_entry (backend, entry, info);
+
+ g_mutex_unlock (backend->entries_lock);
+ g_mutex_unlock (&backend->entries_lock);
+
+ if (entry)
+ g_vfs_job_succeeded (G_VFS_JOB (job));
@ -684,7 +676,7 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
+ g_vfs_job_succeeded (G_VFS_JOB (job));
+
+ files = NULL;
+ g_mutex_lock (backend->entries_lock);
+ g_mutex_lock (&backend->entries_lock);
+ for (l = backend->entries; l != NULL; l = l->next)
+ {
+ BrowseEntry *entry = l->data;
@ -694,7 +686,7 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
+
+ files = g_list_prepend (files, info);
+ }
+ g_mutex_unlock (backend->entries_lock);
+ g_mutex_unlock (&backend->entries_lock);
+
+ files = g_list_reverse (files);
+
@ -749,6 +741,8 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
+ backend_class->try_query_info = try_query_info;
+ backend_class->enumerate = do_enumerate;
+ backend_class->try_enumerate = try_enumerate;
+ backend_class->try_mount_mountable = try_mount_mountable;
+ backend_class->mount_mountable = do_mount_mountable;
+}
+
+void
@ -756,10 +750,10 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.c
+{
+ g_set_application_name (_("Displaying Embedded Objects"));
+}
Index: gvfs-1.9.0/daemon/gvfsbackendnds.h
Index: gvfs-1.34.0/daemon/gvfsbackendnds.h
===================================================================
--- /dev/null
+++ gvfs-1.9.0/daemon/gvfsbackendnds.h
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
+++ gvfs-1.34.0/daemon/gvfsbackendnds.h 2017-09-15 10:53:56.159989373 +0200
@@ -0,0 +1,53 @@
+/* GIO - GLib Input, Output and Streaming Library
+ *
@ -814,11 +808,11 @@ Index: gvfs-1.9.0/daemon/gvfsbackendnds.h
+G_END_DECLS
+
+#endif /* __G_VFS_BACKEND_NDS_H__ */
Index: gvfs-1.9.0/daemon/Makefile.am
Index: gvfs-1.34.0/daemon/Makefile.am
===================================================================
--- gvfs-1.9.0.orig/daemon/Makefile.am
+++ gvfs-1.9.0/daemon/Makefile.am
@@ -143,6 +143,10 @@ mount_in_files += nvvfs.mount.in
--- gvfs-1.34.0.orig/daemon/Makefile.am 2017-09-15 10:15:10.715090208 +0200
+++ gvfs-1.34.0/daemon/Makefile.am 2017-09-15 10:15:46.554940823 +0200
@@ -144,6 +144,10 @@
mount_DATA += nvvfs.mount
libexec_PROGRAMS += gvfsd-nvvfs
@ -829,7 +823,7 @@ Index: gvfs-1.9.0/daemon/Makefile.am
EXTRA_DIST = \
$(service_in_files) \
$(systemd_user_in_files) \
@@ -525,6 +529,19 @@ gvfsd_http_CPPFLAGS = \
@@ -528,6 +532,19 @@
gvfsd_http_LDADD = $(libraries) $(HTTP_LIBS)
@ -849,10 +843,10 @@ Index: gvfs-1.9.0/daemon/Makefile.am
gvfsd_nvvfs_SOURCES = \
gvfsbackendnvvfs.c gvfsbackendnvvfs.h \
daemon-main.c daemon-main.h \
Index: gvfs-1.9.0/daemon/nds.mount.in
Index: gvfs-1.34.0/daemon/nds.mount.in
===================================================================
--- /dev/null
+++ gvfs-1.9.0/daemon/nds.mount.in
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
+++ gvfs-1.34.0/daemon/nds.mount.in 2017-09-15 10:15:46.554940823 +0200
@@ -0,0 +1,5 @@
+[Mount]
+Type=nds

View File

@ -1,3 +1,9 @@
-------------------------------------------------------------------
Fri Sep 15 09:01:05 UTC 2017 - fcrozat@suse.com
- Rebase gvfs-nds.patch for gvfs 1.34.0, including identations and
warnings fixes.
-------------------------------------------------------------------
Mon Sep 11 16:31:55 UTC 2017 - dimstar@opensuse.org