Commit Graph

1750 Commits

Author SHA1 Message Date
e3fd1e8115 StaticInitialValueIterator -> EncodedArrayItemIterator 2018-05-23 13:34:16 -07:00
6c054e1b44 Minor javadoc fixes in MethodProtoReference 2018-05-23 13:34:16 -07:00
b575410a8a Add the basic structures necessary to support invoke-custom 2018-05-23 13:34:16 -07:00
dfdde5ee21 Bump the version to 2.2.3 2018-03-07 16:22:53 -08:00
1fed67b820 Don't use java 1.6 for release.
It's becoming non-trivial to even get a 1.6 JDK these days.

Releases will be done with 1.8 instead
2018-03-07 16:19:45 -08:00
37eb703409 Make smali file iteration more deterministic
In some cases, even when running in single threaded mode (-j 1), smali
could produce slightly different results if files are not listed in
a consistent order.

This ensures that we assemble a given set of smali files in a consistent
order when running in single-threaded mode, regardless of the order
they are listed in.
2018-02-28 16:22:47 -08:00
681222d391 Fix NaN comparison
Use Float.isNaN/Double.isNaN to correctly detect NaN.

Detected by errorprone.
2018-01-23 11:56:02 -08:00
948c0205b8 Bump the version to 2.2.2 2017-10-30 15:34:58 -07:00
38f575608f Fix line_start annotation in debug_info_item
line_start can be > 2^31, so we have to use readBigUleb128 instead
of readSmallUleb128
2017-10-02 19:10:31 -07:00
20a272dbb9 Fix an issue when writing uleb128 values larger than 2^31 2017-10-02 19:10:31 -07:00
b84345935a Fix out registers for invoke-polymorphic
The calculation of the number of output registers for
invoke-polymorphic and invoke-polymorphic-range should be based on the
number of registers provided.
2017-09-12 14:34:56 -07:00
93a4373023 Bump the version to 2.2.1 2017-05-17 11:32:05 -07:00
d4702a45a7 Add basic support for ODEX instructions 2017-05-17 11:20:30 -07:00
dd22a795d8 Add an option to baksmali to allow disassembling odex opcodes
These instructions should never be present in a dex file, only in odex/oat
files. However, it's sometimes useful to be able to disassemble an otherwise
valid dex file that happens to contain odex instructions.
2017-05-15 17:01:44 -07:00
58a4809720 Update Gradle wrapper to 3.5 2017-05-15 15:46:58 -07:00
dd11921529 Fix for counting method implementation sizes 2017-04-25 12:02:57 -07:00
b65e942e7e Add support for getting byte sizes to dex backed references 2017-04-21 13:54:27 -07:00
76d69c7466 Bump smalidea version to v0.05 2017-03-31 17:06:53 -07:00
10fd792f59 Correctly calculate the offset for switch targets in smalidea
This fixes an issue where watches on registers (among other things) don't
work inside a method containing a switch statement, due to a failure
analyzing the method.
2017-03-31 17:06:53 -07:00
cef72530bb Merge pull request #504 from Furniel/master
Fixed Android M and N deodexing(Fixes #503)
2017-03-29 10:07:49 -07:00
9df7a67273 Fixed Android M and N deodexing(Fixes #503) 2017-03-29 12:39:44 +03:00
48cde6219d Add initial support for vdex files
This is the bare minimum to get deodexing to work with vdex files.
2017-03-25 16:25:49 -07:00
bda4477bae Update version to 2.2.0 2017-03-22 00:15:14 -07:00
e72e07fc2e Update version to 0.04 2017-03-21 23:53:11 -07:00
8ed2f18601 Add Project argument to SmaliClassFinder constructor
In some cases, scope.getProject() may be null. Apparently, IDEA will
automatically pass in the project if you specify one in the constructor.
See, e.g. MigrationElementFinder in the IDEA source.
2017-03-21 23:26:06 -07:00
a15fc84ace Add missing read actions in SmaliPositionManager 2017-03-21 22:03:42 -07:00
fa13b13bbd Update linked version of IDEA to 2016.3.5 2017-03-21 21:59:02 -07:00
1390c6cff6 getStubOrPsiParent() -> getParentByStub() 2017-03-21 21:22:29 -07:00
75fdec6e1d Use newer jcommander version for release
The newer version has some fixes we need, but we should still ensure
that we can compile against the old version, since that's the version
currently in AOSP.
2017-03-21 21:22:06 -07:00
9e3e86fda0 Improve the special case logic when propagating register types
This improves the logic dealing with initializing uninitialized reference and
narrowing register types after an instance-of
2017-03-12 15:41:14 -07:00
961c21be98 Fix possible NPE when generating accessor comments 2017-03-11 13:29:14 -08:00
152250d900 Fix missing format argument 2017-03-11 13:20:23 -08:00
cd1e5c5068 Fix download link in README.md 2017-02-22 17:05:01 -08:00
1a83d5a2d0 Propagate sideways conversions after an instance-of + if-eq/if-eqz
Previously, we only propagated the conversion if it was a narrowing
conversion, to avoid problems that can occur with member access with
widening conversions.

However, it should be safe to do the conversion for a "sideways"
conversion - one that is neither widening or narrowing.

This can happen if we don't yet have full knowledge of the register types,
or, less likely, if the "true" branch is impossible to reach.

In the first case, we should get better type info as we continue to analyze
the method, and we'll revisit the conversion once we have better type info.

Or, if it really is an impossible conversion, we still want to propagate
the type from the instance-of to the true branch.
2017-01-07 18:11:39 -08:00
adb12356c3 Don't perform type narrowing after an instance-of on dalvik 2016-11-12 12:54:02 -08:00
5e387e5931 Add better error message for when instruction offset is out of range 2016-11-06 14:25:25 -08:00
a0ccd94bf9 Improve the error message for a truncated last instruction 2016-10-23 22:10:11 -07:00
8e1afdda32 Clean up how api levels are handled in various places
Now that dex files store an associated Opcodes instance, we don't need to
pass the api level around as much.
2016-10-23 22:09:52 -07:00
7a95aa296f Add additional exception info if StringReference doesn't resolve to a String 2016-10-23 13:55:23 -07:00
8f7d1a897d Fix null start/end locations in SmaliCodeFragmentFactory.evaluateRegister 2016-10-23 13:15:32 -07:00
0e773cbe9b Don't attempt to evaluate an out-of-bounds register 2016-10-23 12:49:19 -07:00
ca0a4bdf37 Remove some unneeded casts in BuilderClassDef 2016-10-23 11:54:50 -07:00
fd8a1b4adc Make BuilderAnnotationSet public
It is used as a return type of public api BuilderClassDef.getAnnotations
2016-10-23 11:54:14 -07:00
c8e896b984 Add default dependencies for Android N 2016-10-17 16:19:15 -07:00
cb14aa7074 Remove obsolete TODO 2016-10-17 16:16:28 -07:00
8fa96e2fcd Resolve odex dependencies to jar files when needed 2016-10-17 16:15:17 -07:00
5401a9cbaa Bump the version number to v2.2b4 2016-10-16 14:18:56 -07:00
16d4b5656b Use a BufferedInputStream in ZipDexContainer.isDex 2016-10-16 13:46:42 -07:00
a6593575e7 Be more precise about narrowing after an instance-of
Only do the additional narrowing when all predecessors of the instance-of
are equivalent move instructions.
2016-10-16 13:45:30 -07:00
22e85fc3ff Add a --classes option for disassemble/deodex commands 2016-10-16 13:43:34 -07:00