go-api-bindings: github.com/Tinkerforge/go-api-bindings/red_brick Index | Files

package red_brick

import "github.com/Tinkerforge/go-api-bindings/red_brick"

Executes user programs and controls other Bricks/Bricklets standalone.

See also the documentation here: https://www.tinkerforge.com/en/doc/Software/Bricks/RED_Brick_Go.html.

Index

Package Files

red_brick.go

Constants

const DeviceDisplayName = "RED Brick"
const DeviceIdentifier = 17

type DirectoryEntryType Uses

type DirectoryEntryType uint8
const (
    DirectoryEntryTypeUnknown   DirectoryEntryType = 0
    DirectoryEntryTypeRegular   DirectoryEntryType = 1
    DirectoryEntryTypeDirectory DirectoryEntryType = 2
    DirectoryEntryTypeCharacter DirectoryEntryType = 3
    DirectoryEntryTypeBlock     DirectoryEntryType = 4
    DirectoryEntryTypeFIFO      DirectoryEntryType = 5
    DirectoryEntryTypeSymlink   DirectoryEntryType = 6
    DirectoryEntryTypeSocket    DirectoryEntryType = 7
)

type DirectoryFlag Uses

type DirectoryFlag uint32
const (
    DirectoryFlagRecursive DirectoryFlag = 1
    DirectoryFlagExclusive DirectoryFlag = 2
)

type ErrorCode Uses

type ErrorCode uint8
const (
    ErrorCodeSuccess           ErrorCode = 0
    ErrorCodeUnknownError      ErrorCode = 1
    ErrorCodeInvalidOperation  ErrorCode = 2
    ErrorCodeOperationAborted  ErrorCode = 3
    ErrorCodeInternalError     ErrorCode = 4
    ErrorCodeUnknownSessionId  ErrorCode = 5
    ErrorCodeNoFreeSessionId   ErrorCode = 6
    ErrorCodeUnknownObjectId   ErrorCode = 7
    ErrorCodeNoFreeObjectId    ErrorCode = 8
    ErrorCodeObjectIsLocked    ErrorCode = 9
    ErrorCodeNoMoreData        ErrorCode = 10
    ErrorCodeWrongListItemType ErrorCode = 11
    ErrorCodeProgramIsPurged   ErrorCode = 12
    ErrorCodeInvalidParameter  ErrorCode = 128
    ErrorCodeNoFreeMemory      ErrorCode = 129
    ErrorCodeNoFreeSpace       ErrorCode = 130
    ErrorCodeAccessDenied      ErrorCode = 121
    ErrorCodeAlreadyExists     ErrorCode = 132
    ErrorCodeDoesNotExist      ErrorCode = 133
    ErrorCodeInterrupted       ErrorCode = 134
    ErrorCodeIsDirectory       ErrorCode = 135
    ErrorCodeNotADirectory     ErrorCode = 136
    ErrorCodeWouldBlock        ErrorCode = 137
    ErrorCodeOverflow          ErrorCode = 138
    ErrorCodeBadFileDescriptor ErrorCode = 139
    ErrorCodeOutOfRange        ErrorCode = 140
    ErrorCodeNameTooLong       ErrorCode = 141
    ErrorCodeInvalidSeek       ErrorCode = 142
    ErrorCodeNotSupported      ErrorCode = 143
    ErrorCodeTooManyOpenFiles  ErrorCode = 144
)

type FileEvent Uses

type FileEvent uint16
const (
    FileEventReadable FileEvent = 1
    FileEventWritable FileEvent = 2
)

type FileFlag Uses

type FileFlag uint32
const (
    FileFlagReadOnly    FileFlag = 1
    FileFlagWriteOnly   FileFlag = 2
    FileFlagReadWrite   FileFlag = 4
    FileFlagAppend      FileFlag = 8
    FileFlagCreate      FileFlag = 16
    FileFlagExclusive   FileFlag = 32
    FileFlagNonBlocking FileFlag = 64
    FileFlagTruncate    FileFlag = 128
    FileFlagTemporary   FileFlag = 256
    FileFlagReplace     FileFlag = 512
)

type FileOrigin Uses

type FileOrigin uint8
const (
    FileOriginBeginning FileOrigin = 0
    FileOriginCurrent   FileOrigin = 1
    FileOriginEnd       FileOrigin = 2
)

type FilePermission Uses

type FilePermission uint16
const (
    FilePermissionUserAll       FilePermission = 448
    FilePermissionUserRead      FilePermission = 256
    FilePermissionUserWrite     FilePermission = 128
    FilePermissionUserExecute   FilePermission = 64
    FilePermissionGroupAll      FilePermission = 56
    FilePermissionGroupRead     FilePermission = 32
    FilePermissionGroupWrite    FilePermission = 16
    FilePermissionGroupExecute  FilePermission = 8
    FilePermissionOthersAll     FilePermission = 7
    FilePermissionOthersRead    FilePermission = 4
    FilePermissionOthersWrite   FilePermission = 2
    FilePermissionOthersExecute FilePermission = 1
)

type FileType Uses

type FileType uint8
const (
    FileTypeUnknown   FileType = 0
    FileTypeRegular   FileType = 1
    FileTypeDirectory FileType = 2
    FileTypeCharacter FileType = 3
    FileTypeBlock     FileType = 4
    FileTypeFIFO      FileType = 5
    FileTypeSymlink   FileType = 6
    FileTypeSocket    FileType = 7
    FileTypePipe      FileType = 8
)

