Компиляция примера с помощью gcc - альтернативная версия запуска примера Китаева И.В.

Для линукса - тем паче для демонстрации возможностей логичнее было бы использовать компилятор gcc - так как =

  1. сам линукс написан на си
  2. g++ в стандартных сборка линукс встречается реже , чем gcc

Потому мы перепишем инструкцию по использованию так, чтобы она была более универсальна.

  1. Итак создаём папку с именем fuse (не будем нарушать традицию) с содержимом , перечисленным в следующих пунктах
  2. далее создаём файл test.c c содержимым - точной копией оригинала- а именоно - файл должен содержать такой код =
    (не забудьте добавить после каждого #include открывающий знак "меньше" - вплотную к названию стандартного заголовочного файла) =
    #include fuse.h>
    #include stdio.h>
    #include string.h>
    #include errno.h>
    #include fcntl.h>
    
    static const char *hello_str = "Hello World!\n";
    static const char *hello_path = "/hello";
    
    static int hello_getattr(const char *path, struct stat *stbuf)
    {
        int res = 0;
    
        memset(stbuf, 0, sizeof(struct stat));
        if(strcmp(path, "/") == 0) {
            stbuf->st_mode = S_IFDIR | 0755;
            stbuf->st_nlink = 2;
        }
        else if(strcmp(path, hello_path) == 0) {
            stbuf->st_mode = S_IFREG | 0444;
            stbuf->st_nlink = 1;
            stbuf->st_size = strlen(hello_str);
        }
        else
            res = -ENOENT;
    
        return res;
    }
    
    static int hello_readdir(const char *path, void *buf, fuse_fill_dir_t filler,
                             off_t offset, struct fuse_file_info *fi)
    {
        (void) offset;
        (void) fi;
    
        if(strcmp(path, "/") != 0)
            return -ENOENT;
    
        filler(buf, ".", NULL, 0);
        filler(buf, "..", NULL, 0);
        filler(buf, hello_path + 1, NULL, 0);
    
        return 0;
    }
    
    static int hello_open(const char *path, struct fuse_file_info *fi)
    {
        if(strcmp(path, hello_path) != 0)
            return -ENOENT;
    
        if((fi->flags & 3) != O_RDONLY)
            return -EACCES;
    
        return 0;
    }
    
    static int hello_read(const char *path, char *buf, size_t size, off_t offset,
                          struct fuse_file_info *fi)
    {
        size_t len;
        (void) fi;
        if(strcmp(path, hello_path) != 0)
            return -ENOENT;
    
        len = strlen(hello_str);
        if (offset < len) {
            if (offset + size > len)
                size = len - offset;
            memcpy(buf, hello_str + offset, size);
        } else
            size = 0;
    
        return size;
    }
    
    static struct fuse_operations hello_oper;
    
    int main(int argc, char *argv[])
    {
        hello_oper.getattr = hello_getattr;
        hello_oper.readdir = hello_readdir;
        hello_oper.open = hello_open;
        hello_oper.read = hello_read;
    
        return fuse_main(argc, argv, &hello_oper, 0);
    }
    
    
  3. Сохраните файл созданный в предыдущем пункте в нашей директории, и теперь скомпилируйте его командой (перейдя в эту директории вс помощью команды cd в режиме командной строки)=
    gcc test.c -o test -lfuse -D_FILE_OFFSET_BITS=64 -DFUSE_USE_VERSION=26

    если эта команда вызвала такую ошибку - то это значит, что требуется установить FUSE

  4. Создайте в нашей директории fuse каталог с именем tmp - он станет точкой монтирования нашей файловой системы - чтобы примонтировать систему выолните команду =
    ./test tmp 
  5. Собственно, система должна примонтироваться в Ubuntu она появляется в разделе подобно логическому диску, используемому windows или в флешке в разделе =
    Main menu -> Places 
  6. консоль этих действий вполне может выглядеть как-то так =
    vedromyone:~$ cd fuse
    vedromyone:~/fuse$ gcc test.c -o test -lfuse -D_FILE_OFFSET_BITS=64 -DFUSE_USE_VERSION=26
    vedromyone:~/fuse$ ./test
    fuse: missing mountpoint parameter
    vedromyone:~/fuse$ ./test tmp 
    vedromyone:~/fuse$