blob: 682edffe030c4cb1265fbb183dfea5ce456b14d9 [file] [log] [blame]
java_package thrift.test
cpp_namespace thrift.test
// C++ comment
/* c style comment */
# the new unix comment
[Some doc text goes here. Wow I am [nesting these].]
enum Numberz
{
[This is how to document a parameter]
ONE = 1,
[And this is a doc for a parameter that has no specific value assigned]
TWO,
THREE,
FIVE = 5,
SIX,
EIGHT = 8
}
[This is how you would do a typedef doc]
typedef i64 UserId
[And this is where you would document a struct]
struct Xtruct
{
[And the members of a struct]
1: string string_thing
[doct text goes before a comma]
4: byte byte_thing,
9: i32 i32_thing,
11: i64 i64_thing
}
struct Xtruct2
{
1: byte byte_thing,
2: Xtruct struct_thing,
3: i32 i32_thing
}
[Struct insanity]
struct Insanity
{
[This is doc for field 1]
1: map<Numberz, UserId> userMap,
[And this is doc for field 2]
2: list<Xtruct> xtructs
}
exception Xception {
1: i32 errorCode,
2: string message
}
exception Xception2 {
1: i32 errorCode,
2: Xtruct struct_thing
}
struct EmptyStruct {}
struct OneField {
1: EmptyStruct field
}
[This is where you would document a Service]
service ThriftTest
{
[And this is how you would document functions in a service]
void testVoid(),
string testString(1: string thing),
byte testByte(1: byte thing),
i32 testI32(1: i32 thing),
[Like this one]
i64 testI64(1: i64 thing),
double testDouble(1: double thing),
Xtruct testStruct(1: Xtruct thing),
Xtruct2 testNest(1: Xtruct2 thing),
map<i32,i32> testMap(1: map<i32,i32> thing),
set<i32> testSet(1: set<i32> thing),
list<i32> testList(1: list<i32> thing),
[This is an example of a function with params documented]
Numberz testEnum(
[This param is a thing]
1: Numberz thing
),
UserId testTypedef(1: UserId thing),
map<i32,map<i32,i32>> testMapMap(1: i32 hello),
/* So you think you've got this all worked, out eh? */
map<UserId, map<Numberz,Insanity>> testInsanity(1: Insanity argument),
/* Multiple parameters */
Xtruct testMulti(byte arg0, i32 arg1, i64 arg2, map<i16, string> arg3, Numberz arg4, UserId arg5),
/* Exception specifier */
void testException(string arg) throws(Xception err1),
/* Multiple exceptions specifier */
Xtruct testMultiException(string arg0, string arg1) throws(Xception err1, Xception2 err2)
}
service SecondService
{
void blahBlah()
}