| 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() |
| } |