diff options
| author | Steven Fackler <[email protected]> | 2013-12-28 17:09:18 -0700 |
|---|---|---|
| committer | Steven Fackler <[email protected]> | 2013-12-28 17:09:18 -0700 |
| commit | 53e11b08f5a739213bfab7364cd4ade6b81ceda8 (patch) | |
| tree | f6280bf992d39f38c906ac639c3abe7a1ea83cbc /crypto/hex.rs | |
| parent | update to rust 0.9-pre (a5fa1d9) (diff) | |
| download | rust-openssl-53e11b08f5a739213bfab7364cd4ade6b81ceda8.tar.xz rust-openssl-53e11b08f5a739213bfab7364cd4ade6b81ceda8.zip | |
Prepare rustcrypto to merge into rust-openssl
Diffstat (limited to 'crypto/hex.rs')
| -rw-r--r-- | crypto/hex.rs | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/crypto/hex.rs b/crypto/hex.rs new file mode 100644 index 00000000..1a7ed75b --- /dev/null +++ b/crypto/hex.rs @@ -0,0 +1,82 @@ +/* + * Copyright 2013 Jack Lloyd + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +use std::vec; + +pub trait ToHex { + fn to_hex(&self) -> ~str; +} + +impl<'a> ToHex for &'a [u8] { + fn to_hex(&self) -> ~str { + + let chars = "0123456789ABCDEF".chars().collect::<~[char]>(); + + let mut s = ~""; + + for i in range(0u, self.len()) { + + let x = self[i]; + + let xhi = (x >> 4) & 0x0F; + let xlo = (x ) & 0x0F; + + s.push_char(chars[xhi]); + s.push_char(chars[xlo]); + } + + s + } +} + +pub trait FromHex { + fn from_hex(&self) -> ~[u8]; +} + +impl<'a> FromHex for &'a str { + fn from_hex(&self) -> ~[u8] { + let mut vec = vec::with_capacity(self.len() / 2); + + for (i,c) in self.chars().enumerate() { + let nibble = + if c >= '0' && c <= '9' { (c as u8) - 0x30 } + else if c >= 'a' && c <= 'f' { (c as u8) - (0x61 - 10) } + else if c >= 'A' && c <= 'F' { (c as u8) - (0x41 - 10) } + else { fail!(~"bad hex character"); }; + + if i % 2 == 0 { + vec.push(nibble << 4); + } + else { + vec[i/2] |= nibble; + } + } + + vec + } +} + +#[cfg(test)] +mod tests { + #[test] + pub fn test() { + assert!([05u8, 0xffu8, 0x00u8, 0x59u8].to_hex() == ~"05FF0059"); + + assert!("00FFA9D1F5".from_hex() == ~[0, 0xff, 0xa9, 0xd1, 0xf5]); + + assert!("00FFA9D1F5".from_hex().to_hex() == ~"00FFA9D1F5"); + } +} |