// Copyright 2020 the V8 project authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include #include #include #include #include #include #include #include #include /** * This sample program shows how to set up a stand-alone cppgc heap. */ /** * Simple string rope to illustrate allocation and garbage collection below. * The rope keeps the next parts alive via regular managed reference. */ class Rope final : public cppgc::GarbageCollected { public: explicit Rope(std::string part, Rope* next = nullptr) : part_(part), next_(next) {} void Trace(cppgc::Visitor* visitor) const { visitor->Trace(next_); } private: std::string part_; cppgc::Member next_; friend std::ostream& operator<<(std::ostream& os, const Rope& rope) { os << rope.part_; if (rope.next_) { os << *rope.next_; } return os; } }; int main(int argc, char* argv[]) { // Create a default platform that is used by cppgc::Heap for execution and // backend allocation. auto cppgc_platform = std::make_shared(); // Initialize the process. This must happen before any cppgc::Heap::Create() // calls. cppgc::DefaultPlatform::InitializeProcess(cppgc_platform.get()); // Create a managed heap. std::unique_ptr heap = cppgc::Heap::Create(cppgc_platform); // Allocate a string rope on the managed heap. auto* greeting = cppgc::MakeGarbageCollected( heap->GetAllocationHandle(), "Hello ", cppgc::MakeGarbageCollected(heap->GetAllocationHandle(), "World!")); // Manually trigger garbage collection. The object greeting is held alive // through conservative stack scanning. heap->ForceGarbageCollectionSlow("CppGC example", "Testing"); std::cout << *greeting << std::endl; // Gracefully shutdown the process. cppgc::ShutdownProcess(); return 0; }