mirror of
https://github.com/samba-team/samba.git
synced 2025-01-27 14:04:05 +03:00
take the sructure name to run through vluke on the command line
This commit is contained in:
parent
ca8f1e92ad
commit
03fbe1b151
@ -1,13 +1,22 @@
|
||||
function produce_harness(f,
|
||||
LOCAL, v, struct_num)
|
||||
LOCAL, v, struct_num, i)
|
||||
{
|
||||
struct_num=structs[test];
|
||||
|
||||
v["MODULE"]=module;
|
||||
v["TEST"]=test;
|
||||
v["TEST_FUNC"]=moduletest;
|
||||
v["STRUCTNAME"] = structs[struct_num, "name"];
|
||||
v["FUNCNAME"] = "io_" v["STRUCTNAME"];
|
||||
|
||||
print_template(f, "harness_start.tpl", v);
|
||||
|
||||
for (i=0;i<num_tests;i++) {
|
||||
v["TEST"] = tests[i];
|
||||
print_template(f, "harness.tpl", v);
|
||||
}
|
||||
|
||||
print_template(f, "harness_end.tpl", v);
|
||||
}
|
||||
|
||||
function add_test(test)
|
||||
{
|
||||
tests[num_tests] = test;
|
||||
num_tests++;
|
||||
}
|
||||
|
@ -14,7 +14,7 @@
|
||||
}
|
||||
|
||||
/^test/ {
|
||||
test=$2;
|
||||
add_test($2);
|
||||
next;
|
||||
}
|
||||
|
||||
|
@ -142,7 +142,8 @@ function struct_parser(f, v, struct_num,
|
||||
|
||||
# and any trailers
|
||||
for (i=n1;i<structs[struct_num, "num_elems"];i++) {
|
||||
parse_buffers(f, v, structs[struct_num, i], "PARSE_SCALARS");
|
||||
parse_scalars(f, v, structs[struct_num, i], "PARSE_SCALARS");
|
||||
parse_buffers(f, v, structs[struct_num, i], "PARSE_BUFFERS");
|
||||
}
|
||||
|
||||
print_template(f, "fn_end.tpl", v);
|
||||
|
@ -6,6 +6,7 @@ function start_module(name)
|
||||
num_structs=0;
|
||||
num_elements=0;
|
||||
num_unions=0;
|
||||
num_tests=0;
|
||||
}
|
||||
|
||||
function start_struct(name)
|
||||
|
@ -1,5 +1,16 @@
|
||||
module srvsvc
|
||||
test SRV_R_NET_SHARE_ENUM
|
||||
test SRV_R_NET_SERVER_INFO
|
||||
test SRV_Q_NET_SERVER_INFO
|
||||
|
||||
#define SRV_NETCONNENUM 0x08
|
||||
#define SRV_NETFILEENUM 0x09
|
||||
#define SRV_NETSESSENUM 0x0c
|
||||
#define SRV_NETSHAREENUM 0x0f
|
||||
#define SRV_NET_SHARE_GET_INFO 0x10
|
||||
#define SRV_NET_SRV_GET_INFO 0x15
|
||||
#define SRV_NET_SRV_SET_INFO 0x16
|
||||
#define SRV_NET_REMOTE_TOD 0x1c
|
||||
|
||||
struct UNISTR2 {
|
||||
uint32 max_len;
|
||||
@ -12,6 +23,40 @@ struct LPWSTR {
|
||||
UNISTR2 *str;
|
||||
};
|
||||
|
||||
struct ENUM_HND {
|
||||
uint32 *handle; /* enumeration handle */
|
||||
};
|
||||
|
||||
/* function 8 */
|
||||
struct CONN_INFO_0 {
|
||||
uint32 id; /* connection id. */
|
||||
};
|
||||
|
||||
struct CONN_INFO_1 {
|
||||
uint32 id;
|
||||
uint32 type;
|
||||
uint32 num_opens;
|
||||
uint32 num_users;
|
||||
uint32 open_time;
|
||||
LPWSTR usr_name;
|
||||
LPWSTR net_name;
|
||||
};
|
||||
|
||||
struct SRV_R_NET_CONN_ENUM {
|
||||
uint32 level;
|
||||
uint32 level2;
|
||||
uint32 num_entries;
|
||||
union *info[level] {
|
||||
case 0 CONN_INFO_0 info0[num_entries];
|
||||
case 1 CONN_INFO_1 info1[num_entries];
|
||||
}
|
||||
.trailer;
|
||||
uint32 count;
|
||||
ENUM_HND handle;
|
||||
uint32 status1;
|
||||
uint32 status2;
|
||||
};
|
||||
|
||||
/* function 15 */
|
||||
struct SRV_SHARE_INFO_1 {
|
||||
LPWSTR uni_netname;
|
||||
@ -63,28 +108,35 @@ struct SERVER_INFO_101 {
|
||||
};
|
||||
|
||||
struct SERVER_INFO_102 {
|
||||
uint32 dwPlatformID;
|
||||
uint32 dwPlatformID;
|
||||
LPWSTR pszName;
|
||||
uint32 dwVerMajor;
|
||||
uint32 dwVerMinor;
|
||||
uint32 dwType;
|
||||
uint32 dwVerMajor;
|
||||
uint32 dwVerMinor;
|
||||
uint32 dwType;
|
||||
LPWSTR pszComment;
|
||||
uint32 dwUsers;
|
||||
uint32 lDisc;
|
||||
uint32 bHidden;
|
||||
uint32 dwAnnounce;
|
||||
uint32 dwAnnDelta;
|
||||
uint32 dwLicenses;
|
||||
uint32 dwUsers;
|
||||
uint32 lDisc;
|
||||
uint32 bHidden;
|
||||
uint32 dwAnnounce;
|
||||
uint32 dwAnnDelta;
|
||||
uint32 dwLicenses;
|
||||
LPWSTR pszUserPath;
|
||||
};
|
||||
|
||||
struct SRV_R_NET_SERVER_INFO {
|
||||
uint32 level;
|
||||
union info[level] {
|
||||
case 100 SERVER_INFO_100 *sv100;
|
||||
case 101 SERVER_INFO_101 *sv101;
|
||||
case 102 SERVER_INFO_102 *sv102;
|
||||
}
|
||||
.trailer;
|
||||
uint32 level;
|
||||
union *info[level] {
|
||||
case 100 SERVER_INFO_100 sv100;
|
||||
case 101 SERVER_INFO_101 sv101;
|
||||
case 102 SERVER_INFO_102 sv102;
|
||||
}
|
||||
uint32 status;
|
||||
};
|
||||
|
||||
struct SRV_Q_NET_SERVER_INFO {
|
||||
.trailer;
|
||||
LPWSTR server;
|
||||
uint32 level;
|
||||
};
|
||||
|
||||
|
@ -1,7 +1,8 @@
|
||||
#define TEST_STRUCT @STRUCTNAME@
|
||||
#define TEST_NAME "@TEST@"
|
||||
#define TEST_FUNC @FUNCNAME@
|
||||
|
||||
|
||||
#include "prs_@MODULE@.h"
|
||||
#include "prs_@MODULE@.c"
|
||||
|
||||
static BOOL run_test(char *test, prs_struct *ps)
|
||||
{
|
||||
BOOL ret;
|
||||
|
||||
|
@ -11,18 +11,19 @@
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
BOOL ret;
|
||||
TEST_STRUCT *il;
|
||||
char *desc = TEST_NAME;
|
||||
char *fname = argv[1];
|
||||
char *fname, *test;
|
||||
int fd;
|
||||
struct stat st;
|
||||
prs_struct ps;
|
||||
|
||||
if (argc < 2) {
|
||||
printf("usage: vluke <file>\n");
|
||||
if (argc < 3) {
|
||||
printf("usage: vluke <structure> <file>\n");
|
||||
exit(1);
|
||||
}
|
||||
|
||||
test = argv[1];
|
||||
fname = argv[2];
|
||||
|
||||
fd = open(fname,O_RDONLY);
|
||||
fstat(fd, &st);
|
||||
|
||||
@ -31,8 +32,7 @@ int main(int argc, char *argv[])
|
||||
prs_read(&ps, fd, st.st_size, 0);
|
||||
ps.data_offset = 0;
|
||||
ps.io = UNMARSHALL;
|
||||
il = (TEST_STRUCT *)malloc(sizeof(*il));
|
||||
ret = TEST_FUNC(desc, &ps, 1, il, PARSE_SCALARS|PARSE_BUFFERS);
|
||||
ret = run_test(test, &ps);
|
||||
printf("\nret=%s\n", ret?"OK":"Bad");
|
||||
printf("Trailer is %d bytes\n\n", ps.grow_size - ps.data_offset);
|
||||
dump_data(0, ps.data_p, ps.grow_size);
|
||||
|
Loading…
x
Reference in New Issue
Block a user