ClientStore.h 3.3 KB
Newer Older
1 2
/**************************************************************************/
/*                                                                        */
3
/* Copyright (c) 2001, 2010 NoMachine, http://www.nomachine.com/.         */
4 5 6 7 8 9 10 11
/*                                                                        */
/* NXCOMP, NX protocol compression and NX extensions to this software     */
/* are copyright of NoMachine. Redistribution and use of the present      */
/* software is allowed according to terms specified in the file LICENSE   */
/* which comes in the source distribution.                                */
/*                                                                        */
/* Check http://www.nomachine.com/licensing.html for applicability.       */
/*                                                                        */
12
/* NX and NoMachine are trademarks of Medialogic S.p.A.                   */
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 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135
/*                                                                        */
/* All rights reserved.                                                   */
/*                                                                        */
/**************************************************************************/

#ifndef ClientStore_H
#define ClientStore_H

#include "Message.h"
#include "Split.h"

#include "ChannelStore.h"

class StaticCompressor;

class ClientStore : public ChannelStore
{
  public:

  ClientStore(StaticCompressor *compressor);

  virtual ~ClientStore();

  //
  // Get the store based on the index.
  //

  MessageStore *getRequestStore(unsigned char opcode) const
  {
    return requests_[opcode];
  }

  SplitStore *getSplitStore(int resource) const
  {
    return splits_[resource];
  }

  int getSplitTotalSize() const
  {
    return SplitStore::getTotalSize();
  }

  int getSplitTotalStorageSize() const
  {
    return SplitStore::getTotalStorageSize();
  }

  CommitStore *getCommitStore() const
  {
    return commits_;
  }

  int getCommitSize() const
  {
    return commits_ -> getSize();
  }

  void dumpSplitStore(int resource) const
  {
    splits_[resource] -> dump();
  }

  void dumpCommitStore() const
  {
    commits_ -> dump();
  }

  void dumpSplitStores() const;

  SplitStore *createSplitStore(int resource)
  {
    splits_[resource] = new SplitStore(compressor_, commits_, resource);

    return splits_[resource];
  }

  void destroySplitStore(int resource)
  {
    delete splits_[resource];

    splits_[resource] = NULL;
  }

  //
  // Actually save the message store
  // to disk according to proxy mode.
  //

  int saveRequestStores(ostream *cachefs, md5_state_t *md5StateStream,
                            md5_state_t *md5StateClient, T_checksum_action checksumAction,
                                T_data_action dataAction) const;

  int loadRequestStores(istream *cachefs, md5_state_t *md5StateStream,
                            T_checksum_action checksumAction, T_data_action dataAction) const;

  private:

  //
  // A client store contains requests.
  //

  MessageStore *requests_[CHANNEL_STORE_OPCODE_LIMIT];

  //
  // Client messages being split.
  //

  SplitStore *splits_[CHANNEL_STORE_RESOURCE_LIMIT];

  //
  // Messages having been recomposed.
  //

  CommitStore *commits_;

  //
  // Passed forward to the other stores.
  //

  StaticCompressor *compressor_;
};

#endif /* ClientStore_H */