• Skip to main content
  • Skip to header right navigation
  • Skip to site footer
CDP Studio logo

CDP Studio

The no-code and full-code software development tool for distributed control systems and HMI

  • Doc
  • Why CDP
    • Software developers
    • Automation engineers
    • Managers
  • Products
    • Automation Designer
    • HMI Designer
    • Maritime HMIs
  • Services
  • Use cases
  • Pricing
  • Try CDP

CDP Studio Documentation

  • Framework - Automation
  • ROLOperator
  • 5.0.0

ROLOperator Class

(Automation::ROLOperator)

The ROLOperator rotates bits in a value to the left by Amount. More...

Header: #include <ROLOperator>
Inherits: CDPOperator<T>
  • List of all members, including inherited members

Public Functions

ROLOperator(const CDPPropertyBase &in)

Reimplemented Public Functions

virtual void Configure(XMLPrimitive *operatorXML) override
virtual unsigned int Process() override
  • 18 public functions inherited from CDPOperator
  • 17 public functions inherited from CDPOperatorBase
  • 49 public functions inherited from CDPBaseObject
  • 27 public functions inherited from CDP::StudioAPI::CDPNode
  • 22 public functions inherited from CDP::StudioAPI::ICDPNode

Additional Inherited Members

  • 1 public variable inherited from CDPOperatorBase
  • 1 static public member inherited from CDPBaseObject
  • 1 protected function inherited from CDP::StudioAPI::CDPNode
  • 8 protected variables inherited from CDPOperator
  • 5 protected variables inherited from CDPOperatorBase
  • 10 protected variables inherited from CDPBaseObject

Detailed Description

The ROLOperator rotates bits in a value to the left by Amount.

The bits rotated out to the left, are rotated back in from the right. In other words, when rotating 1 bit left, the most significant bit becomes the least significant bit, and all the other bits move one bit to the left.

Arguments

NameDescription
InThe default input value to rotate.
OutThe default output value after rotating.
AmountSpecifies the amount of bits to rotate.

When operator is used inside a signal its default input is automatically tied to signal's InternalValue or previous operator's output. Its default output is automatically tied to next operator's input or to signal's Value. See also CDP Operator Usage In CDP Signals.

Example

To rotate a signal value 3 bits to the left, add a ROLOperator<unsigned short> into a Signal<unsigned short> in Configure mode. Then go into the ROLOperator that was added, and set Amount to 3.

How to Run the Example

To run the example from CDP Studio, open Welcome mode and find it under Examples. Next, in Configure mode right-click on the system project and select Run & Connect. See the Running the Example Project tutorial for more information.

Set the signal Value containing the ROL operator to 0xff00 (65280), and verify that the value after the operator has been applied becomes 0xf807 (63495)

Actual Processing Code of the ROLOperator

unsigned int ROLOperator<T>::Process()
{
  if (!m_amountToRotate)
    return STATUS_ERROR;

  const T input = static_cast<T>(m_input);
  uint64_t shift_amount = static_cast<T>(*m_amountToRotate);
  uint64_t rightshift_val = (m_bitSize-shift_amount) % m_bitSize;

  uint64_t lower = input >> rightshift_val;
  uint64_t upper = input << shift_amount;
  m_output = static_cast<T>(upper | lower);
  return STATUS_OK;
}

See also Argument.

Member Function Documentation

ROLOperator::ROLOperator(const CDPPropertyBase &in)

Default constructs an instance of ROLOperator.

[override virtual] void ROLOperator::Configure(XMLPrimitive *operatorXML)

[override virtual] unsigned int ROLOperator::Process()

The content of this document is confidential information not to be published without the consent of CDP Technologies AS.

CDP Technologies AS, www.cdpstudio.com

Get started with CDP Studio today

Let us help you take your great ideas and turn them into the products your customer will love.

Try CDP Studio for free
Why CDP Studio?

CDP Technologies AS
Hundsværgata 8,
P.O. Box 144
6001 Ålesund, Norway

Tel: +47 990 80 900
E-mail: info@cdptech.com

Company

About CDP

Contact us

Services

Partners

Blog

Developers

Get started

User manuals

Support

Document download

Release notes

My account

Follow CDP

  • LinkedIn
  • YouTube
  • GitHub

© Copyright 2025 CDP Technologies. Privacy and cookie policy.

Return to top