type Function Uses

type Function uint8
const (
    FunctionCreateSession                        Function = 1
    FunctionExpireSession                        Function = 2
    FunctionExpireSessionUnchecked               Function = 3
    FunctionKeepSessionAlive                     Function = 4
    FunctionReleaseObject                        Function = 5
    FunctionReleaseObjectUnchecked               Function = 6
    FunctionAllocateString                       Function = 7
    FunctionTruncateString                       Function = 8
    FunctionGetStringLength                      Function = 9
    FunctionSetStringChunk                       Function = 10
    FunctionGetStringChunk                       Function = 11
    FunctionAllocateList                         Function = 12
    FunctionGetListLength                        Function = 13
    FunctionGetListItem                          Function = 14
    FunctionAppendToList                         Function = 15
    FunctionRemoveFromList                       Function = 16
    FunctionOpenFile                             Function = 17
    FunctionCreatePipe                           Function = 18
    FunctionGetFileInfo                          Function = 19
    FunctionReadFile                             Function = 20
    FunctionReadFileAsync                        Function = 21
    FunctionAbortAsyncFileRead                   Function = 22
    FunctionWriteFile                            Function = 23
    FunctionWriteFileUnchecked                   Function = 24
    FunctionWriteFileAsync                       Function = 25
    FunctionSetFilePosition                      Function = 26
    FunctionGetFilePosition                      Function = 27
    FunctionSetFileEvents                        Function = 28
    FunctionGetFileEvents                        Function = 29
    FunctionOpenDirectory                        Function = 33
    FunctionGetDirectoryName                     Function = 34
    FunctionGetNextDirectoryEntry                Function = 35
    FunctionRewindDirectory                      Function = 36
    FunctionCreateDirectory                      Function = 37
    FunctionGetProcesses                         Function = 38
    FunctionSpawnProcess                         Function = 39
    FunctionKillProcess                          Function = 40
    FunctionGetProcessCommand                    Function = 41
    FunctionGetProcessIdentity                   Function = 42
    FunctionGetProcessStdio                      Function = 43
    FunctionGetProcessState                      Function = 44
    FunctionGetPrograms                          Function = 46
    FunctionDefineProgram                        Function = 47
    FunctionPurgeProgram                         Function = 48
    FunctionGetProgramIdentifier                 Function = 49
    FunctionGetProgramRootDirectory              Function = 50
    FunctionSetProgramCommand                    Function = 51
    FunctionGetProgramCommand                    Function = 52
    FunctionSetProgramStdioRedirection           Function = 53
    FunctionGetProgramStdioRedirection           Function = 54
    FunctionSetProgramSchedule                   Function = 55
    FunctionGetProgramSchedule                   Function = 56
    FunctionGetProgramSchedulerState             Function = 57
    FunctionContinueProgramSchedule              Function = 58
    FunctionStartProgram                         Function = 59
    FunctionGetLastSpawnedProgramProcess         Function = 60
    FunctionGetCustomProgramOptionNames          Function = 61
    FunctionSetCustomProgramOptionValue          Function = 62
    FunctionGetCustomProgramOptionValue          Function = 63
    FunctionRemoveCustomProgramOption            Function = 64
    FunctionGetIdentity                          Function = 255
    FunctionCallbackAsyncFileRead                Function = 30
    FunctionCallbackAsyncFileWrite               Function = 31
    FunctionCallbackFileEventsOccurred           Function = 32
    FunctionCallbackProcessStateChanged          Function = 45
    FunctionCallbackProgramSchedulerStateChanged Function = 65
    FunctionCallbackProgramProcessSpawned        Function = 66
)

type ObjectType Uses

type ObjectType uint8
const (
    ObjectTypeString    ObjectType = 0
    ObjectTypeList      ObjectType = 1
    ObjectTypeFile      ObjectType = 2
    ObjectTypeDirectory ObjectType = 3
    ObjectTypeProcess   ObjectType = 4
    ObjectTypeProgram   ObjectType = 5
)

type PipeFlag Uses

type PipeFlag uint32
const (
    PipeFlagNonBlockingRead  PipeFlag = 1
    PipeFlagNonBlockingWrite PipeFlag = 2
)

type ProcessSignal Uses

type ProcessSignal uint8
const (
    ProcessSignalInterrupt ProcessSignal = 2
    ProcessSignalQuit      ProcessSignal = 3
    ProcessSignalAbort     ProcessSignal = 6
    ProcessSignalKill      ProcessSignal = 9
    ProcessSignalUser1     ProcessSignal = 10
    ProcessSignalUser2     ProcessSignal = 12
    ProcessSignalTerminate ProcessSignal = 15
    ProcessSignalContinue  ProcessSignal = 18
    ProcessSignalStop      ProcessSignal = 19
)

type ProcessState Uses

type ProcessState uint8
const (
    ProcessStateUnknown ProcessState = 0
    ProcessStateRunning ProcessState = 1
    ProcessStateError   ProcessState = 2
    ProcessStateExited  ProcessState = 3
    ProcessStateKilled  ProcessState = 4
    ProcessStateStopped ProcessState = 5
)

type ProgramSchedulerState Uses

type ProgramSchedulerState uint8
const (
    ProgramSchedulerStateStopped ProgramSchedulerState = 0
    ProgramSchedulerStateRunning ProgramSchedulerState = 1
)

