From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from lists.gentoo.org (pigeon.gentoo.org [208.92.234.80]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by finch.gentoo.org (Postfix) with ESMTPS id EE500138334 for ; Thu, 30 May 2019 23:05:50 +0000 (UTC) Received: from pigeon.gentoo.org (localhost [127.0.0.1]) by pigeon.gentoo.org (Postfix) with SMTP id D44CCE0867; Thu, 30 May 2019 23:05:49 +0000 (UTC) Received: from smtp.gentoo.org (dev.gentoo.org [IPv6:2001:470:ea4a:1:5054:ff:fec7:86e4]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by pigeon.gentoo.org (Postfix) with ESMTPS id 8F607E0867 for ; Thu, 30 May 2019 23:05:49 +0000 (UTC) Received: from oystercatcher.gentoo.org (unknown [IPv6:2a01:4f8:202:4333:225:90ff:fed9:fc84]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.gentoo.org (Postfix) with ESMTPS id AAFC6345012 for ; Thu, 30 May 2019 23:05:47 +0000 (UTC) Received: from localhost.localdomain (localhost [IPv6:::1]) by oystercatcher.gentoo.org (Postfix) with ESMTP id E488B55B for ; Thu, 30 May 2019 23:05:44 +0000 (UTC) From: "Steve Arnold" To: gentoo-commits@lists.gentoo.org Content-Transfer-Encoding: 8bit Content-type: text/plain; charset=UTF-8 Reply-To: gentoo-dev@lists.gentoo.org, "Steve Arnold" Message-ID: <1559257507.9498391cdfe099fb51b68d5a0f68ef8be7476fb7.nerdboy@gentoo> Subject: [gentoo-commits] repo/gentoo:master commit in: dev-util/cccc/files/, dev-util/cccc/ X-VCS-Repository: repo/gentoo X-VCS-Files: dev-util/cccc/Manifest dev-util/cccc/cccc-3.1.5-r1.ebuild dev-util/cccc/files/cccc-MFC-dialect.opt dev-util/cccc/files/cccc-c_dialect.patch dev-util/cccc/metadata.xml X-VCS-Directories: dev-util/cccc/ dev-util/cccc/files/ X-VCS-Committer: nerdboy X-VCS-Committer-Name: Steve Arnold X-VCS-Revision: 9498391cdfe099fb51b68d5a0f68ef8be7476fb7 X-VCS-Branch: master Date: Thu, 30 May 2019 23:05:44 +0000 (UTC) Precedence: bulk List-Post: List-Help: List-Unsubscribe: List-Subscribe: List-Id: Gentoo Linux mail X-BeenThere: gentoo-commits@lists.gentoo.org X-Auto-Response-Suppress: DR, RN, NRN, OOF, AutoReply X-Archives-Salt: af45244a-7997-4230-8c2e-0086d87d547e X-Archives-Hash: 0ad75289b96f9bba19b0808c0f587924 commit: 9498391cdfe099fb51b68d5a0f68ef8be7476fb7 Author: Stephen Arnold gentoo org> AuthorDate: Thu May 30 23:05:07 2019 +0000 Commit: Steve Arnold gentoo org> CommitDate: Thu May 30 23:05:07 2019 +0000 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9498391c dev-util/cccc: rev-bump for eapi migration and QA cleanup * use EAPI 6, filter lto flags, clean up QA issues (restore fixed version from the trash) Bug: https://bugs.gentoo.org/651446 Package-Manager: Portage-2.3.64, Repoman-2.3.12 Signed-off-by: Steve Arnold gentoo.org> dev-util/cccc/Manifest | 1 + dev-util/cccc/cccc-3.1.5-r1.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, 190 insertions(+) diff --git a/dev-util/cccc/Manifest b/dev-util/cccc/Manifest new file mode 100644 index 00000000000..887fa77c8cf --- /dev/null +++ b/dev-util/cccc/Manifest @@ -0,0 +1 @@ +DIST cccc-3.1.5.tar.gz 662760 BLAKE2B 57817ef9a44f002c017245d7dd3b1ef97fec59b59bce465d5e5e1cc12409b5602cfd8bf7ee938e526af9bcc11398639900d26848aa4f8c7f623669159de17117 SHA512 61544669a75ff7bd99c6ff5bb1e6ec163f2a09f4538493fe60e8f9f95eab7ba19ad6d39b6717ae010a223b8efe48c497a4feb8ead218e350ee2ab91b9c52c969 diff --git a/dev-util/cccc/cccc-3.1.5-r1.ebuild b/dev-util/cccc/cccc-3.1.5-r1.ebuild new file mode 100644 index 00000000000..a26523720d4 --- /dev/null +++ b/dev-util/cccc/cccc-3.1.5-r1.ebuild @@ -0,0 +1,70 @@ +# Copyright 1999-2019 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=6 + +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 ~arm64 ~ppc ~x86 ~amd64-linux ~x86-linux ~ppc-macos" +IUSE="apidoc debug doc mfc" + +RDEPEND="" +DEPEND="${RDEPEND} + apidoc? ( app-doc/doxygen[dot] ) + " + +src_prepare() { + is-flagq -flto* && filter-flags -flto* -fuse-linker-plugin + use mfc && eapply "${FILESDIR}"/${PN}-c_dialect.patch + default + +} + +src_compile() { + tc-export CC CXX LD AS AR NM RANLIB STRIP OBJCOPY + if use debug ; then + 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 + insinto /usr/share/doc/${PF} + doins "${FILESDIR}"/cccc-MFC-dialect.opt + fi + + if use doc ; then + insinto /usr/share/doc/${PF}/html + doins cccc/*.html || die "html docs failed" + if use apidoc ; then + insinto /usr/share/doc/${PF}/html/api + doins -r doxygen/html/* || die "dox failed" + insinto /usr/share/doc/${PF}/html/metrics + doins 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 00000000000..4c4acb32e1f --- /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 00000000000..c8951aef13c --- /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 00000000000..ecde1cfd0a0 --- /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 + +