From a97925c5c76c134f36bd3e9908ce5803622614f8 Mon Sep 17 00:00:00 2001 From: GabrielNakamura Date: Tue, 9 Jul 2024 16:16:25 -0300 Subject: [PATCH] atualizando html de conflitos e arrumando cronograma --- Darwin-core-LNP.html | 4 +-- Organizacao_dir_local.html | 4 +-- basics_git.html | 7 ++-- colabs_github.html | 4 +-- commits-travel.html | 12 +++++-- conflitos.html | 70 ++++++++++++++++++++++++++++---------- dados_abertos.html | 4 +-- gitgnore.html | 4 +-- index.html | 5 ++- intro_ciencia_aberta.html | 4 +-- metadata_EML.html | 4 +-- pre-registro.html | 4 +-- publicacoes.html | 4 +-- releasing.html | 4 +-- renv-basics.html | 4 +-- rmarkdown-basics.html | 4 +-- rocker_basics.html | 4 +-- sites-basics.html | 4 +-- targets_basics.html | 4 +-- 19 files changed, 97 insertions(+), 57 deletions(-) diff --git a/Darwin-core-LNP.html b/Darwin-core-LNP.html index 87a9043..1401850 100644 --- a/Darwin-core-LNP.html +++ b/Darwin-core-LNP.html @@ -11,7 +11,7 @@ - + Metadata com Living Norway package @@ -549,7 +549,7 @@

Metadata com Living Norway package

Gabriel Nakamura

-

2024-07-08

+

2024-07-09

diff --git a/Organizacao_dir_local.html b/Organizacao_dir_local.html index de9a5e0..dfdc51b 100644 --- a/Organizacao_dir_local.html +++ b/Organizacao_dir_local.html @@ -11,7 +11,7 @@ - + Organizando o seu trabalho localmente @@ -545,7 +545,7 @@

Organizando o seu trabalho localmente

Gabriel Nakamura

-

2024-07-08

+

2024-07-09

diff --git a/basics_git.html b/basics_git.html index 713ab0b..6e35ff8 100644 --- a/basics_git.html +++ b/basics_git.html @@ -11,7 +11,7 @@ - + Controle de versão @@ -550,7 +550,7 @@

Controle de versão

Gabriel Nakamura

-

2024-07-08

+

2024-07-09

@@ -1044,9 +1044,10 @@

Referências importantes

href="http://www2.stat.duke.edu/~rcs46/lectures_2015/01-markdown-git/slides/naming-slides/naming-slides.pdf">Jenny Bryan

Hadley Wickham

+

Oh Shit, Git!?!

-
---
title: 'Controle de versão'
author: "Gabriel Nakamura"
date: "`r Sys.Date()`"
output: html_document
---

```{r setup, include=FALSE}
knitr::opts_chunk$set(echo = TRUE, fig.align = "center")
```

```{r klippy, echo=FALSE, include=TRUE}
klippy::klippy()
```

# Apresentação

Nesta primeira seção irei apresentar as principais ferramentas que utilizaremos para nos ajudar na organização computacional de dados, scripts, análises e projetos científicos em geral. Estas ferramentas irão auxiliar desde a organização local de seus dados até a disponibilização destes dados em plataformas de acesso aberto. Várias delas já devem ser velhas conhecidas por vocês, por exemplo, o RStudio, então dispensam maiores apresentações. Por isso, grande parte deste documento vai tratar de uma ferramenta até bem conhecida pelo nome, mas que pra muita gente pode parecer coisa de outro mundo: o **Git**. Vocês verão que conhecem mais dele do que imaginam, e que muitas das funções que ele possibilita realizar nós já fazemos em nosso dia-a-dia através de outros aplicativos, porém, com mais eficiência e controle das ações.

## Pacotes necessários 

Para executar os códigos desta parte é importante ter os seguintes pacotes instalados: `usethis`, `devtools` e `gitcreds`

Você pode realizar a instalação utilizando a seguinte linha de código:

```{r librariesRead, echo=TRUE, eval=TRUE}
libs <- c("usethis", "devtoos", "gitcreds")
if (!requireNamespace(libs, quietly = TRUE)){
    install.packages(libs)
  }
```

Caso você não tenha os pacotes acima citados a instalação será realizada. Caso já tenha em seu computador, nada irá acontecer.

# Hello Git - Introdução ao uso de sistema de controle de versões

O Git trata-se de um sistema de controle de versões, mas afinal, o que é um sistema de controle de versões? Estamos mais acostumados do que imaginamos quando o assunto é controle de versões, apesar de parecer algo de outro mundo. Um exemplo que todos nós estamos acostumados é oferecido pelo editor de texto Word, quando ligamos a opção "Track changes". Ao fazermos isso estamos controlando todas as modificações que fazemos em um documento. O Git faz a mesma coisa, porém para uma pasta inteira (ou *diretório*, na linguagem do controle de versões).

Portanto, o Git nada mais é que um sistema criado para realizar o rastreio de toda e qualquer modificação de arquivos dentro de uma pasta, utilizando a terminologia do versionamento, tudo o que é feito em um diretório associado ao Git é *observado* (*watch* na linguagem do versionamento).

## Git e GitHub

Ter a possibilidade de controlar as versões dos documentos já é bom, imagine, além disso, ter um local remoto onde tudo isso fica guardado. Ou seja, se seu computador quebrar, for roubado, pifar, ou se você troca-lo, tudo estará seguro em um lugar chamado GitHub.