type ProgramStartMode Uses

type ProgramStartMode uint8
const (
    ProgramStartModeNever    ProgramStartMode = 0
    ProgramStartModeAlways   ProgramStartMode = 1
    ProgramStartModeInterval ProgramStartMode = 2
    ProgramStartModeCron     ProgramStartMode = 3
)

type ProgramStdioRedirection Uses

type ProgramStdioRedirection uint8
const (
    ProgramStdioRedirectionDevNull       ProgramStdioRedirection = 0
    ProgramStdioRedirectionPipe          ProgramStdioRedirection = 1
    ProgramStdioRedirectionFile          ProgramStdioRedirection = 2
    ProgramStdioRedirectionIndividualLog ProgramStdioRedirection = 3
    ProgramStdioRedirectionContinuousLog ProgramStdioRedirection = 4
    ProgramStdioRedirectionStdout        ProgramStdioRedirection = 5
)

type REDBrick Uses

type REDBrick struct {
    // contains filtered or unexported fields
}

func New Uses

func New(uid string, ipcon *ipconnection.IPConnection) (REDBrick, error)

Creates an object with the unique device ID `uid`. This object can then be used after the IP Connection `ipcon` is connected.

func (*REDBrick) AbortAsyncFileRead Uses

func (device *REDBrick) AbortAsyncFileRead(fileId uint16) (errorCode ErrorCode, err error)

Aborts a ReadFileAsync operation in progress.

Returns the resulting error code.

On success the RegisterAsyncFileReadCallback callback will report *OperationAborted*.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) AllocateList Uses

func (device *REDBrick) AllocateList(lengthToReserve uint16, sessionId uint16) (errorCode ErrorCode, listId uint16, err error)

Allocates a new list object and reserves memory for “length_to_reserve“ items. Set “length_to_reserve“ to the number of items that should be stored in the list object.

Returns the object ID of the new list object and the resulting error code.

When a list object gets destroyed then the reference count of each object in the list object is decreased by one.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) AllocateString Uses

func (device *REDBrick) AllocateString(lengthToReserve uint32, buffer string, sessionId uint16) (errorCode ErrorCode, stringId uint16, err error)

Allocates a new string object, reserves “length_to_reserve“ bytes memory for it and sets up to the first 60 bytes. Set “length_to_reserve“ to the length of the string that should be stored in the string object.

Returns the object ID of the new string object and the resulting error code.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) AppendToList Uses

func (device *REDBrick) AppendToList(listId uint16, itemObjectId uint16) (errorCode ErrorCode, err error)

Appends an object to a list object and increases the reference count of the appended object by one.

Returns the resulting error code.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) ContinueProgramSchedule Uses

func (device *REDBrick) ContinueProgramSchedule(programId uint16) (errorCode ErrorCode, err error)

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) CreateDirectory Uses

func (device *REDBrick) CreateDirectory(nameStringId uint16, flags DirectoryFlag, permissions FilePermission, uid uint32, gid uint32) (errorCode ErrorCode, err error)

FIXME: name has to be absolute

Associated constants:

* DirectoryFlagRecursive
* DirectoryFlagExclusive
* FilePermissionUserAll
* FilePermissionUserRead
* FilePermissionUserWrite
* FilePermissionUserExecute
* FilePermissionGroupAll
* FilePermissionGroupRead
* FilePermissionGroupWrite
* FilePermissionGroupExecute
* FilePermissionOthersAll
* FilePermissionOthersRead
* FilePermissionOthersWrite
* FilePermissionOthersExecute
* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) CreatePipe Uses

func (device *REDBrick) CreatePipe(flags PipeFlag, length uint64, sessionId uint16) (errorCode ErrorCode, fileId uint16, err error)

Creates a new pipe and allocates a new file object for it.

The “flags“ parameter takes a ORed combination of the following possible pipe flags (in hexadecimal notation):

* NonBlockingRead = 0x0001 * NonBlockingWrite = 0x0002

The length of the pipe buffer can be specified with the “length“ parameter in bytes. If length is set to zero, then the default pipe buffer length is used.

Returns the object ID of the new file object and the resulting error code.

Associated constants:

* PipeFlagNonBlockingRead
* PipeFlagNonBlockingWrite
* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) CreateSession Uses

func (device *REDBrick) CreateSession(lifetime uint32) (errorCode ErrorCode, sessionId uint16, err error)

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) DefineProgram Uses

func (device *REDBrick) DefineProgram(identifierStringId uint16, sessionId uint16) (errorCode ErrorCode, programId uint16, err error)

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) DeregisterAsyncFileReadCallback Uses

func (device *REDBrick) DeregisterAsyncFileReadCallback(callbackID uint64)

Remove a registered Async File Read callback.

func (*REDBrick) DeregisterAsyncFileWriteCallback Uses

func (device *REDBrick) DeregisterAsyncFileWriteCallback(callbackID uint64)

Remove a registered Async File Write callback.

func (*REDBrick) DeregisterFileEventsOccurredCallback Uses

func (device *REDBrick) DeregisterFileEventsOccurredCallback(callbackID uint64)

Remove a registered File Events Occurred callback.

func (*REDBrick) DeregisterProcessStateChangedCallback Uses

func (device *REDBrick) DeregisterProcessStateChangedCallback(callbackID uint64)

Remove a registered Process State Changed callback.

