-
Notifications
You must be signed in to change notification settings - Fork 43
/
nvio.cpp
106 lines (81 loc) · 3.06 KB
/
nvio.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
//------------------- Библиотека для работы со структурой бинарный nv-файлов --------------------------------------------
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdint.h>
#include <sys/stat.h>
#include <sys/types.h>
#include "nvexplorer.h"
// Максимально допустимый размер ячеек
#define max_item_len 10000
//******************************************************
// Получение смещения до начала файла по номеру файла
//******************************************************
uint32_t nvexplorer::fileoff(int fid) {
int i;
for (i=0;i<(int)nvhd.file_num;i++) {
if (flist[i].id == (uint32_t)fid) return flist[i].offset;
}
printf("\n - Ошибка структуры файла - компоненты #%i не существует\n",fid);
exit(1);
}
//******************************************************
// Получение индкса по номеру файла
//******************************************************
int32_t nvexplorer::fileidx(int fid) {
int i;
for (i=0;i<(int)nvhd.file_num;i++) {
if (flist[i].id == (uint32_t)fid) return i;
}
return -1;
}
//******************************************************
// Получение смещения до начала ячейки по ее индексу
//******************************************************
uint32_t nvexplorer::itemoff_idx(int idx) {
return itemlist[idx].off+fileoff(itemlist[idx].file_id);
}
//******************************************************
//* Получение индекса ячейки по ее id
//* возврат -1 - ячейка не найдена
//******************************************************
int32_t nvexplorer::itemidx(int item) {
int i;
for(i=0;i<(int)nvhd.item_count;i++) {
if (itemlist[i].id == item) return i;
}
return -1;
}
//******************************************************
// Получение смещения до начала ячейки по ее номеру
//******************************************************
int32_t nvexplorer::itemoff (int item) {
int idx=itemidx(item);
if (item == -1) return -1;
return itemoff_idx(idx);
}
//******************************************************
// Получение размера ячейки по ее номеру
//******************************************************
int32_t nvexplorer::itemlen (int item) {
int idx=itemidx(item);
if (idx == -1) return -1;
return itemlist[idx].len;
}
//**********************************************
//* Поиск минимального из 2 чисед
//**********************************************
int min(int a, int b) {
if (a<b) return a;
else return b;
}
//**********************************************
//* Загрузка ячейки в буфер
//**********************************************
int nvexplorer::load_item(int item, char* buf) {
int idx=itemidx(item);
int len=itemlist[idx].len;
if (idx == -1) return -1; // не найдена
memcpy(buf,pdata+itemoff_idx(idx),len);
return len;
}