Sign in to follow this  

Errors When Reading CG Source Files

This topic is 1851 days old which is more than the 365 day threshold we allow for new replies. Please post a new topic.

If you intended to correct an error in the post then please contact us.

Recommended Posts

Hello all!

I've been trying to load a CG shader from a file, however, I get the following errors:

[code]
basic_v.cg(11) : error C0000: syntax error, unexpected '.', expecting "::" at token "."
basic_v.cg(14) : error C0000: syntax error, unexpected ';', expecting "::" at token ";"
basic_v.cg(15) : error C1016: expression type incompatible with function return type
basic_v.cg(7) : error C1108: function "basic_v" has no statements
[/code]

when I load the source using the following code:
[code]
CGprogram vs = NULL;

vs = cgCreateProgramFromFile(this->context, CG_SOURCE,
        reinterpret_cast(e.vertexShaderFileName.c_str()), vertProfile,
        reinterpret_cast(e.vertexShaderEntryPoint.c_str()), profileOpts);
[/code]

where vertProfile is the optimal vertex profile (vs_5_0 on my computer) and profileOpts is an array of arguments to the compiler (neither of these variables are relevant to my problem).

What could cause this?  The vertex shader source is as follows:
[code]
struct VertexOutput
{
    float4 position : POSITION;
    float3 color : COLOR;
};

VertexOutput basic_v(float4 position : POSITION)
{
    VertexOutput out;
    
    out.position = position;
    out.color = float3(0.0f, 1.0f, 0.0f);
    
    return out;
}
[/code]

My Google searches haven't revealed any relevant information.

Thanks in advance for any help!

Share this post


Link to post
Share on other sites
I am not that familiar with CG as I'm a hlsl/glsl person, however is it possible that you are confusing the entry point? Just had a look at the wikipedia article, and it looks like CG requires an entry point named main:

[url="http://en.wikipedia.org/wiki/Cg_(programming_language)"]http://en.wikipedia.org/wiki/Cg_(programming_language)[/url]

Aimee

Share this post


Link to post
Share on other sites
[quote name='AmzBee' timestamp='1356050081' post='5013008']
is it possible that you are confusing the entry point? Just had a look at the wikipedia article, and it looks like CG requires an entry point named main
[/quote]

I tried changing the entry point to main, and I still got the same errors. I was doubtful about such a fix anyway, because if CG required an entry point named 'main' it would be pointless to specify an entry point when loading the shader.

Share this post


Link to post
Share on other sites
Cg doesn't require entry point to be named main..

Have you tried running it through cgc? Maybe it gives you some more to work with..

Share this post


Link to post
Share on other sites

Yes, 'out' is a reserved keyword, so I changed that in both my vertex shader and fragment shader.  Thanks for that, I feel stupid now.

 

Now the shader compiles correctly, however:

 

 

cgD3D11LoadProgram(vs, flags);
setVertexLayout(vs);  // vs is still null even after being set by cgCreateProgramFromFile, so setVertexLayout causes an Access Violation Exception

 

 

What would be causing this?  My log shows that both cgCreateProgramFromFile and cgD3D11LoadProgram were successful (that is, calling cgGetLastErrorString returns CG_NO_ERROR).

Edited by jburke4126

Share this post


Link to post
Share on other sites
What is the HRESULT returned by cgD3D11LoadProgram()?

According to the debugger, the value is 0x8876086c, but again, cgGetLastErrorString returns CG_NO_ERROR after cgD3D11LoadProgram. To me, that HRESULT is pretty meaningless, but I don't think cgD3D11LoadProgram() is the issue because according to the debugger the memory address of vs (CGprogram is a pointer type) after returned from cgCreateProgramFromFile is 0x0000000e, which I suspect would not be a valid pointer location.

Edit: sorry for the multiple edits; for some reason my full response wouldn't show up. Edited by jburke4126

Share this post


Link to post
Share on other sites

That return value is assigned to D3DERR_INVALIDCALL, so I'm not sure the cgGetLastError*() functions return behind the scenes D3D11 errors.

Have you tried creating a device with the debug layer? 

Share this post


Link to post
Share on other sites
Yes, the flags used for creating the device include D3D11_CREATE_DEVICE_DEBUG. Also, I did call cgD3D11SetDevice with a valid device polnter before I loaded the shader, so I have no idea what's going on.

Share this post


Link to post
Share on other sites

This topic is 1851 days old which is more than the 365 day threshold we allow for new replies. Please post a new topic.

If you intended to correct an error in the post then please contact us.

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

Sign in to follow this