func (*REDBrick) DeregisterProgramProcessSpawnedCallback Uses

func (device *REDBrick) DeregisterProgramProcessSpawnedCallback(callbackID uint64)

Remove a registered Program Process Spawned callback.

func (*REDBrick) DeregisterProgramSchedulerStateChangedCallback Uses

func (device *REDBrick) DeregisterProgramSchedulerStateChangedCallback(callbackID uint64)

Remove a registered Program Scheduler State Changed callback.

func (*REDBrick) ExpireSession Uses

func (device *REDBrick) ExpireSession(sessionId uint16) (errorCode ErrorCode, err error)

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) ExpireSessionUnchecked Uses

func (device *REDBrick) ExpireSessionUnchecked(sessionId uint16) (err error)

func (*REDBrick) GetAPIVersion Uses

func (device *REDBrick) GetAPIVersion() [3]uint8

Returns the version of the API definition (major, minor, revision) implemented by this API bindings. This is neither the release version of this API bindings nor does it tell you anything about the represented Brick or Bricklet.

func (*REDBrick) GetCustomProgramOptionNames Uses

func (device *REDBrick) GetCustomProgramOptionNames(programId uint16, sessionId uint16) (errorCode ErrorCode, namesListId uint16, err error)

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) GetCustomProgramOptionValue Uses

func (device *REDBrick) GetCustomProgramOptionValue(programId uint16, nameStringId uint16, sessionId uint16) (errorCode ErrorCode, valueStringId uint16, err error)

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) GetDirectoryName Uses

func (device *REDBrick) GetDirectoryName(directoryId uint16, sessionId uint16) (errorCode ErrorCode, nameStringId uint16, err error)

Returns the name of a directory object, as passed to OpenDirectory, and the resulting error code.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) GetFileEvents Uses

func (device *REDBrick) GetFileEvents(fileId uint16) (errorCode ErrorCode, events FileEvent, err error)

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles
* FileEventReadable
* FileEventWritable

func (*REDBrick) GetFileInfo Uses

func (device *REDBrick) GetFileInfo(fileId uint16, sessionId uint16) (errorCode ErrorCode, type_ FileType, nameStringId uint16, flags uint32, permissions FilePermission, uid uint32, gid uint32, length uint64, accessTimestamp uint64, modificationTimestamp uint64, statusChangeTimestamp uint64, err error)

Returns various information about a file and the resulting error code.

Possible file types are:

* Unknown = 0 * Regular = 1 * Directory = 2 * Character = 3 * Block = 4 * FIFO = 5 * Symlink = 6 * Socket = 7 * Pipe = 8

If the file type is *Pipe* then the returned name string object is invalid, because a pipe has no name. Otherwise the returned name string object was used to open or create the file object, as passed to OpenFile.

The returned flags were used to open or create the file object, as passed to OpenFile or CreatePipe. See the respective function for a list of possible file and pipe flags.

FIXME: everything except flags and length is invalid if file type is *Pipe*

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles
* FileTypeUnknown
* FileTypeRegular
* FileTypeDirectory
* FileTypeCharacter
* FileTypeBlock
* FileTypeFIFO
* FileTypeSymlink
* FileTypeSocket
* FileTypePipe
* FilePermissionUserAll
* FilePermissionUserRead
* FilePermissionUserWrite
* FilePermissionUserExecute
* FilePermissionGroupAll
* FilePermissionGroupRead
* FilePermissionGroupWrite
* FilePermissionGroupExecute
* FilePermissionOthersAll
* FilePermissionOthersRead
* FilePermissionOthersWrite
* FilePermissionOthersExecute

func (*REDBrick) GetFilePosition Uses

func (device *REDBrick) GetFilePosition(fileId uint16) (errorCode ErrorCode, position uint64, err error)

Returns the current seek position of a file object in bytes and returns the resulting error code.

If the file object was created by CreatePipe then it has no seek position and the error code *InvalidSeek* is returned.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) GetIdentity Uses

func (device *REDBrick) GetIdentity() (uid string, connectedUid string, position rune, hardwareVersion [3]uint8, firmwareVersion [3]uint8, deviceIdentifier uint16, err error)

Returns the UID, the UID where the Brick is connected to, the position, the hardware and firmware version as well as the device identifier.

The position can be '0'-'8' (stack position).

The device identifier numbers can be found `here <device_identifier>`. |device_identifier_constant|

func (*REDBrick) GetLastSpawnedProgramProcess Uses

func (device *REDBrick) GetLastSpawnedProgramProcess(programId uint16, sessionId uint16) (errorCode ErrorCode, processId uint16, timestamp uint64, err error)

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) GetListItem Uses

func (device *REDBrick) GetListItem(listId uint16, index uint16, sessionId uint16) (errorCode ErrorCode, itemObjectId uint16, type_ ObjectType, err error)

Returns the object ID and type of the object stored at “index“ in a list object and returns the resulting error code.

Possible object types are:

* String = 0 * List = 1 * File = 2 * Directory = 3 * Process = 4 * Program = 5

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles
* ObjectTypeString
* ObjectTypeList
* ObjectTypeFile
* ObjectTypeDirectory
* ObjectTypeProcess
* ObjectTypeProgram

func (*REDBrick) GetListLength Uses

func (device *REDBrick) GetListLength(listId uint16) (errorCode ErrorCode, length uint16, err error)

