Doxygen
Loading...
Searching...
No Matches
definition.h File Reference
#include <vector>
#include "types.h"
#include "reflist.h"
#include "construct.h"
+ Include dependency graph for definition.h:
+ This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Classes

struct  DocInfo
 Data associated with a detailed description. More...
 
struct  BriefInfo
 Data associated with a brief description. More...
 
struct  BodyInfo
 Data associated with description found in the body. More...
 
class  Definition
 The common base class of all entity definitions found in the sources. More...
 
class  DefinitionMutable
 

Functions

DefinitiontoDefinition (DefinitionMutable *dm)
 
DefinitionMutabletoDefinitionMutable (Definition *d)
 
bool readCodeFragment (const QCString &fileName, bool isMacro, int &startLine, int &endLine, QCString &result)
 Reads a fragment from file fileName starting with line startLine and ending with line endLine.
 

Function Documentation

◆ readCodeFragment()

bool readCodeFragment ( const QCString & fileName,
bool isMacro,
int & startLine,
int & endLine,
QCString & result )

Reads a fragment from file fileName starting with line startLine and ending with line endLine.

The result is returned as a string via result. The function returns TRUE if successful and FALSE in case of an error.

Reads a fragment of code from file fileName starting at line startLine and ending at line endLine (inclusive). The fragment is stored in result. If FALSE is returned the code fragment could not be found.

The file is scanned for a opening bracket ('{') from startLine onward The line actually containing the bracket is returned via startLine. The file is scanned for a closing bracket ('}') from endLine backward. The line actually containing the bracket is returned via endLine. Note that for VHDL code the bracket search is not done.

Definition at line 752 of file definition.cpp.

