====== OSA : OS_Smsg_Send_Now ======
<color blue>**OS_Smsg_Send_Now (smsg, smessage)**</color>\\ 
<color blue>**OS_Smsg_Send_I (smsg, smessage)**</color>\\ 
=== ===



Отправляем короткое сообщение //smsg// с содержимым //smessage//. Если такое сообщение уже активно, то оно затирается новым.

=== Разрешен вызов: ===
Везде


=== Параметры функции: ===
{| class = "fpl"
|-
|//''smsg''//
|Дескриптор короткого сообщения. Переменная типа ##[[osa:ref:description:data_types#OST_SMSG|OST_SMSG]]##
|-
|//''smessage''//
|Тело отправляемого сообщения (тип ##[[osa:ref:description:data_types#OST_SMSG|OST_SMSG]]##)
|}


=== Возвращаемое значение: ===
{| class = "fpl"
|-
|//''bEventError''//
|Если перед отправкой сообщение было активно (занято), то сервис ##[[osa:ref:allservices:OS_IsEventError|OS_IsEventError]]## возвратит **true**
|}


=== Пример вызова: ===
<code cpp>
OST_SMSG button_smsg;

void Task (void)
{
    static char PrevPORTB;
    char temp;
    for (;;) {
        OS_Yield();
        temp = PORTB ^ PrevPORTB;
        if (temp != 0) OS_Smsg_Send_Now (button_smsg, (OST_SMSG)temp); // Отправляем нажатую кнопку
        PrevPORTB = PORTB;
        /*...*/
    }
}
</code>


=== Old style name ===
<color gray>**OS_SendSMsgNoWait**</color>\\ 









=== См. также ===
  * [[osa:ref:allservices:OS_Smsg_Create|OS_Smsg_Create]]

  * [[osa:ref:allservices:OS_Smsg_Send|OS_Smsg_Send]]
  * [[osa:ref:allservices:OS_Smsg_Send_TO|OS_Smsg_Send_TO]]


  * [[osa:ref:allservices:OS_Smsg_Check|OS_Smsg_Check]]
  * [[osa:ref:allservices:OS_Smsg_Accept|OS_Smsg_Accept]]

  * [[osa:ref:allservices:OS_Smsg_Wait|OS_Smsg_Wait]]
  * [[osa:ref:allservices:OS_Smsg_Wait_TO|OS_Smsg_Wait_TO]]

----
  * [[osa:ref:services:alphabetical|Алфавитный указатель]]
  * [[osa:ref:services:brieflist|Все сервисы]]
~~UP~~