Skip to content
This repository has been archived by the owner on Jan 26, 2023. It is now read-only.

S song develop #12

Open
wants to merge 24 commits into
base: develop
Choose a base branch
from
Open

S song develop #12

wants to merge 24 commits into from

Conversation

SSong-develop
Copy link

No description provided.

@SSong-develop SSong-develop added the 훈기 훈기 작업 label Nov 20, 2020
@SSong-develop SSong-develop self-assigned this Nov 20, 2020
@SSong-develop SSong-develop reopened this Nov 20, 2020
Copy link

@jinsu4755 jinsu4755 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

일단 미리 보라고 리뷰 하나 남깁니다 나머지는 바로 해볼께

Comment on lines 11 to 14
if(modelClass.isAssignableFrom(SearchViewModel::class.java)){
return SearchViewModel(repository) as T
}
throw IllegalArgumentException("Unknown class name")

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
if(modelClass.isAssignableFrom(SearchViewModel::class.java)){
return SearchViewModel(repository) as T
}
throw IllegalArgumentException("Unknown class name")
require(modelClass.isAssignableFrom(SearchViewModel::class.java)) { "Unknown class name" }
return SearchViewModel(repository) as T

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

동일 코드인데 if문을 조금더 줄여서 사용이 가능합니다! 이런 방법도 있구나 알고 있으면 좋음!

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

대박

Copy link
Member

@l2hyunwoo l2hyunwoo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

형님 수고하셨습니다.

Comment on lines 25 to 30
inner class RepoViewHolder<B : RepoItemBinding>(itemView : View) : RecyclerView.ViewHolder(itemView) {
val binding : B = DataBindingUtil.bind(itemView)!!
fun bind(userRepository : UserRepository){
binding.setVariable(BR.userRepository,userRepository)
}
}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
inner class RepoViewHolder<B : RepoItemBinding>(itemView : View) : RecyclerView.ViewHolder(itemView) {
val binding : B = DataBindingUtil.bind(itemView)!!
fun bind(userRepository : UserRepository){
binding.setVariable(BR.userRepository,userRepository)
}
}
inner class RepoViewHolde(private val binding: ViewDataBinding) : RecyclerView.ViewHolder(binding.root) {
fun bind(userRepository : UserRepository){
binding.setVariable(BR.userRepository,userRepository)
}
}

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

역시천재


override fun getItemCount(): Int = data.size