Returns the length of a list object in items and the resulting error code.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) GetNextDirectoryEntry Uses

func (device *REDBrick) GetNextDirectoryEntry(directoryId uint16, sessionId uint16) (errorCode ErrorCode, nameStringId uint16, type_ DirectoryEntryType, err error)

Returns the next entry in a directory object and the resulting error code.

If there is not next entry then error code *NoMoreData* is returned. To rewind a directory object call RewindDirectory.

Possible directory entry types are:

* Unknown = 0 * Regular = 1 * Directory = 2 * Character = 3 * Block = 4 * FIFO = 5 * Symlink = 6 * Socket = 7

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles
* DirectoryEntryTypeUnknown
* DirectoryEntryTypeRegular
* DirectoryEntryTypeDirectory
* DirectoryEntryTypeCharacter
* DirectoryEntryTypeBlock
* DirectoryEntryTypeFIFO
* DirectoryEntryTypeSymlink
* DirectoryEntryTypeSocket

func (*REDBrick) GetProcessCommand Uses

func (device *REDBrick) GetProcessCommand(processId uint16, sessionId uint16) (errorCode ErrorCode, executableStringId uint16, argumentsListId uint16, environmentListId uint16, workingDirectoryStringId uint16, err error)

Returns the executable, arguments, environment and working directory used to spawn a process object, as passed to SpawnProcess, and the resulting error code.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) GetProcessIdentity Uses

func (device *REDBrick) GetProcessIdentity(processId uint16) (errorCode ErrorCode, pid uint32, uid uint32, gid uint32, err error)

Returns the process ID and the user and group ID used to spawn a process object, as passed to SpawnProcess, and the resulting error code.

The process ID is only valid if the state is *Running* or *Stopped*, see GetProcessState.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) GetProcessState Uses

func (device *REDBrick) GetProcessState(processId uint16) (errorCode ErrorCode, state ProcessState, timestamp uint64, exitCode uint8, err error)

Returns the current state, timestamp and exit code of a process object, and the resulting error code.

Possible process states are:

* Unknown = 0 * Running = 1 * Error = 2 * Exited = 3 * Killed = 4 * Stopped = 5

The timestamp represents the UNIX time since when the process is in its current state.

The exit code is only valid if the state is *Error*, *Exited*, *Killed* or *Stopped* and has different meanings depending on the state:

* Error: error code for error occurred while spawning the process (see below) * Exited: exit status of the process * Killed: UNIX signal number used to kill the process * Stopped: UNIX signal number used to stop the process

Possible exit/error codes in *Error* state are:

* InternalError = 125 * CannotExecute = 126 * DoesNotExist = 127

The *CannotExecute* error can be caused by the executable being opened for writing.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles
* ProcessStateUnknown
* ProcessStateRunning
* ProcessStateError
* ProcessStateExited
* ProcessStateKilled
* ProcessStateStopped

func (*REDBrick) GetProcessStdio Uses

func (device *REDBrick) GetProcessStdio(processId uint16, sessionId uint16) (errorCode ErrorCode, stdinFileId uint16, stdoutFileId uint16, stderrFileId uint16, err error)

Returns the stdin, stdout and stderr files used to spawn a process object, as passed to SpawnProcess, and the resulting error code.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) GetProcesses Uses

func (device *REDBrick) GetProcesses(sessionId uint16) (errorCode ErrorCode, processesListId uint16, err error)

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) GetProgramCommand Uses

func (device *REDBrick) GetProgramCommand(programId uint16, sessionId uint16) (errorCode ErrorCode, executableStringId uint16, argumentsListId uint16, environmentListId uint16, workingDirectoryStringId uint16, err error)

FIXME: working directory is relative to <home>/programs/<identifier>/bin

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) GetProgramIdentifier Uses

func (device *REDBrick) GetProgramIdentifier(programId uint16, sessionId uint16) (errorCode ErrorCode, identifierStringId uint16, err error)

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) GetProgramRootDirectory Uses

func (device *REDBrick) GetProgramRootDirectory(programId uint16, sessionId uint16) (errorCode ErrorCode, rootDirectoryStringId uint16, err error)

FIXME: root directory is absolute: <home>/programs/<identifier>

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) GetProgramSchedule Uses

func (device *REDBrick) GetProgramSchedule(programId uint16, sessionId uint16) (errorCode ErrorCode, startMode ProgramStartMode, continueAfterError bool, startInterval uint32, startFieldsStringId uint16, err error)

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles
* ProgramStartModeNever
* ProgramStartModeAlways
* ProgramStartModeInterval
* ProgramStartModeCron

func (*REDBrick) GetProgramSchedulerState Uses

func (device *REDBrick) GetProgramSchedulerState(programId uint16, sessionId uint16) (errorCode ErrorCode, state ProgramSchedulerState, timestamp uint64, messageStringId uint16, err error)

FIXME: message is currently valid in error-occurred state only

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles
* ProgramSchedulerStateStopped
* ProgramSchedulerStateRunning

func (*REDBrick) GetProgramStdioRedirection Uses

func (device *REDBrick) GetProgramStdioRedirection(programId uint16, sessionId uint16) (errorCode ErrorCode, stdinRedirection ProgramStdioRedirection, stdinFileNameStringId uint16, stdoutRedirection ProgramStdioRedirection, stdoutFileNameStringId uint16, stderrRedirection ProgramStdioRedirection, stderrFileNameStringId uint16, err error)

