ОШИБКА: в 'fuse_operations_compat2' нет нестатического члена данных с именем readdir - PullRequest
0 голосов
/ 19 ноября 2018

Я пытаюсь создать простую файловую систему, используя fuse 2.9.7 для хранения в ней avifile.Но у меня возникли проблемы с поиском решения этой ошибки.

‘fuse_operations_compat2’ has no non-static data member named ‘readdir’

У меня есть этот main.cpp

#include<iostream>
#include<fuse.h>

#include "include/AVIContainer.h"
#include "include/Fuse.h"

using namespace std;

int main(int argc, char* argv[])
{
  AVIContainer *avi = new AVIContainer(320, 240, 30, 90);
  avi->WriteToFile("test.avi");


struct fuse_operations oper = {
    .getattr    = getattr_callback,
    .readdir    = readdir_callback,
    .open       = open_callback,
    .read       = read_callback,
};

   return fuse_main(argc, argv , &oper);

}

, и это файл заголовка (.cpp)

#define FUSE_USE_VERSION 30

#include<fuse.h>
#include<stdio.h>
#include<unistd.h>
#include<sys/types.h>
#include<time.h>
#include<string.h>
#include<stdlib.h>

#include "Fuse.h"


char filename[30] = "/avifile";
char filename2[30] = "avifile"; 


int getattr_callback(const char *path, struct stat *st)
{

      st->st_uid = getuid();
      st->st_gid = getgid();
      st->st_atime = time(NULL);
      st->st_mtime = time(NULL);

      if(strcmp(path, "/") == 0)
      {
          st->st_mode = S_IFDIR | 0755;
          st->st_nlink = 2;
      }

      if(strcmp(path,filename) == 0)
      {  
          st->st_mode = S_IFREG | 0644;
          st->st_nlink = 1;
          st->st_size = datasize;
      }

      return 0;       
}


int readdir_callback(const char *path, void *buffer, fuse_fill_dir_t filler, off_t offset, struct fuse_file_info *fi)
{

       filler(buffer, ".", NULL, 0);
       filler(buffer, "..", NULL, 0);

       if(strcmp(path, "/") == 0)
       {
           filler(buffer, filename2, NULL, 0);           
       }

       return 0;
}

int read_callback(const char *path, char *buffer, size_t size, off_t offset, struct fuse_file_info *fi)
{

       unsigned int SizetoRead = size;

       if(  (offset + size) > datasize)
       {
            SizetoRead = datasize - offset;
       }

       memcpy(buffer, databuffer + offset, SizetoRead);      

       return SizetoRead;
}

int open_callback(const char *path, fuse_file_info *fi)
{        

    return 0;
}

и это файл .h

#ifndef FUSE
#define FUSE


#include <fuse.h>

uint8_t* get_data();

unsigned int get_size();

int getattr_callback(const char *path, struct stat *st);

int read_callback(const char *path, char *buffer, size_t size, off_t offset, struct fuse_file_info *fi);

int readdir_callback(const char *path, void *buffer, fuse_fill_dir_t filler, off_t offset, struct fuse_file_info *fi);

int open_callback(const char *path, fuse_file_info *fi);

#endif 

Я думаю, что проблема с версией предохранителя, хотя и не уверен.пожалуйста, помогите, заранее спасибо

Редактировать:

Ответы [ 2 ]

0 голосов
/ 05 февраля 2019

В вашем main.cpp заголовок fuse.h включен до того, как установлена ​​версия, поэтому, когда ваш основной файл компилируется (где предполагается установить readdir), FUSE загружается в режиме совместимости.Удаление #include<fuse.h> из вашего основного файла должно решить проблему, так как FUSE затем включается через заголовочный файл, который устанавливает правильную версию.

0 голосов
/ 08 января 2019

Вы используете предохранители высокого уровня (против низкоуровневых).вот что вы можете сделать с ним (fuse_compat.h)

struct fuse_operations_compat2 {
    int (*getattr)     (const char *, struct stat *);
    int (*readlink)    (const char *, char *, size_t);
    int (*getdir)      (const char *, fuse_dirh_t, fuse_dirfil_t_compat);
    int (*mknod)       (const char *, mode_t, dev_t);
    int (*mkdir)       (const char *, mode_t);
    int (*unlink)      (const char *);
    int (*rmdir)       (const char *);
    int (*symlink)     (const char *, const char *);
    int (*rename)      (const char *, const char *);
    int (*link)    (const char *, const char *);
    int (*chmod)       (const char *, mode_t);
    int (*chown)       (const char *, uid_t, gid_t);
    int (*truncate)    (const char *, off_t);
    int (*utime)       (const char *, struct utimbuf *);
    int (*open)    (const char *, int);
    int (*read)    (const char *, char *, size_t, off_t);
    int (*write)       (const char *, const char *, size_t, off_t);
    int (*statfs)      (const char *, struct statfs *);
    int (*flush)       (const char *);
    int (*release)     (const char *, int);
    int (*fsync)       (const char *, int);
    int (*setxattr)    (const char *, const char *, const char *, size_t, int);
    int (*getxattr)    (const char *, const char *, char *, size_t);
    int (*listxattr)   (const char *, char *, size_t);
    int (*removexattr) (const char *, const char *);

};

попробуйте использовать версию 32

...