From 4f2d7949f03e1c198bc888f2d05f421d35c57e21 Mon Sep 17 00:00:00 2001 From: V3n3RiX Date: Mon, 9 Oct 2017 18:53:29 +0100 Subject: reinit the tree, so we can have metadata --- dev-util/cccc/Manifest | 7 +++ dev-util/cccc/cccc-3.1.5.ebuild | 70 ++++++++++++++++++++++++++++ dev-util/cccc/files/cccc-MFC-dialect.opt | 21 +++++++++ dev-util/cccc/files/cccc-c_dialect.patch | 79 ++++++++++++++++++++++++++++++++ dev-util/cccc/metadata.xml | 19 ++++++++ 5 files changed, 196 insertions(+) create mode 100644 dev-util/cccc/Manifest create mode 100644 dev-util/cccc/cccc-3.1.5.ebuild create mode 100644 dev-util/cccc/files/cccc-MFC-dialect.opt create mode 100644 dev-util/cccc/files/cccc-c_dialect.patch create mode 100644 dev-util/cccc/metadata.xml (limited to 'dev-util/cccc') diff --git a/dev-util/cccc/Manifest b/dev-util/cccc/Manifest new file mode 100644 index 000000000000..fe2b811974dd --- /dev/null +++ b/dev-util/cccc/Manifest @@ -0,0 +1,7 @@ +AUX cccc-MFC-dialect.opt 560 SHA256 16ceb2d534bd0b8ae19a5708be3645a5ad211c2936508ba23638fe860904b52f SHA512 e37ded34821690e0b07e4e3da502bccdb5760a38a9f1fbacb6cec4de143cc9c0160684d9a41ce0c3ff8e2a7716889824594d6f8d374a631dbb0de91ccec53903 WHIRLPOOL a5440d259e84d23b2d607310fbf696f99ff06a2160a35c8fbd654cf7f3829b4ef26c2e050966269f700ba7fd037f69b82ef720bd7266c18fb8c379dd5361c5f5 +AUX cccc-c_dialect.patch 2048 SHA256 e06f50a514297656583ae864b18cd7932c057c7969fe523663b0249e5989cf59 SHA512 5fadc49a0da8ca51b74dd92e673b413b506c8b06dfeabb7da0e2ddf24e7766d58ebbcc00d018677f4b0ff77d10df8b974ff1afd4100c33152e8cad0538b61789 WHIRLPOOL fb911203f0b9b3be3ee1d8445f785454217ff2d6a24f195c0f74199d9d2578382ae9e2dc414c9132969003ef002a5f5fc71e6a70744495a26f6197217ef74711 +DIST cccc-3.1.5.tar.gz 662760 SHA256 6fe91eae83ad0ff4c1fe4277aabb6e7554a4dec1bb266b5657c064ef48a23142 SHA512 61544669a75ff7bd99c6ff5bb1e6ec163f2a09f4538493fe60e8f9f95eab7ba19ad6d39b6717ae010a223b8efe48c497a4feb8ead218e350ee2ab91b9c52c969 WHIRLPOOL 085d897eec29bc6de7fee35261bcde2228bb76e85799a6528d7ff9364712489368ad5f899f8c170169fb9b01931e4b846fd5c63b98b640c733640d10685c100f +EBUILD cccc-3.1.5.ebuild 1535 SHA256 1ed72bb9121c977eb40a67cdbb580376839f33642a7e560be19b257149f6e077 SHA512 d273f384ed06bcd9221e7bcdd468808f7026c108042414703f64b7d176f64e587d1210ae43f2baabec450d552bcd70060a7fc3732f8eefd88ad931f24824a37a WHIRLPOOL 74b2926944456ef3195f19973d242970680ff6da6b6fb0be586ee818f1bcb0c1a4f038abef002d4a9da841c723213db7ef6919188062645537fe916e67b99cce +MISC ChangeLog 3575 SHA256 e0380fbb77a8ddb8dc4466063b93f9d21429ebc6bd047b132a9e5c257f5b7a5d SHA512 cf3be52e361e736845159e7e0bf0145fbb945ce5bd243cfcd1c828c83492271d0fcd0b125a6e8b4ac3463977925e8d885041e2a5bb3650935576be91fc019617 WHIRLPOOL 7f07e125e3e33748bc38f148c70fd769131918caf05ffca5309837346a307a91e0309da2d1aa0e9eb96c820b74812585b50db998e91110d6ac27ed5291c30a0c +MISC ChangeLog-2015 2552 SHA256 5184d39dc42341cf3523965c236ff2b8b9a7435c95163a1c5b156fc07712e0ea SHA512 baaf50c02849f0d507d647b9297ed0c1e19ad99cd034aa8f71565ce85c951a271e88c01e2549e1b08e8c84d0335b24d428897716a0ef43e66a5d1d046bf825ea WHIRLPOOL ceac6ff9b359a51c38748fa15eba7f26ae8df93d1e046ee183656b1e386008e5bf0b5aa46c85abf6d7950c682fdfdf95a67d324eb1bc9e79e4edc8a6e6abaae0 +MISC metadata.xml 694 SHA256 a6e4f3c08611221a26016e5a72b6d6c643cbc08fbe85ffd21829653c7fad92de SHA512 442e37fb776949e1f59ca7074ba1219e77e7e1be0003c5cace090342823227fca6a9a10ef607d133245985c717811005293bf2044fdb0bacfe2e114eea3ec2ad WHIRLPOOL 6cf84571a4b6b69d9e60ecbb971a108f52b09086c8004987644c78fae2d07d0e14955c326223ee8a2ab0e09f6503669487d9c07e949260224503108fb8c9ca01 diff --git a/dev-util/cccc/cccc-3.1.5.ebuild b/dev-util/cccc/cccc-3.1.5.ebuild new file mode 100644 index 000000000000..07042e9343cb --- /dev/null +++ b/dev-util/cccc/cccc-3.1.5.ebuild @@ -0,0 +1,70 @@ +# Copyright 1999-2016 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 + +EAPI=5 + +inherit eutils toolchain-funcs flag-o-matic + +DESCRIPTION="Source metrics (line counts, complexity, etc) for Java and C++" +HOMEPAGE="http://sarnold.github.io/cccc/" +if [[ ${PV} = 9999* ]]; then + EGIT_REPO_URI="https://github.com/sarnold/cccc.git" + EGIT_BRANCH="master" + inherit git-r3 +else + SRC_URI="https://github.com/sarnold/${PN}/archive/${PV}.tar.gz -> ${P}.tar.gz" +fi + +LICENSE="GPL-2" +SLOT="0" +KEYWORDS="~amd64 ~arm ~ppc ~x86 ~amd64-linux ~x86-linux ~ppc-macos" +IUSE="apidoc debug doc mfc" + +RDEPEND="" +DEPEND="${RDEPEND} + apidoc? ( app-doc/doxygen[dot] ) + " + +MAKEOPTS="-j1" + +src_prepare() { + use mfc && epatch "${FILESDIR}"/${PN}-c_dialect.patch +} + +src_compile() { + if use debug ; then + export STRIP_MASK="*/bin/*" + DEBUG="true" emake CCC=$(tc-getCXX) CC=$(tc-getCC) cccc + else + emake CCC=$(tc-getCXX) CC=$(tc-getCC) cccc + fi + + use apidoc && emake CCC=$(tc-getCXX) metrics docs +} + +src_test() { + emake CCC=$(tc-getCXX) test +} + +src_install() { + dobin cccc/cccc + + dodoc README.md + + if use mfc ; then + dodoc "${FILESDIR}"/cccc-MFC-dialect.opt + docompress -x "/usr/share/doc/${PF}/cccc-MFC-dialect.opt" + fi + + if use doc ; then + dodoc CHANGELOG.md HISTORY.md + dohtml cccc/*.html || die "html docs failed" + if use apidoc ; then + docinto api + dohtml -A svg -r doxygen/html || die "dox failed" + docompress -x "/usr/share/doc/${PF}/api" + docinto metrics + dohtml ccccout/* || die "metrics failed" + fi + fi +} diff --git a/dev-util/cccc/files/cccc-MFC-dialect.opt b/dev-util/cccc/files/cccc-MFC-dialect.opt new file mode 100644 index 000000000000..4c4acb32e1fb --- /dev/null +++ b/dev-util/cccc/files/cccc-MFC-dialect.opt @@ -0,0 +1,21 @@ +;;Pro*C embedded SQL +;; looks like +;; EXEC SQL UPDATE ARM43_OD_PRODUIT_SERV +;; SET ARM43ID_TPS_FIN = NULL WHERE +ARM43ID_TPS_FIN = 0; + +CCCC_FileExt@.pc@c++.ansi@ + +CCCC_Dialect@c++.pc@EXEC@skip_stmt@ + +;;MFC +CCCC_Dialect@c++.mfc@ON_WM_PAINT@skip_line@ +CCCC_Dialect@c++.mfc@DECLARE_MESSAGE_MAP@skip_line@ +CCCC_Dialect@c++.mfc@DECLARE_DISPATCH_MAP@skip_line@ + +CCCC_Dialect@c++.stl@__STL_BEGIN_NAMESPACE@ignore@ +CCCC_Dialect@c++.stl@__STL_END_NAMESPACE@ignore@ + +CCCC_Dialect@c++.mfc@BEGIN_EVENT_MAP@start_skipping@ +CCCC_Dialect@c++.mfc@END_EVENT_MAP@stop_skipping@ + diff --git a/dev-util/cccc/files/cccc-c_dialect.patch b/dev-util/cccc/files/cccc-c_dialect.patch new file mode 100644 index 000000000000..c8951aef13c4 --- /dev/null +++ b/dev-util/cccc/files/cccc-c_dialect.patch @@ -0,0 +1,79 @@ +diff --git a/cccc/cccc.g b/cccc/cccc.g +index bdb6805..fd7b504 100644 +--- a/cccc/cccc.g ++++ b/cccc/cccc.g +@@ -84,6 +84,30 @@ inline void endOfLine(CLexer &lexer) + #token MAC_NL "\r" << endOfLine(*this); >> + #token UNIX_NL "\n" << endOfLine(*this); >> + ++/* augment dialect policies -- M.H added */ ++#lexclass SKIP_STMT ++#token SKCOLON ";" << skip();mode(START); >> ++#token SKANYTHING "~[; \t\n]" << skip();more();>> ++#token SKNL "\n" << skip();endOfLine(*this);>> ++#token SKBLANK "[ \t]+" << skip(); >> ++#lexclass START ++ ++#lexclass SKIP_BLOCK ++#token SK_ANY "[a-zA-Z0-9_]*" ++<< ++std::string treatment = ++ CCCC_Options::dialectKeywordPolicy(parse_language,lextext()); ++ ++if ( treatment != "stop_skipping" ) ++{ ++ skip(); ++} ++else ++{ ++ mode(COMMENT_LINE);skip(); ++} ++>> ++#lexclass START + + /* preprocessor constructs - comments, #defines etc */ + +@@ -343,17 +367,29 @@ inline void endOfLine(CLexer &lexer) + if( treatment == "ignore" ) + { + skip(); ++ //std::cout << toktext << std::endl <<" :ignore" << std::endl; + } + // Ultimately, the next two cases will need to be handled + // using a #lexclass or something similar, for the moment + // we just try to skip the tokens themselves. + else if ( treatment == "start_skipping" ) + { +- skip(); ++ mode(SKIP_BLOCK);skip(); + } + else if ( treatment == "stop_skipping" ) + { +- skip(); ++ skip(); mode(COMMENT_LINE); ++ //gobble end of line M.H. ++ } ++ else if ( treatment == "skip_line" )//M.H added ++ { ++ mode(COMMENT_LINE);skip(); ++ //std::cout << "skip_line" << std::endl; ++ } ++ else if ( treatment == "skip_stmt" )//M.H added ++ { ++ mode(SKIP_STMT);skip(); ++ //std::cout << "skip_stmt" << std::endl; + } + >> + +@@ -426,8 +462,10 @@ void init(const string& filename, const string& language) + pu=ParseUtility::currentInstance(); + ps=ParseStore::currentInstance(); + +- ANTLRParser::init(); + parse_language=language; ++ ANTLRParser::init(); ++ //parse_language=language; ++ //move above, M.H.1st otherwise time init not to language + } + + >> diff --git a/dev-util/cccc/metadata.xml b/dev-util/cccc/metadata.xml new file mode 100644 index 000000000000..ecde1cfd0a08 --- /dev/null +++ b/dev-util/cccc/metadata.xml @@ -0,0 +1,19 @@ + + + + + nerdboy@gentoo.org + + + cccc provides source code metrics (line counts, complexity, + object-oriented, and structural metrics) for Java and C++ + + + sarnold/cccc + https://github.com/sarnold/cccc/issues + + + Build software docs with doxygen/graphviz and metrics with cccc + Add patch for MFC dialect options + + -- cgit v1.2.3