X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fbufferable.h;h=cbbde4e1b93f1e07266c097c150774f2b5621d3c;hb=5bc9c7214feaf4ea4797fc0d4a906e5e59b75839;hp=f157c6281d2197d17b56bd78a7d61cd1754ee186;hpb=6c525eff3eaaa617648a869449ed3bddf9c1936d;p=libs%2Fgl.git diff --git a/source/bufferable.h b/source/bufferable.h index f157c628..cbbde4e1 100644 --- a/source/bufferable.h +++ b/source/bufferable.h @@ -20,7 +20,6 @@ public: private: const Bufferable &bufferable; char *mapped_address; - bool buffer_resized; public: AsyncUpdater(const Bufferable &); @@ -34,10 +33,10 @@ private: unsigned offset; Bufferable *next_in_buffer; Bufferable *prev_in_buffer; + mutable bool location_dirty; protected: mutable bool dirty; -protected: Bufferable(); public: virtual ~Bufferable(); @@ -46,18 +45,28 @@ public: buffer, and this object is inserted after it. */ void use_buffer(Buffer *buf, Bufferable *prev = 0); + /** Sets the buffer for the entire chain of objects. */ + void change_buffer(Buffer *); + + /** Returns the total amount of storage required by this object and others + in the same chain, including any alignment between objects. */ + unsigned get_required_buffer_size() const; + /** Uploads new data into the buffer if necessary. */ - void refresh() const { if(dirty) update_buffer(); } + void refresh() const { if(buffer && dirty) upload_data(0); } + /** Returns an object which can be used to upload data to the buffer using + mapped memory. */ AsyncUpdater *refresh_async() const; private: void unlink_from_buffer(); -protected: +public: /** Returns the buffer in which the data is stored. */ - Buffer *get_buffer() const { return buffer; } + const Buffer *get_buffer() const { return buffer; } +protected: /** Returns the amount of data to be stored in the buffer, in bytes. */ virtual unsigned get_data_size() const = 0; @@ -76,19 +85,13 @@ protected: /** Returns the offset where the data should be uploaded. */ unsigned get_offset() const { return offset; } - /** Called when the offset for the data has changed. */ - virtual void offset_changed() { } + /** Called when the target buffer or offset within it has changed. */ + virtual void location_changed(Buffer *, unsigned, unsigned) const { } private: - bool resize_buffer() const; - -protected: - /** Resizes the buffer if necessary and calls upload_data(). */ - void update_buffer() const; - /** Uploads data to the buffer. Receives pointer to mapped buffer memory as - parameter. If null, buffer interface should be used instead. */ - virtual void upload_data(char *) const; + parameter, or null to use the buffer upload interface. */ + void upload_data(char *) const; }; } // namespace GL