uadd.carbon 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  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+7]]: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. // CHECK:STDERR:
  59. var bad_call: [i32; JustRight(1, 2, 3)];
  60. fn RuntimeCallIsValidTooFew(a: i32) -> i32 {
  61. return TooFew(a);
  62. }
  63. fn RuntimeCallIsValidTooMany(a: i32, b: i32, c: i32) -> i32 {
  64. return TooMany(a, b, c);
  65. }
  66. fn RuntimeCallIsValidBadReturnType(a: i32, b: i32) -> bool {
  67. return BadReturnType(a, b);
  68. }
  69. // --- overflow.carbon
  70. package Overflow;
  71. fn Add(a: i32, b: i32) -> i32 = "int.uadd";
  72. // Overflow is OK.
  73. let a: i32 = Add(0x7FFFFFFF, 0);
  74. let b: i32 = Add(0x7FFFFFFF, 1);