diff options
| author | Marc André Tanner <mat@brain-dump.org> | 2015-10-16 12:36:47 +0200 |
|---|---|---|
| committer | Marc André Tanner <mat@brain-dump.org> | 2015-11-08 13:35:36 +0100 |
| commit | 039042f2e323c1f982f1de61b702c88fb33d6ccb (patch) | |
| tree | 67dea69de9462e0c27ea2a743b4c5d1798eaa057 /lexers/cuda.lua | |
| parent | b1ec60061623601ca6185a16d77c6c6c62135e95 (diff) | |
| download | vis-039042f2e323c1f982f1de61b702c88fb33d6ccb.tar.gz vis-039042f2e323c1f982f1de61b702c88fb33d6ccb.tar.xz | |
Import LPeg based lexers from Scintillua 3.6.1-1
These are Copyright (c) 2007-2015 Mitchell and released under the
MIT license.
Diffstat (limited to 'lexers/cuda.lua')
| -rw-r--r-- | lexers/cuda.lua | 92 |
1 files changed, 92 insertions, 0 deletions
diff --git a/lexers/cuda.lua b/lexers/cuda.lua new file mode 100644 index 0000000..0cf22e6 --- /dev/null +++ b/lexers/cuda.lua @@ -0,0 +1,92 @@ +-- Copyright 2006-2015 Mitchell mitchell.att.foicica.com. See LICENSE. +-- CUDA LPeg lexer. + +local l = require('lexer') +local token, word_match = l.token, l.word_match +local P, R, S = lpeg.P, lpeg.R, lpeg.S +local table = _G.table + +local M = {_NAME = 'cuda'} + +-- Whitespace +local ws = token(l.WHITESPACE, l.space^1) + +-- Keywords. +local keyword = token(l.KEYWORD, word_match{ + '__global__', '__host__', '__device__', '__constant__', '__shared__' +}) + +-- Functions. +local func = token(l.FUNCTION, word_match{ + -- Atom. + 'atomicAdd', 'atomicAnd', 'atomicCAS', 'atomicDec', 'atomicExch', 'atomicInc', + 'atomicMax', 'atomicMin', 'atomicOr', 'atomicSub', 'atomicXor', + -- Dev. + 'tex1D', 'tex1Dfetch', 'tex2D', '__float_as_int', '__int_as_float', + '__float2int_rn', '__float2int_rz', '__float2int_ru', '__float2int_rd', + '__float2uint_rn', '__float2uint_rz', '__float2uint_ru', '__float2uint_rd', + '__int2float_rn', '__int2float_rz', '__int2float_ru', '__int2float_rd', + '__uint2float_rn', '__uint2float_rz', '__uint2float_ru', '__uint2float_rd', + '__fadd_rz', '__fmul_rz', '__fdividef', '__mul24', '__umul24', '__mulhi', + '__umulhi', '__mul64hi', '__umul64hi', 'min', 'umin', 'fminf', 'fmin', 'max', + 'umax', 'fmaxf', 'fmax', 'abs', 'fabsf', 'fabs', 'sqrtf', 'sqrt', 'sinf', + '__sinf', 'sin', 'cosf', '__cosf', 'cos', 'sincosf', '__sincosf', 'expf', + '__expf', 'exp', 'logf', '__logf', 'log', + -- Runtime. + 'cudaBindTexture', 'cudaBindTextureToArray', 'cudaChooseDevice', + 'cudaConfigureCall', 'cudaCreateChannelDesc', 'cudaD3D10GetDevice', + 'cudaD3D10MapResources', 'cudaD3D10RegisterResource', + 'cudaD3D10ResourceGetMappedArray', 'cudaD3D10ResourceGetMappedPitch', + 'cudaD3D10ResourceGetMappedPointer', 'cudaD3D10ResourceGetMappedSize', + 'cudaD3D10ResourceGetSurfaceDimensions', 'cudaD3D10ResourceSetMapFlags', + 'cudaD3D10SetDirect3DDevice', 'cudaD3D10UnmapResources', + 'cudaD3D10UnregisterResource', 'cudaD3D9GetDevice', + 'cudaD3D9GetDirect3DDevice', 'cudaD3D9MapResources', + 'cudaD3D9RegisterResource', 'cudaD3D9ResourceGetMappedArray', + 'cudaD3D9ResourceGetMappedPitch', 'cudaD3D9ResourceGetMappedPointer', + 'cudaD3D9ResourceGetMappedSize', 'cudaD3D9ResourceGetSurfaceDimensions', + 'cudaD3D9ResourceSetMapFlags', 'cudaD3D9SetDirect3DDevice', + 'cudaD3D9UnmapResources', 'cudaD3D9UnregisterResource', 'cudaEventCreate', + 'cudaEventDestroy', 'cudaEventElapsedTime', 'cudaEventQuery', + 'cudaEventRecord', 'cudaEventSynchronize', 'cudaFree', 'cudaFreeArray', + 'cudaFreeHost', 'cudaGetChannelDesc', 'cudaGetDevice', 'cudaGetDeviceCount', + 'cudaGetDeviceProperties', 'cudaGetErrorString', 'cudaGetLastError', + 'cudaGetSymbolAddress', 'cudaGetSymbolSize', 'cudaGetTextureAlignmentOffset', + 'cudaGetTextureReference', 'cudaGLMapBufferObject', + 'cudaGLRegisterBufferObject', 'cudaGLSetGLDevice', 'cudaGLUnmapBufferObject', + 'cudaGLUnregisterBufferObject', 'cudaLaunch', 'cudaMalloc', 'cudaMalloc3D', + 'cudaMalloc3DArray', 'cudaMallocArray', 'cudaMallocHost', 'cudaMallocPitch', + 'cudaMemcpy', 'cudaMemcpy2D', 'cudaMemcpy2DArrayToArray', + 'cudaMemcpy2DFromArray', 'cudaMemcpy2DToArray', 'cudaMemcpy3D', + 'cudaMemcpyArrayToArray', 'cudaMemcpyFromArray', 'cudaMemcpyFromSymbol', + 'cudaMemcpyToArray', 'cudaMemcpyToSymbol', 'cudaMemset', 'cudaMemset2D', + 'cudaMemset3D', 'cudaSetDevice', 'cudaSetupArgument', 'cudaStreamCreate', + 'cudaStreamDestroy', 'cudaStreamQuery', 'cudaStreamSynchronize', + 'cudaThreadExit', 'cudaThreadSynchronize', 'cudaUnbindTexture' +}) + +-- Types. +local type = token(l.TYPE, word_match{ + 'uint', 'int1', 'uint1', 'int2', 'uint2', 'int3', 'uint3', 'int4', 'uint4', + 'float1', 'float2', 'float3', 'float4', 'char1', 'char2', 'char3', 'char4', + 'uchar1', 'uchar2', 'uchar3', 'uchar4', 'short1', 'short2', 'short3', + 'short4', 'dim1', 'dim2', 'dim3', 'dim4' +}) + +-- Variables. +local variable = token(l.VARIABLE, word_match{ + 'gridDim', 'blockIdx', 'blockDim', 'threadIdx' +}) + +-- Extend cpp lexer to include CUDA elements. +local cpp = l.load('cpp') +local _rules = cpp._rules +_rules[1] = {'whitespace', ws} +table.insert(_rules, 2, {'cuda_keyword', keyword}) +table.insert(_rules, 3, {'cuda_function', func}) +table.insert(_rules, 4, {'cuda_type', type}) +table.insert(_rules, 5, {'cuda_variable', variable}) +M._rules = _rules +M._foldsymbols = cpp._foldsymbols + +return M |