FIXME: stdio file names are relative to <home>/programs/<identifier>/bin

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles
* ProgramStdioRedirectionDevNull
* ProgramStdioRedirectionPipe
* ProgramStdioRedirectionFile
* ProgramStdioRedirectionIndividualLog
* ProgramStdioRedirectionContinuousLog
* ProgramStdioRedirectionStdout

func (*REDBrick) GetPrograms Uses

func (device *REDBrick) GetPrograms(sessionId uint16) (errorCode ErrorCode, programsListId uint16, err error)

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) GetResponseExpected Uses

func (device *REDBrick) GetResponseExpected(functionID Function) (bool, error)

Returns the response expected flag for the function specified by the function ID parameter. It is true if the function is expected to send a response, false otherwise.

For getter functions this is enabled by default and cannot be disabled, because those functions will always send a response. For callback configuration functions it is enabled by default too, but can be disabled by SetResponseExpected. For setter functions it is disabled by default and can be enabled.

Enabling the response expected flag for a setter function allows to detect timeouts and other error conditions calls of this setter as well. The device will then send a response for this purpose. If this flag is disabled for a setter function then no response is send and errors are silently ignored, because they cannot be detected.

See SetResponseExpected for the list of function ID constants available for this function.

func (*REDBrick) GetStringChunk Uses

func (device *REDBrick) GetStringChunk(stringId uint16, offset uint32) (errorCode ErrorCode, buffer string, err error)

Returns a chunk up to 63 bytes from a string object beginning at “offset“ and returns the resulting error code.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) GetStringLength Uses

func (device *REDBrick) GetStringLength(stringId uint16) (errorCode ErrorCode, length uint32, err error)

Returns the length of a string object in bytes and the resulting error code.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) KeepSessionAlive Uses

func (device *REDBrick) KeepSessionAlive(sessionId uint16, lifetime uint32) (errorCode ErrorCode, err error)

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) KillProcess Uses

func (device *REDBrick) KillProcess(processId uint16, signal ProcessSignal) (errorCode ErrorCode, err error)

Sends a UNIX signal to a process object and returns the resulting error code.

Possible UNIX signals are:

* Interrupt = 2 * Quit = 3 * Abort = 6 * Kill = 9 * User1 = 10 * User2 = 12 * Terminate = 15 * Continue = 18 * Stop = 19

Associated constants:

* ProcessSignalInterrupt
* ProcessSignalQuit
* ProcessSignalAbort
* ProcessSignalKill
* ProcessSignalUser1
* ProcessSignalUser2
* ProcessSignalTerminate
* ProcessSignalContinue
* ProcessSignalStop
* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) OpenDirectory Uses

func (device *REDBrick) OpenDirectory(nameStringId uint16, sessionId uint16) (errorCode ErrorCode, directoryId uint16, err error)

Opens an existing directory and allocates a new directory object for it.

FIXME: name has to be absolute

The reference count of the name string object is increased by one. When the directory object is destroyed then the reference count of the name string object is decreased by one. Also the name string object is locked and cannot be modified while the directory object holds a reference to it.

Returns the object ID of the new directory object and the resulting error code.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) OpenFile Uses

func (device *REDBrick) OpenFile(nameStringId uint16, flags FileFlag, permissions FilePermission, uid uint32, gid uint32, sessionId uint16) (errorCode ErrorCode, fileId uint16, err error)

Opens an existing file or creates a new file and allocates a new file object for it.

FIXME: name has to be absolute

The reference count of the name string object is increased by one. When the file object gets destroyed then the reference count of the name string object is decreased by one. Also the name string object is locked and cannot be modified while the file object holds a reference to it.

The “flags“ parameter takes a ORed combination of the following possible file flags (in hexadecimal notation):

* ReadOnly = 0x0001 (O_RDONLY) * WriteOnly = 0x0002 (O_WRONLY) * ReadWrite = 0x0004 (O_RDWR) * Append = 0x0008 (O_APPEND) * Create = 0x0010 (O_CREAT) * Exclusive = 0x0020 (O_EXCL) * NonBlocking = 0x0040 (O_NONBLOCK) * Truncate = 0x0080 (O_TRUNC) * Temporary = 0x0100 * Replace = 0x0200

FIXME: explain *Temporary* and *Replace* flag

The “permissions“ parameter takes a ORed combination of the following possible file permissions (in octal notation) that match the common UNIX permission bits:

* UserRead = 00400 * UserWrite = 00200 * UserExecute = 00100 * GroupRead = 00040 * GroupWrite = 00020 * GroupExecute = 00010 * OthersRead = 00004 * OthersWrite = 00002 * OthersExecute = 00001

Returns the object ID of the new file object and the resulting error code.

Associated constants:

* FileFlagReadOnly
* FileFlagWriteOnly
* FileFlagReadWrite
* FileFlagAppend
* FileFlagCreate
* FileFlagExclusive
* FileFlagNonBlocking
* FileFlagTruncate
* FileFlagTemporary
* FileFlagReplace
* FilePermissionUserAll
* FilePermissionUserRead
* FilePermissionUserWrite
* FilePermissionUserExecute
* FilePermissionGroupAll
* FilePermissionGroupRead
* FilePermissionGroupWrite
* FilePermissionGroupExecute
* FilePermissionOthersAll
* FilePermissionOthersRead
* FilePermissionOthersWrite
* FilePermissionOthersExecute
* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) PurgeProgram Uses

