1. C++ / Говнокод #17115

    +53

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    53. 53
    54. 54
    55. 55
    56. 56
    57. 57
    58. 58
    59. 59
    60. 60
    61. 61
    62. 62
    63. 63
    64. 64
    65. 65
    66. 66
    67. 67
    68. 68
    69. 69
    70. 70
    71. 71
    72. 72
    73. 73
    74. 74
    75. 75
    76. 76
    77. 77
    78. 78
    79. 79
    int lenNameTrack = byteArrAudioFile->size() - 128 + 3,
          lenAutorTrack =             byteArrAudioFile->size() - 128 + 3 + 30,
          lenAlbumTrack =            byteArrAudioFile->size() - 128 + 3 + 30 + 30,
          lenYearTrack =               byteArrAudioFile->size() - 128 + 3 + 30 + 30 + 30,
          lenCommentTrack =      byteArrAudioFile->size() - 128 + 3 + 30 + 30 + 30 + 4,
          lenFlagNumberTrack =   byteArrAudioFile->size() - 128 + 3 + 30 + 30 + 30 + 4 + 28,
          lenNumberTrack =         byteArrAudioFile->size() - 128 + 3 + 30 + 30 + 30 + 4 + 28 + 1,
          lenIdGenreTrack =         byteArrAudioFile->size() - 128 + 3 + 30 + 30 + 30 + 4 + 28 + 1 + 1;
    
                      for(int i = byteArrAudioFile->size() - 128+3; i <= byteArrAudioFile->size(); i++)
                      {
                          if(i == lenAutorTrack) //Названние трэка
                              for(int j = lenNameTrack, k = 0;   j < lenAutorTrack; ++j)
                              {
                                  if( (int) byteArrAudioFile->at(j) == 0)
                                      break;
                                  if( ((int) byteArrAudioFile->at(j)) < 0 )
                                      ID3v1.title.append( toUnicod( (int) byteArrAudioFile->at(j) ) );
                                  else ID3v1.title.append(  byteArrAudioFile->at(j) );
                              }
                          if(i == lenAlbumTrack) //Исполнитель
                              for(int j = lenAutorTrack; j < lenAlbumTrack; ++j)
                              {
                                  if( (int) byteArrAudioFile->at(j) == 0)
                                      break;
                                  if( ((int) byteArrAudioFile->at(j)) < 0 )
                                      ID3v1.autor.append( toUnicod( (int) byteArrAudioFile->at(j) ) );
                                  else ID3v1.autor.append(  byteArrAudioFile->at(j) );
                              }
                          if(i == lenYearTrack) //Альбом
                              for(int j = lenAlbumTrack; j < lenYearTrack; ++j)
                              {
                                  if( (int) byteArrAudioFile->at(j) == 0)
                                      break;
                                  if( ((int) byteArrAudioFile->at(j)) < 0 )
                                      ID3v1.album.append( toUnicod( (int) byteArrAudioFile->at(j) ) );
                                  else ID3v1.album.append(  byteArrAudioFile->at(j) );
                              }
                          if(i == lenCommentTrack) //Год
                              for(int j = lenYearTrack; j < lenCommentTrack; ++j)
                              {
                                  if( (int) byteArrAudioFile->at(j) == 0)
                                      break;
                                  ID3v1.year.append(byteArrAudioFile->at(j));
                              }
                          if(i == lenFlagNumberTrack) //Комментарий
                              for(int j = lenCommentTrack; j < lenFlagNumberTrack; ++j)
                              {
                                  if( (int) byteArrAudioFile->at(j) == 0)
                                      break;
                                  if( ((int) byteArrAudioFile->at(j)) < 0 )
                                      ID3v1.comment.append( toUnicod( (int) byteArrAudioFile->at(j) ) );
                                  else ID3v1.comment.append(  byteArrAudioFile->at(j) );
                              }
                          if(i == lenNumberTrack) //Если есть номер трэка то установлен нулевой байт
                              for(int j = lenFlagNumberTrack; j < lenNumberTrack; ++j)
                              {
                                  if( (int) byteArrAudioFile->at(j) == 0)
                                      break;
                                  ID3v1.flagNumberTrack.append(byteArrAudioFile->at(j));
                              }
                          if(i == lenIdGenreTrack) //Номер трэка
                              for(int j = lenNumberTrack; j < lenIdGenreTrack; ++j)
                              {
                                  if( (int) byteArrAudioFile->at(j) == 0)
                                      break;
                                  ID3v1.numberTrack.append(byteArrAudioFile->at(j));
                              }
                          if(i == lenIdGenreTrack + 1) //Индетификатор жанра
                          {
                              for(int j = lenIdGenreTrack; j <= lenIdGenreTrack; ++j)
                              {
                                  if( (int) byteArrAudioFile->at(j) == 0)
                                      break;
                                  ID3v1.genre.append( QString::number( (int) byteArrAudioFile->at(j)));
                              }
                              ID3v1.genre.append(genreList(ID3v1.genre.toInt()));
                          }
                      }

    Парсинг ID3v1 тегов

    ConstantineVL, 16 Ноября 2014

    Комментарии (0)
  2. C++ / Говнокод #17113

    +53

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    53. 53
    54. 54
    55. 55
    56. 56
    57. 57
    58. 58
    59. 59
    60. 60
    61. 61
    62. 62
    63. 63
    64. 64
    65. 65
    66. 66
    67. 67
    68. 68
    69. 69
    70. 70
    71. 71
    72. 72
    73. 73
    74. 74
    75. 75
    76. 76
    77. 77
    78. 78
    79. 79
    80. 80
    81. 81
    82. 82
    83. 83
    84. 84
    85. 85
    86. 86
    87. 87
    88. 88
    89. 89
    90. 90
    91. 91
    92. 92
    93. 93
    94. 94
    95. 95
    96. 96
    97. 97
    98. 98
    99. 99
    void zxc()
    {
    	DWORD i = 256, j, k, l, nTry, N = 0;
    	ULONG_PTR a = 0, b = 0, aa = 0, bb = 0;
    	_PTE* pte = PXE(256);
    	do 
    	{
    		if (pte->Valid)
    		{
    			pte->Owner = 1;
    			__try
    			{
    				j = 0, nTry = 0;
    
    				_PTE* pte = PPE(i, 0);
    
    				do 
    				{
    					if (pte->Valid)
    					{
    						pte->Owner = 1;
    
    						__try
    						{
    							k = 0, nTry = 0;
    
    							_PTE* pte = PDE(i, j, 0);
    
    							do 
    							{
    								if (pte->Valid)
    								{
    									pte->Owner = 1;
    
    									if (pte->LargePage)
    									{
    										b = LA(i, j, k, 0);
    
    										if (!a)
    										{
    											a = b;
    										}
    										continue;
    									}
    									__try
    									{
    										l = 0, nTry = 0;
    
    										_PTE* pte = PTE(i, j, k, 0);
    
    										do 
    										{
    											b = LA(i, j, k, l);
    
    											if (pte->Valid)
    											{
    												pte->Owner = 1;
    
    												if (!a)
    												{
    													a = b;
    												}
    											}
    											else
    											{
    												if (!pte->Prototype && pte->Protection && pte->Protection < MM_NOCACHE)
    												{
    												}
    												else if (a)
    												{
    													aa = a, bb = b, a = 0, N++;
    												}
    											}
    										} while (nTry = 0, ++pte, ++l < PTE_PER_PAGE);
    									}
    									__except(OnPteException(pte, nTry)){}
    								}
    								else if (a)
    								{
    									aa = a, bb = LA(i, j, k, 0), a = 0, N++;
    								}
    							} while (nTry = 0, ++pte, ++k < PDE_PER_PAGE);
    						}
    						__except(OnPteException(pte, nTry)){}
    					}
    					else if (a)
    					{
    						aa = a, bb = LA(i, j, 0, 0), a = 0, N++;
    					}
    				} while (nTry = 0, ++pte, ++j < PPE_PER_PAGE);
    			}
    			__except(OnPteException(pte, nTry)){}
    		}
    		else if (a)
    		{
    			aa = a, bb = LA(i, 0, 0, 0), a = 0, N++;
    		}
    	} while (++pte, ++i < PXE_PER_PAGE);
    }

    #define LA(i, j, k, l) (0xFFFF000000000000 + \
    ((ULONG_PTR)(i) << PXI_SHIFT) + \
    ((ULONG_PTR)(j) << PPI_SHIFT) + \
    ((ULONG_PTR)(k) << PDI_SHIFT) + \
    ((ULONG_PTR)(l) << PTI_SHIFT))

    zhukas, 15 Ноября 2014

    Комментарии (0)
  3. C++ / Говнокод #17112

    +51

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    53. 53
    54. 54
    55. 55
    56. 56
    57. 57
    58. 58
    59. 59
    60. 60
    61. 61
    62. 62
    63. 63
    64. 64
    65. 65
    66. 66
    67. 67
    68. 68
    69. 69
    70. 70
    71. 71
    72. 72
    73. 73
    74. 74
    75. 75
    76. 76
    77. 77
    78. 78
    79. 79
    80. 80
    81. 81
    82. 82
    83. 83
    84. 84
    85. 85
    86. 86
    87. 87
    88. 88
    89. 89
    90. 90
    91. 91
    92. 92
    93. 93
    94. 94
    95. 95
    96. 96
    97. 97
    98. 98
    99. 99
    DWORD getDirectoryIndex()
    	{
    		STATIC_OBJECT_ATTRIBUTES(oa, "\\");
    		HANDLE hFile;
    		DWORD ObjectTypeIndex = 0;
    
    		if (0 <= ZwOpenDirectoryObject(&hFile, DIRECTORY_QUERY, &oa))
    		{
    			NTSTATUS status;
    			PVOID buf = 0, stack = alloca(guz);
    			DWORD cb = 0, rcb = 0x10000;
    
    			do 
    			{
    				if (cb < rcb) cb = RtlPointerToOffset(buf = alloca(rcb - cb), stack);
    
    				if (0 <= (status = ZwQuerySystemInformation(SystemExtendedHanfleInformation, buf, cb, &rcb)))
    				{
    					PSYSTEM_HANDLE_INFORMATION_EX pshti = (PSYSTEM_HANDLE_INFORMATION_EX)buf;
    
    					if (ULONG NumberOfHandles = (ULONG)pshti->NumberOfHandles)
    					{
    						PSYSTEM_HANDLE_TABLE_ENTRY_INFO_EX Handles = pshti->Handles;
    
    						ULONG_PTR UniqueProcessId = GetCurrentProcessId();
    						do 
    						{
    							if (Handles->UniqueProcessId == UniqueProcessId && Handles->HandleValue == (ULONG_PTR)hFile)
    							{
    								ObjectTypeIndex = Handles->ObjectTypeIndex;
    								break;
    							}
    
    						} while (Handles++, --NumberOfHandles);
    					}
    				}
    			} while (STATUS_INFO_LENGTH_MISMATCH == status);
    
    			ZwClose(hFile);
    		}
    
    		return ObjectTypeIndex;
    	}
    
    	ZOBJECT_ALL_TYPES_INFORMATION()
    	{
    		_TypeInformation = 0, _NumberOfTypes = 0;
    
    		if (DWORD DirectoryTypeIndex = getDirectoryIndex())
    		{
    			PVOID stack = alloca(guz);
    			OBJECT_ALL_TYPES_INFORMATION* poati = 0;
    			DWORD cb = 0, rcb = 0x2000;
    			NTSTATUS status;
    			do 
    			{
    				if (cb < rcb)
    				{
    					cb = RtlPointerToOffset(poati = (OBJECT_ALL_TYPES_INFORMATION*)alloca(rcb - cb), stack);
    				}
    
    				if (0 <= (status = ZwQueryObject(0, ObjectAllTypeInformation, poati, cb, &rcb)))
    				{
    					if (DWORD NumberOfTypes = poati->NumberOfTypes)
    					{
    						if (OBJECT_TYPE_INFORMATION* TypeInformation = (OBJECT_TYPE_INFORMATION*)LocalAlloc(0, rcb))
    						{
    							_NumberOfTypes = NumberOfTypes;
    							_TypeInformation = TypeInformation;
    
    							STATIC_UNICODE_STRING_(Directory);
    							OBJECT_TYPE_INFORMATION* pti = poati->TypeInformation;
    							PWSTR buf = (PWSTR)(TypeInformation + NumberOfTypes);
    							int Index = 0;
    							do 
    							{
    								if (RtlEqualUnicodeString(&Directory, &pti->TypeName, TRUE))
    								{
    									_firstObjectTypeIndex = DirectoryTypeIndex - Index;
    								}
    
    								DWORD Length = pti->TypeName.Length, MaximumLength = pti->TypeName.MaximumLength;
    								memcpy(buf, pti->TypeName.Buffer, Length);
    
    								*TypeInformation = *pti;
    								TypeInformation++->TypeName.Buffer = buf;
    
    								buf = (PWSTR)RtlOffsetToPointer(buf, Length);
    
    								pti = (OBJECT_TYPE_INFORMATION*)
    									(((ULONG_PTR)pti + sizeof(OBJECT_TYPE_INFORMATION) + MaximumLength + sizeof(PVOID)-1) & ~(sizeof(PVOID)-1));
    
    							} while (Index++, --NumberOfTypes);
    						}
    					}
    				}
    			} while (status == STATUS_INFO_LENGTH_MISMATCH);
    		}
    	}

    ObjectTypeIndex

    zhukas, 15 Ноября 2014

    Комментарии (32)
  4. C++ / Говнокод #17093

    +50

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    #include <iostream>
    using namespace std;
    
    void f(int i)
    {
    	cout << "----" << endl;
    	void *array[] = { &&foo, &&bar, &&baz };
    	goto *array[i];
    	foo:
    	cout << "Foo" << endl;
    	bar:
    	cout << "Bar" << endl;
    	baz:
    	cout << "Baz" << endl;
    }
    
    int main() {
    	// your code goes here
    	f(0);
    	f(1);
    	f(2);
    	return 0;
    }

    http://ideone.com/63tRls
    gcc extension

    DlangGovno, 10 Ноября 2014

    Комментарии (108)
  5. C++ / Говнокод #17064

    +53

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    const char *GetExternalFilesDir ()
      {
        assert (started);
        static std::string s="";
        if (s.length()==0)
        {
          LOGI("Try get external files dir");
          jclass c; jmethodID m; jobject o;
    
          c = env->FindClass        ("android/app/NativeActivity");
          m = env->GetMethodID      (c, "getExternalFilesDir", "(Ljava/lang/String;)Ljava/io/File;");
          o = env->CallObjectMethod  (appState->activity->clazz, m, NULL);
    
          c = env->GetObjectClass    (o);
          m = env->GetMethodID      (c, "getAbsolutePath", "()Ljava/lang/String;");
          o = env->CallObjectMethod  (o, m);
          jstring jo = (jstring)o;
    
          const char *path = env->GetStringUTFChars(jo, NULL);
          s=path;
          env->ReleaseStringUTFChars(jo, path);
          s+='/';
          LOGI("Path for program's data files is %s", s.c_str());
        }
        return s.c_str();
      }

    Этот код был написан одним очень известным в очень узких кругах человеком. Будем надеяться, что он придет в обсуждение и прокомментирует его.

    DlangGovno, 04 Ноября 2014

    Комментарии (83)
  6. C++ / Говнокод #17059

    +55

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    void input (char inpt [64])
    {
    	for (;;)
    	{
    		int i(0);
    		cin >> inpt;
    		i ++;
    		if (inpt[i] == '\n')
    			inpt[i] = '\0';break;
    	}
    }

    normbo, 03 Ноября 2014

    Комментарии (14)
  7. C++ / Говнокод #17005

    +139

    1. 1
    2. 2
    3. 3
    4. 4
    5. 5
    6. 6
    7. 7
    struct Counter{
    	static int k;
    	Counter(){ k++; }
    	~Counter() { k--; }
    };
    int Counter::k = 0;
    #define LOL(x) {string s = #x; Counter c##x; cout<<s.substr(0,1+s.find('['))<<Counter::k<<"]="<<x<<'\n'; }

    Abbath, 01 Ноября 2014

    Комментарии (18)
  8. C++ / Говнокод #17002

    +144

    1. 1
    2. 2
    3. 3
    4. 4
    5. 5
    6. 6
    while (1) { // Не все знают логические значения
        ...
    }
    
    for (;;) // Ещё хуже
    { ... }

    nns2009, 31 Октября 2014

    Комментарии (28)
  9. C++ / Говнокод #17001

    +135

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    void SoundService::stop(){
        if (mOutputMixObj != NULL) {
            (*mOutputMixObj)->Destroy(mOutputMixObj);
            mOutputMixObj = NULL;
        }
        if(mEngineObj != NULL){
            (*mEngineObj)->Destroy(mEngineObj);
             mEngineObj = NULL; mEngine = NULL;
        }
    }

    Случайно нашёл в книге по Android NDK, открытой на случайной странице.

    tehned, 30 Октября 2014

    Комментарии (13)
  10. C++ / Говнокод #16996

    +145

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    //bytes 0-13
      bmp.push_back('B'); bmp.push_back('M'); //0: bfType
      bmp.push_back(0); bmp.push_back(0); bmp.push_back(0); bmp.push_back(0); //2: bfSize; size not yet known for now, filled in later.
      bmp.push_back(0); bmp.push_back(0); //6: bfReserved1
      bmp.push_back(0); bmp.push_back(0); //8: bfReserved2
      bmp.push_back(54 % 256); bmp.push_back(54 / 256); bmp.push_back(0); bmp.push_back(0); //10: bfOffBits (54 header bytes)
    
      //bytes 14-53
      bmp.push_back(40); bmp.push_back(0); bmp.push_back(0); bmp.push_back(0);  //14: biSize
      bmp.push_back(width % 256); bmp.push_back(width / 256); bmp.push_back(0); bmp.push_back(0); //18: biWidth
      bmp.push_back(height % 256); bmp.push_back(height / 256); bmp.push_back(0); bmp.push_back(0); //22: biHeight
      bmp.push_back(1); bmp.push_back(0); //26: biPlanes
      bmp.push_back(outputChannels * 8); bmp.push_back(0); //28: biBitCount
      bmp.push_back(0); bmp.push_back(0); bmp.push_back(0); bmp.push_back(0);  //30: biCompression
      bmp.push_back(0); bmp.push_back(0); bmp.push_back(0); bmp.push_back(0);  //34: biSizeImage
      bmp.push_back(0); bmp.push_back(0); bmp.push_back(0); bmp.push_back(0);  //38: biXPelsPerMeter
      bmp.push_back(0); bmp.push_back(0); bmp.push_back(0); bmp.push_back(0);  //42: biYPelsPerMeter
      bmp.push_back(0); bmp.push_back(0); bmp.push_back(0); bmp.push_back(0);  //46: biClrUsed
      bmp.push_back(0); bmp.push_back(0); bmp.push_back(0); bmp.push_back(0);  //50: biClrImportant

    blackhearted, 30 Октября 2014

    Комментарии (56)