From 23f1339a517c0f9e0be836ce0b8c2f31579201b3 Mon Sep 17 00:00:00 2001 From: Rtfsc8 Date: Thu, 17 Jan 2019 22:53:44 +0800 Subject: [PATCH 1/2] fix bug: some reverse code error like qualifiedName attribute undefined. --- .gitignore | 217 +++++++++++++++++++++++++++++++++++++++++++++++ code-analyzer.js | 4 + 2 files changed, 221 insertions(+) diff --git a/.gitignore b/.gitignore index eadef60..52f6006 100644 --- a/.gitignore +++ b/.gitignore @@ -10,3 +10,220 @@ Thumbs.db #Java Test Sources /unittest-files/src-jdk jisonOutput.txt +### Node template +# Logs +logs +*.log +npm-debug.log* +yarn-debug.log* +yarn-error.log* + +# Runtime data +pids +*.pid +*.seed +*.pid.lock + +# Directory for instrumented libs generated by jscoverage/JSCover +lib-cov + +# Coverage directory used by tools like istanbul +coverage + +# nyc test coverage +.nyc_output + +# Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) +.grunt + +# Bower dependency directory (https://bower.io/) +bower_components + +# node-waf configuration +.lock-wscript + +# Compiled binary addons (https://nodejs.org/api/addons.html) +build/Release + +# Dependency directories +node_modules/ +jspm_packages/ + +# TypeScript v1 declaration files +typings/ + +# Optional npm cache directory +.npm + +# Optional eslint cache +.eslintcache + +# Optional REPL history +.node_repl_history + +# Output of 'npm pack' +*.tgz + +# Yarn Integrity file +.yarn-integrity + +# dotenv environment variables file +.env + +# parcel-bundler cache (https://parceljs.org/) +.cache + +# next.js build output +.next + +# nuxt.js build output +.nuxt + +# vuepress build output +.vuepress/dist + +# Serverless directories +.serverless +### Eclipse template + +.metadata +bin/ +tmp/ +*.tmp +*.bak +*.swp +*~.nib +local.properties +.settings/ +.loadpath +.recommenders + +# External tool builders +.externalToolBuilders/ + +# Locally stored "Eclipse launch configurations" +*.launch + +# PyDev specific (Python IDE for Eclipse) +*.pydevproject + +# CDT-specific (C/C++ Development Tooling) +.cproject + +# CDT- autotools +.autotools + +# Java annotation processor (APT) +.factorypath + +# PDT-specific (PHP Development Tools) +.buildpath + +# sbteclipse plugin +.target + +# Tern plugin +.tern-project + +# TeXlipse plugin +.texlipse + +# STS (Spring Tool Suite) +.springBeans + +# Code Recommenders +.recommenders/ + +# Annotation Processing +.apt_generated/ + +# Scala IDE specific (Scala & Java development for Eclipse) +.cache-main +.scala_dependencies +.worksheet +### Linux template +*~ + +# temporary files which can be created if a process still has a handle open of a deleted file +.fuse_hidden* + +# KDE directory preferences +.directory + +# Linux trash folder which might appear on any partition or disk +.Trash-* + +# .nfs files are created when an open file is removed but is still being accessed +.nfs* +### JetBrains template +# Covers JetBrains IDEs: IntelliJ, RubyMine, PhpStorm, AppCode, PyCharm, CLion, Android Studio and WebStorm +# Reference: https://intellij-support.jetbrains.com/hc/en-us/articles/206544839 + +# User-specific stuff +.idea/**/workspace.xml +.idea/**/tasks.xml +.idea/**/usage.statistics.xml +.idea/**/dictionaries +.idea/**/shelf + +# Sensitive or high-churn files +.idea/**/dataSources/ +.idea/**/dataSources.ids +.idea/**/dataSources.local.xml +.idea/**/sqlDataSources.xml +.idea/**/dynamic.xml +.idea/**/uiDesigner.xml +.idea/**/dbnavigator.xml + +# Gradle +.idea/**/gradle.xml +.idea/**/libraries + +# Gradle and Maven with auto-import +# When using Gradle or Maven with auto-import, you should exclude module files, +# since they will be recreated, and may cause churn. Uncomment if using +# auto-import. +# .idea/modules.xml +# .idea/*.iml +# .idea/modules + +# CMake +cmake-build-*/ + +# Mongo Explorer plugin +.idea/**/mongoSettings.xml + +# File-based project format +*.iws + +# IntelliJ +out/ + +# mpeltonen/sbt-idea plugin +.idea_modules/ + +# JIRA plugin +atlassian-ide-plugin.xml + +# Cursive Clojure plugin +.idea/replstate.xml + +# Crashlytics plugin (for Android Studio and IntelliJ) +com_crashlytics_export_strings.xml +crashlytics.properties +crashlytics-build.properties +fabric.properties + +# Editor-based Rest Client +.idea/httpRequests + +.idea/checkstyle-idea.xml +.idea/copyright/ +.idea/encodings.xml +.idea/inspectionProfiles/ +.idea/markdown-navigator.xml +.idea/markdown-navigator/ +.idea/misc.xml +.idea/modules.xml +.idea/staruml-java.iml +.idea/vcs.xml diff --git a/code-analyzer.js b/code-analyzer.js index dd5f6db..1edefc7 100644 --- a/code-analyzer.js +++ b/code-analyzer.js @@ -303,6 +303,10 @@ class JavaCodeAnalyzer { // Resolve Type References for (i = 0, len = this._typedFeaturePendings.length; i < len; i++) { var _typedFeature = this._typedFeaturePendings[i] + //Fix bug: some reverse code error like qualifiedName attribute undefined + if (!!!_typedFeature.node.type.qualifiedName) { + continue; + } _typeName = _typedFeature.node.type.qualifiedName.name // Find type and assign From 5bb172658e197728cbb99bcd2e9bde100e87b28e Mon Sep 17 00:00:00 2001 From: Rtfsc8 Date: Fri, 18 Jan 2019 18:04:51 +0800 Subject: [PATCH 2/2] Fix: Not processing empty file. --- .gitignore | 48 ++---------------------------------------------- code-analyzer.js | 4 ++++ 2 files changed, 6 insertions(+), 46 deletions(-) diff --git a/.gitignore b/.gitignore index 52f6006..2242592 100644 --- a/.gitignore +++ b/.gitignore @@ -159,40 +159,12 @@ local.properties # Covers JetBrains IDEs: IntelliJ, RubyMine, PhpStorm, AppCode, PyCharm, CLion, Android Studio and WebStorm # Reference: https://intellij-support.jetbrains.com/hc/en-us/articles/206544839 -# User-specific stuff -.idea/**/workspace.xml -.idea/**/tasks.xml -.idea/**/usage.statistics.xml -.idea/**/dictionaries -.idea/**/shelf - -# Sensitive or high-churn files -.idea/**/dataSources/ -.idea/**/dataSources.ids -.idea/**/dataSources.local.xml -.idea/**/sqlDataSources.xml -.idea/**/dynamic.xml -.idea/**/uiDesigner.xml -.idea/**/dbnavigator.xml - -# Gradle -.idea/**/gradle.xml -.idea/**/libraries - -# Gradle and Maven with auto-import -# When using Gradle or Maven with auto-import, you should exclude module files, -# since they will be recreated, and may cause churn. Uncomment if using -# auto-import. -# .idea/modules.xml -# .idea/*.iml -# .idea/modules +# ignore .idea directory +.idea/ # CMake cmake-build-*/ -# Mongo Explorer plugin -.idea/**/mongoSettings.xml - # File-based project format *.iws @@ -205,25 +177,9 @@ out/ # JIRA plugin atlassian-ide-plugin.xml -# Cursive Clojure plugin -.idea/replstate.xml - # Crashlytics plugin (for Android Studio and IntelliJ) com_crashlytics_export_strings.xml crashlytics.properties crashlytics-build.properties fabric.properties -# Editor-based Rest Client -.idea/httpRequests - -.idea/checkstyle-idea.xml -.idea/copyright/ -.idea/encodings.xml -.idea/inspectionProfiles/ -.idea/markdown-navigator.xml -.idea/markdown-navigator/ -.idea/misc.xml -.idea/modules.xml -.idea/staruml-java.iml -.idea/vcs.xml diff --git a/code-analyzer.js b/code-analyzer.js index 1edefc7..0146bb9 100644 --- a/code-analyzer.js +++ b/code-analyzer.js @@ -159,6 +159,10 @@ class JavaCodeAnalyzer { this._files.forEach(file => { var data = fs.readFileSync(file, 'utf8') try { + /* Not processing empty file @author Rtfsc8(rtfsc8@rtfsc8.top) */ + if (!!!data) { + return; + } var ast = java7.parse(data) this._currentCompilationUnit = ast this._currentCompilationUnit.file = file