Flawfinder version 2.0.10, (C) 2001-2019 David A. Wheeler. Number of rules (primarily dangerous function names) in C/C++ ruleset: 223 Examining data/qmmp-1.3.1/src/qmmpui/playlisttrack.cpp Examining data/qmmp-1.3.1/src/qmmpui/qtfiledialog.cpp Examining data/qmmp-1.3.1/src/qmmpui/metadatahelper.cpp Examining data/qmmp-1.3.1/src/qmmpui/qtfiledialog_p.h Examining data/qmmp-1.3.1/src/qmmpui/playlistdownloader.cpp Examining data/qmmp-1.3.1/src/qmmpui/uiloader.h Examining data/qmmp-1.3.1/src/qmmpui/playlistparser.h Examining data/qmmp-1.3.1/src/qmmpui/groupedcontainer.cpp Examining data/qmmp-1.3.1/src/qmmpui/winfileassoc.h Examining data/qmmp-1.3.1/src/qmmpui/general.h Examining data/qmmp-1.3.1/src/qmmpui/playlistmodel.cpp Examining data/qmmp-1.3.1/src/qmmpui/winfileassoc.cpp Examining data/qmmp-1.3.1/src/qmmpui/metadatahelper_p.h Examining data/qmmp-1.3.1/src/qmmpui/metadataformatter.h Examining data/qmmp-1.3.1/src/qmmpui/qmmpuisettings.cpp Examining data/qmmp-1.3.1/src/qmmpui/commandlinehandler.h Examining data/qmmp-1.3.1/src/qmmpui/playlisttask_p.h Examining data/qmmp-1.3.1/src/qmmpui/commandlinemanager.h Examining data/qmmp-1.3.1/src/qmmpui/qmmpuisettings.h Examining data/qmmp-1.3.1/src/qmmpui/uihelper.h Examining data/qmmp-1.3.1/src/qmmpui/columneditor_p.h Examining data/qmmp-1.3.1/src/qmmpui/commandlinemanager.cpp Examining data/qmmp-1.3.1/src/qmmpui/playlistmodel.h Examining data/qmmp-1.3.1/src/qmmpui/detailsdialog.h Examining data/qmmp-1.3.1/src/qmmpui/winfileassocpage.cpp Examining data/qmmp-1.3.1/src/qmmpui/generalfactory.h Examining data/qmmp-1.3.1/src/qmmpui/normalcontainer_p.h Examining data/qmmp-1.3.1/src/qmmpui/jumptotrackdialog_p.h Examining data/qmmp-1.3.1/src/qmmpui/tageditor_p.h Examining data/qmmp-1.3.1/src/qmmpui/tagupdater_p.h Examining data/qmmp-1.3.1/src/qmmpui/mediaplayer.cpp Examining data/qmmp-1.3.1/src/qmmpui/playstate.cpp Examining data/qmmp-1.3.1/src/qmmpui/metadataformattermenu.h Examining data/qmmp-1.3.1/src/qmmpui/qmmpuiplugincache_p.h Examining data/qmmp-1.3.1/src/qmmpui/templateeditor.cpp Examining data/qmmp-1.3.1/src/qmmpui/pluginitem_p.h Examining data/qmmp-1.3.1/src/qmmpui/playlisttask.cpp Examining data/qmmp-1.3.1/src/qmmpui/uifactory.h Examining data/qmmp-1.3.1/src/qmmpui/filedialogfactory.h Examining data/qmmp-1.3.1/src/qmmpui/normalcontainer.cpp Examining data/qmmp-1.3.1/src/qmmpui/uiloader.cpp Examining data/qmmp-1.3.1/src/qmmpui/covereditor.cpp Examining data/qmmp-1.3.1/src/qmmpui/filedialog.cpp Examining data/qmmp-1.3.1/src/qmmpui/filedialog.h Examining data/qmmp-1.3.1/src/qmmpui/playlistcontainer_p.h Examining data/qmmp-1.3.1/src/qmmpui/playlistitem.cpp Examining data/qmmp-1.3.1/src/qmmpui/templateeditor.h Examining data/qmmp-1.3.1/src/qmmpui/groupedcontainer_p.h Examining data/qmmp-1.3.1/src/qmmpui/coverviewer_p.h Examining data/qmmp-1.3.1/src/qmmpui/uihelper.cpp Examining data/qmmp-1.3.1/src/qmmpui/playlistmanager.cpp Examining data/qmmp-1.3.1/src/qmmpui/playlisttrack.h Examining data/qmmp-1.3.1/src/qmmpui/playlistheadermodel.cpp Examining data/qmmp-1.3.1/src/qmmpui/qmmpuiplugincache.cpp Examining data/qmmp-1.3.1/src/qmmpui/winfileassocpage_p.h Examining data/qmmp-1.3.1/src/qmmpui/tageditor.cpp Examining data/qmmp-1.3.1/src/qmmpui/playlistdownloader.h Examining data/qmmp-1.3.1/src/qmmpui/mediaplayer.h Examining data/qmmp-1.3.1/src/qmmpui/metadataformattermenu.cpp Examining data/qmmp-1.3.1/src/qmmpui/metadataformatter.cpp Examining data/qmmp-1.3.1/src/qmmpui/playlistcontainer.cpp Examining data/qmmp-1.3.1/src/qmmpui/columneditor.cpp Examining data/qmmp-1.3.1/src/qmmpui/fileloader_p.h Examining data/qmmp-1.3.1/src/qmmpui/general.cpp Examining data/qmmp-1.3.1/src/qmmpui/tagupdater.cpp Examining data/qmmp-1.3.1/src/qmmpui/commandlinehandler.cpp Examining data/qmmp-1.3.1/src/qmmpui/jumptotrackdialog.cpp Examining data/qmmp-1.3.1/src/qmmpui/playlistheadermodel.h Examining data/qmmp-1.3.1/src/qmmpui/pluginitem.cpp Examining data/qmmp-1.3.1/src/qmmpui/fileloader.cpp Examining data/qmmp-1.3.1/src/qmmpui/covereditor_p.h Examining data/qmmp-1.3.1/src/qmmpui/qmmpui_export.h Examining data/qmmp-1.3.1/src/qmmpui/playlistitem.h Examining data/qmmp-1.3.1/src/qmmpui/configdialog.h Examining data/qmmp-1.3.1/src/qmmpui/radioitemdelegate.cpp Examining data/qmmp-1.3.1/src/qmmpui/addurldialog.cpp Examining data/qmmp-1.3.1/src/qmmpui/detailsdialog.cpp Examining data/qmmp-1.3.1/src/qmmpui/coverviewer.cpp Examining data/qmmp-1.3.1/src/qmmpui/radioitemdelegate_p.h Examining data/qmmp-1.3.1/src/qmmpui/playstate_p.h Examining data/qmmp-1.3.1/src/qmmpui/addurldialog_p.h Examining data/qmmp-1.3.1/src/qmmpui/playlistgroup.cpp Examining data/qmmp-1.3.1/src/qmmpui/playlistgroup.h Examining data/qmmp-1.3.1/src/qmmpui/configdialog.cpp Examining data/qmmp-1.3.1/src/qmmpui/playlistformat.h Examining data/qmmp-1.3.1/src/qmmpui/aboutdialog_p.h Examining data/qmmp-1.3.1/src/qmmpui/playlistmanager.h Examining data/qmmp-1.3.1/src/qmmpui/aboutdialog.cpp Examining data/qmmp-1.3.1/src/qmmpui/playlistparser.cpp Examining data/qmmp-1.3.1/src/plugins/Transports/mms/mmsstreamreader.cpp Examining data/qmmp-1.3.1/src/plugins/Transports/mms/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Transports/mms/mmsinputfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Transports/mms/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Transports/mms/mmsinputfactory.h Examining data/qmmp-1.3.1/src/plugins/Transports/mms/mmsinputsource.h Examining data/qmmp-1.3.1/src/plugins/Transports/mms/mmsinputsource.cpp Examining data/qmmp-1.3.1/src/plugins/Transports/mms/mmsstreamreader.h Examining data/qmmp-1.3.1/src/plugins/Transports/http/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Transports/http/httpinputsource.cpp Examining data/qmmp-1.3.1/src/plugins/Transports/http/httpstreamreader.cpp Examining data/qmmp-1.3.1/src/plugins/Transports/http/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Transports/http/httpstreamreader.h Examining data/qmmp-1.3.1/src/plugins/Transports/http/httpinputsource.h Examining data/qmmp-1.3.1/src/plugins/Transports/http/httpinputfactory.h Examining data/qmmp-1.3.1/src/plugins/Transports/http/httpinputfactory.cpp Examining data/qmmp-1.3.1/src/plugins/CommandLineOptions/PlayListOption/playlistoption.cpp Examining data/qmmp-1.3.1/src/plugins/CommandLineOptions/PlayListOption/playlistoption.h Examining data/qmmp-1.3.1/src/plugins/CommandLineOptions/StatusOption/statusoption.cpp Examining data/qmmp-1.3.1/src/plugins/CommandLineOptions/StatusOption/statusoption.h Examining data/qmmp-1.3.1/src/plugins/CommandLineOptions/IncDecVolumeOption/incdecvolumeoption.cpp Examining data/qmmp-1.3.1/src/plugins/CommandLineOptions/IncDecVolumeOption/incdecvolumeoption.h Examining data/qmmp-1.3.1/src/plugins/CommandLineOptions/SeekOption/seekoption.cpp Examining data/qmmp-1.3.1/src/plugins/CommandLineOptions/SeekOption/seekoption.h Examining data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.h Examining data/qmmp-1.3.1/src/plugins/Input/vorbis/decodervorbisfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Input/vorbis/decodervorbisfactory.h Examining data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp Examining data/qmmp-1.3.1/src/plugins/Input/vorbis/vorbismetadatamodel.h Examining data/qmmp-1.3.1/src/plugins/Input/vorbis/vorbismetadatamodel.cpp Examining data/qmmp-1.3.1/src/plugins/Input/mpeg/decodermpegfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Input/mpeg/decoder_mad.h Examining data/qmmp-1.3.1/src/plugins/Input/mpeg/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Input/mpeg/decoder_mad.cpp Examining data/qmmp-1.3.1/src/plugins/Input/mpeg/decoder_mpg123.cpp Examining data/qmmp-1.3.1/src/plugins/Input/mpeg/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Input/mpeg/decoder_mpg123.h Examining data/qmmp-1.3.1/src/plugins/Input/mpeg/decodermpegfactory.h Examining data/qmmp-1.3.1/src/plugins/Input/mpeg/mpegmetadatamodel.h Examining data/qmmp-1.3.1/src/plugins/Input/mpeg/mpegmetadatamodel.cpp Examining data/qmmp-1.3.1/src/plugins/Input/mpeg/tagextractor.h Examining data/qmmp-1.3.1/src/plugins/Input/mpeg/tagextractor.cpp Examining data/qmmp-1.3.1/src/plugins/Input/sid/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Input/sid/decodersidfactory.h Examining data/qmmp-1.3.1/src/plugins/Input/sid/sidhelper.h Examining data/qmmp-1.3.1/src/plugins/Input/sid/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Input/sid/decoder_sid.h Examining data/qmmp-1.3.1/src/plugins/Input/sid/sidhelper.cpp Examining data/qmmp-1.3.1/src/plugins/Input/sid/decodersidfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Input/sid/decoder_sid.cpp Examining data/qmmp-1.3.1/src/plugins/Input/sndfile/decodersndfilefactory.cpp Examining data/qmmp-1.3.1/src/plugins/Input/sndfile/decoder_sndfile.h Examining data/qmmp-1.3.1/src/plugins/Input/sndfile/decoder_sndfile.cpp Examining data/qmmp-1.3.1/src/plugins/Input/sndfile/decodersndfilefactory.h Examining data/qmmp-1.3.1/src/plugins/Input/mpc/decodermpcfactory.h Examining data/qmmp-1.3.1/src/plugins/Input/mpc/decodermpcfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Input/mpc/decoder_mpc.cpp Examining data/qmmp-1.3.1/src/plugins/Input/mpc/decoder_mpc.h Examining data/qmmp-1.3.1/src/plugins/Input/mpc/mpcmetadatamodel.h Examining data/qmmp-1.3.1/src/plugins/Input/mpc/mpcmetadatamodel.cpp Examining data/qmmp-1.3.1/src/plugins/Input/wildmidi/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Input/wildmidi/decoder_wildmidi.cpp Examining data/qmmp-1.3.1/src/plugins/Input/wildmidi/wildmidihelper.h Examining data/qmmp-1.3.1/src/plugins/Input/wildmidi/wildmidihelper.cpp Examining data/qmmp-1.3.1/src/plugins/Input/wildmidi/decoderwildmidifactory.cpp Examining data/qmmp-1.3.1/src/plugins/Input/wildmidi/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Input/wildmidi/decoder_wildmidi.h Examining data/qmmp-1.3.1/src/plugins/Input/wildmidi/decoderwildmidifactory.h Examining data/qmmp-1.3.1/src/plugins/Input/archive/archiveinputdevice.h Examining data/qmmp-1.3.1/src/plugins/Input/archive/archiveinputdevice.cpp Examining data/qmmp-1.3.1/src/plugins/Input/archive/decoderarchivefactory.cpp Examining data/qmmp-1.3.1/src/plugins/Input/archive/archivetagreader.h Examining data/qmmp-1.3.1/src/plugins/Input/archive/decoder_archive.cpp Examining data/qmmp-1.3.1/src/plugins/Input/archive/archivetagreader.cpp Examining data/qmmp-1.3.1/src/plugins/Input/archive/decoderarchivefactory.h Examining data/qmmp-1.3.1/src/plugins/Input/archive/decoder_archive.h Examining data/qmmp-1.3.1/src/plugins/Input/cue/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Input/cue/cuemetadatamodel.cpp Examining data/qmmp-1.3.1/src/plugins/Input/cue/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Input/cue/decodercuefactory.h Examining data/qmmp-1.3.1/src/plugins/Input/cue/decodercuefactory.cpp Examining data/qmmp-1.3.1/src/plugins/Input/cue/cueparser.cpp Examining data/qmmp-1.3.1/src/plugins/Input/cue/cuemetadatamodel.h Examining data/qmmp-1.3.1/src/plugins/Input/cue/cueparser.h Examining data/qmmp-1.3.1/src/plugins/Input/cue/decoder_cue.cpp Examining data/qmmp-1.3.1/src/plugins/Input/cue/decoder_cue.h Examining data/qmmp-1.3.1/src/plugins/Input/flac/flacmetadatamodel.h Examining data/qmmp-1.3.1/src/plugins/Input/flac/flacmetadatamodel.cpp Examining data/qmmp-1.3.1/src/plugins/Input/flac/decoderflacfactory.h Examining data/qmmp-1.3.1/src/plugins/Input/flac/decoder_flac.h Examining data/qmmp-1.3.1/src/plugins/Input/flac/cueparser.cpp Examining data/qmmp-1.3.1/src/plugins/Input/flac/decoder_flac.cpp Examining data/qmmp-1.3.1/src/plugins/Input/flac/cueparser.h Examining data/qmmp-1.3.1/src/plugins/Input/flac/decoderflacfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Input/gme/decodergmefactory.h Examining data/qmmp-1.3.1/src/plugins/Input/gme/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Input/gme/decoder_gme.h Examining data/qmmp-1.3.1/src/plugins/Input/gme/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Input/gme/decodergmefactory.cpp Examining data/qmmp-1.3.1/src/plugins/Input/gme/gmehelper.cpp Examining data/qmmp-1.3.1/src/plugins/Input/gme/gmehelper.h Examining data/qmmp-1.3.1/src/plugins/Input/gme/decoder_gme.cpp Examining data/qmmp-1.3.1/src/plugins/Input/opus/decoder_opus.h Examining data/qmmp-1.3.1/src/plugins/Input/opus/opusmetadatamodel.h Examining data/qmmp-1.3.1/src/plugins/Input/opus/decoderopusfactory.h Examining data/qmmp-1.3.1/src/plugins/Input/opus/opusmetadatamodel.cpp Examining data/qmmp-1.3.1/src/plugins/Input/opus/decoderopusfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Input/opus/decoder_opus.cpp Examining data/qmmp-1.3.1/src/plugins/Input/ffmpeg/replaygainreader.h Examining data/qmmp-1.3.1/src/plugins/Input/ffmpeg/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Input/ffmpeg/ffmpegmetadatamodel.cpp Examining data/qmmp-1.3.1/src/plugins/Input/ffmpeg/ffmpegmetadatamodel.h Examining data/qmmp-1.3.1/src/plugins/Input/ffmpeg/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Input/ffmpeg/replaygainreader.cpp Examining data/qmmp-1.3.1/src/plugins/Input/ffmpeg/decoder_ffmpeg.cpp Examining data/qmmp-1.3.1/src/plugins/Input/ffmpeg/decoderffmpegfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Input/ffmpeg/decoder_ffmpeg.h Examining data/qmmp-1.3.1/src/plugins/Input/ffmpeg/decoderffmpegfactory.h Examining data/qmmp-1.3.1/src/plugins/Input/aac/decoder_aac.h Examining data/qmmp-1.3.1/src/plugins/Input/aac/decoder_aac.cpp Examining data/qmmp-1.3.1/src/plugins/Input/aac/aacfile.cpp Examining data/qmmp-1.3.1/src/plugins/Input/aac/aacfile.h Examining data/qmmp-1.3.1/src/plugins/Input/aac/decoderaacfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Input/aac/decoderaacfactory.h Examining data/qmmp-1.3.1/src/plugins/Input/modplug/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Input/modplug/archivereader.cpp Examining data/qmmp-1.3.1/src/plugins/Input/modplug/decoder_modplug.h Examining data/qmmp-1.3.1/src/plugins/Input/modplug/decoder_modplug.cpp Examining data/qmmp-1.3.1/src/plugins/Input/modplug/modplugmetadatamodel.cpp Examining data/qmmp-1.3.1/src/plugins/Input/modplug/decodermodplugfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Input/modplug/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Input/modplug/archivereader.h Examining data/qmmp-1.3.1/src/plugins/Input/modplug/modplugmetadatamodel.h Examining data/qmmp-1.3.1/src/plugins/Input/modplug/decodermodplugfactory.h Examining data/qmmp-1.3.1/src/plugins/Input/cdaudio/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Input/cdaudio/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Input/cdaudio/decodercdaudiofactory.cpp Examining data/qmmp-1.3.1/src/plugins/Input/cdaudio/decoder_cdaudio.h Examining data/qmmp-1.3.1/src/plugins/Input/cdaudio/decodercdaudiofactory.h Examining data/qmmp-1.3.1/src/plugins/Input/cdaudio/decoder_cdaudio.cpp Examining data/qmmp-1.3.1/src/plugins/Input/wavpack/decoderwavpackfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Input/wavpack/decoder_wavpack.cpp Examining data/qmmp-1.3.1/src/plugins/Input/wavpack/cueparser.cpp Examining data/qmmp-1.3.1/src/plugins/Input/wavpack/wavpackmetadatamodel.h Examining data/qmmp-1.3.1/src/plugins/Input/wavpack/decoderwavpackfactory.h Examining data/qmmp-1.3.1/src/plugins/Input/wavpack/decoder_wavpack.h Examining data/qmmp-1.3.1/src/plugins/Input/wavpack/cueparser.h Examining data/qmmp-1.3.1/src/plugins/Input/wavpack/wavpackmetadatamodel.cpp Examining data/qmmp-1.3.1/src/plugins/FileDialogs/QmmpFileDialog/qmmpfiledialogimpl.h Examining data/qmmp-1.3.1/src/plugins/FileDialogs/QmmpFileDialog/qmmpfiledialogimpl.cpp Examining data/qmmp-1.3.1/src/plugins/FileDialogs/QmmpFileDialog/qmmpfiledialog.cpp Examining data/qmmp-1.3.1/src/plugins/FileDialogs/QmmpFileDialog/qmmpfiledialog.h Examining data/qmmp-1.3.1/src/plugins/FileDialogs/TwoPanelFileDialog/twopanelfiledialogimpl.cpp Examining data/qmmp-1.3.1/src/plugins/FileDialogs/TwoPanelFileDialog/twopanelfiledialogimpl.h Examining data/qmmp-1.3.1/src/plugins/FileDialogs/TwoPanelFileDialog/twopanelfiledialog.h Examining data/qmmp-1.3.1/src/plugins/FileDialogs/TwoPanelFileDialog/twopanelfiledialog.cpp Examining data/qmmp-1.3.1/src/plugins/Visual/analyzer/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Visual/analyzer/colorwidget.cpp Examining data/qmmp-1.3.1/src/plugins/Visual/analyzer/fft.c Examining data/qmmp-1.3.1/src/plugins/Visual/analyzer/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Visual/analyzer/inlines.h Examining data/qmmp-1.3.1/src/plugins/Visual/analyzer/colorwidget.h Examining data/qmmp-1.3.1/src/plugins/Visual/analyzer/fft.h Examining data/qmmp-1.3.1/src/plugins/Visual/analyzer/visualanalyzerfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Visual/analyzer/visualanalyzerfactory.h Examining data/qmmp-1.3.1/src/plugins/Visual/analyzer/analyzer.cpp Examining data/qmmp-1.3.1/src/plugins/Visual/analyzer/analyzer.h Examining data/qmmp-1.3.1/src/plugins/Visual/projectm/visualprojectmfactory.h Examining data/qmmp-1.3.1/src/plugins/Visual/projectm/projectmwidget.cpp Examining data/qmmp-1.3.1/src/plugins/Visual/projectm/visualprojectmfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Visual/projectm/projectmwrapper.cpp Examining data/qmmp-1.3.1/src/plugins/Visual/projectm/projectmwrapper.h Examining data/qmmp-1.3.1/src/plugins/Visual/projectm/projectmplugin.cpp Examining data/qmmp-1.3.1/src/plugins/Visual/projectm/projectmwidget.h Examining data/qmmp-1.3.1/src/plugins/Visual/projectm/projectmplugin.h Examining data/qmmp-1.3.1/src/plugins/Output/qtmultimedia/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Output/qtmultimedia/outputqtmultimedia.h Examining data/qmmp-1.3.1/src/plugins/Output/qtmultimedia/outputqtmultimedia.cpp Examining data/qmmp-1.3.1/src/plugins/Output/qtmultimedia/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Output/qtmultimedia/outputqtmultimediafactory.cpp Examining data/qmmp-1.3.1/src/plugins/Output/qtmultimedia/outputqtmultimediafactory.h Examining data/qmmp-1.3.1/src/plugins/Output/null/outputnull.h Examining data/qmmp-1.3.1/src/plugins/Output/null/outputnullfactory.h Examining data/qmmp-1.3.1/src/plugins/Output/null/outputnullfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Output/null/outputnull.cpp Examining data/qmmp-1.3.1/src/plugins/Output/pulseaudio/outputpulseaudio.h Examining data/qmmp-1.3.1/src/plugins/Output/pulseaudio/outputpulseaudiofactory.h Examining data/qmmp-1.3.1/src/plugins/Output/pulseaudio/outputpulseaudio.cpp Examining data/qmmp-1.3.1/src/plugins/Output/pulseaudio/outputpulseaudiofactory.cpp Examining data/qmmp-1.3.1/src/plugins/Output/jack/bio2jack.h Examining data/qmmp-1.3.1/src/plugins/Output/jack/bio2jack.c Examining data/qmmp-1.3.1/src/plugins/Output/jack/outputjackfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Output/jack/outputjackfactory.h Examining data/qmmp-1.3.1/src/plugins/Output/jack/outputjack.h Examining data/qmmp-1.3.1/src/plugins/Output/jack/outputjack.cpp Examining data/qmmp-1.3.1/src/plugins/Output/wasapi/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Output/wasapi/outputwasapi.h Examining data/qmmp-1.3.1/src/plugins/Output/wasapi/outputwasapifactory.cpp Examining data/qmmp-1.3.1/src/plugins/Output/wasapi/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Output/wasapi/outputwasapifactory.h Examining data/qmmp-1.3.1/src/plugins/Output/wasapi/outputwasapi.cpp Examining data/qmmp-1.3.1/src/plugins/Output/directsound/outputdirectsoundfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Output/directsound/outputdirectsoundfactory.h Examining data/qmmp-1.3.1/src/plugins/Output/directsound/outputdirectsound.cpp Examining data/qmmp-1.3.1/src/plugins/Output/directsound/outputdirectsound.h Examining data/qmmp-1.3.1/src/plugins/Output/oss/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Output/oss/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Output/oss/outputossfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Output/oss/outputossfactory.h Examining data/qmmp-1.3.1/src/plugins/Output/oss/outputoss.h Examining data/qmmp-1.3.1/src/plugins/Output/oss/outputoss.cpp Examining data/qmmp-1.3.1/src/plugins/Output/oss4/outputoss4factory.cpp Examining data/qmmp-1.3.1/src/plugins/Output/oss4/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Output/oss4/outputoss4.h Examining data/qmmp-1.3.1/src/plugins/Output/oss4/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Output/oss4/outputoss4factory.h Examining data/qmmp-1.3.1/src/plugins/Output/oss4/outputoss4.cpp Examining data/qmmp-1.3.1/src/plugins/Output/shout/outputshoutfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Output/shout/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Output/shout/shoutoutput.h Examining data/qmmp-1.3.1/src/plugins/Output/shout/shoutoutput.cpp Examining data/qmmp-1.3.1/src/plugins/Output/shout/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Output/shout/shoutclient.cpp Examining data/qmmp-1.3.1/src/plugins/Output/shout/shoutclient.h Examining data/qmmp-1.3.1/src/plugins/Output/shout/outputshoutfactory.h Examining data/qmmp-1.3.1/src/plugins/Output/alsa/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Output/alsa/outputalsafactory.cpp Examining data/qmmp-1.3.1/src/plugins/Output/alsa/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Output/alsa/outputalsafactory.h Examining data/qmmp-1.3.1/src/plugins/Output/alsa/outputalsa.h Examining data/qmmp-1.3.1/src/plugins/Output/alsa/outputalsa.cpp Examining data/qmmp-1.3.1/src/plugins/Output/waveout/outputwaveout.h Examining data/qmmp-1.3.1/src/plugins/Output/waveout/outputwaveoutfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Output/waveout/outputwaveout.cpp Examining data/qmmp-1.3.1/src/plugins/Output/waveout/outputwaveoutfactory.h Examining data/qmmp-1.3.1/src/plugins/PlayListFormats/m3u/m3uplaylistformat.cpp Examining data/qmmp-1.3.1/src/plugins/PlayListFormats/m3u/m3uplaylistformat.h Examining data/qmmp-1.3.1/src/plugins/PlayListFormats/pls/plsplaylistformat.cpp Examining data/qmmp-1.3.1/src/plugins/PlayListFormats/pls/plsplaylistformat.h Examining data/qmmp-1.3.1/src/plugins/PlayListFormats/xspf/xspfplaylistformat.h Examining data/qmmp-1.3.1/src/plugins/PlayListFormats/xspf/xspfplaylistformat.cpp Examining data/qmmp-1.3.1/src/plugins/General/rdetect/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/General/rdetect/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/General/rdetect/removablehelper.h Examining data/qmmp-1.3.1/src/plugins/General/rdetect/rdetectfactory.h Examining data/qmmp-1.3.1/src/plugins/General/rdetect/removablehelper.cpp Examining data/qmmp-1.3.1/src/plugins/General/rdetect/rdetectfactory.cpp Examining data/qmmp-1.3.1/src/plugins/General/trackchange/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/General/trackchange/trackchangefactory.h Examining data/qmmp-1.3.1/src/plugins/General/trackchange/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/General/trackchange/trackchangefactory.cpp Examining data/qmmp-1.3.1/src/plugins/General/trackchange/trackchange.cpp Examining data/qmmp-1.3.1/src/plugins/General/trackchange/trackchange.h Examining data/qmmp-1.3.1/src/plugins/General/taskbar/taskbarfactory.cpp Examining data/qmmp-1.3.1/src/plugins/General/taskbar/taskbarfactory.h Examining data/qmmp-1.3.1/src/plugins/General/taskbar/taskbarhelper.cpp Examining data/qmmp-1.3.1/src/plugins/General/taskbar/taskbarhelper.h Examining data/qmmp-1.3.1/src/plugins/General/scrobbler/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/General/scrobbler/defines.h Examining data/qmmp-1.3.1/src/plugins/General/scrobbler/scrobblerhandler.h Examining data/qmmp-1.3.1/src/plugins/General/scrobbler/scrobbler.h Examining data/qmmp-1.3.1/src/plugins/General/scrobbler/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/General/scrobbler/scrobblercache.cpp Examining data/qmmp-1.3.1/src/plugins/General/scrobbler/scrobblercache.h Examining data/qmmp-1.3.1/src/plugins/General/scrobbler/scrobblerfactory.h Examining data/qmmp-1.3.1/src/plugins/General/scrobbler/scrobblerhandler.cpp Examining data/qmmp-1.3.1/src/plugins/General/scrobbler/scrobblerfactory.cpp Examining data/qmmp-1.3.1/src/plugins/General/scrobbler/scrobbler.cpp Examining data/qmmp-1.3.1/src/plugins/General/gnomehotkey/mediakeys.cpp Examining data/qmmp-1.3.1/src/plugins/General/gnomehotkey/gnomehotkeyfactory.h Examining data/qmmp-1.3.1/src/plugins/General/gnomehotkey/gnomehotkeyfactory.cpp Examining data/qmmp-1.3.1/src/plugins/General/gnomehotkey/mediakeys.h Examining data/qmmp-1.3.1/src/plugins/General/rgscan/rgscandialog.h Examining data/qmmp-1.3.1/src/plugins/General/rgscan/gain_analysis.h Examining data/qmmp-1.3.1/src/plugins/General/rgscan/gain_analysis.c Examining data/qmmp-1.3.1/src/plugins/General/rgscan/rgscanner.h Examining data/qmmp-1.3.1/src/plugins/General/rgscan/rgscanfactory.h Examining data/qmmp-1.3.1/src/plugins/General/rgscan/rgscanfactory.cpp Examining data/qmmp-1.3.1/src/plugins/General/rgscan/rgscanhelper.cpp Examining data/qmmp-1.3.1/src/plugins/General/rgscan/rgscanner.cpp Examining data/qmmp-1.3.1/src/plugins/General/rgscan/rgscandialog.cpp Examining data/qmmp-1.3.1/src/plugins/General/rgscan/rgscanhelper.h Examining data/qmmp-1.3.1/src/plugins/General/hotkey/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/General/hotkey/hotkeymanager.h Examining data/qmmp-1.3.1/src/plugins/General/hotkey/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/General/hotkey/hotkeyfactory.h Examining data/qmmp-1.3.1/src/plugins/General/hotkey/hotkeymanager_win.cpp Examining data/qmmp-1.3.1/src/plugins/General/hotkey/hotkeyfactory.cpp Examining data/qmmp-1.3.1/src/plugins/General/hotkey/hotkeymanager_x11.cpp Examining data/qmmp-1.3.1/src/plugins/General/hotkey/hotkeydialog.h Examining data/qmmp-1.3.1/src/plugins/General/hotkey/hotkeydialog.cpp Examining data/qmmp-1.3.1/src/plugins/General/notifier/notifier.cpp Examining data/qmmp-1.3.1/src/plugins/General/notifier/popupwidget.cpp Examining data/qmmp-1.3.1/src/plugins/General/notifier/notifierfactory.cpp Examining data/qmmp-1.3.1/src/plugins/General/notifier/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/General/notifier/popupwidget.h Examining data/qmmp-1.3.1/src/plugins/General/notifier/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/General/notifier/notifierfactory.h Examining data/qmmp-1.3.1/src/plugins/General/notifier/notifier.h Examining data/qmmp-1.3.1/src/plugins/General/history/historysettingsdialog.h Examining data/qmmp-1.3.1/src/plugins/General/history/historywindow.cpp Examining data/qmmp-1.3.1/src/plugins/General/history/progressbaritemdelegate.h Examining data/qmmp-1.3.1/src/plugins/General/history/dateinputdialog.cpp Examining data/qmmp-1.3.1/src/plugins/General/history/history.cpp Examining data/qmmp-1.3.1/src/plugins/General/history/progressbaritemdelegate.cpp Examining data/qmmp-1.3.1/src/plugins/General/history/history.h Examining data/qmmp-1.3.1/src/plugins/General/history/historywindow.h Examining data/qmmp-1.3.1/src/plugins/General/history/historysettingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/General/history/dateinputdialog.h Examining data/qmmp-1.3.1/src/plugins/General/history/historyfactory.h Examining data/qmmp-1.3.1/src/plugins/General/history/historyfactory.cpp Examining data/qmmp-1.3.1/src/plugins/General/converter/converterhelper.cpp Examining data/qmmp-1.3.1/src/plugins/General/converter/converterfactory.h Examining data/qmmp-1.3.1/src/plugins/General/converter/preseteditor.cpp Examining data/qmmp-1.3.1/src/plugins/General/converter/converterhelper.h Examining data/qmmp-1.3.1/src/plugins/General/converter/converter.cpp Examining data/qmmp-1.3.1/src/plugins/General/converter/converterdialog.h Examining data/qmmp-1.3.1/src/plugins/General/converter/converterdialog.cpp Examining data/qmmp-1.3.1/src/plugins/General/converter/converter.h Examining data/qmmp-1.3.1/src/plugins/General/converter/preseteditor.h Examining data/qmmp-1.3.1/src/plugins/General/converter/converterfactory.cpp Examining data/qmmp-1.3.1/src/plugins/General/covermanager/coverwidget.h Examining data/qmmp-1.3.1/src/plugins/General/covermanager/covermanager.h Examining data/qmmp-1.3.1/src/plugins/General/covermanager/covermanager.cpp Examining data/qmmp-1.3.1/src/plugins/General/covermanager/covermanagerfactory.cpp Examining data/qmmp-1.3.1/src/plugins/General/covermanager/covermanagerfactory.h Examining data/qmmp-1.3.1/src/plugins/General/covermanager/coverwidget.cpp Examining data/qmmp-1.3.1/src/plugins/General/statusicon/statusiconpopupwidget.h Examining data/qmmp-1.3.1/src/plugins/General/statusicon/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/General/statusicon/coverwidget.h Examining data/qmmp-1.3.1/src/plugins/General/statusicon/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/General/statusicon/qmmptrayicon.h Examining data/qmmp-1.3.1/src/plugins/General/statusicon/statusiconfactory.cpp Examining data/qmmp-1.3.1/src/plugins/General/statusicon/statusiconfactory.h Examining data/qmmp-1.3.1/src/plugins/General/statusicon/statusiconpopupwidget.cpp Examining data/qmmp-1.3.1/src/plugins/General/statusicon/statusicon.cpp Examining data/qmmp-1.3.1/src/plugins/General/statusicon/qmmptrayicon.cpp Examining data/qmmp-1.3.1/src/plugins/General/statusicon/statusicon.h Examining data/qmmp-1.3.1/src/plugins/General/statusicon/coverwidget.cpp Examining data/qmmp-1.3.1/src/plugins/General/mpris/mpris.h Examining data/qmmp-1.3.1/src/plugins/General/mpris/mpris.cpp Examining data/qmmp-1.3.1/src/plugins/General/mpris/mpris2/root2object.cpp Examining data/qmmp-1.3.1/src/plugins/General/mpris/mpris2/player2object.cpp Examining data/qmmp-1.3.1/src/plugins/General/mpris/mpris2/root2object.h Examining data/qmmp-1.3.1/src/plugins/General/mpris/mpris2/player2object.h Examining data/qmmp-1.3.1/src/plugins/General/mpris/mprisfactory.cpp Examining data/qmmp-1.3.1/src/plugins/General/mpris/mprisfactory.h Examining data/qmmp-1.3.1/src/plugins/General/fileops/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/General/fileops/fileops.h Examining data/qmmp-1.3.1/src/plugins/General/fileops/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/General/fileops/fileops.cpp Examining data/qmmp-1.3.1/src/plugins/General/fileops/fileopsfactory.h Examining data/qmmp-1.3.1/src/plugins/General/fileops/fileopsfactory.cpp Examining data/qmmp-1.3.1/src/plugins/General/fileops/hotkeydialog.h Examining data/qmmp-1.3.1/src/plugins/General/fileops/hotkeydialog.cpp Examining data/qmmp-1.3.1/src/plugins/General/kdenotify/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/General/kdenotify/kdenotify.cpp Examining data/qmmp-1.3.1/src/plugins/General/kdenotify/kdenotifyfactory.cpp Examining data/qmmp-1.3.1/src/plugins/General/kdenotify/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/General/kdenotify/kdenotify.h Examining data/qmmp-1.3.1/src/plugins/General/kdenotify/kdenotifyfactory.h Examining data/qmmp-1.3.1/src/plugins/General/lyrics/lyricsfactory.h Examining data/qmmp-1.3.1/src/plugins/General/lyrics/lyrics.cpp Examining data/qmmp-1.3.1/src/plugins/General/lyrics/lyricsfactory.cpp Examining data/qmmp-1.3.1/src/plugins/General/lyrics/lyricswindow.cpp Examining data/qmmp-1.3.1/src/plugins/General/lyrics/lyrics.h Examining data/qmmp-1.3.1/src/plugins/General/lyrics/lyricswindow.h Examining data/qmmp-1.3.1/src/plugins/General/udisks2/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/General/udisks2/udisks2device.cpp Examining data/qmmp-1.3.1/src/plugins/General/udisks2/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/General/udisks2/udisks2manager.cpp Examining data/qmmp-1.3.1/src/plugins/General/udisks2/udisks2factory.cpp Examining data/qmmp-1.3.1/src/plugins/General/udisks2/udisks2manager.h Examining data/qmmp-1.3.1/src/plugins/General/udisks2/udisks2plugin.cpp Examining data/qmmp-1.3.1/src/plugins/General/udisks2/udisks2device.h Examining data/qmmp-1.3.1/src/plugins/General/udisks2/udisks2factory.h Examining data/qmmp-1.3.1/src/plugins/General/udisks2/udisks2plugin.h Examining data/qmmp-1.3.1/src/plugins/General/hal/halmanager.cpp Examining data/qmmp-1.3.1/src/plugins/General/hal/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/General/hal/haldevice.h Examining data/qmmp-1.3.1/src/plugins/General/hal/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/General/hal/halfactory.h Examining data/qmmp-1.3.1/src/plugins/General/hal/halplugin.h Examining data/qmmp-1.3.1/src/plugins/General/hal/haldevice.cpp Examining data/qmmp-1.3.1/src/plugins/General/hal/halplugin.cpp Examining data/qmmp-1.3.1/src/plugins/General/hal/halmanager.h Examining data/qmmp-1.3.1/src/plugins/General/hal/halfactory.cpp Examining data/qmmp-1.3.1/src/plugins/General/streambrowser/streamwindow.h Examining data/qmmp-1.3.1/src/plugins/General/streambrowser/streambrowserfactory.cpp Examining data/qmmp-1.3.1/src/plugins/General/streambrowser/streambrowserfactory.h Examining data/qmmp-1.3.1/src/plugins/General/streambrowser/editstreamdialog.cpp Examining data/qmmp-1.3.1/src/plugins/General/streambrowser/streamwindow.cpp Examining data/qmmp-1.3.1/src/plugins/General/streambrowser/streambrowser.cpp Examining data/qmmp-1.3.1/src/plugins/General/streambrowser/editstreamdialog.h Examining data/qmmp-1.3.1/src/plugins/General/streambrowser/streambrowser.h Examining data/qmmp-1.3.1/src/plugins/General/copypaste/copypaste.cpp Examining data/qmmp-1.3.1/src/plugins/General/copypaste/copypastefactory.h Examining data/qmmp-1.3.1/src/plugins/General/copypaste/copypastefactory.cpp Examining data/qmmp-1.3.1/src/plugins/General/copypaste/copypaste.h Examining data/qmmp-1.3.1/src/plugins/Engines/mplayer/mplayermetadatamodel.cpp Examining data/qmmp-1.3.1/src/plugins/Engines/mplayer/mplayerengine.cpp Examining data/qmmp-1.3.1/src/plugins/Engines/mplayer/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Engines/mplayer/mplayerenginefactory.cpp Examining data/qmmp-1.3.1/src/plugins/Engines/mplayer/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Engines/mplayer/mplayerenginefactory.h Examining data/qmmp-1.3.1/src/plugins/Engines/mplayer/mplayermetadatamodel.h Examining data/qmmp-1.3.1/src/plugins/Engines/mplayer/mplayerengine.h Examining data/qmmp-1.3.1/src/plugins/Effect/filewriter/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Effect/filewriter/effectfilewriterfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/filewriter/filewriterplugin.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/filewriter/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/filewriter/filewriterplugin.h Examining data/qmmp-1.3.1/src/plugins/Effect/filewriter/effectfilewriterfactory.h Examining data/qmmp-1.3.1/src/plugins/Effect/soxr/soxresampler.h Examining data/qmmp-1.3.1/src/plugins/Effect/soxr/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Effect/soxr/soxresampler.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/soxr/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/soxr/effectsoxrfactory.h Examining data/qmmp-1.3.1/src/plugins/Effect/soxr/effectsoxrfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/crossfade/effectcrossfadefactory.h Examining data/qmmp-1.3.1/src/plugins/Effect/crossfade/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Effect/crossfade/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/crossfade/crossfadeplugin.h Examining data/qmmp-1.3.1/src/plugins/Effect/crossfade/effectcrossfadefactory.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/crossfade/crossfadeplugin.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/monotostereo/monotostereoplugin.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/monotostereo/monotostereoplugin.h Examining data/qmmp-1.3.1/src/plugins/Effect/monotostereo/effectmonotostereofactory.h Examining data/qmmp-1.3.1/src/plugins/Effect/monotostereo/effectmonotostereofactory.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/stereo/stereoplugin.h Examining data/qmmp-1.3.1/src/plugins/Effect/stereo/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Effect/stereo/effectstereofactory.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/stereo/stereoplugin.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/stereo/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/stereo/effectstereofactory.h Examining data/qmmp-1.3.1/src/plugins/Effect/ladspa/ladspabutton.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/ladspa/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Effect/ladspa/ladspahelper.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/ladspa/ladspabutton.h Examining data/qmmp-1.3.1/src/plugins/Effect/ladspa/ladspaslider.h Examining data/qmmp-1.3.1/src/plugins/Effect/ladspa/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/ladspa/effectladspafactory.h Examining data/qmmp-1.3.1/src/plugins/Effect/ladspa/effectladspafactory.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/ladspa/ladspa.h Examining data/qmmp-1.3.1/src/plugins/Effect/ladspa/ladspahost.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/ladspa/ladspaslider.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/ladspa/ladspahost.h Examining data/qmmp-1.3.1/src/plugins/Effect/ladspa/ladspahelper.h Examining data/qmmp-1.3.1/src/plugins/Effect/bs2b/bs2bplugin.h Examining data/qmmp-1.3.1/src/plugins/Effect/bs2b/settingsdialog.h Examining data/qmmp-1.3.1/src/plugins/Effect/bs2b/settingsdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/bs2b/effectbs2bfactory.h Examining data/qmmp-1.3.1/src/plugins/Effect/bs2b/effectbs2bfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Effect/bs2b/bs2bplugin.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/titlebarcontrol.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/actionmanager.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/button.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/listwidgetdrawer.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/popupwidget.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/shadedbar.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/togglebutton.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/hotkeyeditor.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/windowsystem.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/titlebar.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/display.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/playlistheader.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/shadedvisual.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/mainvisual.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/cursorimage.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/textscroller.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/preseteditor.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/eqslider.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/playlistselector.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/fft.c Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/playlisttitlebar.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/keyboardmanager.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/popupsettings.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/visualmenu.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/playlistbrowser.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/popupwidget.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/skinnedfactory.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/shadedbar.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/keyboardmanager.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/skin.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/listwidgetdrawer.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/skinreader.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/eqwidget.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/titlebarcontrol.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/positionbar.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/eqtitlebar.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/horizontalslider.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/timeindicator.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/inlines.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/listwidget.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/dock.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/positionbar.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/pixmapwidget.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/button.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/playlistcontrol.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/playlist.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/playlistbrowser.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/eqgraph.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/playlist.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/shortcutitem.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/timeindicator.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/shortcutdialog.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/monostereo.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/fft.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/monostereo.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/symboldisplay.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/eqpreset.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/shortcutdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/volumebar.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/dock.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/display.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/eqgraph.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/playlistslider.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/playlistheader.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/visualmenu.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/playlistcontrol.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/mainwindow.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/number.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/skinnedsettings.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/playlisttitlebar.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/playlistslider.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/playlistselector.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/symboldisplay.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/titlebar.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/balancebar.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/volumebar.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/skin.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/eqwidget.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/popupsettings.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/togglebutton.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/playstatus.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/cursorimage.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/pixmapwidget.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/number.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/listwidget.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/preseteditor.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/shortcutitem.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/playstatus.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/balancebar.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/skinnedfactory.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/hotkeyeditor.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/eqtitlebar.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/skinreader.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/horizontalslider.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/mainvisual.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/eqslider.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/actionmanager.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/eqpreset.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/shadedvisual.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/mainwindow.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/windowsystem.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/textscroller.h Examining data/qmmp-1.3.1/src/plugins/Ui/skinned/skinnedsettings.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/actionmanager.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/listwidgetdrawer.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/popupwidget.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/logo.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/volumeslider.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/equalizer.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/hotkeyeditor.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/playlistheader.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/elidinglabel.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/coverwidget.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/colorwidget.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/fft.c Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/keyboardmanager.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/qsuitabwidget.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/qsuitabbar.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/popupsettings.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/visualmenu.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/qsuianalyzer.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/playlistbrowser.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/popupwidget.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/keyboardmanager.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/listwidgetdrawer.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/aboutqsuidialog.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/filesystembrowser.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/qsuiquicksearch.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/qsuifactory.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/positionslider.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/inlines.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/listwidget.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/qsuisettings.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/playlistbrowser.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/qsuisettings.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/qsuitabbar.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/toolbareditor.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/shortcutitem.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/qsuifactory.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/colorwidget.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/shortcutdialog.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/qsuianalyzer.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/fft.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/eqpreset.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/shortcutdialog.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/playlistheader.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/visualmenu.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/qsuiquicksearch.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/mainwindow.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/logo.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/toolbareditor.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/popupsettings.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/aboutqsuidialog.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/listwidget.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/positionslider.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/shortcutitem.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/qsuitabwidget.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/hotkeyeditor.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/filesystembrowser.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/volumeslider.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/elidinglabel.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/equalizer.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/actionmanager.cpp Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/eqpreset.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/mainwindow.h Examining data/qmmp-1.3.1/src/plugins/Ui/qsui/coverwidget.cpp Examining data/qmmp-1.3.1/src/qmmp/abstractengine.h Examining data/qmmp-1.3.1/src/qmmp/qmmpplugincache_p.h Examining data/qmmp-1.3.1/src/qmmp/qmmpsettings.h Examining data/qmmp-1.3.1/src/qmmp/soundcore.h Examining data/qmmp-1.3.1/src/qmmp/dithering.cpp Examining data/qmmp-1.3.1/src/qmmp/volume.h Examining data/qmmp-1.3.1/src/qmmp/soundcore.cpp Examining data/qmmp-1.3.1/src/qmmp/qmmpaudioengine_p.h Examining data/qmmp-1.3.1/src/qmmp/visual.h Examining data/qmmp-1.3.1/src/qmmp/metadatamanager.cpp Examining data/qmmp-1.3.1/src/qmmp/fileinputsource.cpp Examining data/qmmp-1.3.1/src/qmmp/qmmpplugincache.cpp Examining data/qmmp-1.3.1/src/qmmp/emptyinputsource_p.h Examining data/qmmp-1.3.1/src/qmmp/effect.h Examining data/qmmp-1.3.1/src/qmmp/qmmpevents.cpp Examining data/qmmp-1.3.1/src/qmmp/enginefactory.h Examining data/qmmp-1.3.1/src/qmmp/channelmap.cpp Examining data/qmmp-1.3.1/src/qmmp/replaygain_p.h Examining data/qmmp-1.3.1/src/qmmp/decoder.cpp Examining data/qmmp-1.3.1/src/qmmp/volume.cpp Examining data/qmmp-1.3.1/src/qmmp/tagmodel.cpp Examining data/qmmp-1.3.1/src/qmmp/qmmp.cpp Examining data/qmmp-1.3.1/src/qmmp/audioconverter.cpp Examining data/qmmp-1.3.1/src/qmmp/volumecontrol.cpp Examining data/qmmp-1.3.1/src/qmmp/fileinputsource_p.h Examining data/qmmp-1.3.1/src/qmmp/visual.cpp Examining data/qmmp-1.3.1/src/qmmp/metadatamanager.h Examining data/qmmp-1.3.1/src/qmmp/qmmp.h Examining data/qmmp-1.3.1/src/qmmp/audioparameters.cpp Examining data/qmmp-1.3.1/src/qmmp/trackinfo.cpp Examining data/qmmp-1.3.1/src/qmmp/volumecontrol_p.h Examining data/qmmp-1.3.1/src/qmmp/audioconverter.h Examining data/qmmp-1.3.1/src/qmmp/emptyinputsource.cpp Examining data/qmmp-1.3.1/src/qmmp/decoder.h Examining data/qmmp-1.3.1/src/qmmp/metadatamodel.cpp Examining data/qmmp-1.3.1/src/qmmp/replaygain.cpp Examining data/qmmp-1.3.1/src/qmmp/recycler.cpp Examining data/qmmp-1.3.1/src/qmmp/statehandler.h Examining data/qmmp-1.3.1/src/qmmp/visualbuffer_p.h Examining data/qmmp-1.3.1/src/qmmp/equ/iir.h Examining data/qmmp-1.3.1/src/qmmp/equ/iir_fpu.h Examining data/qmmp-1.3.1/src/qmmp/equ/iir_fpu.c Examining data/qmmp-1.3.1/src/qmmp/equ/iir.c Examining data/qmmp-1.3.1/src/qmmp/equ/iir_cfs.c Examining data/qmmp-1.3.1/src/qmmp/equ/iir_cfs.h Examining data/qmmp-1.3.1/src/qmmp/metadatamodel.h Examining data/qmmp-1.3.1/src/qmmp/output.cpp Examining data/qmmp-1.3.1/src/qmmp/inputsource.h Examining data/qmmp-1.3.1/src/qmmp/qmmpevents_p.h Examining data/qmmp-1.3.1/src/qmmp/channelconverter.cpp Examining data/qmmp-1.3.1/src/qmmp/effect.cpp Examining data/qmmp-1.3.1/src/qmmp/eqsettings.cpp Examining data/qmmp-1.3.1/src/qmmp/channelmap.h Examining data/qmmp-1.3.1/src/qmmp/outputwriter_p.h Examining data/qmmp-1.3.1/src/qmmp/qmmp_export.h Examining data/qmmp-1.3.1/src/qmmp/inputsource.cpp Examining data/qmmp-1.3.1/src/qmmp/buffer.h Examining data/qmmp-1.3.1/src/qmmp/visualbuffer.cpp Examining data/qmmp-1.3.1/src/qmmp/tagmodel.h Examining data/qmmp-1.3.1/src/qmmp/output.h Examining data/qmmp-1.3.1/src/qmmp/decoderfactory.h Examining data/qmmp-1.3.1/src/qmmp/outputwriter.cpp Examining data/qmmp-1.3.1/src/qmmp/abstractengine.cpp Examining data/qmmp-1.3.1/src/qmmp/recycler_p.h Examining data/qmmp-1.3.1/src/qmmp/statehandler.cpp Examining data/qmmp-1.3.1/src/qmmp/audioparameters.h Examining data/qmmp-1.3.1/src/qmmp/qmmpsettings.cpp Examining data/qmmp-1.3.1/src/qmmp/outputfactory.h Examining data/qmmp-1.3.1/src/qmmp/visualfactory.h Examining data/qmmp-1.3.1/src/qmmp/effectfactory.h Examining data/qmmp-1.3.1/src/qmmp/dithering_p.h Examining data/qmmp-1.3.1/src/qmmp/inputsourcefactory.h Examining data/qmmp-1.3.1/src/qmmp/eqsettings.h Examining data/qmmp-1.3.1/src/qmmp/channelconverter_p.h Examining data/qmmp-1.3.1/src/qmmp/qmmpaudioengine.cpp Examining data/qmmp-1.3.1/src/qmmp/trackinfo.h Examining data/qmmp-1.3.1/src/app/main.cpp Examining data/qmmp-1.3.1/src/app/builtincommandlineoption.cpp Examining data/qmmp-1.3.1/src/app/qmmpstarter.h Examining data/qmmp-1.3.1/src/app/builtincommandlineoption.h Examining data/qmmp-1.3.1/src/app/qmmpstarter.cpp FINAL RESULTS: data/qmmp-1.3.1/src/app/qmmpstarter.cpp:174:9: [5] (race) chmod: This accepts filename arguments; if an attacker can move those files, a race condition results. (CWE-362). Use fchmod( ) instead. chmod(UDS_PATH, S_IRUSR | S_IWUSR); data/qmmp-1.3.1/src/app/qmmpstarter.cpp:201:17: [5] (race) chmod: This accepts filename arguments; if an attacker can move those files, a race condition results. (CWE-362). Use fchmod( ) instead. chmod(UDS_PATH, S_IRUSR | S_IWUSR); data/qmmp-1.3.1/src/plugins/General/converter/converter.cpp:207:70: [4] (shell) popen: This causes a new program to execute and is difficult to use safely (CWE-78). try using a library call that implements the same functionality if available. FILE *enc_pipe = use_file ? fopen(qPrintable(tmp_path), "w+b") : popen(qPrintable(command), "w"); data/qmmp-1.3.1/src/plugins/General/converter/converter.cpp:241:20: [4] (shell) popen: This causes a new program to execute and is difficult to use safely (CWE-78). try using a library call that implements the same functionality if available. enc_pipe = popen(qPrintable(command), "w"); data/qmmp-1.3.1/src/plugins/Input/gme/gmehelper.cpp:116:59: [4] (shell) system: This causes a new program to execute and is difficult to use safely (CWE-78). try using a library call that implements the same functionality if available. info->setValue(Qmmp::FORMAT_NAME, track_info->system); data/qmmp-1.3.1/src/plugins/Output/jack/bio2jack.c:71:3: [4] (format) fprintf: If format strings can be influenced by an attacker, they can be exploited (CWE-134). Use a constant for the format specification. fprintf(OUTFILE, "%ld.%06ld: %s::%s(%d) "format, timer_now.tv_sec, timer_now.tv_usec, __FILE__, __FUNCTION__, __LINE__, ##args) data/qmmp-1.3.1/src/plugins/Output/jack/bio2jack.c:79:5: [4] (format) fprintf: If format strings can be influenced by an attacker, they can be exploited (CWE-134). Use a constant for the format specification. fprintf(OUTFILE, "%s::%s(%d) "format, __FILE__, __FUNCTION__, __LINE__,##args); \ data/qmmp-1.3.1/src/plugins/Output/jack/bio2jack.c:89:5: [4] (format) fprintf: If format strings can be influenced by an attacker, they can be exploited (CWE-134). Use a constant for the format specification. fprintf(OUTFILE, "%s::%s(%d) "format, __FILE__, __FUNCTION__, __LINE__,##args); \ data/qmmp-1.3.1/src/plugins/Output/jack/bio2jack.c:99:5: [4] (format) fprintf: If format strings can be influenced by an attacker, they can be exploited (CWE-134). Use a constant for the format specification. fprintf(OUTFILE, "%s::%s(%d) "format, __FILE__, __FUNCTION__, __LINE__,##args); \ data/qmmp-1.3.1/src/plugins/Output/jack/bio2jack.c:109:4: [4] (format) fprintf: If format strings can be influenced by an attacker, they can be exploited (CWE-134). Use a constant for the format specification. fprintf(OUTFILE, "WARN: %s::%s(%d) "format, __FILE__,__FUNCTION__,__LINE__,##args); \ data/qmmp-1.3.1/src/plugins/Output/jack/bio2jack.c:118:5: [4] (format) fprintf: If format strings can be influenced by an attacker, they can be exploited (CWE-134). Use a constant for the format specification. fprintf(OUTFILE, "ERR: %s::%s(%d) "format, __FILE__,__FUNCTION__,__LINE__,##args); \ data/qmmp-1.3.1/src/plugins/Output/jack/bio2jack.c:984:3: [4] (buffer) sprintf: Does not check for buffer overflows (CWE-120). Use sprintf_s, snprintf, or vsnprintf. sprintf(our_client_name, "%s_%d_%d%02d", client_name, getpid(), data/qmmp-1.3.1/src/qmmp/qmmp.cpp:130:22: [4] (shell) system: This causes a new program to execute and is difficult to use safely (CWE-78). try using a library call that implements the same functionality if available. return QLocale::system().name(); data/qmmp-1.3.1/src/plugins/Output/waveout/outputwaveout.cpp:48:9: [3] (misc) EnterCriticalSection: On some versions of Windows, exceptions can be thrown in low-memory situations. Use InitializeCriticalSectionAndSpinCount instead. EnterCriticalSection (&cs); data/qmmp-1.3.1/src/plugins/Output/waveout/outputwaveout.cpp:61:5: [3] (misc) EnterCriticalSection: On some versions of Windows, exceptions can be thrown in low-memory situations. Use InitializeCriticalSectionAndSpinCount instead. EnterCriticalSection (&cs); data/qmmp-1.3.1/src/plugins/Output/waveout/outputwaveout.cpp:134:5: [3] (misc) InitializeCriticalSection: Exceptions can be thrown in low-memory situations. Use InitializeCriticalSectionAndSpinCount instead. InitializeCriticalSection (&cs); data/qmmp-1.3.1/src/plugins/Output/waveout/outputwaveout.cpp:200:5: [3] (misc) EnterCriticalSection: On some versions of Windows, exceptions can be thrown in low-memory situations. Use InitializeCriticalSectionAndSpinCount instead. EnterCriticalSection (&cs); data/qmmp-1.3.1/src/qmmp/dithering.cpp:102:27: [3] (random) random: This function is not sufficiently random for security-related functions such as key and nonce creation (CWE-327). Use a more secure technique for acquiring random values. float output; quint32 random; data/qmmp-1.3.1/src/qmmp/dithering.cpp:114:27: [3] (random) random: This function is not sufficiently random for security-related functions such as key and nonce creation (CWE-327). Use a more secure technique for acquiring random values. random = prng(dither->random); data/qmmp-1.3.1/src/qmmp/dithering.cpp:115:40: [3] (random) random: This function is not sufficiently random for security-related functions such as key and nonce creation (CWE-327). Use a more secure technique for acquiring random values. output += (float)(random - dither->random) / 0xffffffffL * m_lsb; data/qmmp-1.3.1/src/qmmp/dithering.cpp:116:22: [3] (random) random: This function is not sufficiently random for security-related functions such as key and nonce creation (CWE-327). Use a more secure technique for acquiring random values. dither->random = random; data/qmmp-1.3.1/src/qmmp/dithering_p.h:49:17: [3] (random) random: This function is not sufficiently random for security-related functions such as key and nonce creation (CWE-327). Use a more secure technique for acquiring random values. quint32 random; data/qmmp-1.3.1/src/plugins/Effect/crossfade/crossfadeplugin.cpp:81:17: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(m_buffer + m_buffer_at, b->data, b->samples * sizeof(float)); data/qmmp-1.3.1/src/plugins/Effect/filewriter/filewriterplugin.cpp:141:16: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(!m_file.open(QIODevice::WriteOnly)) data/qmmp-1.3.1/src/plugins/Effect/monotostereo/monotostereoplugin.cpp:51:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(m_tmp, b->data, b->samples * sizeof(float)); data/qmmp-1.3.1/src/plugins/Effect/soxr/soxresampler.cpp:58:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(b->data, m_out, b->samples * sizeof(float)); data/qmmp-1.3.1/src/plugins/General/converter/converter.cpp:72:33: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(!source->ioDevice()->open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/plugins/General/converter/converter.cpp:201:5: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(&wave_header[22], &channels, 2); data/qmmp-1.3.1/src/plugins/General/converter/converter.cpp:202:5: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(&wave_header[24], &sample_rate, 4); data/qmmp-1.3.1/src/plugins/General/converter/converter.cpp:203:5: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(&wave_header[32], &block_align, 2); data/qmmp-1.3.1/src/plugins/General/converter/converter.cpp:204:5: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(&wave_header[34], &bps, 2); data/qmmp-1.3.1/src/plugins/General/converter/converter.cpp:205:5: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(&wave_header[40], &size, 4); data/qmmp-1.3.1/src/plugins/General/converter/converter.cpp:207:33: [2] (misc) fopen: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). FILE *enc_pipe = use_file ? fopen(qPrintable(tmp_path), "w+b") : popen(qPrintable(command), "w"); data/qmmp-1.3.1/src/plugins/General/converter/converter.cpp:309:14: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. unsigned char input_buffer[QMMP_BLOCK_FRAMES * ap.frameSize() * 4]; data/qmmp-1.3.1/src/plugins/General/converter/converter.cpp:311:14: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. unsigned char output_buffer[QMMP_BLOCK_FRAMES * outSampleSize * ap.channels() * 4]; data/qmmp-1.3.1/src/plugins/General/converter/converterdialog.cpp:269:14: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(!file.open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/plugins/General/converter/converterdialog.cpp:306:14: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(!file.open(QIODevice::WriteOnly | QIODevice::Truncate)) data/qmmp-1.3.1/src/plugins/General/fileops/fileops.cpp:182:17: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if (!in.open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/plugins/General/fileops/fileops.cpp:187:18: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if (!out.open(QIODevice::WriteOnly)) data/qmmp-1.3.1/src/plugins/General/fileops/fileops.cpp:285:17: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if (!in.open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/plugins/General/fileops/fileops.cpp:290:18: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if (!out.open(QIODevice::WriteOnly)) data/qmmp-1.3.1/src/plugins/General/history/history.cpp:44:12: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). db.open(); data/qmmp-1.3.1/src/plugins/General/lyrics/lyricswindow.cpp:201:14: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(!file.open(QIODevice::ReadOnly | QIODevice::Text)) data/qmmp-1.3.1/src/plugins/General/lyrics/lyricswindow.cpp:216:14: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(!file.open(QIODevice::WriteOnly | QIODevice::Text)) data/qmmp-1.3.1/src/plugins/General/notifier/notifier.cpp:148:14: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). file.open(QIODevice::WriteOnly | QIODevice::Text | QIODevice::Truncate); data/qmmp-1.3.1/src/plugins/General/rgscan/gain_analysis.c:346:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy (handle->linprebuf + MAX_ORDER, left_samples , num_samples * sizeof(Float_t) ); data/qmmp-1.3.1/src/plugins/General/rgscan/gain_analysis.c:347:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy (handle->rinprebuf + MAX_ORDER, right_samples, num_samples * sizeof(Float_t) ); data/qmmp-1.3.1/src/plugins/General/rgscan/gain_analysis.c:351:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy (handle->linprebuf + MAX_ORDER, left_samples, MAX_ORDER * sizeof(Float_t) ); data/qmmp-1.3.1/src/plugins/General/rgscan/gain_analysis.c:352:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy (handle->rinprebuf + MAX_ORDER, right_samples, MAX_ORDER * sizeof(Float_t) ); data/qmmp-1.3.1/src/plugins/General/rgscan/gain_analysis.c:451:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(handle->linprebuf + MAX_ORDER - num_samples, left_samples, num_samples * sizeof(Float_t)); data/qmmp-1.3.1/src/plugins/General/rgscan/gain_analysis.c:452:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(handle->rinprebuf + MAX_ORDER - num_samples, right_samples, num_samples * sizeof(Float_t)); data/qmmp-1.3.1/src/plugins/General/rgscan/gain_analysis.c:456:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(handle->linprebuf, left_samples + num_samples - MAX_ORDER, MAX_ORDER * sizeof(Float_t)); data/qmmp-1.3.1/src/plugins/General/rgscan/gain_analysis.c:457:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(handle->rinprebuf, right_samples + num_samples - MAX_ORDER, MAX_ORDER * sizeof(Float_t)); data/qmmp-1.3.1/src/plugins/General/rgscan/rgscanner.cpp:68:51: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(source->ioDevice() && !source->ioDevice()->open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/plugins/General/rgscan/rgscanner.cpp:186:14: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. unsigned char char_buf[buf_size]; //char buffer data/qmmp-1.3.1/src/plugins/General/scrobbler/scrobblercache.cpp:123:14: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(!file.open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/plugins/General/scrobbler/scrobblercache.cpp:171:14: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(!file.open(QIODevice::WriteOnly)) data/qmmp-1.3.1/src/plugins/General/streambrowser/streamwindow.cpp:123:13: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(file.open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/plugins/General/streambrowser/streamwindow.cpp:128:14: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(file2.open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/plugins/General/streambrowser/streamwindow.cpp:333:10: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). file.open(QIODevice::WriteOnly); data/qmmp-1.3.1/src/plugins/General/streambrowser/streamwindow.cpp:354:11: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). file2.open(QIODevice::WriteOnly); data/qmmp-1.3.1/src/plugins/Input/aac/aacfile.cpp:41:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char buf[AAC_BUFFER_SIZE]; data/qmmp-1.3.1/src/plugins/Input/aac/decoder_aac.cpp:89:9: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char data[aac_file.offset()]; data/qmmp-1.3.1/src/plugins/Input/aac/decoder_aac.cpp:183:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(audio, (char *)(m_sample_buf) + m_sample_buf_at, size); data/qmmp-1.3.1/src/plugins/Input/aac/decoderaacfactory.cpp:62:14: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(!file.open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/plugins/Input/archive/archiveinputdevice.cpp:53:13: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). open(QIODevice::ReadOnly); data/qmmp-1.3.1/src/plugins/Input/archive/archiveinputdevice.cpp:54:22: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). m_buffer.open(QBuffer::ReadWrite); data/qmmp-1.3.1/src/plugins/Input/archive/archiveinputdevice.cpp:66:5: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). open(QIODevice::ReadOnly); data/qmmp-1.3.1/src/plugins/Input/archive/archiveinputdevice.cpp:67:14: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). m_buffer.open(QBuffer::ReadWrite); data/qmmp-1.3.1/src/plugins/Input/archive/archiveinputdevice.cpp:87:9: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char tmp[1024]; data/qmmp-1.3.1/src/plugins/Input/archive/archiveinputdevice.cpp:121:9: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char tmp[l]; data/qmmp-1.3.1/src/plugins/Input/cdaudio/decoder_cdaudio.cpp:508:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(audio, m_buffer, len); data/qmmp-1.3.1/src/plugins/Input/cue/cueparser.cpp:43:15: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if (!file.open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/plugins/Input/cue/decoder_cue.cpp:85:22: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(!m_input->open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/plugins/Input/ffmpeg/decoder_ffmpeg.cpp:341:13: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(audio + i * bps, m_decoded_frame->extended_data[i % m_channels] + i / m_channels * bps, bps); data/qmmp-1.3.1/src/plugins/Input/ffmpeg/decoder_ffmpeg.cpp:353:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(audio, m_decoded_frame->extended_data[0], len); data/qmmp-1.3.1/src/plugins/Input/flac/decoder_flac.cpp:107:5: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy (buf, data->sample_buffer, to_copy); data/qmmp-1.3.1/src/plugins/Input/flac/decoder_flac.cpp:321:32: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). m_data->input->open(QIODevice::ReadOnly); data/qmmp-1.3.1/src/plugins/Input/flac/decoder_flac.cpp:365:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char buf[500]; data/qmmp-1.3.1/src/plugins/Input/flac/decoderflacfactory.cpp:39:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char buf[36]; data/qmmp-1.3.1/src/plugins/Input/flac/flacmetadatamodel.cpp:146:16: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). buffer.open(QIODevice::WriteOnly); data/qmmp-1.3.1/src/plugins/Input/modplug/decoder_modplug.cpp:78:19: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if (!file.open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/plugins/Input/modplug/decodermodplugfactory.cpp:84:19: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if (!file.open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/plugins/Input/modplug/modplugmetadatamodel.cpp:44:18: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(!file.open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/plugins/Input/modplug/modplugmetadatamodel.cpp:85:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char lBuffer[33]; data/qmmp-1.3.1/src/plugins/Input/modplug/modplugmetadatamodel.cpp:105:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char message[MAX_MESSAGE_LENGTH]; data/qmmp-1.3.1/src/plugins/Input/mpc/decoder_mpc.cpp:157:13: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(audio, buffer, qMin(qint64(m_len * sizeof(float)), maxSize)); data/qmmp-1.3.1/src/plugins/Input/mpc/decodermpcfactory.cpp:34:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char buf[36]; data/qmmp-1.3.1/src/plugins/Input/mpeg/decoder_mad.h:82:18: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. unsigned char toc[100]; data/qmmp-1.3.1/src/plugins/Input/mpeg/decodermpegfactory.cpp:69:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char buf[8192]; data/qmmp-1.3.1/src/plugins/Input/mpeg/mpegmetadatamodel.cpp:131:12: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). buffer.open(QIODevice::WriteOnly); data/qmmp-1.3.1/src/plugins/Input/mpeg/tagextractor.cpp:106:12: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). m_buf->open(QIODevice::ReadOnly); data/qmmp-1.3.1/src/plugins/Input/opus/decoderopusfactory.cpp:32:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char buf[36]; data/qmmp-1.3.1/src/plugins/Input/opus/opusmetadatamodel.cpp:119:16: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). buffer.open(QIODevice::WriteOnly); data/qmmp-1.3.1/src/plugins/Input/sid/decoder_sid.cpp:95:9: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char md5[SidTune::MD5_LENGTH+1]; data/qmmp-1.3.1/src/plugins/Input/sid/decodersidfactory.cpp:41:18: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(!m_db.open(qPrintable(settings.value("hvsc_path", default_path).toString()))) data/qmmp-1.3.1/src/plugins/Input/sid/decodersidfactory.cpp:49:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char buf[4]; data/qmmp-1.3.1/src/plugins/Input/sid/settingsdialog.cpp:83:19: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(!m_db->open(qPrintable(m_ui.hvscPathLineEdit->text()))) data/qmmp-1.3.1/src/plugins/Input/sid/sidhelper.cpp:66:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char md5[SidTune::MD5_LENGTH+1]; data/qmmp-1.3.1/src/plugins/Input/sndfile/decodersndfilefactory.cpp:43:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char buf[36] = {0}; data/qmmp-1.3.1/src/plugins/Input/sndfile/decodersndfilefactory.cpp:223:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char version [128] = { 0 }; data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:194:58: [2] (integer) atoi: Unless checked, the resulting number can exceed the expected range (CWE-190). If source untrusted, check both minimum and maximum, even if the input had no minus sign (large numbers can roll over into negative number; consider saving to an unsigned value if that is intended). metaData.insert(Qmmp::TRACK, QString::number(atoi(comments->user_comments[i] data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:198:58: [2] (integer) atoi: Unless checked, the resulting number can exceed the expected range (CWE-190). If source untrusted, check both minimum and maximum, even if the input had no minus sign (large numbers can roll over into negative number; consider saving to an unsigned value if that is intended). metaData.insert(Qmmp::TRACK, QString::number(atoi(comments->user_comments[i] data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:202:57: [2] (integer) atoi: Unless checked, the resulting number can exceed the expected range (CWE-190). If source untrusted, check both minimum and maximum, even if the input had no minus sign (large numbers can roll over into negative number; consider saving to an unsigned value if that is intended). metaData.insert(Qmmp::YEAR, QString::number(atoi(comments->user_comments[i] data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:210:63: [2] (integer) atoi: Unless checked, the resulting number can exceed the expected range (CWE-190). If source untrusted, check both minimum and maximum, even if the input had no minus sign (large numbers can roll over into negative number; consider saving to an unsigned value if that is intended). metaData.insert(Qmmp::DISCNUMBER, QString::number(atoi(comments->user_comments[i] data/qmmp-1.3.1/src/plugins/Input/vorbis/decodervorbisfactory.cpp:33:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char buf[36]; data/qmmp-1.3.1/src/plugins/Input/vorbis/vorbismetadatamodel.cpp:105:16: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). buffer.open(QIODevice::WriteOnly); data/qmmp-1.3.1/src/plugins/Input/wavpack/decoder_wavpack.cpp:65:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char err [80]; data/qmmp-1.3.1/src/plugins/Input/wavpack/decoderwavpackfactory.cpp:30:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char buf[4]; data/qmmp-1.3.1/src/plugins/Input/wavpack/decoderwavpackfactory.cpp:80:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char err[80]; data/qmmp-1.3.1/src/plugins/Input/wavpack/decoderwavpackfactory.cpp:103:13: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char value[cue_len + 1]; data/qmmp-1.3.1/src/plugins/Input/wavpack/decoderwavpackfactory.cpp:112:13: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char value[200] = { 0 }; data/qmmp-1.3.1/src/plugins/Input/wavpack/decoderwavpackfactory.cpp:148:9: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char value[200] = { 0 }; data/qmmp-1.3.1/src/plugins/Input/wavpack/wavpackmetadatamodel.cpp:38:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char err[80] = {0}; data/qmmp-1.3.1/src/plugins/Input/wavpack/wavpackmetadatamodel.cpp:103:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char value[200]; data/qmmp-1.3.1/src/plugins/Input/wildmidi/decoderwildmidifactory.cpp:36:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char buf[4]; data/qmmp-1.3.1/src/plugins/Output/alsa/outputalsa.cpp:217:9: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char tmp[256]; data/qmmp-1.3.1/src/plugins/Output/alsa/outputalsa.cpp:503:18: [2] (integer) atoi: Unless checked, the resulting number can exceed the expected range (CWE-190). If source untrusted, check both minimum and maximum, even if the input had no minus sign (large numbers can roll over into negative number; consider saving to an unsigned value if that is intended). *index = atoi(end); data/qmmp-1.3.1/src/plugins/Output/alsa/settingsdialog.cpp:128:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char dev[64], *card_name; data/qmmp-1.3.1/src/plugins/Output/alsa/settingsdialog.cpp:130:5: [2] (buffer) sprintf: Does not check for buffer overflows (CWE-120). Use sprintf_s, snprintf, or vsnprintf. Risk is low because the source has a constant maximum length. sprintf(dev, "hw:%i", card); data/qmmp-1.3.1/src/plugins/Output/jack/bio2jack.c:1037:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char portname[32]; data/qmmp-1.3.1/src/plugins/Output/jack/bio2jack.c:1038:5: [2] (buffer) sprintf: Does not check for buffer overflows (CWE-120). Use sprintf_s, snprintf, or vsnprintf. Risk is low because the source has a constant maximum length. sprintf(portname, "out_%d", i); data/qmmp-1.3.1/src/plugins/Output/jack/bio2jack.c:1051:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char portname[32]; data/qmmp-1.3.1/src/plugins/Output/jack/bio2jack.c:1052:5: [2] (buffer) sprintf: Does not check for buffer overflows (CWE-120). Use sprintf_s, snprintf, or vsnprintf. Risk is low because the source has a constant maximum length. sprintf(portname, "in_%d", i); data/qmmp-1.3.1/src/plugins/Output/oss/outputoss.cpp:75:18: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). m_audio_fd = open(m_audio_device.toLatin1().constData(), O_WRONLY); data/qmmp-1.3.1/src/plugins/Output/oss/outputoss.cpp:218:18: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). m_mixer_fd = open(m_mixer_device.toLatin1().constData(), O_RDWR); data/qmmp-1.3.1/src/plugins/Output/oss4/outputoss4.cpp:111:18: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). m_audio_fd = open(m_audio_device.toLatin1().constData(), O_WRONLY); data/qmmp-1.3.1/src/plugins/Output/oss4/settingsdialog.cpp:53:23: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if ((mixer_fd = ::open(DEFAULT_MIXER, O_RDWR)) < 0) data/qmmp-1.3.1/src/plugins/Output/shout/shoutclient.cpp:68:19: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). bool ShoutClient::open() data/qmmp-1.3.1/src/plugins/Output/shout/shoutclient.h:37:10: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). bool open(); data/qmmp-1.3.1/src/plugins/Output/shout/shoutoutput.cpp:81:22: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). return m_client->open(); data/qmmp-1.3.1/src/plugins/Output/shout/shoutoutput.cpp:129:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(buffer[0], input_data, frames * sizeof(float)); data/qmmp-1.3.1/src/plugins/Output/shout/shoutoutput.cpp:130:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(buffer[1], input_data, frames * sizeof(float)); data/qmmp-1.3.1/src/plugins/Output/shout/shoutoutput.cpp:188:23: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(!m_client->open()) data/qmmp-1.3.1/src/plugins/Output/wasapi/outputwasapi.cpp:254:5: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(pData, data, framesToWrite * m_frameSize); data/qmmp-1.3.1/src/plugins/Output/waveout/outputwaveout.cpp:177:5: [2] (buffer) CopyMemory: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. CopyMemory (allocptr, data, len); // Here we can call any modification output functions we want.... data/qmmp-1.3.1/src/plugins/Transports/http/httpstreamreader.cpp:70:5: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(dl->stream()->buf + dl->stream()->buf_fill, data, data_size); data/qmmp-1.3.1/src/plugins/Transports/http/httpstreamreader.cpp:213:24: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). bool HttpStreamReader::open(OpenMode mode) data/qmmp-1.3.1/src/plugins/Transports/http/httpstreamreader.cpp:217:20: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). QIODevice::open(mode); data/qmmp-1.3.1/src/plugins/Transports/http/httpstreamreader.cpp:323:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char errorBuffer[CURL_ERROR_SIZE]; data/qmmp-1.3.1/src/plugins/Transports/http/httpstreamreader.cpp:405:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(data, m_stream.buf, len); data/qmmp-1.3.1/src/plugins/Transports/http/httpstreamreader.cpp:461:9: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char packet[size]; data/qmmp-1.3.1/src/plugins/Transports/http/httpstreamreader.h:74:10: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). bool open (OpenMode mode) override; data/qmmp-1.3.1/src/plugins/Transports/mms/mmsstreamreader.cpp:76:23: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). bool MMSStreamReader::open (OpenMode mode) data/qmmp-1.3.1/src/plugins/Transports/mms/mmsstreamreader.cpp:80:16: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). QIODevice::open(mode); data/qmmp-1.3.1/src/plugins/Transports/mms/mmsstreamreader.cpp:142:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char prebuf[to_read]; data/qmmp-1.3.1/src/plugins/Transports/mms/mmsstreamreader.cpp:197:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(m_buffer + m_buffer_at, prebuf, len); data/qmmp-1.3.1/src/plugins/Transports/mms/mmsstreamreader.h:55:10: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). bool open (OpenMode mode) override; data/qmmp-1.3.1/src/plugins/Ui/qsui/aboutqsuidialog.cpp:72:18: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if (file.open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/plugins/Ui/qsui/logo.cpp:58:10: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). file.open(QIODevice::ReadOnly | QIODevice::Text); data/qmmp-1.3.1/src/plugins/Ui/skinned/cursorimage.cpp:38:10: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). curFile.open(QIODevice::ReadOnly); data/qmmp-1.3.1/src/plugins/Ui/skinned/cursorimage.cpp:65:12: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. unsigned char magic[2]; data/qmmp-1.3.1/src/plugins/Ui/skinned/eqwidget.cpp:404:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char header[31]; data/qmmp-1.3.1/src/plugins/Ui/skinned/eqwidget.cpp:405:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char name[257]; data/qmmp-1.3.1/src/plugins/Ui/skinned/eqwidget.cpp:406:5: [2] (buffer) char: Statically-sized arrays can be improperly restricted, leading to potential overflows or other issues (CWE-119!/CWE-120). Perform bounds checking, use functions that limit length, or ensure that the size is larger than the maximum possible length. char bands[11]; data/qmmp-1.3.1/src/plugins/Ui/skinned/eqwidget.cpp:412:10: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). file.open(QIODevice::ReadOnly); data/qmmp-1.3.1/src/plugins/Ui/skinned/inlines.h:41:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(l, s, cnt * sizeof(float)); data/qmmp-1.3.1/src/plugins/Ui/skinned/inlines.h:42:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(r, s, cnt * sizeof(float)); data/qmmp-1.3.1/src/plugins/Ui/skinned/inlines.h:62:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(l, s, cnt * sizeof(float)); data/qmmp-1.3.1/src/plugins/Ui/skinned/skin.cpp:450:15: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if (!file.open(QIODevice::ReadOnly | QIODevice::Text)) data/qmmp-1.3.1/src/plugins/Ui/skinned/skin.cpp:561:15: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if (!file.open(QIODevice::ReadOnly | QIODevice::Text)) data/qmmp-1.3.1/src/plugins/Ui/skinned/skinreader.cpp:180:18: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). file.open(QIODevice::WriteOnly); data/qmmp-1.3.1/src/qmmp/audioconverter.cpp:103:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy((void*)out, (void*)in, samples * sizeof(float)); data/qmmp-1.3.1/src/qmmp/audioconverter.cpp:155:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy((void*)out, (void*)in, samples * sizeof(float)); data/qmmp-1.3.1/src/qmmp/channelconverter.cpp:73:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(m_tmp_buf, data, m_channels * sizeof(float)); data/qmmp-1.3.1/src/qmmp/decoder.cpp:183:18: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(!file.open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/qmmp/decoder.cpp:217:14: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(!file.open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/qmmp/soundcore.cpp:271:69: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(s->ioDevice() && !s->ioDevice()->isOpen() && !s->ioDevice()->open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/qmmp/visual.cpp:76:13: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(left, node->data[0], QMMP_VISUAL_NODE_SIZE * sizeof(float)); data/qmmp-1.3.1/src/qmmp/visual.cpp:77:13: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(right, node->data[1], QMMP_VISUAL_NODE_SIZE * sizeof(float)); data/qmmp-1.3.1/src/qmmp/visualbuffer.cpp:31:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(l, s, cnt * sizeof(float)); data/qmmp-1.3.1/src/qmmp/visualbuffer.cpp:32:9: [2] (buffer) memcpy: Does not check for buffer overflows when copying to destination (CWE-120). Make sure destination can always hold the source data. memcpy(r, s, cnt * sizeof(float)); data/qmmp-1.3.1/src/qmmpui/aboutdialog.cpp:141:18: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if (file.open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/qmmpui/playlistmanager.cpp:266:10: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). file.open(QIODevice::ReadOnly); data/qmmp-1.3.1/src/qmmpui/playlistmanager.cpp:270:12: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). buffer.open(QIODevice::ReadOnly); data/qmmp-1.3.1/src/qmmpui/playlistmanager.cpp:341:16: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if(!plFile.open(QIODevice::WriteOnly)) data/qmmp-1.3.1/src/qmmpui/playlistparser.cpp:100:14: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if (file.open(QIODevice::WriteOnly)) data/qmmp-1.3.1/src/qmmpui/playlistparser.cpp:118:15: [2] (misc) open: Check when opening files - can an attacker redirect it (via symlinks), force the opening of special file type (e.g., device files), move things around to create a race condition, control its ancestors, or change its contents? (CWE-362). if (!file.open(QIODevice::ReadOnly)) data/qmmp-1.3.1/src/plugins/General/converter/converter.cpp:318:24: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). len = decoder->read(input_buffer, sizeof(input_buffer)); data/qmmp-1.3.1/src/plugins/General/fileops/fileops.cpp:200:26: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). out.write(in.read(COPY_BLOCK_SIZE)); data/qmmp-1.3.1/src/plugins/General/fileops/fileops.cpp:303:26: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). out.write(in.read(COPY_BLOCK_SIZE)); data/qmmp-1.3.1/src/plugins/General/rgscan/rgscanner.cpp:201:26: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). len = m_decoder->read(char_buf, buf_size); data/qmmp-1.3.1/src/plugins/Input/aac/aacfile.cpp:71:39: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). parseID3v2(input->read(header.tagSize())); data/qmmp-1.3.1/src/plugins/Input/aac/aacfile.cpp:75:29: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). buf_at = input->read(buf, sizeof(buf)); data/qmmp-1.3.1/src/plugins/Input/aac/aacfile.cpp:177:23: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). buf_at = m_input->read((char *)buf, FAAD_MIN_STREAMSIZE*MAX_CHANNELS); data/qmmp-1.3.1/src/plugins/Input/aac/aacfile.cpp:193:28: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). buf_at += m_input->read((char *)buf + buf_at, FAAD_MIN_STREAMSIZE*MAX_CHANNELS - buf_at); data/qmmp-1.3.1/src/plugins/Input/aac/aacfile.cpp:263:5: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). read(); data/qmmp-1.3.1/src/plugins/Input/aac/aacfile.cpp:266:16: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). void ID3v2Tag::read () data/qmmp-1.3.1/src/plugins/Input/aac/aacfile.h:74:10: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). void read(); data/qmmp-1.3.1/src/plugins/Input/aac/decoder_aac.cpp:90:18: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). input()->read(data, aac_file.offset()); data/qmmp-1.3.1/src/plugins/Input/aac/decoder_aac.cpp:110:27: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). m_input_at = input()->read((char *)m_input_buf, AAC_BUFFER_SIZE); data/qmmp-1.3.1/src/plugins/Input/aac/decoder_aac.cpp:139:20: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 DecoderAAC::read(unsigned char *audio, qint64 maxSize) data/qmmp-1.3.1/src/plugins/Input/aac/decoder_aac.cpp:142:31: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 size = 0, to_read, read; data/qmmp-1.3.1/src/plugins/Input/aac/decoder_aac.cpp:151:29: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). read = input()->read((char *) (m_input_buf + m_input_at), to_read); data/qmmp-1.3.1/src/plugins/Input/aac/decoder_aac.cpp:152:20: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). eof = (read != to_read); data/qmmp-1.3.1/src/plugins/Input/aac/decoder_aac.cpp:153:27: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). m_input_at += read; data/qmmp-1.3.1/src/plugins/Input/aac/decoder_aac.h:50:12: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 read(unsigned char *audio, qint64 maxSize) override; data/qmmp-1.3.1/src/plugins/Input/archive/archiveinputdevice.cpp:128:21: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). return m_buffer.read(data, maxSize); data/qmmp-1.3.1/src/plugins/Input/archive/archivetagreader.cpp:49:36: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). QByteArray data = m_input->read(length); data/qmmp-1.3.1/src/plugins/Input/archive/decoder_archive.cpp:131:24: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 DecoderArchive::read(unsigned char *data, qint64 maxSize) data/qmmp-1.3.1/src/plugins/Input/archive/decoder_archive.cpp:133:23: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). return m_decoder->read(data, maxSize); data/qmmp-1.3.1/src/plugins/Input/archive/decoder_archive.h:40:12: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 read(unsigned char *data, qint64 maxSize) override; data/qmmp-1.3.1/src/plugins/Input/cdaudio/decoder_cdaudio.cpp:482:24: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 DecoderCDAudio::read(unsigned char *audio, qint64 maxSize) data/qmmp-1.3.1/src/plugins/Input/cdaudio/decoder_cdaudio.h:58:12: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 read(unsigned char *audio, qint64 maxSize) override; data/qmmp-1.3.1/src/plugins/Input/cue/decoder_cue.cpp:123:20: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 DecoderCUE::read(unsigned char *data, qint64 size) data/qmmp-1.3.1/src/plugins/Input/cue/decoder_cue.cpp:144:26: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). len = m_decoder->read(data, size); data/qmmp-1.3.1/src/plugins/Input/cue/decoder_cue.h:41:12: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 read(unsigned char *data, qint64 size) override; data/qmmp-1.3.1/src/plugins/Input/ffmpeg/decoder_ffmpeg.cpp:38:29: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). return (int)d->input()->read((char*)buf, size); data/qmmp-1.3.1/src/plugins/Input/ffmpeg/decoder_ffmpeg.cpp:323:23: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 DecoderFFmpeg::read(unsigned char *audio, qint64 maxSize) data/qmmp-1.3.1/src/plugins/Input/ffmpeg/decoder_ffmpeg.h:47:12: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 read(unsigned char *audio, qint64 maxSize) override; data/qmmp-1.3.1/src/plugins/Input/flac/decoder_flac.cpp:122:31: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 res = data->input->read((char *)buffer, *bytes); data/qmmp-1.3.1/src/plugins/Input/flac/decoder_flac.cpp:493:21: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 DecoderFLAC::read(unsigned char *buf, qint64 size) data/qmmp-1.3.1/src/plugins/Input/flac/decoder_flac.h:71:12: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 read(unsigned char *data, qint64 maxSize) override; data/qmmp-1.3.1/src/plugins/Input/gme/decoder_gme.cpp:95:20: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 DecoderGme::read(unsigned char *data, qint64 size) data/qmmp-1.3.1/src/plugins/Input/gme/decoder_gme.h:42:12: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 read(unsigned char *data, qint64 size) override; data/qmmp-1.3.1/src/plugins/Input/modplug/decoder_modplug.cpp:111:24: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 DecoderModPlug::read(unsigned char *audio, qint64 maxSize) data/qmmp-1.3.1/src/plugins/Input/modplug/decoder_modplug.h:40:12: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 read(unsigned char *audio, qint64 maxSize) override; data/qmmp-1.3.1/src/plugins/Input/mpc/decoder_mpc.cpp:34:27: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). return dmpc->input()->read((char *)buffer, size); data/qmmp-1.3.1/src/plugins/Input/mpc/decoder_mpc.cpp:138:20: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 DecoderMPC::read(unsigned char *audio, qint64 maxSize) data/qmmp-1.3.1/src/plugins/Input/mpc/decoder_mpc.h:49:12: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 read(unsigned char *audio, qint64 maxSize) override; data/qmmp-1.3.1/src/plugins/Input/mpeg/decoder_mad.cpp:255:38: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). m_input_bytes = input()->read(m_input_buf + remaining, INPUT_BUFFER_SIZE - remaining); data/qmmp-1.3.1/src/plugins/Input/mpeg/decoder_mad.cpp:377:20: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 DecoderMAD::read(unsigned char *data, qint64 size) data/qmmp-1.3.1/src/plugins/Input/mpeg/decoder_mad.cpp:445:24: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). int len = input()->read((char *) m_input_buf + m_input_bytes, INPUT_BUFFER_SIZE - m_input_bytes); data/qmmp-1.3.1/src/plugins/Input/mpeg/decoder_mad.h:41:12: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 read(unsigned char *data, qint64 size) override; data/qmmp-1.3.1/src/plugins/Input/mpeg/decoder_mpg123.cpp:33:24: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). return d->input()->read((char *)buf, size); data/qmmp-1.3.1/src/plugins/Input/mpeg/decoder_mpg123.cpp:162:23: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 DecoderMPG123::read(unsigned char *data, qint64 size) data/qmmp-1.3.1/src/plugins/Input/mpeg/decoder_mpg123.h:40:12: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 read(unsigned char *data, qint64 size) override; data/qmmp-1.3.1/src/plugins/Input/mpeg/decodermpegfactory.cpp:98:31: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). dataSize = input->read(buf, sizeof(buf)); data/qmmp-1.3.1/src/plugins/Input/mpeg/tagextractor.cpp:108:5: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). read(); data/qmmp-1.3.1/src/plugins/Input/mpeg/tagextractor.cpp:111:16: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). void ID3v2Tag::read () data/qmmp-1.3.1/src/plugins/Input/mpeg/tagextractor.cpp:117:49: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). header()->setData(TagLib::ByteVector(m_buf->read(to_read).data(), to_read)); data/qmmp-1.3.1/src/plugins/Input/mpeg/tagextractor.cpp:121:31: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). QByteArray array = m_buf->read(to_read); data/qmmp-1.3.1/src/plugins/Input/mpeg/tagextractor.h:61:10: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). void read (); data/qmmp-1.3.1/src/plugins/Input/opus/decoder_opus.cpp:31:24: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). return d->input()->read((char *) buf, size); data/qmmp-1.3.1/src/plugins/Input/opus/decoder_opus.cpp:151:21: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 DecoderOpus::read(unsigned char *data, qint64 maxSize) data/qmmp-1.3.1/src/plugins/Input/opus/decoder_opus.h:42:20: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). virtual qint64 read(unsigned char *data, qint64 maxSize) override; data/qmmp-1.3.1/src/plugins/Input/sid/decoder_sid.cpp:161:20: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 DecoderSID::read(unsigned char *data, qint64 size) data/qmmp-1.3.1/src/plugins/Input/sid/decoder_sid.h:43:12: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 read(unsigned char *data, qint64 size) override; data/qmmp-1.3.1/src/plugins/Input/sndfile/decoder_sndfile.cpp:62:33: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). return ((QIODevice*) data)->read((char *)ptr, count); data/qmmp-1.3.1/src/plugins/Input/sndfile/decoder_sndfile.cpp:149:24: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 DecoderSndFile::read(unsigned char *audio, qint64 maxSize) data/qmmp-1.3.1/src/plugins/Input/sndfile/decoder_sndfile.h:42:12: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 read(unsigned char *audio, qint64 maxSize) override; data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:22:30: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). int len = dogg->input()->read((char *) buf, (size * nmemb)); data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:169:26: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). strlen ("title="))) data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:171:31: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). + strlen ("title="))); data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:173:42: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). "artist=", strlen ("artist="))) data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:176:49: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). + strlen ("artist="))); data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:178:41: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). "album=", strlen ("album="))) data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:181:49: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). + strlen ("album="))); data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:183:43: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). "comment=", strlen ("comment="))) data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:186:49: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). + strlen ("comment="))); data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:188:41: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). "genre=", strlen ("genre="))) data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:190:31: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). + strlen ("genre="))); data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:193:31: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). strlen ("tracknumber="))) data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:195:31: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). + strlen ("tracknumber=")))); data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:197:41: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). "track=", strlen ("track="))) data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:199:31: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). + strlen ("track=")))); data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:201:40: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). "date=", strlen ("date="))) data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:203:31: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). + strlen ("date=")))); data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:205:44: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). "composer=", strlen ("composer="))) data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:207:31: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). + strlen ("composer="))); data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:209:46: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). "discnumber=", strlen ("discnumber="))) data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:211:31: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). + strlen ("discnumber=")))); data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.cpp:285:23: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 DecoderVorbis::read(unsigned char *data, qint64 maxSize) data/qmmp-1.3.1/src/plugins/Input/vorbis/decoder_vorbis.h:27:20: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). virtual qint64 read(unsigned char *data, qint64 maxSize) override; data/qmmp-1.3.1/src/plugins/Input/wavpack/decoder_wavpack.cpp:202:24: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 DecoderWavPack::read(unsigned char *data, qint64 size) data/qmmp-1.3.1/src/plugins/Input/wavpack/decoder_wavpack.h:41:12: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 read(unsigned char *data, qint64 maxSize) override; data/qmmp-1.3.1/src/plugins/Input/wildmidi/decoder_wildmidi.cpp:86:25: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 DecoderWildMidi::read(unsigned char *data, qint64 size) data/qmmp-1.3.1/src/plugins/Input/wildmidi/decoder_wildmidi.h:39:12: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). qint64 read(unsigned char *data, qint64 size) override; data/qmmp-1.3.1/src/plugins/Output/directsound/outputdirectsound.cpp:212:9: [1] (obsolete) usleep: This C routine is considered obsolete (as opposed to the shell command by the same name). The interaction of this function with SIGALRM and other timer functions such as sleep(), alarm(), setitimer(), and nanosleep() is unspecified (CWE-676). Use nanosleep(2) or setitimer(2) instead. usleep(5000); data/qmmp-1.3.1/src/plugins/Output/jack/bio2jack.c:658:36: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). drv->written_client_bytes += read; data/qmmp-1.3.1/src/plugins/Output/jack/bio2jack.c:660:32: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). drv->clientBytesInJack = read; /* record the input bytes we wrote to jack */ data/qmmp-1.3.1/src/plugins/Output/jack/bio2jack.c:2642:16: [1] (buffer) strlen: Does not handle strings that are not \0-terminated; if given one it may perform an over-read (it could cause a crash if unprotected) (CWE-126). int size = strlen(name) + 1; /* take into account the terminating null */ data/qmmp-1.3.1/src/plugins/Output/jack/outputjack.cpp:97:9: [1] (obsolete) usleep: This C routine is considered obsolete (as opposed to the shell command by the same name). The interaction of this function with SIGALRM and other timer functions such as sleep(), alarm(), setitimer(), and nanosleep() is unspecified (CWE-676). Use nanosleep(2) or setitimer(2) instead. usleep(2000); data/qmmp-1.3.1/src/plugins/Output/null/outputnull.cpp:61:4: [1] (obsolete) usleep: This C routine is considered obsolete (as opposed to the shell command by the same name). The interaction of this function with SIGALRM and other timer functions such as sleep(), alarm(), setitimer(), and nanosleep() is unspecified (CWE-676). Use nanosleep(2) or setitimer(2) instead. usleep(maxSize * 1000000 / m_bytes_per_second); data/qmmp-1.3.1/src/plugins/Output/qtmultimedia/outputqtmultimedia.cpp:125:9: [1] (obsolete) usleep: This C routine is considered obsolete (as opposed to the shell command by the same name). The interaction of this function with SIGALRM and other timer functions such as sleep(), alarm(), setitimer(), and nanosleep() is unspecified (CWE-676). Use nanosleep(2) or setitimer(2) instead. usleep(qMin(maxSize, static_cast<qint64>(m_output->bufferSize() / 2)) * 1000000 / m_bytes_per_second); data/qmmp-1.3.1/src/plugins/Output/wasapi/outputwasapi.cpp:235:9: [1] (obsolete) usleep: This C routine is considered obsolete (as opposed to the shell command by the same name). The interaction of this function with SIGALRM and other timer functions such as sleep(), alarm(), setitimer(), and nanosleep() is unspecified (CWE-676). Use nanosleep(2) or setitimer(2) instead. usleep(len * 1000000L / sampleRate() / m_frameSize / 2); data/qmmp-1.3.1/src/plugins/Output/wasapi/outputwasapi.cpp:263:9: [1] (obsolete) usleep: This C routine is considered obsolete (as opposed to the shell command by the same name). The interaction of this function with SIGALRM and other timer functions such as sleep(), alarm(), setitimer(), and nanosleep() is unspecified (CWE-676). Use nanosleep(2) or setitimer(2) instead. usleep(50); data/qmmp-1.3.1/src/plugins/Output/waveout/outputwaveout.cpp:166:9: [1] (obsolete) usleep: This C routine is considered obsolete (as opposed to the shell command by the same name). The interaction of this function with SIGALRM and other timer functions such as sleep(), alarm(), setitimer(), and nanosleep() is unspecified (CWE-676). Use nanosleep(2) or setitimer(2) instead. usleep(50000); data/qmmp-1.3.1/src/plugins/Transports/mms/mmsstreamreader.cpp:204:25: [1] (obsolete) usleep: This C routine is considered obsolete (as opposed to the shell command by the same name). The interaction of this function with SIGALRM and other timer functions such as sleep(), alarm(), setitimer(), and nanosleep() is unspecified (CWE-676). Use nanosleep(2) or setitimer(2) instead. DownloadThread::usleep(5000); data/qmmp-1.3.1/src/plugins/Transports/mms/mmsstreamreader.h:94:17: [1] (obsolete) usleep: This C routine is considered obsolete (as opposed to the shell command by the same name). The interaction of this function with SIGALRM and other timer functions such as sleep(), alarm(), setitimer(), and nanosleep() is unspecified (CWE-676). Use nanosleep(2) or setitimer(2) instead. static void usleep(unsigned long usecs) data/qmmp-1.3.1/src/plugins/Transports/mms/mmsstreamreader.h:96:22: [1] (obsolete) usleep: This C routine is considered obsolete (as opposed to the shell command by the same name). The interaction of this function with SIGALRM and other timer functions such as sleep(), alarm(), setitimer(), and nanosleep() is unspecified (CWE-676). Use nanosleep(2) or setitimer(2) instead. QThread::usleep(usecs); data/qmmp-1.3.1/src/plugins/Ui/skinned/cursorimage.cpp:101:25: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). bmpData.append(curFile.read(directory2.bytes - dibHeaderSize)); data/qmmp-1.3.1/src/plugins/Ui/skinned/eqwidget.cpp:413:10: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). file.read (header, 31); data/qmmp-1.3.1/src/plugins/Ui/skinned/eqwidget.cpp:416:21: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). while (file.read (name, 257)) data/qmmp-1.3.1/src/plugins/Ui/skinned/eqwidget.cpp:421:18: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). file.read(bands,11); data/qmmp-1.3.1/src/qmmp/decoder.h:57:20: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). virtual qint64 read(unsigned char *data, qint64 maxSize) = 0; data/qmmp-1.3.1/src/qmmp/qmmpaudioengine.cpp:416:30: [1] (buffer) read: Check buffer boundaries if used in a loop including recursive loops (CWE-120, CWE-20). len = m_decoder->read((m_output_buf + m_output_at), m_output_size - m_output_at); ANALYSIS SUMMARY: Hits = 287 Lines analyzed = 103490 in approximately 2.85 seconds (36332 lines/second) Physical Source Lines of Code (SLOC) = 70744 Hits@level = [0] 28 [1] 109 [2] 156 [3] 9 [4] 11 [5] 2 Hits@level+ = [0+] 315 [1+] 287 [2+] 178 [3+] 22 [4+] 13 [5+] 2 Hits/KSLOC@level+ = [0+] 4.45267 [1+] 4.05688 [2+] 2.51611 [3+] 0.31098 [4+] 0.183761 [5+] 0.0282709 Dot directories skipped = 2 (--followdotdir overrides) Minimum risk level = 1 Not every hit is necessarily a security vulnerability. There may be other security vulnerabilities; review your code! See 'Secure Programming HOWTO' (https://dwheeler.com/secure-programs) for more information.