func (device *REDBrick) PurgeProgram(programId uint16, cookie uint32) (errorCode ErrorCode, err error)

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) ReadFile Uses

func (device *REDBrick) ReadFile(fileId uint16, lengthToRead uint8) (errorCode ErrorCode, buffer [62]uint8, lengthRead uint8, err error)

Reads up to 62 bytes from a file object.

Returns the bytes read, the actual number of bytes read and the resulting error code.

If there is not data to be read, either because the file position reached end-of-file or because there is not data in the pipe, then zero bytes are returned.

If the file object was created by OpenFile without the *NonBlocking* flag or by CreatePipe without the *NonBlockingRead* flag then the error code *NotSupported* is returned.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) ReadFileAsync Uses

func (device *REDBrick) ReadFileAsync(fileId uint16, lengthToRead uint64) (err error)

Reads up to 2\ :sup:`63`\ - 1 bytes from a file object asynchronously.

Reports the bytes read (in 60 byte chunks), the actual number of bytes read and the resulting error code via the RegisterAsyncFileReadCallback callback.

If there is not data to be read, either because the file position reached end-of-file or because there is not data in the pipe, then zero bytes are reported.

If the file object was created by OpenFile without the *NonBlocking* flag or by CreatePipe without the *NonBlockingRead* flag then the error code *NotSupported* is reported via the RegisterAsyncFileReadCallback callback.

func (*REDBrick) RegisterAsyncFileReadCallback Uses

func (device *REDBrick) RegisterAsyncFileReadCallback(fn func(uint16, ErrorCode, [60]uint8, uint8)) uint64

This callback reports the result of a call to the ReadFileAsync function.

func (*REDBrick) RegisterAsyncFileWriteCallback Uses

func (device *REDBrick) RegisterAsyncFileWriteCallback(fn func(uint16, ErrorCode, uint8)) uint64

This callback reports the result of a call to the WriteFileAsync function.

func (*REDBrick) RegisterFileEventsOccurredCallback Uses

func (device *REDBrick) RegisterFileEventsOccurredCallback(fn func(uint16, FileEvent)) uint64

func (*REDBrick) RegisterProcessStateChangedCallback Uses

func (device *REDBrick) RegisterProcessStateChangedCallback(fn func(uint16, ProcessState, uint64, uint8)) uint64

func (*REDBrick) RegisterProgramProcessSpawnedCallback Uses

func (device *REDBrick) RegisterProgramProcessSpawnedCallback(fn func(uint16)) uint64

func (*REDBrick) RegisterProgramSchedulerStateChangedCallback Uses

func (device *REDBrick) RegisterProgramSchedulerStateChangedCallback(fn func(uint16)) uint64

func (*REDBrick) ReleaseObject Uses

func (device *REDBrick) ReleaseObject(objectId uint16, sessionId uint16) (errorCode ErrorCode, err error)

Decreases the reference count of an object by one and returns the resulting error code. If the reference count reaches zero the object gets destroyed.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) ReleaseObjectUnchecked Uses

func (device *REDBrick) ReleaseObjectUnchecked(objectId uint16, sessionId uint16) (err error)

func (*REDBrick) RemoveCustomProgramOption Uses

func (device *REDBrick) RemoveCustomProgramOption(programId uint16, nameStringId uint16) (errorCode ErrorCode, err error)

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) RemoveFromList Uses

func (device *REDBrick) RemoveFromList(listId uint16, index uint16) (errorCode ErrorCode, err error)

Removes the object stored at “index“ from a list object and decreases the reference count of the removed object by one.

Returns the resulting error code.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) RewindDirectory Uses

func (device *REDBrick) RewindDirectory(directoryId uint16) (errorCode ErrorCode, err error)

Rewinds a directory object and returns the resulting error code.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) SetCustomProgramOptionValue Uses

func (device *REDBrick) SetCustomProgramOptionValue(programId uint16, nameStringId uint16, valueStringId uint16) (errorCode ErrorCode, err error)

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) SetFileEvents Uses

func (device *REDBrick) SetFileEvents(fileId uint16, events FileEvent) (errorCode ErrorCode, err error)

Associated constants:

* FileEventReadable
* FileEventWritable
* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) SetFilePosition Uses

func (device *REDBrick) SetFilePosition(fileId uint16, offset int64, origin FileOrigin) (errorCode ErrorCode, position uint64, err error)

Set the current seek position of a file object in bytes relative to “origin“.

Possible file origins are:

* Beginning = 0 * Current = 1 * End = 2

Returns the resulting absolute seek position and error code.

If the file object was created by CreatePipe then it has no seek position and the error code *InvalidSeek* is returned.

Associated constants:

* FileOriginBeginning
* FileOriginCurrent
* FileOriginEnd
* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) SetProgramCommand Uses

func (device *REDBrick) SetProgramCommand(programId uint16, executableStringId uint16, argumentsListId uint16, environmentListId uint16, workingDirectoryStringId uint16) (errorCode ErrorCode, err error)

FIXME: working directory is relative to <home>/programs/<identifier>/bin

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) SetProgramSchedule Uses

func (device *REDBrick) SetProgramSchedule(programId uint16, startMode ProgramStartMode, continueAfterError bool, startInterval uint32, startFieldsStringId uint16) (errorCode ErrorCode, err error)

