Skip to content
This repository has been archived by the owner on Oct 27, 2020. It is now read-only.

Default API version for compiling is set to 21 #1

Closed
calebsander opened this issue Jun 4, 2015 · 10 comments
Closed

Default API version for compiling is set to 21 #1

calebsander opened this issue Jun 4, 2015 · 10 comments

Comments

@calebsander
Copy link

FtcRobotController/build.gradle instructs Gradle to try to build the app using Android SDK 21, which doesn't make sense given that it is designed for SDK 19 and SDK 22 is the newest release version.

@acharraggi
Copy link

I noticed that too, I wondered why I had to download API 21 when the "targetSdkVersion 19" . I think the 21 is coming from compileSdkVersion = 'Google Inc.:Google APIs:21'. I let Android Studio build it that way, it works, but we shouldn't need that. International teams may not be able to use the ZTE Speed phones so their set up could be different, but I think it Android 4.4 is still recommended.

I think we'll want to set compileSdkVersion to 19 based on:
http://stackoverflow.com/questions/26694108/what-is-the-difference-between-compilesdkversion-and-targetsdkversion

I tried this and was able to get it to run. I changed compileSdkVersion = 'Google Inc.:Google APIs:19' and also set minSdkVersion 19.
File at: https://github.com/acharraggi/ftc_app/blob/master/FtcRobotController/build.gradle

Seems to work ok, I've got the driver and robot apps running on the ZTE phones (but with no other hardware yet).

@cuuupid
Copy link

cuuupid commented Jun 5, 2015

Can you make a pull request so everyone gets an updated copy? Thanks!

@acharraggi acharraggi mentioned this issue Jun 5, 2015
@agileconnor
Copy link

@acharraggi While I agree with you on the topic of European users having differences in hardware, I disagree on your judgement that we should downgrade to API 19. The target SDK has no effect on the software or the phones that it runs on. All that is saying is that this is the API we tested it the most and where it is guaranteed to work. This is used in the Android app store to determine which phone cannot run the software / what version the app is optimized for.
By using the latest API we can get access to newer features only available in that version (ie Better multithreading). Android has automatic backwards compatibility so even if the phone is running API 19 it can still use the application.

Sources

@JacobAMason
Copy link
Contributor

I have to agree with @agileconnor; leaving the compileSdkVersion at 21 will allow the app to build on devices running Lolipop (Android 5.0). I have built the app for Lolipop on my OnePlus and I didn't have any build errors. I might need to change the targetSdkVersion to do a true test of sdk21/Lolipop for this app (maybe?).
In addition, the .iml file here probably shouldn't have been included in the repository to begin with, since I believe that is a file regenerated at build.

@acharraggi
Copy link

If this was a general purpose Android app, then the highest API level possible would be best. And perhaps ftctech should leave it as is since this is an example we can all use and some will deploy to newer versions.

But once you copy this app, you are going to customize it for your robot and it's only going to run on your robot controller phone and that will have a specific API level. That app will not run on an earlier API or a later API, it's only running on one phone.

If you leave compileSdkVersion at 21 but you're phone's API is 19, you can possibly include calls to features not supported. eg. Sensor.TYPE_HEART_RATE requires API level 20, it's flagged as 'field requires API level 20 (current min is 19)' when the min is 19 and compileSdkVersion is 21. You're allowed to build it even though it won't do what you want. Change compileSdkVersion to 19 however and you get a 'cannot resolve symbol' error. Also, Android Studio helps with auto-complete based on the compileSdkVersion so you don't even see TYPE_HEART_RATE as an option to pick from.

Why not let the compiler flag newer stuff that won't work on your phone?

I'm not sure we need to change compileSdkVersion at source. But I do think each team should set compileSdkVersion to match their phones after they copy the software. I think now I would recommend "build instructions" in the README mention some recommendation or suggestions. And that may come as part of User manual that the README says is forthcoming.

@acharraggi
Copy link

@JacobAMason: I agree, FtcRobotController.iml could be removed from the repository.

I confirmed that FtcRobotController.iml will be rebuilt if you start with a clean directory and that IML deleted and then open that directory with "Open an existing Android Studio project".

The build process populates the API version in the IML file. If you also change build.gradle prior to the build to set compileSdkVersion to 19 you get Android 4.4.2 in the IML file, instead of the 5.0.1 reference.

@ftclhsrobotics
Copy link

The FtcRobotController.iml is an IntelliJ module file and should not be part of the repository

@ftclhsrobotics
Copy link

You closed the issue but you did not remove the FtcRobotController.iml

Do you feel is still necessary?

@calebsander
Copy link
Author

That seems like a different issue. I was originally only referring to FtcRobotController/build.gradle, although I agree removing FtcRobotController.iml is a good idea.

@ftclhsrobotics
Copy link

Yeah...I think the topic was hijacked :-)

On Sat, Aug 15, 2015 at 4:51 PM, Caleb Sander [email protected]
wrote:

That seems like a different issue. I was originally only referring to
FtcRobotController/build.gradle, although I agree removing
FtcRobotController.iml is a good idea.


Reply to this email directly or view it on GitHub
#1 (comment).

markshancock referenced this issue in TigardRobotics/ftc_app Nov 4, 2015
AwesomeJohnR pushed a commit to GG7190/ftc_app that referenced this issue Jul 29, 2016
dedztbh pushed a commit to dedztbh/ftc_app that referenced this issue Oct 5, 2016
cporter pushed a commit to cporter/ftc_app that referenced this issue Nov 25, 2016
Code we've been working on after school
cporter pushed a commit to cporter/ftc_app that referenced this issue Sep 7, 2017
cporter pushed a commit to cporter/ftc_app that referenced this issue Sep 14, 2017
citruseel referenced this issue in ARC-Thunder/ftc_app Sep 27, 2017
cporter pushed a commit to cporter/ftc_app that referenced this issue Oct 8, 2017
cporter pushed a commit to cporter/ftc_app that referenced this issue Oct 8, 2017
sameer-s referenced this issue in FTC7604/ftc_app Oct 9, 2017
Signed-off-by: Sameer Suri <[email protected]>
cporter pushed a commit to cporter/ftc_app that referenced this issue Nov 14, 2017
tei06398 added a commit to tei06398/twentyeighteen that referenced this issue Dec 1, 2017
Contains OpenCV Code First Revision
TheSaminator added a commit to Aedificatores8581/rover-ruckus-legacy that referenced this issue Dec 9, 2017
NanoGurus4347 pushed a commit to NanoGurus4347/ftc_app that referenced this issue Jan 26, 2018
* Get rid of dex util bloat. (Not needed since OnBotJava is now history)

* Get rid of javac. (Not needed since OnBotJava is now history)

* Get rid of WirelessP2p AAR file (Not needed I guess since it builds fine without it)

* Add turbo version to about activity

* Remove 2016-17 Vuforia target files
NanoGurus4347 pushed a commit to NanoGurus4347/ftc_app that referenced this issue Jan 26, 2018
JoelzCodez added a commit to CyberEagles/ftc_app that referenced this issue Sep 29, 2018
LBYPatrick added a commit to NozomiWorks-LLC/FTC2019 that referenced this issue Oct 3, 2018
TKeeney25 referenced this issue in CHSRobo/ftc_app Oct 20, 2018
knightsean00 referenced this issue in Thunderbots5604/2019-2020-Code Nov 3, 2018
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

No branches or pull requests

6 participants