diff options
Diffstat (limited to 'crates/ra_hir/src/ty')
| -rw-r--r-- | crates/ra_hir/src/ty/primitive.rs | 50 | ||||
| -rw-r--r-- | crates/ra_hir/src/ty/tests/data/basics.txt | 4 | ||||
| -rw-r--r-- | crates/ra_hir/src/ty/tests/data/binary_op.txt | 2 | ||||
| -rw-r--r-- | crates/ra_hir/src/ty/tests/data/let.txt | 4 | ||||
| -rw-r--r-- | crates/ra_hir/src/ty/tests/data/literals.txt | 2 |
5 files changed, 56 insertions, 6 deletions
diff --git a/crates/ra_hir/src/ty/primitive.rs b/crates/ra_hir/src/ty/primitive.rs index 498d42d52..5741ca90d 100644 --- a/crates/ra_hir/src/ty/primitive.rs +++ b/crates/ra_hir/src/ty/primitive.rs | |||
| @@ -2,6 +2,56 @@ use std::fmt; | |||
| 2 | 2 | ||
| 3 | use crate::{Name, KnownName}; | 3 | use crate::{Name, KnownName}; |
| 4 | 4 | ||
| 5 | #[derive(Debug, Clone, Eq, PartialEq, Hash, Copy)] | ||
| 6 | pub enum UncertainIntTy { | ||
| 7 | Unknown, | ||
| 8 | Unsigned(UintTy), | ||
| 9 | Signed(IntTy), | ||
| 10 | } | ||
| 11 | |||
| 12 | impl UncertainIntTy { | ||
| 13 | pub fn ty_to_string(&self) -> &'static str { | ||
| 14 | match *self { | ||
| 15 | UncertainIntTy::Unknown => "{integer}", | ||
| 16 | UncertainIntTy::Signed(ty) => ty.ty_to_string(), | ||
| 17 | UncertainIntTy::Unsigned(ty) => ty.ty_to_string(), | ||
| 18 | } | ||
| 19 | } | ||
| 20 | |||
| 21 | pub fn from_name(name: &Name) -> Option<UncertainIntTy> { | ||
| 22 | if let Some(ty) = IntTy::from_name(name) { | ||
| 23 | Some(UncertainIntTy::Signed(ty)) | ||
| 24 | } else if let Some(ty) = UintTy::from_name(name) { | ||
| 25 | Some(UncertainIntTy::Unsigned(ty)) | ||
| 26 | } else { | ||
| 27 | None | ||
| 28 | } | ||
| 29 | } | ||
| 30 | } | ||
| 31 | |||
| 32 | #[derive(Debug, Clone, Eq, PartialEq, Hash, Copy)] | ||
| 33 | pub enum UncertainFloatTy { | ||
| 34 | Unknown, | ||
| 35 | Known(FloatTy), | ||
| 36 | } | ||
| 37 | |||
| 38 | impl UncertainFloatTy { | ||
| 39 | pub fn ty_to_string(&self) -> &'static str { | ||
| 40 | match *self { | ||
| 41 | UncertainFloatTy::Unknown => "{float}", | ||
| 42 | UncertainFloatTy::Known(ty) => ty.ty_to_string(), | ||
| 43 | } | ||
| 44 | } | ||
| 45 | |||
| 46 | pub fn from_name(name: &Name) -> Option<UncertainFloatTy> { | ||
| 47 | if let Some(ty) = FloatTy::from_name(name) { | ||
| 48 | Some(UncertainFloatTy::Known(ty)) | ||
| 49 | } else { | ||
| 50 | None | ||
| 51 | } | ||
| 52 | } | ||
| 53 | } | ||
| 54 | |||
| 5 | #[derive(Clone, PartialEq, Eq, PartialOrd, Ord, Hash, Copy)] | 55 | #[derive(Clone, PartialEq, Eq, PartialOrd, Ord, Hash, Copy)] |
| 6 | pub enum IntTy { | 56 | pub enum IntTy { |
| 7 | Isize, | 57 | Isize, |
diff --git a/crates/ra_hir/src/ty/tests/data/basics.txt b/crates/ra_hir/src/ty/tests/data/basics.txt index e02947ba8..4a3b69b7e 100644 --- a/crates/ra_hir/src/ty/tests/data/basics.txt +++ b/crates/ra_hir/src/ty/tests/data/basics.txt | |||
| @@ -7,7 +7,7 @@ | |||
| 7 | [55; 56) 'b': isize | 7 | [55; 56) 'b': isize |
| 8 | [62; 63) 'c': ! | 8 | [62; 63) 'c': ! |
| 9 | [69; 70) 'd': &str | 9 | [69; 70) 'd': &str |
| 10 | [76; 82) '1usize': [unknown] | 10 | [76; 82) '1usize': usize |
| 11 | [88; 94) '1isize': [unknown] | 11 | [88; 94) '1isize': isize |
| 12 | [100; 106) '"test"': &str | 12 | [100; 106) '"test"': &str |
| 13 | [112; 118) '1.0f32': [unknown] | 13 | [112; 118) '1.0f32': [unknown] |
diff --git a/crates/ra_hir/src/ty/tests/data/binary_op.txt b/crates/ra_hir/src/ty/tests/data/binary_op.txt index 8a515ac5e..7fdb8a900 100644 --- a/crates/ra_hir/src/ty/tests/data/binary_op.txt +++ b/crates/ra_hir/src/ty/tests/data/binary_op.txt | |||
| @@ -16,7 +16,7 @@ | |||
| 16 | [112; 113) 'y': bool | 16 | [112; 113) 'y': bool |
| 17 | [123; 134) 'minus_forty': isize | 17 | [123; 134) 'minus_forty': isize |
| 18 | [144; 152) '-40isize': isize | 18 | [144; 152) '-40isize': isize |
| 19 | [145; 152) '40isize': [unknown] | 19 | [145; 152) '40isize': isize |
| 20 | [162; 163) 'h': bool | 20 | [162; 163) 'h': bool |
| 21 | [166; 177) 'minus_forty': isize | 21 | [166; 177) 'minus_forty': isize |
| 22 | [166; 188) 'minus_...ONST_2': bool | 22 | [166; 188) 'minus_...ONST_2': bool |
diff --git a/crates/ra_hir/src/ty/tests/data/let.txt b/crates/ra_hir/src/ty/tests/data/let.txt index 30f4a2cf5..8815dba41 100644 --- a/crates/ra_hir/src/ty/tests/data/let.txt +++ b/crates/ra_hir/src/ty/tests/data/let.txt | |||
| @@ -1,6 +1,6 @@ | |||
| 1 | [11; 71) '{ ...= b; }': () | 1 | [11; 71) '{ ...= b; }': () |
| 2 | [21; 22) 'a': [unknown] | 2 | [21; 22) 'a': isize |
| 3 | [25; 31) '1isize': [unknown] | 3 | [25; 31) '1isize': isize |
| 4 | [41; 42) 'b': usize | 4 | [41; 42) 'b': usize |
| 5 | [52; 53) '1': usize | 5 | [52; 53) '1': usize |
| 6 | [63; 64) 'c': usize | 6 | [63; 64) 'c': usize |
diff --git a/crates/ra_hir/src/ty/tests/data/literals.txt b/crates/ra_hir/src/ty/tests/data/literals.txt index 8b22eee31..e139d57a8 100644 --- a/crates/ra_hir/src/ty/tests/data/literals.txt +++ b/crates/ra_hir/src/ty/tests/data/literals.txt | |||
| @@ -1,5 +1,5 @@ | |||
| 1 | [11; 135) '{ ...lse] }': () | 1 | [11; 135) '{ ...lse] }': () |
| 2 | [17; 21) '5i32': [unknown] | 2 | [17; 21) '5i32': i32 |
| 3 | [27; 34) '"hello"': &str | 3 | [27; 34) '"hello"': &str |
| 4 | [40; 48) 'b"bytes"': &[u8] | 4 | [40; 48) 'b"bytes"': &[u8] |
| 5 | [54; 57) ''c'': char | 5 | [54; 57) ''c'': char |
