Summary: Throwing non-exceptions, though allowed in some languages, is a weird concept and causes problems in many places. Disallow it in the Thrift compiler and throw an informative error.
Reviewed By: dreiss
Test Plan: Generate a file with an int or something in a throws clause. Peep the nice informative compiler error.
git-svn-id: https://svn.apache.org/repos/asf/incubator/thrift/trunk@665450
13f79535-47bb-0310-9956-
ffa450edef68
validate_const_rec(field->get_name(), field->get_type(), cv);
}
+/**
+ * Check that all the elements of a throws block are actually exceptions.
+ */
+bool validate_throws(t_struct* throws) {
+ const vector<t_field*>& members = throws->get_members();
+ vector<t_field*>::const_iterator m_iter;
+ for (m_iter = members.begin(); m_iter != members.end(); ++m_iter) {
+ if (!(*m_iter)->get_type()->is_xception()) {
+ return false;
+ }
+ }
+ return true;
+}
+
/**
* Parses a program
*/
*/
void validate_field_value(t_field* field, t_const_value* cv);
+/**
+ * Check members of a throws block
+ */
+bool validate_throws(t_struct* throws);
+
/**
* Converts a string filename into a thrift program name
*/
{
pdebug("Throws -> tok_throws ( FieldList )");
$$ = $3;
+ if (!validate_throws($$)) {
+ yyerror("Throws clause may not contain non-exception types");
+ exit(1);
+ }
}
|
{