tuplelist.h 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. #pragma once
  2. #include "common.h"
  3. #include "memory.h"
  4. #include "str.h"
  5. #include "vector.h"
  6. namespace pkpy {
  7. using List = pod_vector<PyVar, 4>;
  8. struct Tuple {
  9. PyVar* _args;
  10. PyVar _inlined[3];
  11. int _size;
  12. Tuple(int n);
  13. Tuple(const Tuple& other);
  14. Tuple(Tuple&& other) noexcept;
  15. Tuple(List&& other) noexcept;
  16. ~Tuple();
  17. Tuple(PyVar, PyVar);
  18. Tuple(PyVar, PyVar, PyVar);
  19. Tuple(PyVar, PyVar, PyVar, PyVar);
  20. bool is_inlined() const { return _args == _inlined; }
  21. PyVar& operator[](int i){ return _args[i]; }
  22. PyVar operator[](int i) const { return _args[i]; }
  23. int size() const { return _size; }
  24. PyVar* begin() const { return _args; }
  25. PyVar* end() const { return _args + _size; }
  26. PyVar* data() const { return _args; }
  27. };
  28. // a lightweight view for function args, it does not own the memory
  29. struct ArgsView{
  30. PyVar* _begin;
  31. PyVar* _end;
  32. ArgsView(PyVar* begin, PyVar* end) : _begin(begin), _end(end) {}
  33. ArgsView(const Tuple& t) : _begin(t.begin()), _end(t.end()) {}
  34. PyVar* begin() const { return _begin; }
  35. PyVar* end() const { return _end; }
  36. int size() const { return _end - _begin; }
  37. bool empty() const { return _begin == _end; }
  38. PyVar operator[](int i) const { return _begin[i]; }
  39. List to_list() const;
  40. Tuple to_tuple() const;
  41. };
  42. } // namespace pkpy