Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
cta
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Package registry
Container Registry
Harbor Registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
dCache
cta
Commits
06be8a21
Commit
06be8a21
authored
10 years ago
by
Steven Murray
Browse files
Options
Downloads
Patches
Plain Diff
Added StorageClassAndUsageCount
parent
5a3f273f
No related branches found
Branches containing commit
No related tags found
Tags containing commit
No related merge requests found
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
libs/client/CMakeLists.txt
+1
-0
1 addition, 0 deletions
libs/client/CMakeLists.txt
libs/client/StorageClassAndUsageCount.cpp
+61
-0
61 additions, 0 deletions
libs/client/StorageClassAndUsageCount.cpp
libs/client/StorageClassAndUsageCount.hpp
+64
-0
64 additions, 0 deletions
libs/client/StorageClassAndUsageCount.hpp
with
126 additions
and
0 deletions
libs/client/CMakeLists.txt
+
1
−
0
View file @
06be8a21
...
...
@@ -10,6 +10,7 @@ set (CLIENT_LIB_SRC_FILES
MockClientAPI.cpp
SecurityIdentity.cpp
StorageClass.cpp
StorageClassAndUsageCount.cpp
UserIdentity.cpp
)
add_library
(
ctaclient SHARED
...
...
This diff is collapsed.
Click to expand it.
libs/client/StorageClassAndUsageCount.cpp
0 → 100644
+
61
−
0
View file @
06be8a21
#define __STDC_LIMIT_MACROS
#include
"StorageClassAndUsageCount.hpp"
//------------------------------------------------------------------------------
// constructor
//------------------------------------------------------------------------------
cta
::
StorageClassAndUsageCount
::
StorageClassAndUsageCount
()
:
m_usageCount
(
0
)
{
}
//------------------------------------------------------------------------------
// constructor
//------------------------------------------------------------------------------
cta
::
StorageClassAndUsageCount
::
StorageClassAndUsageCount
(
const
StorageClass
&
storageClass
)
:
m_storageClass
(
storageClass
),
m_usageCount
(
0
)
{
}
//------------------------------------------------------------------------------
// getStorageClass
//------------------------------------------------------------------------------
const
cta
::
StorageClass
&
cta
::
StorageClassAndUsageCount
::
getStorageClass
()
const
throw
()
{
return
m_storageClass
;
}
//------------------------------------------------------------------------------
// getUsageCount
//------------------------------------------------------------------------------
uint64_t
cta
::
StorageClassAndUsageCount
::
getUsageCount
()
const
throw
()
{
return
m_usageCount
;
}
//------------------------------------------------------------------------------
// incUsageCount
//------------------------------------------------------------------------------
void
cta
::
StorageClassAndUsageCount
::
incUsageCount
()
{
if
(
UINT64_MAX
==
m_usageCount
)
{
std
::
ostringstream
message
;
message
<<
"Cannot increment usage count of storage class "
<<
m_storageClass
.
name
<<
" because its maximum value of UINT64_MAX has "
"already been reached"
;
throw
Exception
(
message
.
str
());
}
m_usageCount
++
;
}
//------------------------------------------------------------------------------
// decUsageCount
//------------------------------------------------------------------------------
void
cta
::
StorageClassAndUsageCount
::
decUsageCount
()
{
if
(
0
==
m_usageCount
)
{
std
::
ostringstream
message
;
message
<<
"Cannot decrement usage count of storage class "
<<
m_storageClass
.
name
<<
" because it is already at zero"
;
throw
Exception
(
message
.
str
());
}
m_usageCount
--
;
}
This diff is collapsed.
Click to expand it.
libs/client/StorageClassAndUsageCount.hpp
0 → 100644
+
64
−
0
View file @
06be8a21
#pragma once
#include
"Exception.hpp"
#include
"StorageClass.hpp"
#include
<sstream>
namespace
cta
{
/**
* Class used to store a storage class and it usage count.
*/
class
StorageClassAndUsageCount
{
public:
/**
* Constructor.
*
* Initialisez the usage count to 0.
*/
StorageClassAndUsageCount
();
/**
* Constructor.
*
* Initialisez the usage count to 0.
*/
StorageClassAndUsageCount
(
const
StorageClass
&
storageClass
);
/**
* Returns the storage class.
*/
const
StorageClass
&
getStorageClass
()
const
throw
();
/**
* Returns the usage count.
*/
uint64_t
getUsageCount
()
const
throw
();
/**
* Increments the usage count by 1.
*/
void
incUsageCount
();
/**
* Decrements the usage count by 1.
*/
void
decUsageCount
();
private:
/**
* The storage class.
*/
StorageClass
m_storageClass
;
/**
* The usage count.
*/
uint64_t
m_usageCount
;
};
// class StorageClassAndUsageCount
}
// namespace cta
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment