summaryrefslogblamecommitdiff
path: root/src/generic/intern-pool.hpp
blob: f9c1e8f8cb9db369acbeb2cbac22c6446ffd5f74 (plain) (tree)
1
2
3
4
5
6
7
8
9

                                    
 
                   
 

                  
 
                                  

                                  
 

                

                                    
       
                                
     

                                                                           
                                                






                                                       
                                    
     
                                   








                            
                                      
#ifndef TMWA_GENERIC_INTERN_POOL_HPP
#define TMWA_GENERIC_INTERN_POOL_HPP

# include <cassert>

# include <map>
# include <vector>

# include "../strings/rstring.hpp"
# include "../strings/zstring.hpp"
# include "../strings/xstring.hpp"

class InternPool
{
    std::map<RString, size_t> known;
    std::vector<RString> names;
public:
    size_t intern(XString name_)
    {
        // TODO just look up the XString, the memory should not move by now
        RString name = name_;
        // hm, I could change this to do aliases
        auto pair = known.insert({name, known.size()});
        if (pair.second)
            names.push_back(name);
        assert (known.size() == names.size());
        return pair.first->second;
    }

    ZString outtern(size_t sz) const
    {
        assert (sz < names.size());
        return names[sz];
    }

    size_t size() const
    {
        return known.size();
    }
};

#endif // TMWA_GENERIC_INTERN_POOL_HPP