avp1.0_impl.cpp 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. #include "nvparse_errors.h"
  2. #include "nvparse_externs.h"
  3. #include <string.h>
  4. #include <string>
  5. #include <ctype.h>
  6. #if defined(__APPLE__) && defined(__GNUC__)
  7. #include <OpenGL/glu.h>
  8. #else
  9. #include <GL/glu.h>
  10. #endif
  11. using namespace std;
  12. namespace
  13. {
  14. void LoadProgram( GLenum target, GLuint id, char *instring );
  15. void StrToUpper(char * string);
  16. GLint vpid;
  17. }
  18. bool is_avp10(const char * s)
  19. {
  20. return ! strncmp(s, "!!ARBvp1.0", 10);
  21. }
  22. bool avp10_init(char * s)
  23. {
  24. static bool avpinit = false;
  25. if (avpinit == false )
  26. {
  27. /*
  28. if(! glh_init_extensions("GL_ARB_vertex_program"))
  29. {
  30. errors.set("unable to initialize GL_ARB_vertex_program");
  31. return false;
  32. }
  33. else
  34. {
  35. */
  36. avpinit = true;
  37. /*
  38. }
  39. */
  40. }
  41. errors.reset();
  42. line_number = 1;
  43. myin = s;
  44. glGetProgramivARB(GL_VERTEX_PROGRAM_ARB, GL_PROGRAM_BINDING_ARB, &vpid);
  45. if ( vpid == 0 )
  46. {
  47. char str[128];
  48. sprintf( str, "No vertex program id bound for nvparse() invocation. Bound id = %d\n", (int)vpid );
  49. errors.set( str );
  50. return false;
  51. }
  52. return true;
  53. }
  54. int avp10_parse()
  55. {
  56. LoadProgram( GL_VERTEX_PROGRAM_ARB, vpid, myin );
  57. return 0;
  58. }
  59. namespace
  60. {
  61. //.----------------------------------------------------------------------------.
  62. //| Function : LoadProgram |
  63. //| Description: Load a program into GL, and report any errors encountered. |
  64. //.----------------------------------------------------------------------------.
  65. void LoadProgram( GLenum target, GLuint id, char *instring )
  66. {
  67. GLint errPos;
  68. GLenum errCode;
  69. const GLubyte *errString;
  70. int len = strlen(instring);
  71. glBindProgramARB(target, id);
  72. errCode = glGetError();
  73. if (errCode == GL_INVALID_OPERATION)
  74. errString = gluErrorString(errCode);
  75. glProgramStringARB(target,
  76. GL_PROGRAM_FORMAT_ASCII_ARB,
  77. len,
  78. instring);
  79. if ((errCode = glGetError()) != GL_NO_ERROR)
  80. {
  81. errString = gluErrorString(errCode);
  82. glGetIntegerv(GL_PROGRAM_ERROR_POSITION_ARB, &errPos);
  83. if (errPos == -1)
  84. return;
  85. int nlines = 1;
  86. int nchar = 1;
  87. int i;
  88. for (i = 0; i < errPos; i++)
  89. {
  90. if (instring[i] == '\n')
  91. {
  92. nlines++;
  93. nchar = 1;
  94. }
  95. else
  96. {
  97. nchar++;
  98. }
  99. }
  100. int start = 0;
  101. int end = 0;
  102. int flag = ((instring[errPos]==';') | (instring[errPos-1]==';')) ? 1 : 0;
  103. for (i = errPos; i >= 0; i--)
  104. {
  105. start = i;
  106. if (flag && (start >= errPos-1))
  107. continue;
  108. if (instring[i] == ';')
  109. {
  110. if (!flag)
  111. {
  112. start = i+1;
  113. if (instring[start] == '\n')
  114. start++;
  115. }
  116. break;
  117. }
  118. }
  119. for (i = errPos; i < len; i++)
  120. {
  121. end = i;
  122. if (instring[i] == ';' && end > start)
  123. {
  124. break;
  125. }
  126. }
  127. if (errPos - start > 30)
  128. {
  129. start = errPos - 30;
  130. }
  131. if (end - errPos > 30)
  132. {
  133. end = errPos + 30;
  134. }
  135. char substring[96];
  136. memset( substring, 0, 96 );
  137. strncpy( substring, &(instring[start]), end-start+1 );
  138. char str[256];
  139. sprintf(str, "error at line %d character %d\n\"%s\"\n", nlines, nchar, substring);
  140. int width = errPos-start;
  141. for (i = 0; i < width; i++)
  142. {
  143. strcat(str, " ");
  144. }
  145. strcat(str, "|\n");
  146. for (i = 0; i < width; i++)
  147. {
  148. strcat(str, " ");
  149. }
  150. strcat(str, "^\n");
  151. errors.set(str);
  152. }
  153. }
  154. //.----------------------------------------------------------------------------.
  155. //| Function : StrToUpper |
  156. //| Description: Converts all lowercase chars in a string to uppercase. |
  157. //.----------------------------------------------------------------------------.
  158. void StrToUpper(char *string)
  159. {
  160. for (unsigned int i = 0; i < strlen(string); i++)
  161. string[i] = toupper(string[i]);
  162. }
  163. }