File: ActionCache.cpp

package info (click to toggle)
swiftlang 6.1.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,791,604 kB
  • sloc: cpp: 9,901,740; ansic: 2,201,431; asm: 1,091,827; python: 308,252; objc: 82,166; f90: 80,126; lisp: 38,358; pascal: 25,559; sh: 20,429; ml: 5,058; perl: 4,745; makefile: 4,484; awk: 3,535; javascript: 3,018; xml: 918; fortran: 664; cs: 573; ruby: 396
file content (62 lines) | stat: -rw-r--r-- 2,440 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
//===- ActionCache.cpp ------------------------------------------*- C++ -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//

#include "llvm/CAS/ActionCache.h"
#include "llvm/CAS/CASID.h"
#include "llvm/CAS/ObjectStore.h"

using namespace llvm;
using namespace llvm::cas;

void ActionCache::anchor() {}

CacheKey::CacheKey(const CASID &ID) : Key(toStringRef(ID.getHash()).str()) {}
CacheKey::CacheKey(const ObjectProxy &Proxy)
    : CacheKey(Proxy.getCAS(), Proxy.getRef()) {}
CacheKey::CacheKey(const ObjectStore &CAS, const ObjectRef &Ref)
    : Key(toStringRef(CAS.getID(Ref).getHash())) {}

std::future<AsyncCASIDValue> ActionCache::getFuture(const CacheKey &ActionKey,
                                                    bool Globally) const {
  std::promise<AsyncCASIDValue> Promise;
  auto Future = Promise.get_future();
  getAsync(ActionKey, Globally,
           [Promise =
                std::move(Promise)](Expected<std::optional<CASID>> ID) mutable {
             Promise.set_value(std::move(ID));
           });
  return Future;
}

std::future<AsyncErrorValue> ActionCache::putFuture(const CacheKey &ActionKey,
                                                    const CASID &Result,
                                                    bool Globally) {
  std::promise<AsyncErrorValue> Promise;
  auto Future = Promise.get_future();
  putAsync(ActionKey, Result, Globally,
           [Promise = std::move(Promise)](Error E) mutable {
             Promise.set_value(std::move(E));
           });
  return Future;
}

void ActionCache::getImplAsync(
    ArrayRef<uint8_t> ResolvedKey, bool Globally,
    unique_function<void(Expected<std::optional<CASID>>)> Callback,
    std::unique_ptr<Cancellable> *) const {
  // The default implementation is synchronous.
  return Callback(getImpl(ResolvedKey, Globally));
}

void ActionCache::putImplAsync(ArrayRef<uint8_t> ResolvedKey,
                               const CASID &Result, bool Globally,
                               unique_function<void(Error)> Callback,
                               std::unique_ptr<Cancellable> *) {
  // The default implementation is synchronous.
  return Callback(putImpl(ResolvedKey, Result, Globally));
}