754{
755 bool filterSourceFiles = Config_getBool(FILTER_SOURCE_FILES);
756 QCString filter = getFileFilter(fileName,TRUE);
757 bool usePipe = !filter.isEmpty() && filterSourceFiles;
758 int tabSize = Config_getInt(TAB_SIZE);
759 SrcLangExt lang = getLanguageFromFileName(fileName);
760 const int blockSize = 4096;
761 std::string str;
763 static_cast<size_t>(std::max(1,startLine)),
764 static_cast<size_t>(std::max({1,startLine,endLine})),str);
765 //printf("readCodeFragment(%s,startLine=%d,endLine=%d)=\n[[[\n%s]]]\n",qPrint(fileName),startLine,endLine,qPrint(str));
766
767 bool found = lang==SrcLangExt::VHDL ||
768 lang==SrcLangExt::Python ||
769 lang==SrcLangExt::Fortran ||
770 isMacro;
771 // for VHDL, Python, and Fortran no bracket search is possible
772 char *p=str.data();
773 if (p && *p)
774 {
775 char c=0;
776 int col=0;
777 int lineNr=startLine;
778 // skip until the opening bracket or lonely : is found
779 char cn=0;
780 while (*p && !found)
781 {
782 int pc=0;
783 while ((c=*p++)!='{' && c!=':' && c!=0)
784 {
785 //printf("parsing char '%c'\n",c);
786 if (c=='\n')
787 {
788 lineNr++,col=0;
789 }
790 else if (c=='\t')
791 {
792 col+=tabSize - (col%tabSize);
793 }
794 else if (pc=='/' && c=='/') // skip single line comment
795 {
796 while ((c=*p++)!='\n' && c!=0);
797 if (c=='\n') lineNr++,col=0;
798 }
799 else if (pc=='/' && c=='*') // skip C style comment
800 {
801 while (((c=*p++)!='/' || pc!='*') && c!=0)
802 {
803 if (c=='\n') lineNr++,col=0;
804 pc=c;
805 }
806 }
807 else
808 {
809 col++;
810 }
811 pc = c;
812 }
813 if (c==':')
814 {
815 cn=*p++;
816 if (cn!=':') found=TRUE;
817 }
818 else if (c=='{')
819 {
820 found=TRUE;
821 }
822 else if (c==0)
823 {
824 break;
825 }
826 }
827 //printf(" -> readCodeFragment(%s,%d,%d) lineNr=%d\n",fileName,startLine,endLine,lineNr);
828 if (found)
829 {
830 // For code with more than one line,
831 // fill the line with spaces until we are at the right column
832 // so that the opening brace lines up with the closing brace
833 if (endLine!=startLine)
834 {
835 QCString spaces;
836 spaces.fill(' ',col);
837 result+=spaces;
838 }
839 // copy until end of line
840 if (c) result+=c;
841 startLine=lineNr;
842 if (c==':')
843 {
844 result+=cn;
845 if (cn=='\n') lineNr++;
846 }
847 char lineStr[blockSize];
848 do
849 {
850 //printf("reading line %d in range %d-%d\n",lineNr,startLine,endLine);
851 int size_read=0;
852 do
853 {
854 // read up to blockSize-1 non-zero characters
855 int i=0;
856 while ((c=*p) && i<blockSize-1)
857 {
858 lineStr[i++]=c;
859 p++;
860 if (c=='\n') break; // stop at end of the line
861 }
862 lineStr[i]=0;
863 size_read=i;
864 result+=lineStr; // append line to the output
865 } while (size_read == (blockSize-1)); // append more if line does not fit in buffer
866 lineNr++;
867 } while (*p);
868
869 // strip stuff after closing bracket
870 int newLineIndex = result.findRev('\n');
871 int braceIndex = result.findRev('}');
872 if (braceIndex > newLineIndex)
873 {
874 result.resize(static_cast<size_t>(braceIndex+1));
875 }
876 endLine=lineNr-1;
877 }
878 if (usePipe)
879 {
880 Debug::print(Debug::FilterOutput, 0, "Filter output\n");
881 Debug::print(Debug::FilterOutput,0,"-------------\n{}\n-------------\n",result);
882 }
883 }
884 QCString encoding = getEncoding(FileInfo(fileName.str()));
885 if (encoding!="UTF-8")
886 {
887 std::string encBuf = result.str();
888 bool ok = transcodeCharacterStringToUTF8(encBuf,encoding.data());
889 if (ok)
890 {
891 result = QCString(encBuf);
892 }
893 else
894 {
895 err("failed to transcode characters in code fragment in file {} lines {} to {}, from input encoding {} to UTF-8\n",
896 fileName,startLine,endLine,encoding);
897
898 }
899 }
900 if (!result.isEmpty() && result.at(result.length()-1)!='\n') result += "\n";
901 //printf("readCodeFragment(%d-%d)=%s\n",startLine,endLine,qPrint(result));
902 return found;
903}
@ FilterOutput
Definition debug.h:38
static void print(DebugMask mask, int prio, fmt::format_string< Args... > fmt, Args &&... args)
Definition debug.h:76
Minimal replacement for QFileInfo.
Definition fileinfo.h:23
static FilterCache & instance()
bool getFileContents(const QCString &fileName, size_t startLine, size_t endLine, std::string &str)
This is an alternative implementation of QCString.
Definition qcstring.h:101
void fill(char c, int len=-1)
Fills a string with a predefined character.
Definition qcstring.h:180
size_t length() const
Returns the length of the string, not counting the 0-terminator.
Definition qcstring.h:153
char & at(size_t i)
Returns a reference to the character at index i.
Definition qcstring.h:578
bool isEmpty() const
Returns TRUE iff the string is empty.
Definition qcstring.h:150
void resize(size_t newlen)
Definition qcstring.h:167
const std::string & str() const
Definition qcstring.h:537
int findRev(char c, int index=-1, bool cs=TRUE) const
Definition qcstring.cpp:91
const char * data() const
Returns a pointer to the contents of the string in the form of a 0-terminated C string.
Definition qcstring.h:159
#define Config_getInt(name)
Definition config.h:34
#define Config_getBool(name)
Definition config.h:33
#define err(fmt,...)
Definition message.h:127
#define TRUE
Definition qcstring.h:37
SrcLangExt
Language as given by extension.
Definition types.h:42
@ Fortran
Definition types.h:53
@ Python
Definition types.h:52
SrcLangExt getLanguageFromFileName(const QCString &fileName, SrcLangExt defLang)
Definition util.cpp:5645
bool transcodeCharacterStringToUTF8(std::string &input, const char *inputEncoding)
Definition util.cpp:1376
bool found
Definition util.cpp:984
QCString getEncoding(const FileInfo &fi)
Definition util.cpp:6104
QCString getFileFilter(const QCString &name, bool isSourceCode)
Definition util.cpp:1342

References QCString::at(), Config_getBool, Config_getInt, QCString::data(), err, QCString::fill(), Debug::FilterOutput, QCString::findRev(), Fortran, found, getEncoding(), FilterCache::getFileContents(), getFileFilter(), getLanguageFromFileName(), FilterCache::instance(), QCString::isEmpty(), QCString::length(), Debug::print(), Python, QCString::resize(), QCString::str(), transcodeCharacterStringToUTF8(), TRUE, and VHDL.

Referenced by VhdlDocGen::createFlowChart(), DefinitionMutable::toDefinition_(), and DefinitionImpl::writeInlineCode().

◆ toDefinition()

◆ toDefinitionMutable()

DefinitionMutable * toDefinitionMutable ( Definition * d)

Definition at line 300 of file definition.cpp.

1879{
1880 if (d==nullptr) return nullptr;
1881 return d->toDefinitionMutable_();
1882}
virtual DefinitionMutable * toDefinitionMutable_()=0

Referenced by addConceptToContext(), buildNamespaceList(), buildScopeFromQualifiedName(), computeTooltipTexts(), createTagLessInstance(), resolveClassNestingRelations(), and DefinitionMutable::toDefinition_().