Associated constants:

* ProgramStartModeNever
* ProgramStartModeAlways
* ProgramStartModeInterval
* ProgramStartModeCron
* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) SetProgramStdioRedirection Uses

func (device *REDBrick) SetProgramStdioRedirection(programId uint16, stdinRedirection ProgramStdioRedirection, stdinFileNameStringId uint16, stdoutRedirection ProgramStdioRedirection, stdoutFileNameStringId uint16, stderrRedirection ProgramStdioRedirection, stderrFileNameStringId uint16) (errorCode ErrorCode, err error)

FIXME: stdio file names are relative to <home>/programs/<identifier>/bin

Associated constants:

* ProgramStdioRedirectionDevNull
* ProgramStdioRedirectionPipe
* ProgramStdioRedirectionFile
* ProgramStdioRedirectionIndividualLog
* ProgramStdioRedirectionContinuousLog
* ProgramStdioRedirectionStdout
* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) SetResponseExpected Uses

func (device *REDBrick) SetResponseExpected(functionID Function, responseExpected bool) error

Changes the response expected flag of the function specified by the function ID parameter. This flag can only be changed for setter (default value: false) and callback configuration functions (default value: true). For getter functions it is always enabled.

Enabling the response expected flag for a setter function allows to detect timeouts and other error conditions calls of this setter as well. The device will then send a response for this purpose. If this flag is disabled for a setter function then no response is send and errors are silently ignored, because they cannot be detected.

func (*REDBrick) SetResponseExpectedAll Uses

func (device *REDBrick) SetResponseExpectedAll(responseExpected bool)

Changes the response expected flag for all setter and callback configuration functions of this device at once.

func (*REDBrick) SetStringChunk Uses

func (device *REDBrick) SetStringChunk(stringId uint16, offset uint32, buffer string) (errorCode ErrorCode, err error)

Sets a chunk of up to 58 bytes in a string object beginning at “offset“.

Returns the resulting error code.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) SpawnProcess Uses

func (device *REDBrick) SpawnProcess(executableStringId uint16, argumentsListId uint16, environmentListId uint16, workingDirectoryStringId uint16, uid uint32, gid uint32, stdinFileId uint16, stdoutFileId uint16, stderrFileId uint16, sessionId uint16) (errorCode ErrorCode, processId uint16, err error)

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) StartProgram Uses

func (device *REDBrick) StartProgram(programId uint16) (errorCode ErrorCode, err error)

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) TruncateString Uses

func (device *REDBrick) TruncateString(stringId uint16, length uint32) (errorCode ErrorCode, err error)

Truncates a string object to “length“ bytes and returns the resulting error code.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) WriteFile Uses

func (device *REDBrick) WriteFile(fileId uint16, buffer [61]uint8, lengthToWrite uint8) (errorCode ErrorCode, lengthWritten uint8, err error)

Writes up to 61 bytes to a file object.

Returns the actual number of bytes written and the resulting error code.

If the file object was created by OpenFile without the *NonBlocking* flag or by CreatePipe without the *NonBlockingWrite* flag then the error code *NotSupported* is returned.

Associated constants:

* ErrorCodeSuccess
* ErrorCodeUnknownError
* ErrorCodeInvalidOperation
* ErrorCodeOperationAborted
* ErrorCodeInternalError
* ErrorCodeUnknownSessionId
* ErrorCodeNoFreeSessionId
* ErrorCodeUnknownObjectId
* ErrorCodeNoFreeObjectId
* ErrorCodeObjectIsLocked
* ErrorCodeNoMoreData
* ErrorCodeWrongListItemType
* ErrorCodeProgramIsPurged
* ErrorCodeInvalidParameter
* ErrorCodeNoFreeMemory
* ErrorCodeNoFreeSpace
* ErrorCodeAccessDenied
* ErrorCodeAlreadyExists
* ErrorCodeDoesNotExist
* ErrorCodeInterrupted
* ErrorCodeIsDirectory
* ErrorCodeNotADirectory
* ErrorCodeWouldBlock
* ErrorCodeOverflow
* ErrorCodeBadFileDescriptor
* ErrorCodeOutOfRange
* ErrorCodeNameTooLong
* ErrorCodeInvalidSeek
* ErrorCodeNotSupported
* ErrorCodeTooManyOpenFiles

func (*REDBrick) WriteFileAsync Uses

func (device *REDBrick) WriteFileAsync(fileId uint16, buffer [61]uint8, lengthToWrite uint8) (err error)

Writes up to 61 bytes to a file object.

Reports the actual number of bytes written and the resulting error code via the RegisterAsyncFileWriteCallback callback.

If the file object was created by OpenFile without the *NonBlocking* flag or by CreatePipe without the *NonBlockingWrite* flag then the error code *NotSupported* is reported via the RegisterAsyncFileWriteCallback callback.

func (*REDBrick) WriteFileUnchecked Uses

func (device *REDBrick) WriteFileUnchecked(fileId uint16, buffer [61]uint8, lengthToWrite uint8) (err error)

Writes up to 61 bytes to a file object.

Does neither report the actual number of bytes written nor the resulting error code.

If the file object was created by OpenFile without the *NonBlocking* flag or by CreatePipe without the *NonBlockingWrite* flag then the write operation will fail silently.

Package red_brick imports 4 packages (graph). Updated 2019-02-11. Refresh now. Tools for package owners.