Fork to update libraries and fix disk_read/disk_write functions
Dependencies: FATFileSystem mbed-rtos
Dependents: lpc4088_qsb_usbhost
Fork of LPC4088-USBHost by
USBHost/mymap.h@0:148fca6fd246, 2014-04-25 (annotated)
- Committer:
- va009039
- Date:
- Fri Apr 25 05:18:55 2014 +0000
- Revision:
- 0:148fca6fd246
first commit
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
va009039 | 0:148fca6fd246 | 1 | #pragma once |
va009039 | 0:148fca6fd246 | 2 | |
va009039 | 0:148fca6fd246 | 3 | template<class K,class T> |
va009039 | 0:148fca6fd246 | 4 | class mymap { |
va009039 | 0:148fca6fd246 | 5 | struct mypair { |
va009039 | 0:148fca6fd246 | 6 | K first; |
va009039 | 0:148fca6fd246 | 7 | T second; |
va009039 | 0:148fca6fd246 | 8 | }; |
va009039 | 0:148fca6fd246 | 9 | public: |
va009039 | 0:148fca6fd246 | 10 | mymap() { |
va009039 | 0:148fca6fd246 | 11 | m_size = 0; |
va009039 | 0:148fca6fd246 | 12 | } |
va009039 | 0:148fca6fd246 | 13 | T& operator[](const K& key) { |
va009039 | 0:148fca6fd246 | 14 | int it; |
va009039 | 0:148fca6fd246 | 15 | if (count(key) == 0) { |
va009039 | 0:148fca6fd246 | 16 | it = insert(key, 0); |
va009039 | 0:148fca6fd246 | 17 | } else { |
va009039 | 0:148fca6fd246 | 18 | it = find(key); |
va009039 | 0:148fca6fd246 | 19 | } |
va009039 | 0:148fca6fd246 | 20 | return m_buf[it].second; |
va009039 | 0:148fca6fd246 | 21 | } |
va009039 | 0:148fca6fd246 | 22 | bool empty() { return m_size == 0 ? true : false; } |
va009039 | 0:148fca6fd246 | 23 | int size() { return m_size; } |
va009039 | 0:148fca6fd246 | 24 | void clear() { m_size = 0; } |
va009039 | 0:148fca6fd246 | 25 | int count(K key) { |
va009039 | 0:148fca6fd246 | 26 | for(int i = 0; i < m_size; i++) { |
va009039 | 0:148fca6fd246 | 27 | if (m_buf[i].first == key) { |
va009039 | 0:148fca6fd246 | 28 | return 1; |
va009039 | 0:148fca6fd246 | 29 | } |
va009039 | 0:148fca6fd246 | 30 | } |
va009039 | 0:148fca6fd246 | 31 | return 0; |
va009039 | 0:148fca6fd246 | 32 | } |
va009039 | 0:148fca6fd246 | 33 | |
va009039 | 0:148fca6fd246 | 34 | private: |
va009039 | 0:148fca6fd246 | 35 | int find(K key) { |
va009039 | 0:148fca6fd246 | 36 | for(int i = 0; i < m_size; i++) { |
va009039 | 0:148fca6fd246 | 37 | if (m_buf[i].first == key) { |
va009039 | 0:148fca6fd246 | 38 | return i; |
va009039 | 0:148fca6fd246 | 39 | } |
va009039 | 0:148fca6fd246 | 40 | } |
va009039 | 0:148fca6fd246 | 41 | return -1; |
va009039 | 0:148fca6fd246 | 42 | } |
va009039 | 0:148fca6fd246 | 43 | int insert(K key, T value) { |
va009039 | 0:148fca6fd246 | 44 | int it = find(key); |
va009039 | 0:148fca6fd246 | 45 | if (it != -1) { |
va009039 | 0:148fca6fd246 | 46 | m_buf[it].second = value; |
va009039 | 0:148fca6fd246 | 47 | return it; |
va009039 | 0:148fca6fd246 | 48 | } |
va009039 | 0:148fca6fd246 | 49 | mypair* new_buf = new mypair[m_size+1]; |
va009039 | 0:148fca6fd246 | 50 | if (m_size > 0) { |
va009039 | 0:148fca6fd246 | 51 | for(int i = 0; i < m_size; i++) { |
va009039 | 0:148fca6fd246 | 52 | new_buf[i] = m_buf[i]; |
va009039 | 0:148fca6fd246 | 53 | } |
va009039 | 0:148fca6fd246 | 54 | delete[] m_buf; |
va009039 | 0:148fca6fd246 | 55 | } |
va009039 | 0:148fca6fd246 | 56 | m_buf = new_buf; |
va009039 | 0:148fca6fd246 | 57 | it = m_size++; |
va009039 | 0:148fca6fd246 | 58 | m_buf[it].first = key; |
va009039 | 0:148fca6fd246 | 59 | m_buf[it].second = value; |
va009039 | 0:148fca6fd246 | 60 | return it; |
va009039 | 0:148fca6fd246 | 61 | } |
va009039 | 0:148fca6fd246 | 62 | |
va009039 | 0:148fca6fd246 | 63 | int m_size; |
va009039 | 0:148fca6fd246 | 64 | mypair *m_buf; |
va009039 | 0:148fca6fd246 | 65 | }; |