summaryrefslogtreecommitdiff
path: root/internal_rewrite/bf_write.hpp
diff options
context:
space:
mode:
authorJustSomePwner <crotchyalt@gmail.com>2018-08-30 14:01:54 +0200
committerJustSomePwner <crotchyalt@gmail.com>2018-08-30 14:01:54 +0200
commit7ccb819f867493f8ec202ea3b39c94c198c64584 (patch)
tree94622e61af0ff359e3d6689cf274d74f60b2492a /internal_rewrite/bf_write.hpp
parent564d979b79e8a5aaa5014eba0ecd36c61575934f (diff)
first
Diffstat (limited to 'internal_rewrite/bf_write.hpp')
-rw-r--r--internal_rewrite/bf_write.hpp34
1 files changed, 34 insertions, 0 deletions
diff --git a/internal_rewrite/bf_write.hpp b/internal_rewrite/bf_write.hpp
new file mode 100644
index 0000000..7d759b2
--- /dev/null
+++ b/internal_rewrite/bf_write.hpp
@@ -0,0 +1,34 @@
+#pragma once
+
+class bf_write {
+public:
+ bf_write( void* data, int bytes, int max_bits = -1 ) {
+ m_data = ( unsigned char* )data;
+ m_bytes = bytes;
+ if( max_bits == -1 )
+ m_bits = bytes * 8;
+ else
+ m_bits = max_bits;
+ }
+
+ bf_write( const char* debug_name, void* data, int bytes, int max_bits = -1 ) {
+ m_debug_name = debug_name;
+ m_data = ( unsigned char* )data;
+ m_bytes = bytes;
+ if( max_bits == -1 )
+ m_bits = bytes * 8;
+ else
+ m_bits = max_bits;
+ }
+
+public:
+ unsigned char* m_data{ };
+ int m_bytes{ };
+ int m_bits{ };
+ int m_cur_bit{ };
+
+private:
+ bool m_overflow{ };
+ bool m_assert_on_overflow{ };
+ const char* m_debug_name{ };
+}; \ No newline at end of file