internal fun setData(recentSearchTerm: List<RecentSearchTerm>){
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

결국엔 이것도 public이네....(같은 모듈에서만 사용하는거니까) 그냥 접근제한자 없애도 될 것 같아

Comment on lines 29 to 34
inner class SearchTermViewHolder<B : SearchTermItemBinding>(itemView : View) : RecyclerView.ViewHolder(itemView) {
val binding : B = DataBindingUtil.bind(itemView)!!
fun bind(recentSearchTerm: RecentSearchTerm){
binding.setVariable(BR.searchTerm,recentSearchTerm)
}
}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

카톡에 있는거 참고

android:id="@+id/login"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="16dp"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
android:layout_marginLeft="16dp"
android:layout_marginStart="16dp"

android:layout_width="match_parent"
android:layout_height="wrap_content">
<TextView
android:id="@+id/login"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

id 이름이 뭐하는 건지 모르겠군요

android:id="@+id/url"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="10dp"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

4의 배수 맞추시고

app:layout_constraintTop_toTopOf="parent" />

<TextView
android:id="@+id/url"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

id 쌉극혐이고

</data>

<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="401dp"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

401dp 모냐고~

Comment on lines 15 to 27
<TextView
android:id="@+id/login"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="16dp"
android:layout_marginTop="16dp"
android:text="@{users.login}"
android:textSize="12sp"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />

<TextView
android:id="@+id/url"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

다른 뷰인데 같은 id가 보이네...나중에 헷갈릴 수 있을 것 같아

</data>

<androidx.constraintlayout.widget.ConstraintLayout
android:id="@+id/frameLayout2"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

호오 쒸잇

@jinsu4755
Copy link

불필요한 제네렉 삭제해주세요~~~~

import com.siba.searchmvvmpractice.remote.model.Users

class UserAdapter<B : UserItemBinding> : RecyclerView.Adapter<UserAdapter<B>.UserViewHolder<B>>() {
var data = mutableListOf<Users>()

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Adapter를 제작할때 내부에 데이터들은 밖으로 줄 필요가 없으니 불필요한 getter를 만드는 var은 별로 좋지 않은거 같아.
val로 불변하게 만들어서 clear같은걸 이용해보는건 어때?
아니면 해당 어뎁터를 일급 컬랙션으로 래핑해서
어떤 메소드를 통해 데이터를 변경하라는 메시지를 던지는게 더 좋을 거 같아

Copy link

@jinsu4755 jinsu4755 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

의견 남겨봤어~ 한번 보고 다시 의견 남겨줘도 좋고 굿잡 형이 젤 진도 빠르네 멋지다..

Comment on lines +18 to +30
fun getInstance(context: Context): SearchTermDatabase {
synchronized(this) {
var instance = INSTANCE

if (instance == null) {
instance = Room.databaseBuilder(
context.applicationContext,
SearchTermDatabase::class.java,
"search_keyword_history_database2"
).build()
INSTANCE = instance
}
return instance

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

이 부분에 대한 코드인데 사실 구글에서 하라는 대로긴 하지만 너무 깊게 depth가 들어가는 부분이라 나는 이 부분은 좀 자바 같다고 생각하는데 어떻게 생각해?
depth를 줄이고 가독성 있게 만드는 방법이 있지 않을까?

그리고 약간 return 값이 instance인데 내부 변수인 이 친구를 던지는 이유는 뭘까..? 따로 변수를 만들지 않아도 충분히 가능한 부분 같아

Copy link

@jinsu4755 jinsu4755 Dec 2, 2020

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
fun getInstance(context: Context): SearchTermDatabase {
synchronized(this) {
var instance = INSTANCE
if (instance == null) {
instance = Room.databaseBuilder(
context.applicationContext,
SearchTermDatabase::class.java,
"search_keyword_history_database2"
).build()
INSTANCE = instance
}
return instance
fun getInstance(context: Context): SearchTermDatabase = INSTANCE ?: synchronized(this) {
INSTANCE ?: Room.databaseBuilder(
context.applicationContext,
SearchTermDatabase::class.java,
"search_keyword_history_database2"
).build().apply {
INSTANCE = this
}
}

이런 식으로 하면 기존 코드보다 뎁스도 줄이고 가독성도 해치지 않는다고 생각해

Copy link

@jinsu4755 jinsu4755 Dec 2, 2020

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

해당 함수가 SearchTermDatabase 타입의 INSTANCE를 던져주는데 만약 null이라면 동기화 블럭에 들어가서 Room 데이터베이스 빌더로 데이터 베이스 만들어주고 그걸 INSTANCE에 apply하는거지

기존 코드랑 똑같은데 다르게 작성해서 indent 를 줄이고 조금더 읽으면서 한눈에 파악되게 작성한거고

큰 차이점이 있다면 미리 우리가 선언해둔 인스턴스에 값이 들어있다면 동기화 블럭을 거치지 않아도 해당 인스턴스를 던져주는 느낌?
난 기존코드를 생각했을때 INSTANCE가 있던 없던 동기화 블럭에 간다고 생각해서
굳이 이미 INSTANCE가 있을때도 멀티스레드 세이프티하게 인스턴스를 던져줄 필요가 없다고 생각했어 어짜피 그땐 동일한 INSTANCE를 가져가니까

import retrofit2.http.GET
import retrofit2.http.Query

interface RetrofitService {

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

리트로핏 서비스 리트로핏에 대한 서비스? 뭔가 이름이 이상하다고 생각해
나였으면 GitHubSearchService 혹은 SearchService 로 할 것 같아

): UserCatalog

@GET("search/repositories")
suspend fun getRepositories(

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

이 프로젝트 안에서도 레포지터리가 있고 우리가 원하는 깃헙의 온라인 레포지터리도 있어서 그 두가지의 구분으로 나라면 getOnlineRepositories 뭐 이런 느낌으로 했을 것 같음!

import com.siba.searchmvvmpractice.databinding.RepoItemBinding
import com.siba.searchmvvmpractice.remote.model.UserRepository

class RepoAdapter<B : RepoItemBinding> : RecyclerView.Adapter<RepoAdapter<B>.RepoViewHolder<B>>() {

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

제네릭을 써서 컴파일시 강한 타입 검사와 손쉬운 타입 변화가 될 수 있는 건 좋은데 어짜피 해당 뷰 홀더에는 하나의 뷰 홀더를 사용하고 있고
굳이 Fragment에서 뷰홀더가 써야하는 RepoItemBinding을 엑티비티에서 이런 타입이다 선언해줄 필요가 있을까..? 이미 레포지터리를 위한 어뎁터인데 당연하게 안에 들어가는 바인딩은 레포지터리 아이템에 대한 바인딩이겠지..?

그래서 뭔가 RepoItemBinding 라는 클래스 타입을 B라는 제네릭으로 축약해버린거 같아서 아쉽다...

Comment on lines +18 to +19
require(modelClass.isAssignableFrom(SearchViewModel::class.java)){"Unknown class name"}
return SearchViewModel(repository) as T

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

굳 코드가 간결하고 더 읽기 쉬워졌네 👍


private fun setObserver() {
viewModel.githubRepo.observe(viewLifecycleOwner) {
repoAdapter.data = it.userRepository as MutableList<UserRepository>

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

이부분도 뭔가 어뎁터에 MutableList를 잘 사용하지 못한거 같아. 추가와 삭제가 자유로운데 결국 새로운 변하는 리스트를 대입해버리면 애초에 그냥 repoAdapter.data가 List여도 상관 없는거 아닐까..?

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
훈기 훈기 작업
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants