-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTextEncoderUnicode.cls
95 lines (83 loc) · 4.47 KB
/
TextEncoderUnicode.cls
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
VERSION 1.0 CLASS
BEGIN
MultiUse = -1 'True
END
Attribute VB_Name = "TextEncoderUnicode"
Attribute VB_GlobalNameSpace = False
Attribute VB_Creatable = False
Attribute VB_PredeclaredId = False
Attribute VB_Exposed = False
Attribute VB_Description = "A Unicode text encoder that converts a string to a unicode hex string using a managed variant read-only integer array overlay. \r\n\r\nVBA-IDictionary v2.0 (July 28, 2019)\r\n(c) Mark Johnstone - https://github.com/MarkJohnstoneGitHub/VBA-IDictionary\r\nAuthor: [email protected]\r\n"
'@TODO Rename ToHexString to Encode and some for Interface functions
''
'Rubberduck annotations
'@Folder("VBA-IScriptingDictionary.TextEncoding")
'@ModuleDescription "A Unicode text encoder that converts a string to a unicode hex string using a managed variant read-only integer array overlay. \r\n\r\nVBA-IDictionary v2.0 (July 28, 2019)\r\n(c) Mark Johnstone - https://github.com/MarkJohnstoneGitHub/VBA-IDictionary\r\nAuthor: [email protected]\r\n"
''
''
'@Version VBA-IScriptingDictionary v2.1 (September 02, 2019)
'(c) Mark Johnstone - https://github.com/MarkJohnstoneGitHub/VBA-IDictionary
'@Author Mark Johnstone [email protected]
'@LastModified September 05, 2019
'@Description Converts a string to a unicode hex string using a read-only integer array overlay.
''@Dependencies
' ManagedCharSafeArray.cls
' TypeSafeArray.bas
'
'@Usage Eg. Dim textEncoder As UnicodeTextEncoder
' Set textEncoder = New UnicodeTextEncoder
' Debug.Print textEncoder.ToHexString("ABCabc")
' Set textEncoder = Nothing
'@Remarks
'------------------------------------------------------------'
Option Explicit
Implements ITextEncoding
Private Type TUnicodeTextEncoder
managedCharsSafeArrayDescriptor As ManagedCharSafeArray 'managed safe array descriptor which is assigned to the managedChars array
managedChars() As Integer 'managed character array containing Unicode characters for a string specified.
End Type
'============================================='
'Private Variables
'============================================='
Private this As TUnicodeTextEncoder
'============================================='
'Constructors and destructors
'============================================='
Private Sub Class_Initialize()
Set this.managedCharsSafeArrayDescriptor = ManagedCharSafeArray.Create(this.managedChars)
End Sub
Private Sub Class_Terminate()
this.managedCharsSafeArrayDescriptor.Dispose
End Sub
'============================================='
'Public Methods
'============================================='
''
'@Description("Converts a string to unicode hex string.")
'@param inText The unicode string to be converted to a unicode hex string.
'@Remarks
' Each string character is converted into four hex characters.
' Interuption or resetting while running this function may cause
' the application to crash if the managed chars array hasn't been freed.
'------------------------------------------------------------'
Public Function ToHexString(ByRef inText As String) As String
Attribute ToHexString.VB_Description = "Converts a string to unicode hex string."
Const HEX_CHARACTER_LENGTH As Long = 4 'Each string character is represented by four UTF-16 hexidemial characters.
Const HEX_CHARACTER_PADDING As Long = 65536 'Ensures that four hex characters are obtained with 0 padding
this.managedCharsSafeArrayDescriptor.AllocateCharData inText 'Allocate string data to managedChar array
'Allocate the hex string buffer according to specified string size, where each string character converts to four hex characters
ToHexString = VBA.Space$(HEX_CHARACTER_LENGTH * (UBound(this.managedChars) - LBound(this.managedChars) + 1))
Dim charIndex As Long
For charIndex = LBound(this.managedChars) To UBound(this.managedChars)
Mid$(ToHexString, (charIndex * HEX_CHARACTER_LENGTH) + 1, HEX_CHARACTER_LENGTH) = VBA.Right$(VBA.Hex(HEX_CHARACTER_PADDING Or this.managedChars(charIndex)), HEX_CHARACTER_LENGTH)
Next
End Function
'============================================='
'Interfaces
'============================================='
' --------------------------------------------- '
' Interface ITextEncoding
' --------------------------------------------- '
Private Function ITextEncoding_Encode(ByRef inText As String) As String
ITextEncoding_Encode = Me.ToHexString(inText)
End Function