Portanto, Git e [GitHub](https://github.com/) são coisas distintas. O GitHub é o GoogleDrive (ou o OneDrive) dos códigos. Ele tem como função armazenar remotamente todos os trabalhos que são feitos localmente e que estão sendo monitorados pelo Git, mas com muito mais potencialidades e controle de armazenamento que as ferramentas do Bill Gates. Por exemplo, imagine guardar um site inteiro no Google Drive, ou um pacote estatístico que você escreveu, e ainda disponibilizar essas coisas para outras pessoas... parece complicado se usarmos as ferramentas comerciais mais comuns, mas com o GitHub tudo isso se torna possível ser realizado com facilidade

## Git e Git client

Temos uma ferramenta que possibilita o versionamento (o Git), outra que possibilita o armazenamento, colaboração, compartilhamento (GitHub), mas como controlamos essas ferramentas? É aí que entra o que chamamos de **Git client**

Uma simples analogia para entender a diferença entre um Git client e o Git é a diferença entre R e RStudio. O R é a ferramenta onde os processos são realizados, o RStudio é uma interface específica e amigável para o uso do R. Da mesma forma o Git é a ferramenta que realiza o controle de versão, já o Git client é a interface específica para que o usuário possa interagir de maneira mais amigável com o Git e GitHub. Existem vários Git clients que podemos utilizar para realizar essa interação, por exemplo, o [GitKraken](https://www.gitkraken.com/) e [GitLab](https://about.gitlab.com/). Cada um tem suas vantagens e desvantagens.

Neste curso usaremos um Git client que é um velho conhecido nosso, o **RStudio**. Faremos isso  pois o RStudio (agora chamado Posit, mas vamos manter o velho nome) é a interface mais comum utilizada nos estudos de ecologia e evolução, além de apresentar uma grande quantidade de materiais disponíveis na internet e também por ser aquela que o instrutor que vos fala tem mais familiaridade. 

## Integrando Git, GitHub e RStudio

Agora que conhecemos as ferramentas, imagine se conseguíssemos colocar elas em um só lugar. Imagine um sistema que integra o seu programa favorito de análises estatísticas, o seu programa favorito de controle de versões e também o seu repositório remoto favorito. Pois é disso que se trata a integração do Git com o GitHub e RStudio. Tudo (quase tudo) pode ser feito no Git através do RStudio. Portanto, nas próximas seções irei apresentar como podemos integrar o controle de versão (Git) com o repositório remoto (GitHub) e o RStudio.

# Mãos no teclado - Instalando e configurando o Git

O primeiro passo antes de instalar o Git é saber se você já tem ele instalado em seu computador. Para tanto você deve acessar a linha de comando de seu sistema operacional (bash, prompt, isso vai variar dependendo do tipo de sistema que usa) e digitar o comando:

```{r echo=TRUE, eval=FALSE}
git
```

Caso retorne uma mensagem indicando o local do git no seu computador, ótimo, uma tarefa a menos, caso contrário você terá que instalar o git de acordo com as especificidades do seu sistema operacional que serão apresentadas a seguir.

## Instalação do Git no Windows

Instale o Git acessando [aqui](https://gitforwindows.org/) e siga as informações do auxiliar de instalação que foi baixado.

## Instação do Git no Mac OS

Instale o Git no seu Mac baixando o Xcode command line tools caso você ainda não o tenha. Esta aplicação já vem com o git. Aceite as configurações e clique em instalar

Em seguida configure o git usando a linha de comando seguinte no seu terminal:

```{r echo=TRUE, eval=FALSE}
git --version
git config --global user.name "Your name here"
git config --global user.email "your_email@example.com"
```

## Instalação do Git no Linux 

Digite a seguinte linha de comando caso você tenha Ubuntu ou Debian Linux

```{r echo=TRUE, eval=FALSE}
sudo apt-get install git
```

Se tem Fedora ou HatLinux use:

```{r echo=TRUE, eval=FALSE}
sudo yum install git
```

**Algumas coisas podem ser diferentes dependendo do seu sistema operacional e versão do Linux**, caso se depare com algum problema tente abrir um **Issue** no repositório desta apostila no GitHub e tentaremos resolver :)

# Configuração do Git e integração com RStudio

## Utilizando o pacote `usethis`

Após a instalação do Git devemos configur o GitHub no nosso computador. Para configurar o GitHub, ou seja, para que o Git e GitHub saiba quem está usando, vamos utilizar a configuração com auxílio do ótimo pacote `usethis`. Portanto, abra o RStudio e digite:

```{r echo=TRUE, eval=FALSE}
library(usethis)
use_git_config(user.name = "SeuNomeDeUsuario", user.email = "seuMail@example.br")
```

Lembre de substituir os campos que aparecerão no console do seu R com suas informações. "SeuNomeDeUsuario" é o nome que você cadastrou no GitHub

```{r echo=FALSE,eval=TRUE,fig.cap="Nome do usuário destacado em vermelho"}
knitr::include_graphics("figs/NomeUsuario.png")
```


## Utilizando o pacote `gitcreds` - **Mais recomendada**

Apesar de estarmos falando de ciência aberta, o seu perfil no GitHub é pessoal, portanto é importante que haja uma forma de autenticação onde o GitHub saiba que você é o dono do perfil. Isso geralmente é feito através do uso de senhas, porém senhas nem sempre são seguras (ok, provavelmente ninguém vai querer invadir nosso GitHub para tomar informações sobre uma função que calcula a dimensionalidade da biodiversidade, mas outras coisas são desenvolvidas e hospedadas no GitHub), e por isso a forma padrão de autenticação utilizada pelo GitHub é o chamado PAT (Personal Access Token). Segundo o próprio GitHub um PAT é:

> "Personal access tokens are an alternative to using passwords for authentication to GitHub when using the GitHub API or the command line."

O PAT nada mais é que uma "senha" gerada pelo próprio github e que deve ser renovada com certa periodicidade. **O GitHub não permite mais autenticações via senha, apenas usando o PAT**. Portanto, o último passo para integrar o R, RStudio, Git e GitHub é informar o PAT. Precisaremos fazer isso apenas uma vez, e repetir apenas quando o PAT expirar. Vamos começar gerando o PAT. Para informações mais detalhadas sobre o PAT você pode acessar [esta](https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/managing-your-personal-access-tokens) página.

Para configurar o PAT vamos usar primeiro o pacote `usethis` e depois vamos utilizar as funcionalidades do pacote `gitcreds`.Digite a linha de código no seu console do R:

```{r echo=TRUE, eval=FALSE}
library(usethis)
create_github_token()
```

Isso abrirá uma guia no seu navegador para que você gere um token, tal como mostrado na imagem abaixo

```{r echo=FALSE,eval=TRUE,fig.cap="Exemplo da página do GitHub para gerar um token"}
knitr::include_graphics("figs/PAT-creation.png")
```

Você verá inúmeras opções de acesso. As caixinhas que vamos escolher vai depender do grau de controle que você deseja ter para usar o GitHub via Rstudio.

Após gerado, **guarde esse token com carinho**, pois ele vai ser sua nova senha de entrada para o GitHub via RStudio, quando for requerido. Para armazenar senhas e dados eu sugiro o programa **LastPass**.

Próximo passo é registar esse token gerado em nosso computador. Para tanto, faça o seguinte:

```{r PAT, echo=TRUE, eval=FALSE}
library(gitcreds)
gitcreds::gitcreds_set()
```

No console aparecerá a mensagem para digitar o token, copie o token e cole direto no navegador, pressione enter e pronto, seu RStudio está autenticado e agora está devidamente conectado com o repositório remoto. Estamos pronto para o nosso primeiro commit!!!!


# Conectando Git, RStudio e Github pela primeira vez

Antes de começar a utilizar o Git e GitHib via RStudio vamos primeiro dar uma olhadinha no site do GitHub. Abra o GitHub, faça o seu login e vamos dar uma explorada por lá.

Após esse passeio pelo GitHub, vamos criar nosso repositório para esta aula. Só lembrando que para fazer isso você já precisa ter uma conta criada no GitHub e o Git instalado. Tendo sua conta feita vá o seu navegador de internet, acesse o site do GitHub e faça o login. Feito isso:

1 - Crie um repositório 

Crie um novo repositório clicando no botão destacado na figura abaixo

```{r echo=FALSE,eval=TRUE,fig.cap="Criando um novo repositório a partir do GitHub"}
knitr::include_graphics("figs/Create-Reppo.png")
```

Existem outras formas de iniciar um repositório, inclusive direto pelo RStudio, mas vamos pelo caminho mais simples por enquanto.

# O ABC do versionamento: Clone, Pull, Push and Commits 

Vimos nas aulas teóricas que essas palavrinhas não são nada mais que ações que praticamos no nosso dia-a-dia. Agora é hora de colocar em prática.

Já temos um repositório remoto, agora precisamos que ele exista em nossos computadores para que possamos sincronizar nosso trabalho local e remoto. De maneira geral o que queremos fazer a partir de agora está ilustrado na figura seguinte

```{r echo=FALSE,eval=TRUE,out.width="55%"}
knitr::include_graphics("figs/version-control-all.png")
```

A partir de agora iremos, passo a passo, realizar todas as funções básicas essenciais para organização computacional de um projeto científico.

O primeiro passo é realizar uma clonagem!

## O Clone

```{r echo=FALSE,eval=TRUE,fig.cap="Referência de velho",out.width="55%"}
knitr::include_graphics("figs/o-clone.jpeg")
```

Para que nosso repositório local esteja ligado ao nosso repositório remoto precisamos primeiro conectá-los. Fazemos isso ao clonar o repositório remoto em nossa máquina. Clonar (clone) nesse caso não é nada mais que criar uma cópia exata de um repositório remoto em sua máquina. A partir desse momento esses repositórios estarão conectados até que o Git os separe.

Para clonar vá até o repositório remoto de interesse, e copie a chave https, como mostrado na figura a seguir:

```{r echo=FALSE,eval=TRUE}
knitr::include_graphics("figs/github-copy-https.png")
```

Clique no botão de cópia e vamos para o RStudio. No RStudio vá em `File` e depois `New Project`. A partir daí siga as imagens abaixo:

### 1. Copiando a chave https no GitHub

```{r echo=FALSE,eval=TRUE,fig.cap="Copiando chave https"}
knitr::include_graphics("figs/github-copy-https.png")
```

### 2. Criando um novo **projeto** localmente

```{r echo=FALSE,eval=TRUE,fig.cap="Abrindo um novo projeto"}
knitr::include_graphics("figs/github-versioncontrol-option.png")
```

### 3. Colando a chave para ligar o repositório remoto com o local

```{r echo=FALSE,eval=TRUE,fig.cap="Colando a chave https"}
knitr::include_graphics("figs/github-paste-https.png")
```

Ao clicar em `Create project` o repositório remoto será imediatamente transferido para o seu computador. Uma pasta (o diretório local) será criado no local que você escolheu e, assim, RStudio, Git e Github estarão plenamente conectados. Tudo certo até aqui? Uma pausa para descanso com um vídeo.

```{r echo=FALSE,eval=TRUE}
vembedr::embed_url("https://www.youtube.com/watch?v=j7K3s_vi_1Y")
```


## Pull, Commits e Push 

Se você chegou até aqui sem erros isso quer dizer que Git e GitHub já estão integrados no RStudio. Portanto, qualquer coisa que fizermos nesta pasta está sendo observado a partir de agora pelo git. Para certirficar-se disso, habilite a visualização de arquivos ocultos no seu computador, você vai notar que na raiz desta pasta clonada existe uma pasta `.git`, como na figura a seguir

```{r echo=FALSE,eval=TRUE}
knitr::include_graphics("figs/git-inside-folder.png")
```

Se você consegue ver esta pasta quer dizer que está tudo certo, e o git está observando (**watch** no jargão do versionamento) cada modificação e cada arquivo dentro desta pasta (a menos que você inclua o arquivo no .gitignore, mas isso é assunto para outro momento).

```{r echo=FALSE,eval=TRUE,out.width="55%"}
knitr::include_graphics("figs/big-brother-watching.png")
```

Agora iremos executar funções que, até o fim deste curso, serão quase automáticas no nosso fluxo de trabalho com versionamento.

### Meu primeiro commit

O que é um commit?

Commit, ou "revisão", é uma mudança individual em um arquivo ou um conjunto de arquivos dentro da pasta observada pelo git. Os commits são como check-points para o nosso repositório. Uma analogia interessante para os commits foi apresentada na aula e está ilustrada aqui, na figura seguinte


```{r echo=FALSE, eval=FALSE,out.width="60%"}
knitr::include_graphics(here::here("figs", "commit-only-concept.png"))
```

Vamos pensar que nosso projeto é uma montanha, e estamos escalando ele. Nosso objetivo final é, obviamente, finalizar o projeto, chegando ao topo da montanha. A medida que progredimos,caso venhamos a cometer um erro, a queda pode ser grande. Desta maneira, utilizamos grampos onde ancoramos nossa corda a medida que a escalada progride. Em caso de erro, a queda será apenas até o grampo anterior onde a corda foi ancorada. Os commits servem como os clipes que ancoram a corda a medida que progredimos no projeto. Se cometermos um erro em algum arquivo, tudo certo, podemos voltar no commit anterior, ou anteriores, para tentar descobrir onde o erro foi cometido.

Da mesma forma que na escalada, se utilizarmos clipes muito pertinhos uns dos outros vamos ficar lentos demais, e o progresso até o topo será comprometido, se fizermos muitos commits será difícil voltar em momentos específicos do projeto, visto que terão muitos commits para serem checados. Portanto, a regra é: faça commits com parcimonia, ou seja, nem muitos, nem poucos.

Vamos fazer uma modificação na nossa pasta. Podemos adicionar arquivos, já que ela está vazia. Para tanto vamos usar os arquivos do pacote de dados palmer penguins que estão nesse repositório. Lembre-se de ler os arquivos utilizando o `{here}` e utilizar o Rproject para abrir o diretório

```{r echo=TRUE,eval=FALSE}
data_penguins <- read.csv(here::here("data", "data-penguins.csv")) 
```

**Obs** se quiserem usar seus próprios dados fiquem a vontade, o uso do palmerpenguins é apenas opcional e a título de procedimento didático. 

Caso estejam trabalhando com seus próprios dados, jogue os arquivos para dentro do diretório que clonamos. O próximo passo é fazer nosso primeiro commit.


### Explorando commits

```{r echo=FALSE, eval=TRUE,out.width="70%"}
knitr::include_graphics(here::here("figs", "commit-safe.png"))
```
Existem duas formas de fazer versionamento usando o Git e Github via RStudio. Uma delas é a linha de comando, a outra é via uma interface visual, que nesse caso é o próprio RStudio. Vamos começar fazendo o versionamento via interface visual. A opção para isso é que ninguém se assuste num primeiro momento com a linha de comando, e que isso não seja um impeditivo para utilizar o versionamento no seu fluxo de trabalho. A maioria dos comandos básicos podem ser executados através desta interface gráfica que chamamos de **Git Client**

Repare que seu RStudio agora tem algumas coisas novas. Especificamente, veja que agora ele tem uma aba chamada Git, como ilustrado na figura abaixo


```{r echo=FALSE,eval=TRUE}
knitr::include_graphics(here::here("figs", "git-tab-rstudio.png"))
```

Isso indica que o git está funcionando no seu diretório, e agora podemos fazer o versionamento deste diretório local e sincronizá-lo com o repositório remoto.

Tudo e qualquer coisa que for adicionado ou modificado na sua pasta vai aparecer na janela abaixo da aba git. Como mostrado na figura abaixo

```{r echo=FALSE,eval=TRUE}
knitr::include_graphics(here::here("figs", "git-tab-rstudio2.png"))
```

Como eu mencionei na aula teórica e aqui acima, o commit é como um track changes do word, mas melhor. Precisamos fazer um track change manual, indicando o que foi modificado, isso é o nosso commit. Para realizar um commit via a interface do RStudio você precisa:

1 - Clicar no botão `commit pending changes` (ou em qualquer botão naquela aba), como mostrado abaixo

```{r echo=FALSE,eval=TRUE}
knitr::include_graphics(here::here("figs", "git-tab-rstudio3.png"))
```

2 - Isso vai abrir uma nova janela, nela você deve selecionar nos checkbox os arquivos (vamos dar uma olhada nessa janela antes de prosseguir)

```{r echo=FALSE,eval=TRUE}
knitr::include_graphics(here::here("figs", "git-tab-rstudio4.png"))
```

3 - Escreva uma mensagem informativa. Como este é o primeiro commit geralmente selecionamos todos os arquivos e escrevemos a mensagem `First commit` para indicar que é o primeiro commit deste repositório

```{r echo=FALSE,eval=TRUE}
knitr::include_graphics(here::here("figs", "git-tab-rstudio5.png"))
```

**OBS** A mensagem deve ser realmente informativa, o commit fica armazenado no seu repositório e aparecerá publicamente caso o repositório seja público. 

```{r echo=FALSE,eval=TRUE,out.width="60%"}
knitr::include_graphics(here::here("figs", "commit-meme.png"))
```

Pronto, o que fizemos agora foi basicamente colocar nossos arquivos na **stagging area** (marcar as checking box) e prepará-los para a entrega com uma mensagem informativa, o commit. Agora precisamos enviar os arquivos para o repositório remoto (upstream)

### Meu primeiro push

Temos um diretório functionando com o git, ligado ao github, com documentos dentro, mas, até agora ele apenas vive em nossos computadores. Chegou a hora de empurrar estes documentos para o diretório remoto, ou seja, aquele que clonamos lá no início. Para tanto vamos fazer um `push`

O push nada mais é que empurrar os documentos para o repositório do github, chamado as vezes de `origin/master` e outras vezes `origin/main`, mas ambos querem dizer "um repositório remoto o qual o diretório que estou trabalhando está ligado".

Sem mais delongas, para fazer um push precisamos apenas apertar o botão verde como mostrado na figura abaixo

```{r echo=FALSE,eval=TRUE}
knitr::include_graphics(here::here("figs", "git-tab-rstudio6.png"))
```

Duas coisas são importantes notar nesse momento. Primeiro o botão de push, que vai empurrar os arquivos para o repositório remoto (origin). Segundo, a mensagem destacada com a seta. Ela diz que o *branch* está a frente do *origin/master* por um *commit*. Traduzindo, nosso diretório local (branch), está uma versão a frente (pois modificamos coisas aqui) em relação ao nosso repositório remoto (origin/master). Ao empurrar (push) as modificações, essa mensagem desaparecerá, indicando que tanto branch quanto origin estão na mesma linha do tempo!

# Extras

Aqui algumas dicas extras caso você queira seguir caminhos diferentes que os apresentados até agora para montar um repositório e conectar com o github. Vamos supor que você já tenha um projeto local em seu computador que já está monitorado pelo git, contém alguns commits, e você não quer perder estes commit. A forma mais fácil de fazer isso é através do pacote `{usethis}`. Para utilizar esta abordagem você precisa ter o PAT (Personal Access Token que criamos lá em cima).

1 - verifique se o git está funcionando em seu repositório (veja se aparece a tab git no seu RStudio). Caso não veja você precisa iniciar o git no diretório que está trabalhando. Para fazer isso:

```{r echo=TRUE,eval=FALSE}
usethis::use_git()
```

Outras opções existem, por exemplo, usando o terminal diretamente. Mas vamos manter a consistência e utilizar sempre o pacote usethis quando possível.

2 - uma vez que o git está funcionando neste repositório, precisamos criar um repositório remoto para ele no nosso perfil do GitHub. Para tanto precisamos apenas digitar:

```{r echo=TRUE,eval=FALSE}
usethis::use_github()
```


# Atividade

Hora de praticar com seus dados, ou ainda com os dados do palmerpenguins. Faça algumas modificações na tabela, salve um novo objeto, faça um commit e um push. Após fazer isso verifique na página do repositório no GitHub o que aconteceu.

# Referências importantes

[Douglas McDonald website](https://www.douganddata.com/2022/07/on-naming-things/)

[Jenny Bryan](http://www2.stat.duke.edu/~rcs46/lectures_2015/01-markdown-git/slides/naming-slides/naming-slides.pdf)

[Hadley Wickham](http://adv-r.had.co.nz/Style.html)



+
---
title: 'Controle de versão'
author: "Gabriel Nakamura"
date: "`r Sys.Date()`"
output: html_document
---

```{r setup, include=FALSE}
knitr::opts_chunk$set(echo = TRUE, fig.align = "center")
```

```{r klippy, echo=FALSE, include=TRUE}
klippy::klippy()
```

# Apresentação

Nesta primeira seção irei apresentar as principais ferramentas que utilizaremos para nos ajudar na organização computacional de dados, scripts, análises e projetos científicos em geral. Estas ferramentas irão auxiliar desde a organização local de seus dados até a disponibilização destes dados em plataformas de acesso aberto. Várias delas já devem ser velhas conhecidas por vocês, por exemplo, o RStudio, então dispensam maiores apresentações. Por isso, grande parte deste documento vai tratar de uma ferramenta até bem conhecida pelo nome, mas que pra muita gente pode parecer coisa de outro mundo: o **Git**. Vocês verão que conhecem mais dele do que imaginam, e que muitas das funções que ele possibilita realizar nós já fazemos em nosso dia-a-dia através de outros aplicativos, porém, com mais eficiência e controle das ações.

## Pacotes necessários 

Para executar os códigos desta parte é importante ter os seguintes pacotes instalados: `usethis`, `devtools` e `gitcreds`

Você pode realizar a instalação utilizando a seguinte linha de código:

```{r librariesRead, echo=TRUE, eval=TRUE}
libs <- c("usethis", "devtoos", "gitcreds")
if (!requireNamespace(libs, quietly = TRUE)){
    install.packages(libs)
  }
```

Caso você não tenha os pacotes acima citados a instalação será realizada. Caso já tenha em seu computador, nada irá acontecer.

# Hello Git - Introdução ao uso de sistema de controle de versões

O Git trata-se de um sistema de controle de versões, mas afinal, o que é um sistema de controle de versões? Estamos mais acostumados do que imaginamos quando o assunto é controle de versões, apesar de parecer algo de outro mundo. Um exemplo que todos nós estamos acostumados é oferecido pelo editor de texto Word, quando ligamos a opção "Track changes". Ao fazermos isso estamos controlando todas as modificações que fazemos em um documento. O Git faz a mesma coisa, porém para uma pasta inteira (ou *diretório*, na linguagem do controle de versões).

Portanto, o Git nada mais é que um sistema criado para realizar o rastreio de toda e qualquer modificação de arquivos dentro de uma pasta, utilizando a terminologia do versionamento, tudo o que é feito em um diretório associado ao Git é *observado* (*watch* na linguagem do versionamento).

## Git e GitHub

Ter a possibilidade de controlar as versões dos documentos já é bom, imagine, além disso, ter um local remoto onde tudo isso fica guardado. Ou seja, se seu computador quebrar, for roubado, pifar, ou se você troca-lo, tudo estará seguro em um lugar chamado GitHub.

Portanto, Git e [GitHub](https://github.com/) são coisas distintas. O GitHub é o GoogleDrive (ou o OneDrive) dos códigos. Ele tem como função armazenar remotamente todos os trabalhos que são feitos localmente e que estão sendo monitorados pelo Git, mas com muito mais potencialidades e controle de armazenamento que as ferramentas do Bill Gates. Por exemplo, imagine guardar um site inteiro no Google Drive, ou um pacote estatístico que você escreveu, e ainda disponibilizar essas coisas para outras pessoas... parece complicado se usarmos as ferramentas comerciais mais comuns, mas com o GitHub tudo isso se torna possível ser realizado com facilidade

## Git e Git client

Temos uma ferramenta que possibilita o versionamento (o Git), outra que possibilita o armazenamento, colaboração, compartilhamento (GitHub), mas como controlamos essas ferramentas? É aí que entra o que chamamos de **Git client**

Uma simples analogia para entender a diferença entre um Git client e o Git é a diferença entre R e RStudio. O R é a ferramenta onde os processos são realizados, o RStudio é uma interface específica e amigável para o uso do R. Da mesma forma o Git é a ferramenta que realiza o controle de versão, já o Git client é a interface específica para que o usuário possa interagir de maneira mais amigável com o Git e GitHub. Existem vários Git clients que podemos utilizar para realizar essa interação, por exemplo, o [GitKraken](https://www.gitkraken.com/) e [GitLab](https://about.gitlab.com/). Cada um tem suas vantagens e desvantagens.

Neste curso usaremos um Git client que é um velho conhecido nosso, o **RStudio**. Faremos isso  pois o RStudio (agora chamado Posit, mas vamos manter o velho nome) é a interface mais comum utilizada nos estudos de ecologia e evolução, além de apresentar uma grande quantidade de materiais disponíveis na internet e também por ser aquela que o instrutor que vos fala tem mais familiaridade. 

## Integrando Git, GitHub e RStudio

Agora que conhecemos as ferramentas, imagine se conseguíssemos colocar elas em um só lugar. Imagine um sistema que integra o seu programa favorito de análises estatísticas, o seu programa favorito de controle de versões e também o seu repositório remoto favorito. Pois é disso que se trata a integração do Git com o GitHub e RStudio. Tudo (quase tudo) pode ser feito no Git através do RStudio. Portanto, nas próximas seções irei apresentar como podemos integrar o controle de versão (Git) com o repositório remoto (GitHub) e o RStudio.

# Mãos no teclado - Instalando e configurando o Git

O primeiro passo antes de instalar o Git é saber se você já tem ele instalado em seu computador. Para tanto você deve acessar a linha de comando de seu sistema operacional (bash, prompt, isso vai variar dependendo do tipo de sistema que usa) e digitar o comando:

```{r echo=TRUE, eval=FALSE}
git
```

Caso retorne uma mensagem indicando o local do git no seu computador, ótimo, uma tarefa a menos, caso contrário você terá que instalar o git de acordo com as especificidades do seu sistema operacional que serão apresentadas a seguir.

## Instalação do Git no Windows

Instale o Git acessando [aqui](https://gitforwindows.org/) e siga as informações do auxiliar de instalação que foi baixado.

## Instação do Git no Mac OS

Instale o Git no seu Mac baixando o Xcode command line tools caso você ainda não o tenha. Esta aplicação já vem com o git. Aceite as configurações e clique em instalar

Em seguida configure o git usando a linha de comando seguinte no seu terminal:

```{r echo=TRUE, eval=FALSE}
git --version
git config --global user.name "Your name here"
git config --global user.email "your_email@example.com"
```

## Instalação do Git no Linux 

Digite a seguinte linha de comando caso você tenha Ubuntu ou Debian Linux

```{r echo=TRUE, eval=FALSE}
sudo apt-get install git
```

Se tem Fedora ou HatLinux use:

```{r echo=TRUE, eval=FALSE}
sudo yum install git
```

**Algumas coisas podem ser diferentes dependendo do seu sistema operacional e versão do Linux**, caso se depare com algum problema tente abrir um **Issue** no repositório desta apostila no GitHub e tentaremos resolver :)

# Configuração do Git e integração com RStudio

## Utilizando o pacote `usethis`

Após a instalação do Git devemos configur o GitHub no nosso computador. Para configurar o GitHub, ou seja, para que o Git e GitHub saiba quem está usando, vamos utilizar a configuração com auxílio do ótimo pacote `usethis`. Portanto, abra o RStudio e digite:

```{r echo=TRUE, eval=FALSE}
library(usethis)
use_git_config(user.name = "SeuNomeDeUsuario", user.email = "seuMail@example.br")
```

Lembre de substituir os campos que aparecerão no console do seu R com suas informações. "SeuNomeDeUsuario" é o nome que você cadastrou no GitHub

```{r echo=FALSE,eval=TRUE,fig.cap="Nome do usuário destacado em vermelho"}
knitr::include_graphics("figs/NomeUsuario.png")
```


## Utilizando o pacote `gitcreds` - **Mais recomendada**

Apesar de estarmos falando de ciência aberta, o seu perfil no GitHub é pessoal, portanto é importante que haja uma forma de autenticação onde o GitHub saiba que você é o dono do perfil. Isso geralmente é feito através do uso de senhas, porém senhas nem sempre são seguras (ok, provavelmente ninguém vai querer invadir nosso GitHub para tomar informações sobre uma função que calcula a dimensionalidade da biodiversidade, mas outras coisas são desenvolvidas e hospedadas no GitHub), e por isso a forma padrão de autenticação utilizada pelo GitHub é o chamado PAT (Personal Access Token). Segundo o próprio GitHub um PAT é:

> "Personal access tokens are an alternative to using passwords for authentication to GitHub when using the GitHub API or the command line."

O PAT nada mais é que uma "senha" gerada pelo próprio github e que deve ser renovada com certa periodicidade. **O GitHub não permite mais autenticações via senha, apenas usando o PAT**. Portanto, o último passo para integrar o R, RStudio, Git e GitHub é informar o PAT. Precisaremos fazer isso apenas uma vez, e repetir apenas quando o PAT expirar. Vamos começar gerando o PAT. Para informações mais detalhadas sobre o PAT você pode acessar [esta](https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/managing-your-personal-access-tokens) página.

Para configurar o PAT vamos usar primeiro o pacote `usethis` e depois vamos utilizar as funcionalidades do pacote `gitcreds`.Digite a linha de código no seu console do R:

```{r echo=TRUE, eval=FALSE}
library(usethis)
create_github_token()
```

Isso abrirá uma guia no seu navegador para que você gere um token, tal como mostrado na imagem abaixo

```{r echo=FALSE,eval=TRUE,fig.cap="Exemplo da página do GitHub para gerar um token"}
knitr::include_graphics("figs/PAT-creation.png")
```

Você verá inúmeras opções de acesso. As caixinhas que vamos escolher vai depender do grau de controle que você deseja ter para usar o GitHub via Rstudio.

Após gerado, **guarde esse token com carinho**, pois ele vai ser sua nova senha de entrada para o GitHub via RStudio, quando for requerido. Para armazenar senhas e dados eu sugiro o programa **LastPass**.

Próximo passo é registar esse token gerado em nosso computador. Para tanto, faça o seguinte:

```{r PAT, echo=TRUE, eval=FALSE}
library(gitcreds)
gitcreds::gitcreds_set()
```

No console aparecerá a mensagem para digitar o token, copie o token e cole direto no navegador, pressione enter e pronto, seu RStudio está autenticado e agora está devidamente conectado com o repositório remoto. Estamos pronto para o nosso primeiro commit!!!!


# Conectando Git, RStudio e Github pela primeira vez

Antes de começar a utilizar o Git e GitHib via RStudio vamos primeiro dar uma olhadinha no site do GitHub. Abra o GitHub, faça o seu login e vamos dar uma explorada por lá.

Após esse passeio pelo GitHub, vamos criar nosso repositório para esta aula. Só lembrando que para fazer isso você já precisa ter uma conta criada no GitHub e o Git instalado. Tendo sua conta feita vá o seu navegador de internet, acesse o site do GitHub e faça o login. Feito isso:

1 - Crie um repositório 

Crie um novo repositório clicando no botão destacado na figura abaixo

```{r echo=FALSE,eval=TRUE,fig.cap="Criando um novo repositório a partir do GitHub"}
knitr::include_graphics("figs/Create-Reppo.png")
```

Existem outras formas de iniciar um repositório, inclusive direto pelo RStudio, mas vamos pelo caminho mais simples por enquanto.

# O ABC do versionamento: Clone, Pull, Push and Commits 

Vimos nas aulas teóricas que essas palavrinhas não são nada mais que ações que praticamos no nosso dia-a-dia. Agora é hora de colocar em prática.

Já temos um repositório remoto, agora precisamos que ele exista em nossos computadores para que possamos sincronizar nosso trabalho local e remoto. De maneira geral o que queremos fazer a partir de agora está ilustrado na figura seguinte

```{r echo=FALSE,eval=TRUE,out.width="55%"}
knitr::include_graphics("figs/version-control-all.png")
```

A partir de agora iremos, passo a passo, realizar todas as funções básicas essenciais para organização computacional de um projeto científico.

O primeiro passo é realizar uma clonagem!

## O Clone

```{r echo=FALSE,eval=TRUE,fig.cap="Referência de velho",out.width="55%"}
knitr::include_graphics("figs/o-clone.jpeg")
```

Para que nosso repositório local esteja ligado ao nosso repositório remoto precisamos primeiro conectá-los. Fazemos isso ao clonar o repositório remoto em nossa máquina. Clonar (clone) nesse caso não é nada mais que criar uma cópia exata de um repositório remoto em sua máquina. A partir desse momento esses repositórios estarão conectados até que o Git os separe.

Para clonar vá até o repositório remoto de interesse, e copie a chave https, como mostrado na figura a seguir:

```{r echo=FALSE,eval=TRUE}
knitr::include_graphics("figs/github-copy-https.png")
```

Clique no botão de cópia e vamos para o RStudio. No RStudio vá em `File` e depois `New Project`. A partir daí siga as imagens abaixo:

### 1. Copiando a chave https no GitHub

```{r echo=FALSE,eval=TRUE,fig.cap="Copiando chave https"}
knitr::include_graphics("figs/github-copy-https.png")
```

### 2. Criando um novo **projeto** localmente

```{r echo=FALSE,eval=TRUE,fig.cap="Abrindo um novo projeto"}
knitr::include_graphics("figs/github-versioncontrol-option.png")
```

### 3. Colando a chave para ligar o repositório remoto com o local

```{r echo=FALSE,eval=TRUE,fig.cap="Colando a chave https"}
knitr::include_graphics("figs/github-paste-https.png")
```

Ao clicar em `Create project` o repositório remoto será imediatamente transferido para o seu computador. Uma pasta (o diretório local) será criado no local que você escolheu e, assim, RStudio, Git e Github estarão plenamente conectados. Tudo certo até aqui? Uma pausa para descanso com um vídeo.

```{r echo=FALSE,eval=TRUE}
vembedr::embed_url("https://www.youtube.com/watch?v=j7K3s_vi_1Y")
```


## Pull, Commits e Push 

Se você chegou até aqui sem erros isso quer dizer que Git e GitHub já estão integrados no RStudio. Portanto, qualquer coisa que fizermos nesta pasta está sendo observado a partir de agora pelo git. Para certirficar-se disso, habilite a visualização de arquivos ocultos no seu computador, você vai notar que na raiz desta pasta clonada existe uma pasta `.git`, como na figura a seguir

```{r echo=FALSE,eval=TRUE}
knitr::include_graphics("figs/git-inside-folder.png")
```

Se você consegue ver esta pasta quer dizer que está tudo certo, e o git está observando (**watch** no jargão do versionamento) cada modificação e cada arquivo dentro desta pasta (a menos que você inclua o arquivo no .gitignore, mas isso é assunto para outro momento).

```{r echo=FALSE,eval=TRUE,out.width="55%"}
knitr::include_graphics("figs/big-brother-watching.png")
```

Agora iremos executar funções que, até o fim deste curso, serão quase automáticas no nosso fluxo de trabalho com versionamento.

### Meu primeiro commit

O que é um commit?

Commit, ou "revisão", é uma mudança individual em um arquivo ou um conjunto de arquivos dentro da pasta observada pelo git. Os commits são como check-points para o nosso repositório. Uma analogia interessante para os commits foi apresentada na aula e está ilustrada aqui, na figura seguinte


```{r echo=FALSE, eval=FALSE,out.width="60%"}
knitr::include_graphics(here::here("figs", "commit-only-concept.png"))
```

Vamos pensar que nosso projeto é uma montanha, e estamos escalando ele. Nosso objetivo final é, obviamente, finalizar o projeto, chegando ao topo da montanha. A medida que progredimos,caso venhamos a cometer um erro, a queda pode ser grande. Desta maneira, utilizamos grampos onde ancoramos nossa corda a medida que a escalada progride. Em caso de erro, a queda será apenas até o grampo anterior onde a corda foi ancorada. Os commits servem como os clipes que ancoram a corda a medida que progredimos no projeto. Se cometermos um erro em algum arquivo, tudo certo, podemos voltar no commit anterior, ou anteriores, para tentar descobrir onde o erro foi cometido.

Da mesma forma que na escalada, se utilizarmos clipes muito pertinhos uns dos outros vamos ficar lentos demais, e o progresso até o topo será comprometido, se fizermos muitos commits será difícil voltar em momentos específicos do projeto, visto que terão muitos commits para serem checados. Portanto, a regra é: faça commits com parcimonia, ou seja, nem muitos, nem poucos.

Vamos fazer uma modificação na nossa pasta. Podemos adicionar arquivos, já que ela está vazia. Para tanto vamos usar os arquivos do pacote de dados palmer penguins que estão nesse repositório. Lembre-se de ler os arquivos utilizando o `{here}` e utilizar o Rproject para abrir o diretório

```{r echo=TRUE,eval=FALSE}
data_penguins <- read.csv(here::here("data", "data-penguins.csv")) 
```

**Obs** se quiserem usar seus próprios dados fiquem a vontade, o uso do palmerpenguins é apenas opcional e a título de procedimento didático. 

Caso estejam trabalhando com seus próprios dados, jogue os arquivos para dentro do diretório que clonamos. O próximo passo é fazer nosso primeiro commit.


### Explorando commits

```{r echo=FALSE, eval=TRUE,out.width="70%"}
knitr::include_graphics(here::here("figs", "commit-safe.png"))
```
Existem duas formas de fazer versionamento usando o Git e Github via RStudio. Uma delas é a linha de comando, a outra é via uma interface visual, que nesse caso é o próprio RStudio. Vamos começar fazendo o versionamento via interface visual. A opção para isso é que ninguém se assuste num primeiro momento com a linha de comando, e que isso não seja um impeditivo para utilizar o versionamento no seu fluxo de trabalho. A maioria dos comandos básicos podem ser executados através desta interface gráfica que chamamos de **Git Client**

Repare que seu RStudio agora tem algumas coisas novas. Especificamente, veja que agora ele tem uma aba chamada Git, como ilustrado na figura abaixo


```{r echo=FALSE,eval=TRUE}
knitr::include_graphics(here::here("figs", "git-tab-rstudio.png"))
```

Isso indica que o git está funcionando no seu diretório, e agora podemos fazer o versionamento deste diretório local e sincronizá-lo com o repositório remoto.

Tudo e qualquer coisa que for adicionado ou modificado na sua pasta vai aparecer na janela abaixo da aba git. Como mostrado na figura abaixo

```{r echo=FALSE,eval=TRUE}
knitr::include_graphics(here::here("figs", "git-tab-rstudio2.png"))
```

Como eu mencionei na aula teórica e aqui acima, o commit é como um track changes do word, mas melhor. Precisamos fazer um track change manual, indicando o que foi modificado, isso é o nosso commit. Para realizar um commit via a interface do RStudio você precisa:

1 - Clicar no botão `commit pending changes` (ou em qualquer botão naquela aba), como mostrado abaixo

```{r echo=FALSE,eval=TRUE}
knitr::include_graphics(here::here("figs", "git-tab-rstudio3.png"))
```

2 - Isso vai abrir uma nova janela, nela você deve selecionar nos checkbox os arquivos (vamos dar uma olhada nessa janela antes de prosseguir)

```{r echo=FALSE,eval=TRUE}
knitr::include_graphics(here::here("figs", "git-tab-rstudio4.png"))
```

3 - Escreva uma mensagem informativa. Como este é o primeiro commit geralmente selecionamos todos os arquivos e escrevemos a mensagem `First commit` para indicar que é o primeiro commit deste repositório

```{r echo=FALSE,eval=TRUE}
knitr::include_graphics(here::here("figs", "git-tab-rstudio5.png"))
```

**OBS** A mensagem deve ser realmente informativa, o commit fica armazenado no seu repositório e aparecerá publicamente caso o repositório seja público. 

```{r echo=FALSE,eval=TRUE,out.width="60%"}
knitr::include_graphics(here::here("figs", "commit-meme.png"))
```

Pronto, o que fizemos agora foi basicamente colocar nossos arquivos na **stagging area** (marcar as checking box) e prepará-los para a entrega com uma mensagem informativa, o commit. Agora precisamos enviar os arquivos para o repositório remoto (upstream)

### Meu primeiro push

Temos um diretório functionando com o git, ligado ao github, com documentos dentro, mas, até agora ele apenas vive em nossos computadores. Chegou a hora de empurrar estes documentos para o diretório remoto, ou seja, aquele que clonamos lá no início. Para tanto vamos fazer um `push`

O push nada mais é que empurrar os documentos para o repositório do github, chamado as vezes de `origin/master` e outras vezes `origin/main`, mas ambos querem dizer "um repositório remoto o qual o diretório que estou trabalhando está ligado".

Sem mais delongas, para fazer um push precisamos apenas apertar o botão verde como mostrado na figura abaixo

```{r echo=FALSE,eval=TRUE}
knitr::include_graphics(here::here("figs", "git-tab-rstudio6.png"))
```

Duas coisas são importantes notar nesse momento. Primeiro o botão de push, que vai empurrar os arquivos para o repositório remoto (origin). Segundo, a mensagem destacada com a seta. Ela diz que o *branch* está a frente do *origin/master* por um *commit*. Traduzindo, nosso diretório local (branch), está uma versão a frente (pois modificamos coisas aqui) em relação ao nosso repositório remoto (origin/master). Ao empurrar (push) as modificações, essa mensagem desaparecerá, indicando que tanto branch quanto origin estão na mesma linha do tempo!

# Extras

Aqui algumas dicas extras caso você queira seguir caminhos diferentes que os apresentados até agora para montar um repositório e conectar com o github. Vamos supor que você já tenha um projeto local em seu computador que já está monitorado pelo git, contém alguns commits, e você não quer perder estes commit. A forma mais fácil de fazer isso é através do pacote `{usethis}`. Para utilizar esta abordagem você precisa ter o PAT (Personal Access Token que criamos lá em cima).

1 - verifique se o git está funcionando em seu repositório (veja se aparece a tab git no seu RStudio). Caso não veja você precisa iniciar o git no diretório que está trabalhando. Para fazer isso:

```{r echo=TRUE,eval=FALSE}
usethis::use_git()
```

Outras opções existem, por exemplo, usando o terminal diretamente. Mas vamos manter a consistência e utilizar sempre o pacote usethis quando possível.

2 - uma vez que o git está funcionando neste repositório, precisamos criar um repositório remoto para ele no nosso perfil do GitHub. Para tanto precisamos apenas digitar:

```{r echo=TRUE,eval=FALSE}
usethis::use_github()
```


# Atividade

Hora de praticar com seus dados, ou ainda com os dados do palmerpenguins. Faça algumas modificações na tabela, salve um novo objeto, faça um commit e um push. Após fazer isso verifique na página do repositório no GitHub o que aconteceu.

# Referências importantes

[Douglas McDonald website](https://www.douganddata.com/2022/07/on-naming-things/)

[Jenny Bryan](http://www2.stat.duke.edu/~rcs46/lectures_2015/01-markdown-git/slides/naming-slides/naming-slides.pdf)

[Hadley Wickham](http://adv-r.had.co.nz/Style.html)

[Oh Shit, Git!?!](https://ohshitgit.com/)



diff --git a/colabs_github.html b/colabs_github.html index b18a0e4..c3c6f39 100644 --- a/colabs_github.html +++ b/colabs_github.html @@ -11,7 +11,7 @@ - + Trabalho em colaboração @@ -549,7 +549,7 @@

Trabalho em colaboração

Gabriel Nakamura

-

2024-07-08

+

2024-07-09

diff --git a/commits-travel.html b/commits-travel.html index afb84dd..e882f1f 100644 --- a/commits-travel.html +++ b/commits-travel.html @@ -11,7 +11,7 @@ - + Explorando melhor os commits @@ -549,7 +549,7 @@

Explorando melhor os commits

Gabriel Nakamura

-

2024-07-08

+

2024-07-09

@@ -671,8 +671,14 @@

Throwback Commit

site.)

+
+

Inutilidades públicas necessárias

+

No fim do dia, aprendemos fazer commits apenas para utilizar essa +ferramenta aqui. Cole o link de seu +repositório contendo alguns commits e veja o que acontece

+
-
---
title: 'Explorando melhor os commits'
author: "Gabriel Nakamura"
date: "`r Sys.Date()`"
output: html_document
---

```{r setup, include=FALSE}
knitr::opts_chunk$set(echo = TRUE, fig.align = "center")
```

```{r klippy, echo=FALSE, include=TRUE}
klippy::klippy()
```

# Apresentação

Nesta seção iremos explorar um pouco mais o poder que os commits nos oferecem, incluindo boas práticas para fazer commits nos nossos arquivos e como "viajar" entre commits passados e presente. Este momento também servirá para ficarmos um pouco mais familiarizados com o uso do git através do terminal. Vamos utilizar o teminal visto que algumas coisas que faremos aqui não podem ser feitas através do RStudio.

Sempre ao fazer commits vale lembrar essas palavras:

```{r echo=FALSE, eval=TRUE,out.width="70%"}
knitr::include_graphics(here::here("figs", "commit-safe.png"))
```

# Workflow para os commits 

Em primeiro lugar sempre cheque se está tudo certo com seu repositório, se seu trabalho local está sincronizado com seu trabalho remoto. Para tanto pode digitar na linha de comando do terminal

```{r echo=T,eval=FALSE}
git status
```

Se sua *working tree* estiver no status *clean*, quer dizer que você está sincronizada com o *origin*

Faça algumas modificações e depois vamos fazer a mesma sequencia de ações que fizemos anteriormente (stage, commit, push), mas agora usando a linha de comando. Para tanto podemos fazer assim

```{r echo=TRUE,eval=FALSE}
git add .
git commit -m "uma mensagem informativa"
git push
```

Pronto, fizemos a mesma coisa que anteriormente, mas agora utilizando o terminal :)

## Amend

Lembra que muitos commits podem te deixar muito lento na escalada? E poucos commits podem ser pouco informativos caso queira reconstruir o que aconteceu com o repositório? Pois então, existe uma estratégia interessante para realizar commits, chamada de `amend`

Em um amend nós basicamente adicionamos um commit a um outro já existente. Por exemplo, imagine que fez apenas algumas poucas modificações de código que não necessitam necessariamente de um commit dedicada exclusivamente para tais, você pode fazer o seguinte:

1 - stage o arquivo que modificou

```{r echo=TRUE,eval=FALSE}
git add path/to/file
```

2 - faça um commit 

```{r echo=TRUE,eval=FALSE}
git commit -m "WIP"
```

Note que coloquei **WIP** neste commit, por que? WIP é uma sigla usada comumente no versionamente para Working In Progress. Sempre que tiver um commit desse quer dizer que o commit que fez ainda está sendo trabalhado.

Ainda não faça o push. Faça mais algumas modificações, e, digamos que agora fez modificações relevantes no código que merecem um commit dedicado. Mas lembre-se que o último commit é um WIP. O que fazemos agora é um amend ao WIP

3 - faça um amend

```{r echo=TRUE,eval=FALSE}
git commit --amend -m "Aqui um commit com uma mensagem informativa, como sempre"
git push
```

Pronto, agora temos uma mensagem informativa que foi adicionada ao WIP e não precisamos fazer um push do passo intermediário (WIP), deixando nossa escalada mais rápida

## Viajando entre commits

Uma das maiores potencialidades dos commits é a possibilidade que podemos navegar entre commits. Ou seja, podemos navegar entre estados distintos do nosso trabalho a medida que ele é desenvolvido. Podemos checar esse histórico tanto na nossa página do repositório no GitHub quanto usando o RStudio, como mostrado na imagem a seguir

```{r echo=FALSE, eval=TRUE,out.width="70%"}
knitr::include_graphics(here::here("figs", "github-history.png"))
```

Para tanto você precisa apenas abrir a aba do Git no RStudio, como vimos anteriormente, e clicar em **History** no canto superior esquerdo da janela de revisões. Tudo o que vemos são todos os commits que foram realizados desde que esse repositório foi formado pela primeira vez.

## Elementos importantes do commit

Alguns elementos presentes no commit são importantes. O principal deles é a chave SHA-1. Esta se trata de um identificador único do commit. Com ela podemos viajar entre commits, ou referenciar um dado commit em uma discussão no github. Por exemplo, supondo que estamos trabalhando colaborativamente (como nesse site :)), e eu gostei particularmente mais da versão do site que está há alguns commits atrás. Uma opção é abrir uma Issue (veremos isso mais tarde), e referenciar esse número. Ou simplesmente dizer para meu colaborador "Hey dê uma olhada no commit número XXXXXX". Na imagem abaixo está em destaque a chave SHA.

```{r echo=FALSE, eval=TRUE,out.width="70%"}
knitr::include_graphics(here::here("figs", "git-sha-key.png"))
```

Você pode abrir o arquivo no estado em que ele se encontrava em um dado commit clicando no arquivo modificado naquele commit selecionado. Por exemplo, digamos que eu queira ver o arquivo chamado `rmarkdown-basics` deste site editado dia 02 de Agosto, só precisamos clicar no arquivo, como mostrado na imagem abaixo:

```{r echo=FALSE, eval=TRUE,out.width="70%"}
knitr::include_graphics(here::here("figs", "git-history-file.png"))
```

## Atividade

Explore um pouco os commits que realizaram. Abra a página do github e também através do Rstudio, veja as diferenças, as vantangens e desvantagens de cada uma das abordagens


## Throwback Commit

Vamos supor que realizamos um commit errado, e agora queremos voltar ao commit anterior, mas sem perder o trabalho que fizemos nos arquivos. Para isso podemos usar a abordagem anterior, navegando entre os arquivos e selecionando o arquivo que queremos em um determinado estado, substituimos pelo arquivo atual e fazemos um novo commit. Esta opção pode ser a mais segura se estamos começando a mexer no versionamento. Outra opção é explorar as funções do git chamadas `reset`. As funções reset basicamente move o HEAD do seu diretório para um commit no passado. Esta abordagem pode causar algumas dores de cabeça no início, portanto recomendo usa-lá com cautela. Para mais informações sobre isso dê uma olhada [nesse site](https://devconnected.com/how-to-git-reset-to-head/#:~:text=To%20hard%20reset%20files%20to,option%20and%20specify%20the%20HEAD.&text=The%20purpose%20of%20the%20%E2%80%9Cgit,before%20HEAD%20and%20so%20on).)


+
---
title: 'Explorando melhor os commits'
author: "Gabriel Nakamura"
date: "`r Sys.Date()`"
output: html_document
---

```{r setup, include=FALSE}
knitr::opts_chunk$set(echo = TRUE, fig.align = "center")
```

```{r klippy, echo=FALSE, include=TRUE}
klippy::klippy()
```

# Apresentação

Nesta seção iremos explorar um pouco mais o poder que os commits nos oferecem, incluindo boas práticas para fazer commits nos nossos arquivos e como "viajar" entre commits passados e presente. Este momento também servirá para ficarmos um pouco mais familiarizados com o uso do git através do terminal. Vamos utilizar o teminal visto que algumas coisas que faremos aqui não podem ser feitas através do RStudio.

Sempre ao fazer commits vale lembrar essas palavras:

```{r echo=FALSE, eval=TRUE,out.width="70%"}
knitr::include_graphics(here::here("figs", "commit-safe.png"))
```

# Workflow para os commits 

Em primeiro lugar sempre cheque se está tudo certo com seu repositório, se seu trabalho local está sincronizado com seu trabalho remoto. Para tanto pode digitar na linha de comando do terminal

```{r echo=T,eval=FALSE}
git status
```

Se sua *working tree* estiver no status *clean*, quer dizer que você está sincronizada com o *origin*

Faça algumas modificações e depois vamos fazer a mesma sequencia de ações que fizemos anteriormente (stage, commit, push), mas agora usando a linha de comando. Para tanto podemos fazer assim

```{r echo=TRUE,eval=FALSE}
git add .
git commit -m "uma mensagem informativa"
git push
```

Pronto, fizemos a mesma coisa que anteriormente, mas agora utilizando o terminal :)

## Amend

Lembra que muitos commits podem te deixar muito lento na escalada? E poucos commits podem ser pouco informativos caso queira reconstruir o que aconteceu com o repositório? Pois então, existe uma estratégia interessante para realizar commits, chamada de `amend`

Em um amend nós basicamente adicionamos um commit a um outro já existente. Por exemplo, imagine que fez apenas algumas poucas modificações de código que não necessitam necessariamente de um commit dedicada exclusivamente para tais, você pode fazer o seguinte:

1 - stage o arquivo que modificou

```{r echo=TRUE,eval=FALSE}
git add path/to/file
```

2 - faça um commit 

```{r echo=TRUE,eval=FALSE}
git commit -m "WIP"
```

Note que coloquei **WIP** neste commit, por que? WIP é uma sigla usada comumente no versionamente para Working In Progress. Sempre que tiver um commit desse quer dizer que o commit que fez ainda está sendo trabalhado.

Ainda não faça o push. Faça mais algumas modificações, e, digamos que agora fez modificações relevantes no código que merecem um commit dedicado. Mas lembre-se que o último commit é um WIP. O que fazemos agora é um amend ao WIP

3 - faça um amend

```{r echo=TRUE,eval=FALSE}
git commit --amend -m "Aqui um commit com uma mensagem informativa, como sempre"
git push
```

Pronto, agora temos uma mensagem informativa que foi adicionada ao WIP e não precisamos fazer um push do passo intermediário (WIP), deixando nossa escalada mais rápida

## Viajando entre commits

Uma das maiores potencialidades dos commits é a possibilidade que podemos navegar entre commits. Ou seja, podemos navegar entre estados distintos do nosso trabalho a medida que ele é desenvolvido. Podemos checar esse histórico tanto na nossa página do repositório no GitHub quanto usando o RStudio, como mostrado na imagem a seguir

```{r echo=FALSE, eval=TRUE,out.width="70%"}
knitr::include_graphics(here::here("figs", "github-history.png"))
```

Para tanto você precisa apenas abrir a aba do Git no RStudio, como vimos anteriormente, e clicar em **History** no canto superior esquerdo da janela de revisões. Tudo o que vemos são todos os commits que foram realizados desde que esse repositório foi formado pela primeira vez.

## Elementos importantes do commit

Alguns elementos presentes no commit são importantes. O principal deles é a chave SHA-1. Esta se trata de um identificador único do commit. Com ela podemos viajar entre commits, ou referenciar um dado commit em uma discussão no github. Por exemplo, supondo que estamos trabalhando colaborativamente (como nesse site :)), e eu gostei particularmente mais da versão do site que está há alguns commits atrás. Uma opção é abrir uma Issue (veremos isso mais tarde), e referenciar esse número. Ou simplesmente dizer para meu colaborador "Hey dê uma olhada no commit número XXXXXX". Na imagem abaixo está em destaque a chave SHA.

```{r echo=FALSE, eval=TRUE,out.width="70%"}
knitr::include_graphics(here::here("figs", "git-sha-key.png"))
```

Você pode abrir o arquivo no estado em que ele se encontrava em um dado commit clicando no arquivo modificado naquele commit selecionado. Por exemplo, digamos que eu queira ver o arquivo chamado `rmarkdown-basics` deste site editado dia 02 de Agosto, só precisamos clicar no arquivo, como mostrado na imagem abaixo:

```{r echo=FALSE, eval=TRUE,out.width="70%"}
knitr::include_graphics(here::here("figs", "git-history-file.png"))
```

## Atividade

Explore um pouco os commits que realizaram. Abra a página do github e também através do Rstudio, veja as diferenças, as vantangens e desvantagens de cada uma das abordagens


## Throwback Commit

Vamos supor que realizamos um commit errado, e agora queremos voltar ao commit anterior, mas sem perder o trabalho que fizemos nos arquivos. Para isso podemos usar a abordagem anterior, navegando entre os arquivos e selecionando o arquivo que queremos em um determinado estado, substituimos pelo arquivo atual e fazemos um novo commit. Esta opção pode ser a mais segura se estamos começando a mexer no versionamento. Outra opção é explorar as funções do git chamadas `reset`. As funções reset basicamente move o HEAD do seu diretório para um commit no passado. Esta abordagem pode causar algumas dores de cabeça no início, portanto recomendo usa-lá com cautela. Para mais informações sobre isso dê uma olhada [nesse site](https://devconnected.com/how-to-git-reset-to-head/#:~:text=To%20hard%20reset%20files%20to,option%20and%20specify%20the%20HEAD.&text=The%20purpose%20of%20the%20%E2%80%9Cgit,before%20HEAD%20and%20so%20on).)


# Inutilidades públicas necessárias

No fim do dia, aprendemos fazer commits apenas para utilizar essa ferramenta [aqui](https://starlogs.dev/). Cole o link de seu repositório contendo alguns commits e veja o que acontece


diff --git a/conflitos.html b/conflitos.html index 5701a0e..0354174 100644 --- a/conflitos.html +++ b/conflitos.html @@ -11,7 +11,7 @@ - + Resolução de conflitos de versão @@ -448,7 +448,7 @@

Resolução de conflitos de versão

Gabriel Nakamura

-

2024-07-08

+

2024-07-09

@@ -461,16 +461,15 @@

2024-07-08

Apresentação

Não há nada mais frustrante no mundo do versionamento que um push ou um pull rejeitado. Mas ao incorporarmos as ferramentas de versionamento -em nossa rotina de trabalho será inevitável que em algum momento vamos -nos deparar com alguma mensagem de rejeição de um push ou pull que, a +em nossa rotina de trabalho será inevitável em algum momento não +esbarrar em alguma mensagem de rejeição de um push ou pull que, a maioria das vezes, tem como principal razão a existência de conflitos em -versões de documentos. Portanto, nesta seção vamos entender como -resolver conflitos em versionamento

+versões de documentos. Portanto, nesta seção vamos entender o que são +conflitos de versionamento, quais suas principais causas e como podemos +resolvê-los.

-
-

Resolvendo conflitos de versões

-
-

O que são os conflitos?

+
+

O que são os conflitos?

Conflitos são, de maneira muito sucinta, duas (ou mais) versões de um mesmo arquivo. Conflitos são comuns mesmo quando não estamos utilizando ferramentas de versionamento. Por exemplo, quando tentamos “colar” um @@ -481,31 +480,66 @@

O que são os conflitos?

conflitos de versões utilizando o git. Com a diferença que temos muito mais controle de decisão do manejo dos conflitos nos arquivos sob versionamento.

-

Quais as principais causas?

Os conflitos surgem por uma série de razões. Baseado no nosso uso pessoal do versionamento, as duas razões mais comuns que geram versões conflitantes são:

1 - Devido ao uso de arquivos em repositórios compartilhados, onde -duas ou mais pessoas criam versões diferentes de um mesmo arquivo +duas ou mais pessoas criam versões diferentes de um mesmo arquivo em comum.

2 - Devido ao uso de arquivos em diferentes máquinas. Mesmo que o repositório seja de um único proprietário, caso esteja sendo utilizado em mais de um computador, versões diferentes de um mesmo arquivo podem ser criados.

Novamente, essas são as duas fontes mais comuns de conflitos que nós -lidamos na nossa prática diária, mas outras formas existem.

+nos deparamos na nossa prática diária, mas é importante lembrar que +outras fontes de conflito existem. O importante é saber identificar a +fonte de conflito e encotrar a melhor solução para sua resolução. +Veremos isso na próxima seção.

-
-

Conflitos na prática

-
-

Como identificar conflitos

+
+

Como identificar conflitos

+

O conflito irá aparecer em seu console da seguinte maneira:

+

Quando gerados, os conflitos aparecem em nossos códigos da seguinte +maneira

+

+

O arquivo com conflito vai ser indicado no seu console, ao abrir este +arquivo o local de conflito vai aparecer como indicado na figura +acima.

+

O que é importante entender: A região entre os caracteres +<<<<<< HEAD ======= indica a situação do seu arquivo +local. A região do código entre os caracteres ===== +>>>>>>>>> [caracteres e números como indicado +na figura] indica a situação do arquivo no remoto.

+

A partir disso uma decisão deve ser tomada:

+

1 - manter um dos dois estados do repositório

+

2 - realizar um híbrido

+

3 - excluir ambas

+

Após tomada essa decisão os caracteres especiais devem ser removidos +do texto

+
+

Referências para resolução de conflitos

+

Aqui trago algumas das referências mais úteis para a resolução de +conflitos. Primeiro, um velho conhecido, o livro da Jenny Brian. O capítulo +22 é um apanhado muito interessante que apresenta +diferentes formas de resolução de conflitos, incluindo os prós e contras +de cada uma delas.

+

A segunda referência é o site “Oh +shit, Git!?!?”. Este site não se trata de um conjunto didático, mas +sim um compilado de soluções práticas a problemas recorentes no mundo do +versionamento, incluindo problemas de conflitos.

+

A terceira referência é este material produzido por Tapas +Adhikary, que apresenta de maneira detalhada a origem dos conflitos +e como resolvê-los

-
LS0tDQp0aXRsZTogJ1Jlc29sdcOnw6NvIGRlIGNvbmZsaXRvcyBkZSB2ZXJzw6NvJw0KYXV0aG9yOiAiR2FicmllbCBOYWthbXVyYSINCmRhdGU6ICJgciBTeXMuRGF0ZSgpYCINCm91dHB1dDogaHRtbF9kb2N1bWVudA0KLS0tDQoNCmBgYHtyIHNldHVwLCBpbmNsdWRlPUZBTFNFfQ0Ka25pdHI6Om9wdHNfY2h1bmskc2V0KGVjaG8gPSBUUlVFLCBmaWcuYWxpZ24gPSAiY2VudGVyIikNCmBgYA0KDQpgYGB7ciBrbGlwcHksIGVjaG89RkFMU0UsIGluY2x1ZGU9VFJVRX0NCmtsaXBweTo6a2xpcHB5KCkNCmBgYA0KDQojIEFwcmVzZW50YcOnw6NvDQoNCk7Do28gaMOhIG5hZGEgbWFpcyBmcnVzdHJhbnRlIG5vIG11bmRvIGRvIHZlcnNpb25hbWVudG8gcXVlIHVtIHB1c2ggb3UgdW0gcHVsbCByZWplaXRhZG8uIE1hcyBhbyBpbmNvcnBvcmFybW9zIGFzIGZlcnJhbWVudGFzIGRlIHZlcnNpb25hbWVudG8gZW0gbm9zc2Egcm90aW5hIGRlIHRyYWJhbGhvIHNlcsOhIGluZXZpdMOhdmVsIHF1ZSBlbSBhbGd1bSBtb21lbnRvIHZhbW9zIG5vcyBkZXBhcmFyIGNvbSBhbGd1bWEgbWVuc2FnZW0gZGUgcmVqZWnDp8OjbyBkZSB1bSBwdXNoIG91IHB1bGwgcXVlLCBhIG1haW9yaWEgZGFzIHZlemVzLCB0ZW0gY29tbyBwcmluY2lwYWwgcmF6w6NvIGEgZXhpc3TDqm5jaWEgZGUgY29uZmxpdG9zIGVtIHZlcnPDtWVzIGRlIGRvY3VtZW50b3MuIFBvcnRhbnRvLCBuZXN0YSBzZcOnw6NvIHZhbW9zIGVudGVuZGVyIGNvbW8gcmVzb2x2ZXIgY29uZmxpdG9zIGVtIHZlcnNpb25hbWVudG8NCg0KIyBSZXNvbHZlbmRvIGNvbmZsaXRvcyBkZSB2ZXJzw7Vlcw0KDQojIyBPIHF1ZSBzw6NvIG9zIGNvbmZsaXRvcz8NCg0KQ29uZmxpdG9zIHPDo28sIGRlIG1hbmVpcmEgbXVpdG8gc3VjaW50YSwgZHVhcyAob3UgbWFpcykgdmVyc8O1ZXMgZGUgdW0gbWVzbW8gYXJxdWl2by4gQ29uZmxpdG9zIHPDo28gY29tdW5zIG1lc21vIHF1YW5kbyBuw6NvIGVzdGFtb3MgdXRpbGl6YW5kbyBmZXJyYW1lbnRhcyBkZSB2ZXJzaW9uYW1lbnRvLiBQb3IgZXhlbXBsbywgcXVhbmRvIHRlbnRhbW9zICJjb2xhciIgdW0gZG9jdW1lbnRvIGVtIHVtYSBwYXN0YSBjb20gdW0gYXJxdWl2byBxdWUgasOhIGFwcmVzZW50YSBvIG1lc21vIG5vbWUuIE5lc3RlIG1vbWVudG8gdGVtb3MgcXVlIHRvbWFyIGRlY2lzw7VlczogTWFudGVyIG8gYXJxdWl2byBhbnRpZ28/IFN1YnN0aXR1aXIgbyBhcnF1aXZvIGFudGlnbyBwZWxvIG5vdm8gYXJxdWl2bz8gTWFudGVyIGFtYm9zIG9zIGFycXVpdm9zPyANCkVzc2FzIHPDo28gYXMgbWVzbWFzIGRlY2lzw7VlcyBxdWUgZGV2ZW1vcyB0b21hciBxdWFuZG8gbGlkYW1vcyBjb20gY29uZmxpdG9zIGRlIHZlcnPDtWVzIHV0aWxpemFuZG8gbyBnaXQuIENvbSBhIGRpZmVyZW7Dp2EgcXVlIHRlbW9zIG11aXRvIG1haXMgY29udHJvbGUgZGUgZGVjaXPDo28gZG8gbWFuZWpvIGRvcyBjb25mbGl0b3Mgbm9zIGFycXVpdm9zIHNvYiB2ZXJzaW9uYW1lbnRvLg0KDQojIyBRdWFpcyBhcyBwcmluY2lwYWlzIGNhdXNhcz8NCg0KT3MgY29uZmxpdG9zIHN1cmdlbSBwb3IgdW1hIHPDqXJpZSBkZSByYXrDtWVzLiBCYXNlYWRvIG5vIG5vc3NvIHVzbyBwZXNzb2FsIGRvIHZlcnNpb25hbWVudG8sIGFzIGR1YXMgcmF6w7VlcyBtYWlzIGNvbXVucyBxdWUgZ2VyYW0gdmVyc8O1ZXMgY29uZmxpdGFudGVzIHPDo286IA0KDQoxIC0gRGV2aWRvIGFvIHVzbyBkZSBhcnF1aXZvcyBlbSByZXBvc2l0w7NyaW9zIGNvbXBhcnRpbGhhZG9zLCBvbmRlIGR1YXMgb3UgbWFpcyBwZXNzb2FzIGNyaWFtIHZlcnPDtWVzIGRpZmVyZW50ZXMgZGUgdW0gbWVzbW8gYXJxdWl2byBjb211bS4gDQoNCjIgLSBEZXZpZG8gYW8gdXNvIGRlIGFycXVpdm9zIGVtIGRpZmVyZW50ZXMgbcOhcXVpbmFzLiBNZXNtbyBxdWUgbyByZXBvc2l0w7NyaW8gc2VqYSBkZSB1bSDDum5pY28gcHJvcHJpZXTDoXJpbywgY2FzbyBlc3RlamEgc2VuZG8gdXRpbGl6YWRvIGVtIG1haXMgZGUgdW0gY29tcHV0YWRvciwgdmVyc8O1ZXMgZGlmZXJlbnRlcyBkZSB1bSBtZXNtbyBhcnF1aXZvIHBvZGVtIHNlciBjcmlhZG9zLg0KDQpOb3ZhbWVudGUsIGVzc2FzIHPDo28gYXMgZHVhcyBmb250ZXMgbWFpcyBjb211bnMgZGUgY29uZmxpdG9zIHF1ZSBuw7NzIGxpZGFtb3MgbmEgbm9zc2EgcHLDoXRpY2EgZGnDoXJpYSwgbWFzIG91dHJhcyBmb3JtYXMgZXhpc3RlbS4NCg0KIyBDb25mbGl0b3MgbmEgcHLDoXRpY2ENCg0KIyMgQ29tbyBpZGVudGlmaWNhciBjb25mbGl0b3MNCg0KDQo=
+
LS0tDQp0aXRsZTogJ1Jlc29sdcOnw6NvIGRlIGNvbmZsaXRvcyBkZSB2ZXJzw6NvJw0KYXV0aG9yOiAiR2FicmllbCBOYWthbXVyYSINCmRhdGU6ICJgciBTeXMuRGF0ZSgpYCINCm91dHB1dDogaHRtbF9kb2N1bWVudA0KLS0tDQoNCmBgYHtyIHNldHVwLCBpbmNsdWRlPUZBTFNFfQ0Ka25pdHI6Om9wdHNfY2h1bmskc2V0KGVjaG8gPSBUUlVFLCBmaWcuYWxpZ24gPSAiY2VudGVyIikNCmBgYA0KDQpgYGB7ciBrbGlwcHksIGVjaG89RkFMU0UsIGluY2x1ZGU9VFJVRX0NCmtsaXBweTo6a2xpcHB5KCkNCmBgYA0KDQojIEFwcmVzZW50YcOnw6NvDQoNCk7Do28gaMOhIG5hZGEgbWFpcyBmcnVzdHJhbnRlIG5vIG11bmRvIGRvIHZlcnNpb25hbWVudG8gcXVlIHVtIHB1c2ggb3UgdW0gcHVsbCByZWplaXRhZG8uIE1hcyBhbyBpbmNvcnBvcmFybW9zIGFzIGZlcnJhbWVudGFzIGRlIHZlcnNpb25hbWVudG8gZW0gbm9zc2Egcm90aW5hIGRlIHRyYWJhbGhvIHNlcsOhIGluZXZpdMOhdmVsIGVtIGFsZ3VtIG1vbWVudG8gbsOjbyBlc2JhcnJhciBlbSBhbGd1bWEgbWVuc2FnZW0gZGUgcmVqZWnDp8OjbyBkZSB1bSBwdXNoIG91IHB1bGwgcXVlLCBhIG1haW9yaWEgZGFzIHZlemVzLCB0ZW0gY29tbyBwcmluY2lwYWwgcmF6w6NvIGEgZXhpc3TDqm5jaWEgZGUgY29uZmxpdG9zIGVtIHZlcnPDtWVzIGRlIGRvY3VtZW50b3MuIFBvcnRhbnRvLCBuZXN0YSBzZcOnw6NvIHZhbW9zIGVudGVuZGVyIG8gcXVlIHPDo28gY29uZmxpdG9zIGRlIHZlcnNpb25hbWVudG8sIHF1YWlzIHN1YXMgcHJpbmNpcGFpcyBjYXVzYXMgZSBjb21vIHBvZGVtb3MgcmVzb2x2w6otbG9zLg0KDQojIE8gcXVlIHPDo28gb3MgY29uZmxpdG9zPw0KDQpDb25mbGl0b3Mgc8OjbywgZGUgbWFuZWlyYSBtdWl0byBzdWNpbnRhLCBkdWFzIChvdSBtYWlzKSB2ZXJzw7VlcyBkZSB1bSBtZXNtbyBhcnF1aXZvLiBDb25mbGl0b3Mgc8OjbyBjb211bnMgbWVzbW8gcXVhbmRvIG7Do28gZXN0YW1vcyB1dGlsaXphbmRvIGZlcnJhbWVudGFzIGRlIHZlcnNpb25hbWVudG8uIFBvciBleGVtcGxvLCBxdWFuZG8gdGVudGFtb3MgImNvbGFyIiB1bSBkb2N1bWVudG8gZW0gdW1hIHBhc3RhIGNvbSB1bSBhcnF1aXZvIHF1ZSBqw6EgYXByZXNlbnRhIG8gbWVzbW8gbm9tZS4gTmVzdGUgbW9tZW50byB0ZW1vcyBxdWUgdG9tYXIgZGVjaXPDtWVzOiBNYW50ZXIgbyBhcnF1aXZvIGFudGlnbz8gU3Vic3RpdHVpciBvIGFycXVpdm8gYW50aWdvIHBlbG8gbm92byBhcnF1aXZvPyBNYW50ZXIgYW1ib3Mgb3MgYXJxdWl2b3M/IA0KRXNzYXMgc8OjbyBhcyBtZXNtYXMgZGVjaXPDtWVzIHF1ZSBkZXZlbW9zIHRvbWFyIHF1YW5kbyBsaWRhbW9zIGNvbSBjb25mbGl0b3MgZGUgdmVyc8O1ZXMgdXRpbGl6YW5kbyBvIGdpdC4gQ29tIGEgZGlmZXJlbsOnYSBxdWUgdGVtb3MgbXVpdG8gbWFpcyBjb250cm9sZSBkZSBkZWNpc8OjbyBkbyBtYW5lam8gZG9zIGNvbmZsaXRvcyBub3MgYXJxdWl2b3Mgc29iIHZlcnNpb25hbWVudG8uDQoNCiMjIFF1YWlzIGFzIHByaW5jaXBhaXMgY2F1c2FzPw0KDQpPcyBjb25mbGl0b3Mgc3VyZ2VtIHBvciB1bWEgc8OpcmllIGRlIHJhesO1ZXMuIEJhc2VhZG8gbm8gbm9zc28gdXNvIHBlc3NvYWwgZG8gdmVyc2lvbmFtZW50bywgYXMgZHVhcyByYXrDtWVzIG1haXMgY29tdW5zIHF1ZSBnZXJhbSB2ZXJzw7VlcyBjb25mbGl0YW50ZXMgc8OjbzogDQoNCjEgLSBEZXZpZG8gYW8gdXNvIGRlIGFycXVpdm9zIGVtIHJlcG9zaXTDs3Jpb3MgY29tcGFydGlsaGFkb3MsIG9uZGUgZHVhcyBvdSBtYWlzIHBlc3NvYXMgY3JpYW0gdmVyc8O1ZXMgZGlmZXJlbnRlcyBkZSB1bSBtZXNtbyBhcnF1aXZvIGVtIGNvbXVtLiANCg0KMiAtIERldmlkbyBhbyB1c28gZGUgYXJxdWl2b3MgZW0gZGlmZXJlbnRlcyBtw6FxdWluYXMuIE1lc21vIHF1ZSBvIHJlcG9zaXTDs3JpbyBzZWphIGRlIHVtIMO6bmljbyBwcm9wcmlldMOhcmlvLCBjYXNvIGVzdGVqYSBzZW5kbyB1dGlsaXphZG8gZW0gbWFpcyBkZSB1bSBjb21wdXRhZG9yLCB2ZXJzw7VlcyBkaWZlcmVudGVzIGRlIHVtIG1lc21vIGFycXVpdm8gcG9kZW0gc2VyIGNyaWFkb3MuDQoNCk5vdmFtZW50ZSwgZXNzYXMgc8OjbyBhcyBkdWFzIGZvbnRlcyBtYWlzIGNvbXVucyBkZSBjb25mbGl0b3MgcXVlIG7Ds3Mgbm9zIGRlcGFyYW1vcyBuYSBub3NzYSBwcsOhdGljYSBkacOhcmlhLCBtYXMgw6kgaW1wb3J0YW50ZSBsZW1icmFyIHF1ZSBvdXRyYXMgZm9udGVzIGRlIGNvbmZsaXRvIGV4aXN0ZW0uIE8gaW1wb3J0YW50ZSDDqSBzYWJlciBpZGVudGlmaWNhciBhIGZvbnRlIGRlIGNvbmZsaXRvIGUgZW5jb3RyYXIgYSBtZWxob3Igc29sdcOnw6NvIHBhcmEgc3VhIHJlc29sdcOnw6NvLiBWZXJlbW9zIGlzc28gbmEgcHLDs3hpbWEgc2XDp8Ojby4NCg0KDQojIENvbW8gaWRlbnRpZmljYXIgY29uZmxpdG9zDQoNCk8gY29uZmxpdG8gaXLDoSBhcGFyZWNlciBlbSBzZXUgY29uc29sZSBkYSBzZWd1aW50ZSBtYW5laXJhOg0KDQpRdWFuZG8gZ2VyYWRvcywgb3MgY29uZmxpdG9zIGFwYXJlY2VtIGVtIG5vc3NvcyBjw7NkaWdvcyBkYSBzZWd1aW50ZSBtYW5laXJhDQoNCmBgYHtyIGVjaG89RkFMU0UsIGV2YWw9VFJVRSxvdXQud2lkdGg9IjgwJSJ9DQprbml0cjo6aW5jbHVkZV9ncmFwaGljcyhoZXJlOjpoZXJlKCJmaWdzIiwgImNvbmZsaWN0cy1hbGwucG5nIikpDQpgYGANCg0KTyBhcnF1aXZvIGNvbSBjb25mbGl0byB2YWkgc2VyIGluZGljYWRvIG5vIHNldSBjb25zb2xlLCBhbyBhYnJpciBlc3RlIGFycXVpdm8gbyBsb2NhbCBkZSBjb25mbGl0byB2YWkgYXBhcmVjZXIgY29tbyBpbmRpY2FkbyBuYSBmaWd1cmEgYWNpbWEuIA0KDQpPIHF1ZSDDqSBpbXBvcnRhbnRlIGVudGVuZGVyOiBBIHJlZ2nDo28gZW50cmUgb3MgY2FyYWN0ZXJlcyA8PDw8PDwgSEVBRCA9PT09PT09IGluZGljYSBhIHNpdHVhw6fDo28gZG8gc2V1IGFycXVpdm8gbG9jYWwuIEEgcmVnacOjbyBkbyBjw7NkaWdvIGVudHJlIG9zIGNhcmFjdGVyZXMgPT09PT0gPj4+Pj4+Pj4+IFtjYXJhY3RlcmVzIGUgbsO6bWVyb3MgY29tbyBpbmRpY2FkbyBuYSBmaWd1cmFdIGluZGljYSBhIHNpdHVhw6fDo28gZG8gYXJxdWl2byBubyByZW1vdG8uDQoNCkEgcGFydGlyIGRpc3NvIHVtYSBkZWNpc8OjbyBkZXZlIHNlciB0b21hZGE6DQoNCjEgLSBtYW50ZXIgdW0gZG9zIGRvaXMgZXN0YWRvcyBkbyByZXBvc2l0w7NyaW8NCg0KMiAtIHJlYWxpemFyIHVtIGjDrWJyaWRvIA0KDQozIC0gZXhjbHVpciBhbWJhcw0KDQpBcMOzcyB0b21hZGEgZXNzYSBkZWNpc8OjbyBvcyBjYXJhY3RlcmVzIGVzcGVjaWFpcyBkZXZlbSBzZXIgcmVtb3ZpZG9zIGRvIHRleHRvDQoNCiMgUmVmZXLDqm5jaWFzIHBhcmEgcmVzb2x1w6fDo28gZGUgY29uZmxpdG9zDQoNCkFxdWkgdHJhZ28gYWxndW1hcyBkYXMgcmVmZXLDqm5jaWFzIG1haXMgw7p0ZWlzIHBhcmEgYSByZXNvbHXDp8OjbyBkZSBjb25mbGl0b3MuIA0KUHJpbWVpcm8sIHVtIHZlbGhvIGNvbmhlY2lkbywgbyBsaXZybyBkYSBKZW5ueSBCcmlhbi4gTyBbKipjYXDDrXR1bG8gMjIqKl0oaHR0cHM6Ly9oYXBweWdpdHdpdGhyLmNvbS9naXQtYnJhbmNoZXMuaHRtbD9xPWNvbmZsaSNkZWFsaW5nLXdpdGgtY29uZmxpY3RzKSDDqSB1bSBhcGFuaGFkbyBtdWl0byBpbnRlcmVzc2FudGUgcXVlIGFwcmVzZW50YSBkaWZlcmVudGVzIGZvcm1hcyBkZSByZXNvbHXDp8OjbyBkZSBjb25mbGl0b3MsIGluY2x1aW5kbyBvcyBwcsOzcyBlIGNvbnRyYXMgZGUgY2FkYSB1bWEgZGVsYXMuDQoNCkEgc2VndW5kYSByZWZlcsOqbmNpYSDDqSBvIHNpdGUgWyJPaCBzaGl0LCBHaXQhPyE/Il0oaHR0cHM6Ly9vaHNoaXRnaXQuY29tLykuIEVzdGUgc2l0ZSBuw6NvIHNlIHRyYXRhIGRlIHVtIGNvbmp1bnRvIGRpZMOhdGljbywgbWFzIHNpbSB1bSBjb21waWxhZG8gZGUgc29sdcOnw7VlcyBwcsOhdGljYXMgYSBwcm9ibGVtYXMgcmVjb3JlbnRlcyBubyBtdW5kbyBkbyB2ZXJzaW9uYW1lbnRvLCBpbmNsdWluZG8gcHJvYmxlbWFzIGRlIGNvbmZsaXRvcy4NCg0KQSB0ZXJjZWlyYSByZWZlcsOqbmNpYSDDqSBlc3RlIG1hdGVyaWFsIHByb2R1emlkbyBwb3IgW1RhcGFzIEFkaGlrYXJ5XShodHRwczovL3d3dy5mcmVlY29kZWNhbXAub3JnL25ld3MvcmVzb2x2ZS1tZXJnZS1jb25mbGljdHMtaW4tZ2l0LWEtcHJhY3RpY2FsLWd1aWRlLyksIHF1ZSBhcHJlc2VudGEgZGUgbWFuZWlyYSBkZXRhbGhhZGEgYSBvcmlnZW0gZG9zIGNvbmZsaXRvcyBlIGNvbW8gcmVzb2x2w6otbG9zDQo=
diff --git a/dados_abertos.html b/dados_abertos.html index adf9c08..56cfb57 100644 --- a/dados_abertos.html +++ b/dados_abertos.html @@ -11,7 +11,7 @@ - + Dados abertos @@ -445,7 +445,7 @@

Dados abertos

Melina Leite

-

2024-07-08

+

2024-07-09

diff --git a/gitgnore.html b/gitgnore.html index 0e2fddd..b9b792e 100644 --- a/gitgnore.html +++ b/gitgnore.html @@ -11,7 +11,7 @@ - + Utilizando o gitignore @@ -448,7 +448,7 @@

Utilizando o gitignore

Gabriel Nakamura

-

2024-07-08

+

2024-07-09

diff --git a/index.html b/index.html index 8ba1568..dc829c8 100644 --- a/index.html +++ b/index.html @@ -537,8 +537,7 @@

Cronograma das aulas

Ciência Aberta + Apresentação da disciplina -Organização local de projetos: pastas, scripts limpos, etc -{link_org_local} +Organização local de projetos: pastas, scripts limpos Git, Github, integração @@ -613,7 +612,7 @@

Dados

-
---
title: "Boas Práticas e Ferramentas da Ciência Aberta na Ecologia - BIE5798"
---

# Apresentação

Olá!

Obrigado pelo interesse em participar da disciplina "Boas Práticas e Ferramentas da Ciência Aberta na Ecologia - BIE5798", que será ministrada entre os dias **08, 10, 12, 15 e 17 de Julho de 2024** no Departamento de Ecologia, IB-USP, São Paulo. Nesta disciplina serão abordados conceitos teóricos, tendências e ferramentas práticas para desenvolver pesquisas que vão ao encontro dos princípios e movimento da ciência aberta. 

Este sítio servirá como um guia para nossas aulas. Nele vocês encontrarão os materiais necessários ([dados](https://github.com/GabrielNakamura/USP_reproducibility_BIE5798)) bem como os scripts que utilizaremos durante as aulas para as atividades práticas. Ah! O site continuará funcionando após o término da disciplina, portanto, sempre que tiver alguma dúvida é só voltar aqui e revisitar o que vimos nas aulas.

# Ministrantes

O curso será ministrado por Melina Leite e Gabriel Nakamura.


## Melina

```{r echo=FALSE,eval=TRUE,out.width="20%"}
knitr::include_graphics("figs/melina-foto.png")
```

Sou ecóloga e cientista de dados no departamento de Ecologia da USP. Tenho graduação em biologia (UFRJ), mestrado (UFRJ) e doutorado em Ecologia (USP). Acumulei também um MBA em Gestão Ambiental (Poli-USP) e MBA em Ciência de Dados (ESALQ-USP). Ao longo dos anos trabalhei em diferentes áreas da ecologia e biologia da conservação como ecologia da paisagem, de comunidades, de populações e ecologia aplicada. Tenho bastante interesse na aplicação métodos estatísticos para descobertas ecológicas (modelos mistos são meu xodó). Adoro escalada, trilhas e esportes de aventura no geral! Ah, e sou uma entusiasta do movimento da **Ciência Aberta**!! 

Para me achar e saber mais sobre mim, veja meu [site](https://melinaleite.weebly.com/).


## Gabriel

```{r echo=FALSE,eval=TRUE,out.width="20%"}
knitr::include_graphics("figs/gabriel-avatar.jpg")
```

Gabriel é formado em licenciatura em Ciências Biológicas (apesar da dúvida entre Ciências Sociais e História), fez algumas andanças de difícil reprodutibilidade para obter o mestrado (Ecologia e Conservação UFMS) e doutorado (Ecologia UFRGS). Após um tempo fora (posdoc Texas A&M University), a saudade do pequi e da guariroba do cerrado falou mais alto e retornou como posdoc da Universidade Federal de Goiás no INCT-EECBio. Atualmente é posdoc na Universidade de São Paulo. Vem desenvolvendo  métodos e ferramentas estatísticas em ecologia de comunidades, macroecologia e macroevolução. Tem interesse também em entender os viéses da dinâmica de produção científica. [Aqui](http://lattes.cnpq.br/2456515948049565) um pouquinho mais do que venho desenvolvendo.


# Cronograma das aulas

Abaixo está o cronograma das aulas que iremos seguir. Algumas coisas podem mudar (mais ou menos tempo gasto) dependendo do andamento das atividades práticas.

```{r, eval=T, echo=FALSE}
library(glue)
link_org_local <- glue::glue("`[link aula](https://gabrielnakamura.github.io/USP_BIE5798_apresentacoes/#21)`")

```


```{r, eval=T, echo=FALSE}
crono <- suppressWarnings(read.csv("cronograma.csv", header = T, sep = ","))  
rownames(crono) <- c("Manhã \n 9-12h", "Tarde \n 14-17h")
colnames(crono) <- paste(c(8, 10, 12, 15, 17), ("Jul"), sep = " ")
crono[1, 1] <- c("Ciência Aberta + Apresentação da disciplina")
crono[2, 1] <- c("Dados abertos: plano de gestão, organização, metadados, publicação")
crono[1, 2] <- c("Organização local de projetos: pastas, scripts limpos, etc {link_org_local}")
crono[2, 2] <- c("Controle de versão")
crono[1, 3] <- c("Git, Github, integração")
crono[2, 3] <- c("Prática em controle de versão/ Ações básicas")
#crono[1, 4] <- c("Prática em controle de versão/ Forks, commits, pull requests")
#crono[2, 4] <- c("Prática em controle de versão/ Forks, commits, pull requests/ Pacotes")
crono[1, 4] <- c("Literate programming/ Rmarkdown/Quarto")
crono[2, 4] <- c("Revisão de código")
crono[1, 5] <- c("Publicação: Preprints, tipos de acesso aberto")
crono[2, 5] <- c("Extra: Dockers e Target / Finalização")

#DT::datatable(crono, editable = "cell")
```

```{r, eval=T, echo=FALSE}
crono |>
  htmlTable::addHtmlTableStyle(col.columns = rep(c("#E6E6F0","none"), 3)) |>
  htmlTable::htmlTable()
```


**OBS 1**: O início das aulas matinais será aberto para dúvidas e discussões em grupo sobre assuntos de dias anteriores. 

**OBS 2**: O fim das aulas vespertinas (16-17h) também serão livres para discussões e dúvidas de projetos individuais.

# Preparação pré-aula e materiais para práticas

Aqui algumas informações sobre os materiais utilizados durante esta aula, os pacotes estatísticos necessários para realizar as atividades práticas e algumas coisas importantes para fazer antes do primeiro dia de aula.

## Programas/platarformas utilizadas:

Você precisará ter instalado previamente a última versão do [R](https://cran.r-project.org/) e [Rstudio Desktop](https://posit.co/downloads/), e também deverá ter uma conta no [GitHub](https://github.com/pricing). Todas as ferramentas são gratuitas ou têm versão gratuita. Traga seu computador para as aulas **TODOS OS DIAS**! 

## Dados

Com o intuito de manter o foco na compreensão dos conceitos e processos que serão ensinados, preferimos utilizar um material único compartilhado com toda turma. Para tanto vamos utilizar conjuntos de dados disponíveis em outros tutoriais como o [Living Norway Project](https://livingnorway.github.io/LivingNorwayR/articles/LNWorkshopExample_TOV-E.html), os dados do pacote [EML](https://github.com/ropensci/EML/tree/master/inst/examples) e um conjunto de dados chamado **Palmer Penguins**. Todos os dados já estão presentes no repositório deste curso, portanto, tudo que você deve fazer é o download deste repositório para o seu computador.


Para fazer o download deste repositório é só clicar neste botão

```{r echo=FALSE,eval=TRUE}

downloadthis::download_link(
  link = "https://github.com/GabrielNakamura/USP_reproducibility_BIE5798/archive/refs/heads/master.zip",
  button_label = "Download do repositório",
  button_type = "danger",
  has_icon = TRUE,
  icon = "fa fa-save",
  self_contained = FALSE
)
```



+
---
title: "Boas Práticas e Ferramentas da Ciência Aberta na Ecologia - BIE5798"
---

# Apresentação

Olá!

Obrigado pelo interesse em participar da disciplina "Boas Práticas e Ferramentas da Ciência Aberta na Ecologia - BIE5798", que será ministrada entre os dias **08, 10, 12, 15 e 17 de Julho de 2024** no Departamento de Ecologia, IB-USP, São Paulo. Nesta disciplina serão abordados conceitos teóricos, tendências e ferramentas práticas para desenvolver pesquisas que vão ao encontro dos princípios e movimento da ciência aberta. 

Este sítio servirá como um guia para nossas aulas. Nele vocês encontrarão os materiais necessários ([dados](https://github.com/GabrielNakamura/USP_reproducibility_BIE5798)) bem como os scripts que utilizaremos durante as aulas para as atividades práticas. Ah! O site continuará funcionando após o término da disciplina, portanto, sempre que tiver alguma dúvida é só voltar aqui e revisitar o que vimos nas aulas.

# Ministrantes

O curso será ministrado por Melina Leite e Gabriel Nakamura.


## Melina

```{r echo=FALSE,eval=TRUE,out.width="20%"}
knitr::include_graphics("figs/melina-foto.png")
```

Sou ecóloga e cientista de dados no departamento de Ecologia da USP. Tenho graduação em biologia (UFRJ), mestrado (UFRJ) e doutorado em Ecologia (USP). Acumulei também um MBA em Gestão Ambiental (Poli-USP) e MBA em Ciência de Dados (ESALQ-USP). Ao longo dos anos trabalhei em diferentes áreas da ecologia e biologia da conservação como ecologia da paisagem, de comunidades, de populações e ecologia aplicada. Tenho bastante interesse na aplicação métodos estatísticos para descobertas ecológicas (modelos mistos são meu xodó). Adoro escalada, trilhas e esportes de aventura no geral! Ah, e sou uma entusiasta do movimento da **Ciência Aberta**!! 

Para me achar e saber mais sobre mim, veja meu [site](https://melinaleite.weebly.com/).


## Gabriel

```{r echo=FALSE,eval=TRUE,out.width="20%"}
knitr::include_graphics("figs/gabriel-avatar.jpg")
```

Gabriel é formado em licenciatura em Ciências Biológicas (apesar da dúvida entre Ciências Sociais e História), fez algumas andanças de difícil reprodutibilidade para obter o mestrado (Ecologia e Conservação UFMS) e doutorado (Ecologia UFRGS). Após um tempo fora (posdoc Texas A&M University), a saudade do pequi e da guariroba do cerrado falou mais alto e retornou como posdoc da Universidade Federal de Goiás no INCT-EECBio. Atualmente é posdoc na Universidade de São Paulo. Vem desenvolvendo  métodos e ferramentas estatísticas em ecologia de comunidades, macroecologia e macroevolução. Tem interesse também em entender os viéses da dinâmica de produção científica. [Aqui](http://lattes.cnpq.br/2456515948049565) um pouquinho mais do que venho desenvolvendo.


# Cronograma das aulas

Abaixo está o cronograma das aulas que iremos seguir. Algumas coisas podem mudar (mais ou menos tempo gasto) dependendo do andamento das atividades práticas.

```{r, eval=T, echo=FALSE}
library(glue)
link_org_local <- glue::glue("`[link aula](https://gabrielnakamura.github.io/USP_BIE5798_apresentacoes/#21)`")

```


```{r, eval=T, echo=FALSE}
crono <- suppressWarnings(read.csv("cronograma.csv", header = T, sep = ","))  
rownames(crono) <- c("Manhã \n 9-12h", "Tarde \n 14-17h")
colnames(crono) <- paste(c(8, 10, 12, 15, 17), ("Jul"), sep = " ")
crono[1, 1] <- c("Ciência Aberta + Apresentação da disciplina")
crono[2, 1] <- c("Dados abertos: plano de gestão, organização, metadados, publicação")
crono[1, 2] <- c("Organização local de projetos: pastas, scripts limpos")
crono[2, 2] <- c("Controle de versão")
crono[1, 3] <- c("Git, Github, integração")
crono[2, 3] <- c("Prática em controle de versão/ Ações básicas")
#crono[1, 4] <- c("Prática em controle de versão/ Forks, commits, pull requests")
#crono[2, 4] <- c("Prática em controle de versão/ Forks, commits, pull requests/ Pacotes")
crono[1, 4] <- c("Literate programming/ Rmarkdown/Quarto")
crono[2, 4] <- c("Revisão de código")
crono[1, 5] <- c("Publicação: Preprints, tipos de acesso aberto")
crono[2, 5] <- c("Extra: Dockers e Target / Finalização")

#DT::datatable(crono, editable = "cell")
```

```{r, eval=T, echo=FALSE}
crono |>
  htmlTable::addHtmlTableStyle(col.columns = rep(c("#E6E6F0","none"), 3)) |>
  htmlTable::htmlTable()
```


**OBS 1**: O início das aulas matinais será aberto para dúvidas e discussões em grupo sobre assuntos de dias anteriores. 

**OBS 2**: O fim das aulas vespertinas (16-17h) também serão livres para discussões e dúvidas de projetos individuais.

# Preparação pré-aula e materiais para práticas

Aqui algumas informações sobre os materiais utilizados durante esta aula, os pacotes estatísticos necessários para realizar as atividades práticas e algumas coisas importantes para fazer antes do primeiro dia de aula.

## Programas/platarformas utilizadas:

Você precisará ter instalado previamente a última versão do [R](https://cran.r-project.org/) e [Rstudio Desktop](https://posit.co/downloads/), e também deverá ter uma conta no [GitHub](https://github.com/pricing). Todas as ferramentas são gratuitas ou têm versão gratuita. Traga seu computador para as aulas **TODOS OS DIAS**! 

## Dados

Com o intuito de manter o foco na compreensão dos conceitos e processos que serão ensinados, preferimos utilizar um material único compartilhado com toda turma. Para tanto vamos utilizar conjuntos de dados disponíveis em outros tutoriais como o [Living Norway Project](https://livingnorway.github.io/LivingNorwayR/articles/LNWorkshopExample_TOV-E.html), os dados do pacote [EML](https://github.com/ropensci/EML/tree/master/inst/examples) e um conjunto de dados chamado **Palmer Penguins**. Todos os dados já estão presentes no repositório deste curso, portanto, tudo que você deve fazer é o download deste repositório para o seu computador.


Para fazer o download deste repositório é só clicar neste botão

```{r echo=FALSE,eval=TRUE}

downloadthis::download_link(
  link = "https://github.com/GabrielNakamura/USP_reproducibility_BIE5798/archive/refs/heads/master.zip",
  button_label = "Download do repositório",
  button_type = "danger",
  has_icon = TRUE,
  icon = "fa fa-save",
  self_contained = FALSE
)
```



diff --git a/intro_ciencia_aberta.html b/intro_ciencia_aberta.html index 93dcb23..d97f660 100644 --- a/intro_ciencia_aberta.html +++ b/intro_ciencia_aberta.html @@ -11,7 +11,7 @@ - + O que é Ciência Aberta? @@ -444,7 +444,7 @@

O que é Ciência Aberta?

Melina Leite

-

2024-07-08

+

2024-07-09

diff --git a/metadata_EML.html b/metadata_EML.html index 668e7cd..70a79e3 100644 --- a/metadata_EML.html +++ b/metadata_EML.html @@ -11,7 +11,7 @@ - + Metadados @@ -448,7 +448,7 @@

Metadados

Gabriel Nakamura

-

2024-07-08

+

2024-07-09

diff --git a/pre-registro.html b/pre-registro.html index 92b9cac..d35c0de 100644 --- a/pre-registro.html +++ b/pre-registro.html @@ -11,7 +11,7 @@ - + Pré-registro de projetos científicos @@ -444,7 +444,7 @@

Pré-registro de projetos científicos

Melina Leite

-

2024-07-08

+

2024-07-09

diff --git a/publicacoes.html b/publicacoes.html index 06a8069..c48bcc0 100644 --- a/publicacoes.html +++ b/publicacoes.html @@ -11,7 +11,7 @@ - + Acesso aberto a publicações científicas @@ -445,7 +445,7 @@

Acesso aberto a publicações científicas

Melina Leite

-

2024-07-08

+

2024-07-09

diff --git a/releasing.html b/releasing.html index 91d9eeb..3a2f158 100644 --- a/releasing.html +++ b/releasing.html @@ -11,7 +11,7 @@ - + Releasing @@ -444,7 +444,7 @@

Releasing

Gabriel Nakamura

-

2024-07-08

+

2024-07-09

diff --git a/renv-basics.html b/renv-basics.html index 2ac4c5f..27cbd90 100644 --- a/renv-basics.html +++ b/renv-basics.html @@ -11,7 +11,7 @@ - + Ambiente reprodutível com ‘Renv’ @@ -545,7 +545,7 @@

Ambiente reprodutível com ‘Renv’

Melina Leite

-

2024-07-08

+

2024-07-09

diff --git a/rmarkdown-basics.html b/rmarkdown-basics.html index ac0031f..1aaf99a 100644 --- a/rmarkdown-basics.html +++ b/rmarkdown-basics.html @@ -11,7 +11,7 @@ - + R markdown @@ -546,7 +546,7 @@

R markdown

Gabriel Nakamura

-

2024-07-08

+

2024-07-09

diff --git a/rocker_basics.html b/rocker_basics.html index 808097a..0d6916c 100644 --- a/rocker_basics.html +++ b/rocker_basics.html @@ -11,7 +11,7 @@ - + Containers @@ -448,7 +448,7 @@

Containers

Gabriel Nakamura

-

2024-07-08

+

2024-07-09

diff --git a/sites-basics.html b/sites-basics.html index be66f6a..9a86240 100644 --- a/sites-basics.html +++ b/sites-basics.html @@ -11,7 +11,7 @@ - + R markdown @@ -545,7 +545,7 @@

R markdown

Gabriel Nakamura

-

2024-07-08

+

2024-07-09

diff --git a/targets_basics.html b/targets_basics.html index b53c755..b963ce4 100644 --- a/targets_basics.html +++ b/targets_basics.html @@ -11,7 +11,7 @@ - + Pipelines com targets @@ -549,7 +549,7 @@

Pipelines com targets

Gabriel Nakamura

-

2024-07-08

+

2024-07-09