OLD | NEW |
---|---|
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 7819 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
7830 static const ParserFlag always_flags[] = {kAllowTypes}; | 7830 static const ParserFlag always_flags[] = {kAllowTypes}; |
7831 RunParserSyncTest(untyped_context_data, correct_data, kError, NULL, 0, | 7831 RunParserSyncTest(untyped_context_data, correct_data, kError, NULL, 0, |
7832 always_flags, arraysize(always_flags)); | 7832 always_flags, arraysize(always_flags)); |
7833 RunParserSyncTest(typed_context_data, correct_data, kSuccess, NULL, 0, | 7833 RunParserSyncTest(typed_context_data, correct_data, kSuccess, NULL, 0, |
7834 always_flags, arraysize(always_flags)); | 7834 always_flags, arraysize(always_flags)); |
7835 RunParserSyncTest(untyped_context_data, error_data, kError, NULL, 0, | 7835 RunParserSyncTest(untyped_context_data, error_data, kError, NULL, 0, |
7836 always_flags, arraysize(always_flags)); | 7836 always_flags, arraysize(always_flags)); |
7837 RunParserSyncTest(typed_context_data, error_data, kError, NULL, 0, | 7837 RunParserSyncTest(typed_context_data, error_data, kError, NULL, 0, |
7838 always_flags, arraysize(always_flags)); | 7838 always_flags, arraysize(always_flags)); |
7839 } | 7839 } |
7840 | |
7841 TEST(TypedModeTypeAliases) { | |
7842 const char* untyped_context_data[][2] = {{"", ""}, {NULL, NULL}}; | |
7843 const char* typed_context_data[][2] = {{"'use types'; ", ""}, {NULL, NULL}}; | |
7844 | |
7845 const char* correct_data[] = { | |
7846 "type NumArray = number[]", | |
7847 "type Fun = (x: number) => number", | |
7848 "type Tree<A> = A | Tree<A>[]", | |
7849 NULL | |
7850 }; | |
7851 | |
7852 const char* error_data[] = { | |
7853 "type Err<> = number", | |
rossberg
2016/04/18 09:27:43
How about "type", with no identifier following.
nickie
2016/04/19 13:52:51
Done.
We agreed that "type = number" should parse
| |
7854 "type Err", | |
7855 "type Err =", | |
7856 "type Err = ()", | |
7857 NULL | |
7858 }; | |
7859 | |
7860 static const ParserFlag always_flags[] = {kAllowTypes}; | |
7861 RunParserSyncTest(untyped_context_data, correct_data, kError, NULL, 0, | |
7862 always_flags, arraysize(always_flags)); | |
7863 RunParserSyncTest(typed_context_data, correct_data, kSuccess, NULL, 0, | |
7864 always_flags, arraysize(always_flags)); | |
7865 RunParserSyncTest(untyped_context_data, error_data, kError, NULL, 0, | |
7866 always_flags, arraysize(always_flags)); | |
7867 RunParserSyncTest(typed_context_data, error_data, kError, NULL, 0, | |
7868 always_flags, arraysize(always_flags)); | |
7869 } | |
OLD | NEW |