DocumentMessages returns a documentation for the message format.
()
| 42 | |
| 43 | // DocumentMessages returns a documentation for the message format. |
| 44 | func DocumentMessages() Documentation { |
| 45 | typeDocs := getTypeDocs() |
| 46 | |
| 47 | msg := document(&Message{}, typeDocs) |
| 48 | payloads := map[DocType]*DocStruct{} |
| 49 | for _, messageType := range ListTypes() { |
| 50 | payload, err := messageType.Payload() |
| 51 | if err != nil { |
| 52 | panic(err) |
| 53 | } |
| 54 | var payloadDoc *DocStruct = nil |
| 55 | if payload != nil { |
| 56 | d := document(payload, typeDocs) |
| 57 | payloadDoc = &d |
| 58 | } |
| 59 | typeVal := reflect.ValueOf(messageType) |
| 60 | payloads[DocType{ |
| 61 | Type: messageType, |
| 62 | Description: typeDocs[typeVal.Kind().String()], |
| 63 | }] = payloadDoc |
| 64 | } |
| 65 | return Documentation{ |
| 66 | Message: msg, |
| 67 | Payloads: payloads, |
| 68 | } |
| 69 | } |
| 70 | |
| 71 | func getTypeDocs() map[string]string { |
| 72 | fset := token.NewFileSet() |