uadd.carbon 3.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. // Part of the Carbon Language project, under the Apache License v2.0 with LLVM
  2. // Exceptions. See /LICENSE for license information.
  3. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  4. //
  5. // EXTRA-ARGS: --no-dump-sem-ir
  6. //
  7. // AUTOUPDATE
  8. // TIP: To test this file alone, run:
  9. // TIP: bazel test //toolchain/testing:file_test --test_arg=--file_tests=toolchain/check/testdata/builtins/int/uadd.carbon
  10. // TIP: To dump output, run:
  11. // TIP: bazel run //toolchain/testing:file_test -- --dump_output --file_tests=toolchain/check/testdata/builtins/int/uadd.carbon
  12. // --- int_add.carbon
  13. fn Add(a: i32, b: i32) -> i32 = "int.uadd";
  14. var arr: [i32; Add(1, 2)];
  15. let arr_p: [i32; 3]* = &arr;
  16. fn RuntimeCallIsValid(a: i32, b: i32) -> i32 {
  17. return Add(a, b);
  18. }
  19. // --- fail_bad_decl.carbon
  20. package FailBadDecl;
  21. // CHECK:STDERR: fail_bad_decl.carbon:[[@LINE+4]]:1: error: invalid signature for builtin function "int.uadd" [InvalidBuiltinSignature]
  22. // CHECK:STDERR: fn TooFew(a: i32) -> i32 = "int.uadd";
  23. // CHECK:STDERR: ^~~~~~~~~~~~~~~~~~~~~~~~~~
  24. // CHECK:STDERR:
  25. fn TooFew(a: i32) -> i32 = "int.uadd";
  26. // CHECK:STDERR: fail_bad_decl.carbon:[[@LINE+4]]:1: error: invalid signature for builtin function "int.uadd" [InvalidBuiltinSignature]
  27. // CHECK:STDERR: fn TooMany(a: i32, b: i32, c: i32) -> i32 = "int.uadd";
  28. // CHECK:STDERR: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  29. // CHECK:STDERR:
  30. fn TooMany(a: i32, b: i32, c: i32) -> i32 = "int.uadd";
  31. // CHECK:STDERR: fail_bad_decl.carbon:[[@LINE+4]]:1: error: invalid signature for builtin function "int.uadd" [InvalidBuiltinSignature]
  32. // CHECK:STDERR: fn BadReturnType(a: i32, b: i32) -> bool = "int.uadd";
  33. // CHECK:STDERR: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  34. // CHECK:STDERR:
  35. fn BadReturnType(a: i32, b: i32) -> bool = "int.uadd";
  36. fn JustRight(a: i32, b: i32) -> i32 = "int.uadd";
  37. // CHECK:STDERR: fail_bad_decl.carbon:[[@LINE+4]]:20: error: array bound is not a constant [InvalidArrayExpr]
  38. // CHECK:STDERR: var too_few: [i32; TooFew(1)];
  39. // CHECK:STDERR: ^~~~~~~~~
  40. // CHECK:STDERR:
  41. var too_few: [i32; TooFew(1)];
  42. // CHECK:STDERR: fail_bad_decl.carbon:[[@LINE+4]]:21: error: array bound is not a constant [InvalidArrayExpr]
  43. // CHECK:STDERR: var too_many: [i32; TooMany(1, 2, 3)];
  44. // CHECK:STDERR: ^~~~~~~~~~~~~~~~
  45. // CHECK:STDERR:
  46. var too_many: [i32; TooMany(1, 2, 3)];
  47. // CHECK:STDERR: fail_bad_decl.carbon:[[@LINE+4]]:28: error: array bound is not a constant [InvalidArrayExpr]
  48. // CHECK:STDERR: var bad_return_type: [i32; BadReturnType(1, 2)];
  49. // CHECK:STDERR: ^~~~~~~~~~~~~~~~~~~
  50. // CHECK:STDERR:
  51. var bad_return_type: [i32; BadReturnType(1, 2)];
  52. // CHECK:STDERR: fail_bad_decl.carbon:[[@LINE+6]]:21: error: 3 arguments passed to function expecting 2 arguments [CallArgCountMismatch]
  53. // CHECK:STDERR: var bad_call: [i32; JustRight(1, 2, 3)];
  54. // CHECK:STDERR: ^~~~~~~~~~~~~~~~~~
  55. // CHECK:STDERR: fail_bad_decl.carbon:[[@LINE-21]]:1: note: calling function declared here [InCallToEntity]
  56. // CHECK:STDERR: fn JustRight(a: i32, b: i32) -> i32 = "int.uadd";
  57. // CHECK:STDERR: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  58. var bad_call: [i32; JustRight(1, 2, 3)];
  59. fn RuntimeCallIsValidTooFew(a: i32) -> i32 {
  60. return TooFew(a);
  61. }
  62. fn RuntimeCallIsValidTooMany(a: i32, b: i32, c: i32) -> i32 {
  63. return TooMany(a, b, c);
  64. }
  65. fn RuntimeCallIsValidBadReturnType(a: i32, b: i32) -> bool {
  66. return BadReturnType(a, b);
  67. }
  68. // --- overflow.carbon
  69. package Overflow;
  70. fn Add(a: i32, b: i32) -> i32 = "int.uadd";
  71. // Overflow is OK.
  72. let a: i32 = Add(0x7FFFFFFF, 0);
  73. let b: i32 = Add(0x7FFFFFFF, 1);