C/C++
Endentação de código em C

Endentação definição:

ato ou efeito de endentar.

Como o próprio nome diz endentar é deixar o código mais legível e bonito, melhorando o entendimento sobre o mesmo.

Como endentar código em C no Linux

Para endentar o código em C, usaremos o comando indent , que explicaremos a seguir.

Instalação do Indent

A instalação do indent, é extremamente simples, para tanto, usaremos o comando:

apt install indent

O vídeo abaixo mostra como fazer o processo de instalação.

apresentação da instalação do indent

Endentando o código em C

O processo de endentação é muito simples.

Basta digitar o comando como se segue:

indent [nome_do_fonte.c]

O programa irá endentar no padrão, segue um vídeo demonstrando seu uso.

Apresentação prática do indent em código de projeto.

Customizando Endentação

A endentação do código pelo comando indent, pode ser mudada conforme sua necessidade.

No site https://linux.die.net/man/1/indent , voce pode ver a explicação completa das sintaxes disponíveis para o indent.

Estarei explicando poucos comandos estilisticos.

indent -br [codigo_fonte.c]

Forçamos que o { esteja no final da linha que o gerou.

Comando -br

Perceba que o } não entrou na jogada, se incluirmos o parametro -ce, tambem alinharemos ele.

indent -br -ce [codigo_fonte.c]

Conforme figura abaixo:

opções de indent

Declaração de valores

Agora, vamos ver a declaração de valores, com endentação.

O parametro -di, inclui declaração conforme o apresentado:

indent -di16 [fonte.c]

Neste exemplo percebemos um recuo, entre o tipo e seu nome.

recuo do parâmetro -di16

Já o parâmetro indent -di2

indent -di2 [fonte.c]

Separa o tipo de seu nome de variável, pulando uma linha.

Existem uma infinidade de parâmetros do indent. Entre no site, e busque a que melhor se adequa a seu código.

Blog Dicas
Mudar resolução do linux

Muitas vezes cometemos erros que acabam inviabilizando a exibição do vídeo, na interface grafica.

Este procedimento visa corrigir este passo.

Foi testado no xubuntu.

Primeiro pare o serviço grafico:

sudo service lightdm stop

Parando interface grafica

Em seguida crie o arquivo xorg.conf,

sudo Xorg -configure

Criando o arquivo em root

Agora vc precisa copiar para a pasta

mv /root/xorg.conf.new /etc/X11/xorg.conf

Movendo o arquivo para a pasta correta

Agora precisamos reiniciar o serviço

sudo service lightdm start

Reiniciando o serviço

De forma geral isso resolve.

MNote2 Sem categoria
Liberada a versão 2.9 AMD64

Encontra-se disponível no git a versão 2.9 para Linux AMD64.

Esta versão conta com acesso a banco mysql, bem como todas as melhorias do windows.

Existe muito trabalho a ser feito, e estamos trabalhando duramente para resolver todos os problemas das versões. Estabilizar o MNote2 e criar uma ferramenta de edição de fontes estável e segura.

Blog MNote2 pacotes
Criar um pacote Debian

Para criar um pacote debian ou ubuntu, primeiramente siga os procedimentos descritos neste artigo.

https://maurinsoft.com.br/index.php/criando-pacotes-no-debian/

Em seguida, crie uma pasta com o nome do pacote que deseja chamar.

Iremos usar como referencia o mnote2, pois já fizemos.

Crie as seguintes pastas:

mnote2

  • DEBIAN
  • usr
    • bin
    • share
      • applications
      • doc
      • icons
      • man

Dentro da pasta Debian, crie um arquivo, chamado control

Package: mnote2
Version: 2.8
Section: custom
Priority: optional
Architecture: all
Essential: no
Installed-Size: 1024
Maintainer: maurinsoft.com.br
Description: Easy Graphic multiplataform editor.

Arquivo control

Na pasta bin, jogue o binário do seu pacote.

Na pasta share, crie um arquivo, com o nome do seu pacote, no meu caso mnote2.

Section: editors
Priority: optional
Maintainer: marcelo maurin marcelomaurinmartins@maurinsoft.com.br
Homepage: http://www.maurinsoft.com.br/index.php/projeto-mnote2/
Package: mnote2
Architecture: amd64
Version: 2.8
Depends:
Description: Easy Graphic Editor.

Arquivo mnote2

Dentro da pasta usr > share > icons > hicolor, copie o icone do seu aplicativo.

Script de criação de pacotes:

Para facilitar criei um script que automatiza a montagem do pacote.

!/bin/bash
cp ./src/MNote2 ./mnote2/usr/bin/
cp ./src/MNote2.ico ./mnote2/usr/share/icons/hicolor/
ln -s ./src/MNote2 ./mnote2/usr/applications/
dpkg-deb –build mnote2
mv mnote2.deb mnote2-2.8_amd64.deb
cp ./mnote2-2.8_amd64.deb ./bin/

Arquivo buildlinux

Pronto, vc tem um pacote debian, pronto para uso.

Artigos relacionados

      Sem categoria
      CMake no KDevelop

      O CMake é um conjunto de ferramentas multi plataforma, destinada a geração automatizada de programas. Ele é usando em conjunto com o compilador, orquestrando compilações complexas.

      Iremos abordar aqui um exemplo simples de código, integrado com o KDevelop.

      Fontes do projeto

      Iremos explicar como criamos nosso projeto.

      Primeiramente crie um projeto c, conforme apresentado no tutorial do link a seguir:

      http://maurinsoft.com.br/index.php/2021/02/12/kdevelop-novo-projeto/

      Em seguida, entre no projeto teste02, e com o botão direito, abra o menu, conforme apresentado a seguir:

      Agora selecione a opção create file, conforme figura acima.

      Digite os funcoes.c, depois repita a mesma operação com funcoes.h.

      Agora temos no projeto, conforme o exemplo abaixo:

      Neste exemplo temos dois fontes:

      • main.c
      • funcoes.c

      O main.c usa uma função do funcoes.c, iremos ver como incluir isso no CMAKE.

      Copie os códigos para os respectivos fontes, conforme apresentado.

      Fonte do main.c:

      #include <stdio.h>
      #include <stdlib.h>
      #include “funcoes.h”

      int main(int argc, char *argv[])
      {
      teste1();
      return 0;
      }

      Fonte do funcoes.c:

      #include “funcoes.h”
      #include <stdio.h>
      #include <stdlib.h>
      void teste1(void)
      {
      printf(“Teste funcoes”);
      }

      Fonte do funcoes.h:

      #ifndef FUNCOES_H
      #define FUNCOES_H
      void teste1(void);
      # endif /FUNCOES_H/

      Exemplo do CMakeList.txt

      cmake_minimum_required(VERSION 3.0)
      project(teste02 LANGUAGES C)
      include_directories(include)
      set(CMAKE_C_FLAGS “-Wall”)
      file( GLOB SRCS *.c *.h)
      add_executable(teste02
      main.c
      funcoes.c
      )
      install(TARGETS teste02 RUNTIME DESTINATION bin)

      Agora vem a explicação do CMAKE

      O cmake_minimum_required diz a versão mínima do cmake exigida para executar o script.

      project diz, qual linguagem é o alvo que iremos compilar. Neste caso indiretamente dizemos também o compilador e informações a respeito de linkagem.

      include_directories, diz para incluirmos o diretório corrente.

      Já o comando set, avisa o compilador para ativar o parâmetro -Wall

      O file pesquisa, como fonte qualquer arquivo de extensão .c ou .h;

      E por fim add_executable, monta o binário (executável) a partir dos arquivos .c adicionados.

      O install, cria um fluxo de instalação. Já é o processo tipo make install.

      Delphi Lazarus
      Instalando fpcupdeluxe Windows

      O fpcupdeluxe é o instalador do lazarus já com atualização de pacotes automáticos e plataformas.

      
      
      
      
      

      Qual a diferença de instalar o lazarus e o fpcupdeluxe?

      No lazarus, voce instala apenas os compiladores para a plataforma alvo, ou seja, para o sistema que esta instalando. Isso quer dizer, que se instalar no windows 10, terá apenas os compiladores do windows 10.

      Já o fpcupdeluxe, voce alem de instalar o lazarus do windows 10, no caso do nosso exemplo acima, tambem, já pode preparar binarios em linux i386, alem de arm, mac os, android entre outras plataformas que o lazarus permite compilar.

      Existe um ótimo tutorial, para quem deseja instalar no linux i386, segue o link:

      https://www.embarcados.com.br/cross-compilando-pascal-para-arm-utilizando-o-lazarus/

      Aqui irei abordar o procedimento para o windows, pois há uma pequena variação.

      Pré requisitos

      • GIT instalado
      • Git Tortoise (recomendado) porem não é requerido
      • GTK+-Bundle-3.4
      • Win64Bins.zip

      Instalação

      Primeiro baixe o projeto no repositório do git na pasta
      c:\fpcupdeluxe, o repositório segue no link abaixo:

      https://github.com/LongDirtyAnimAlf/fpcupdeluxe.git

      Em seguida, pegue a ultima versão do binário já compilado e mova para a pasta c:\fpcupdeluxe

      https://github.com/LongDirtyAnimAlf/fpcupdeluxe/releases

      Lembrando que a versão para windows 10 64bits será como demonstrado:


      Copie o binário na pasta c:\fpcupdeluxe , e execute o mesmo.

      Irá aparecer uma tela, primeiramente, voce deve selecionar o caminho
      c:\fpcupdeluxe\fpcupdeluxe, conforme figura abaixo:

      Agora selecione o stable do FPC e Lazarus, conforme figura abaixo:

      Click no botão Install/Update, conforme figura abaixo:

      Lembre-se este procedimento irá demorar muito.

      Então deixe rodando e vá fazer outra coisa, tipo escrever um tutorial 😉

      Ao final da instalação surgirá o resultado como da imagem abaixo: ankara escort çankaya escort ankara escort çankaya escort escort ankara çankaya escort escort bayan çankaya istanbul rus escort eryaman escort escort bayan ankara ankara escort kızılay escort istanbul escort ankara escort ankara rus escort escort çankaya ankara escort bayan istanbul rus Escort atasehir Escort beylikduzu Escort Ankara Escort malatya Escort kuşadası Escort gaziantep Escort izmir Escort

      Finalização do procedimento de instalação

      Rodando o Lazarus

      O Lazarus pode ser encontrado no c:\fpcupdeluxe\fpcupdeluxe, conforme figura abaixo:

      Entre na pasta lazarus, e procure o executável startlazarus.

      aplicativo startlazarus

      Segue o exemplo do Lazarus, já com aplicativo compilado.

      Lazarus com projeto compilado!


      Gerando binário para o Windows

      Agora criaremos uma aplicativo e executaremos no windows.

      Para tanto criei um projeto hello world, que disponibilizarei neste link:

      http://maurinsoft.com.br/downloads/hello%20world.rar

      Como estamos compilando em máquina nativa, não há muito a ser feito, basta compilar e rodar a aplicação.

      Para compilar, selecione RUN e dentro dele a opção Build.

      Podemos ver que ele funcionou.

      Lembre-se que a opção Default é a nativa do sistema.

      Para isso precisa ir no menu Project, selecionando a opção Project Options.

      Lá surgirá um menu, conforme o da figura abaixo:

      Selecione a opção Compiler Options, e dentro dela o item Config and Target, conforme figura acima.

      Gerando binários para Raspberry PI – Linux

      Agora irei descrever o procedimento para gerar compilação para o raspberry pi, estando no lazarus do windows.

      Este procedimento aproveita, que o lazarus tem como lema a compilação cruzada, ou como eles dizem:

      Write once! Compile Anyware!

      Para isso precisa ir no menu Project, selecionando a opção Project Options.

      Lá surgirá um menu, conforme o da figura abaixo:

      Selecione a opção Compiler Options, e dentro dela o item Config and Target, conforme figura acima.

      Selecione o processador (CPU) arm.

      Selecione o OS (Sistema Operacional) linux.

      Conforme figura abaixo:

      Click no botão Install compiler, conforme figura acima.

      O fpcupdeluxe irá providenciar a instalação do ambiente crox para esta plataforma, conforme descrito.

      Este procedimento irá demorar alguns minutos.

      Instalação/Atualização concluída com sucesso.

      Para tanto criei um projeto hello world, que disponibilizarei neste link:

      http://maurinsoft.com.br/downloads/hello%20world.rar

      Basicamente a tela dele, é como se segue.

      hello world

      Aponte o Target OS, para ser Linux, e em seguida o CPU para arm, conforme figura acima.

      Click no botão Test, para realizar teste de compatibilidade.

      No meu teste, ele encontrou os fontes tanto do X64 como do ARM, dê ignorar, e verifique se deu tudo certo.

      Na figura acima, podemos ver que ele conseguiu achar os alvos necessários.

      Click no botão OK.

      Agora vamos compilar, através do menu RUN, com o item Build.

      O resultado esperado será o apresentado acima.

      No meu caso eu salvei o projeto em:

      C:\fpcupdeluxe\fpcupdeluxe\projects\projetos\hello world

      Lá vc encontra 2 grandes arquivos:

      O primeiro hello, é o do arm, pois não eh reconhecido como executável.

      O segundo já é o compilado no windows.

      Vamos copiar o primeiro hello, e copiar para o raspberry.

      Usando o bitvise, copie o arquivo, o resultado, é como se segue:


      Agora, no terminal, execute o comando a seguir:

      chmod +777 ./hello

      Não se esqueça de ir na pasta onde copiou o aplicativo, no meu caso foi /home/mmm/Downloads.

      Agora entre no VNC, e execute o aplicativo na referida pasta.

      Para executar, dê duplo click, o resultado será conforme apresentado.

      Ao clicar no botão, surgirá a mensagem abaixo:

      Parabéns! você conseguiu compilar no raspberry!

      Gerando binário para o Linux X64

      Agora iremos preparar o ambiente para compilar nosso exemplo no Linux X64. Ou seja em um pc com linux.

      O primeiro passo conforme apresentado na imagem acima é selecionar a aba CROSS, em seguida em CPU selecionar a opção x86_64.

      Ainda na aba CROSS, selecione em OS (Sistema Operacional) o sistema operacional LINUX, conforme figura acima.

      Por fim, selecione o botão INSTALL COMPILER, conforme figura acima.

      O processo irá demorar alguns minutos, pois o sistema irá gerar o ambiente necessário para compilar em Linux.

      Para testarmos nosso binário, iremos primeiro montar uma VM (Virtual Machine) com ubuntu. No caso de nossa vm, já é 64bits.

      VM Ubuntu

      Agora identificaremos o IP para posteriormente transferir o arquivo para a maquina.

      Agora iremos entrar no bitviser e conectar para podermos jogar nosso arquivo, quando pronto.

      Pronto, agora irei aguardar até fpcupdeluxe terminar de preparar a versão de compilação cruzada linux X64.

      Pronto agora podemos comecar a compilar nosso exemplo.

      Começamos, entrando na pasta do lazarus.

      No meu caso, podemos ver que instalei em C:\fpcupdeluxe\fpcupdeluxe\lazarus.

      Agora iniciarei o lazarus, através do comando startlazarus.

      Já no lazarus aberto, iremos carregar nosso projeto:

      http://maurinsoft.com.br/downloads/hello%20world.rar

      Neste exemplo, iremos mostrar uma janela simples, conforme apresentado abaixo:

      Primeiramente precisamos apontar para o target correto, para isso, iremos em Project, selecionando a opção Project Options.

      Selecione a opção Compiler Options, da arvore de opções do lado esquerdo.

      Selecione a opção Config and Target, selecione agora a opção Target OS, indicando Linux.

      Selecione o Target CPU family X86_64, conforme figura acima.

      Para ter certeza que o processo de instalação esta correto, iremos clicar no botão Test, conforme figura acima.

      Poderão surgir alguns avisos, dizendo que os fontes estão duplicados, dê ignore.

      Click no botão OK.

      Pronto! Podemos gerar o binário.

      Agora iremos gerar o binário, simplesmente Clicando na opção de menu RUN, no sub item Build.

      Estamos quase acabando, pois já geramos nosso binário. Agora devemos leva-lo para o linux e testar.

      O nosso projeto foi originalmente gravado em

      C:\fpcupdeluxe\fpcupdeluxe\projects\projetos\hello world

      Podemos ver, que existem 2 arquivos hello, o primeiro com data de hoje, e o segundo com data de ontem. O primeiro já é o nosso aplicativo linux, e deve ser copiado para uma pasta no linux.

      Conforme figura acima, podemos ver que copiamos o arquivo para a pasta do download.

      O próximo passo é dar permissão de execução no arquivo.

      Para tanto, iremos na pasta e em seguida dar o comando:

       chmod +777 ./hello

      Pronto, agora basta chamar nosso aplicativo.

      Ao clicar no nosso botão, teremos o seguinte resultado:

      Observando, que agora temos 3 opções de binário.

      Gerando binário para o MAC OS

      Agora iremos para nossa terceira etapa, gerando para o MAC.

      Irei gerar o binário para este mac, um modelo 2009, já velinho.

      Que venho apresentando em diversos posts.

      Primeiramente precisamos saber a versão do processador.

      No nosso exemplo usamos um processador INTEL Core 2 Duo, o que iremos parametrizar.

      Agora iremos novamente entrar no nosso fpcupdeluxe-x86_64-win64.exe, localizado na pasta C:\fpcupdeluxe

      Entraremos na aba CROSS, e em seguida selecionamos CPU i386.

      Agora marcamos no OS, o sistema darwin, que é o MACOS.

      Erroneamente marcado como x86_64

      Click em INSTALL COMPILER, e mostrará a aba abaixo, informando que para rodar o free pascal, necessita de versão superior ao 3.2, dê Yes.

      Pronto, agora é só aguardar…

      Para testar e fazermos testes, usaremos o RealVNC, pois facilita em muito.

      Para tanto, configure em seu mac uma versão do RealVNC, e conecte com o view no seu PC, conforme demonstrado abaixo:

      Crie uma pasta no MAC, para levar o binario.

      Abra a pasta e já deixe pronto para a próxima etapa.

      Pronto! A maquina cross esta pronta!

      Agora iremos compilar no MAC

      Para tanto, iremos abrir o Lazarus, que fica localizado em C:\fpcupdeluxe\fpcupdeluxe\lazarus.

      Para rodar o Lazarus, execute o startlazarus, conforme figura acima.

      Para gerar, entre no menu na opção Project, no sub item Project Options.

      Agora, selecione a arvore de opções Compiler Options, e em seguida o sub item Config and Target, conforme figura acima.

      Selecione no Target OS, o item Darwin, e para o Target CPU i386, conforme figura acima.

      Selecione o Botão Test, conforme figura acima.

      Por fim, click no botão OK.

      Agora, iremos compilar nossa aplicação, para tanto click em RUN, selecionando a opção BUILD.

      Agora se olharmos a pasta do projeto, eu instalei em C:\fpcupdeluxe\fpcupdeluxe\projects\projetos\hello world

      Podemos ver que foi criado um arquivo hello e tambem uma pasta hello.app.

      Devemos copiar ambos.

      Pronto! Segue o executável, funcionando!

      Gerando binário para o Android

      Agora iremos criar um procedimento para criar aplicações android.

      Para testar iremos utilizar um CubieTruck com SO Android 4.

      CubieTruck é um equipamento bem versátil com 2Gb.

      O CubieTruck permite ser usado tanto como maquina linux, como máquina Android.

      Para me auxiliar, instalei o aplicativo que cria um servidor ssh.

      Pronto, agora tenho comandos e ftp para lançar minha aplicação.

      A ilustração acima, demonstra que posso disponibilizar arquivos para o celular.

      Na ilustração acima, o console terminal, permite rodar comandos.

      Podemos ver também, que a atualização do cpu ARM, com SO android foi finalizada.

      Agora irei compilar meu projeto.

      Agora, clicando em Test, gerando

      Instalação de Pacotes Adicionais

      O FPCUPdeluxe permite tambem a instalação de pacotes adicionais, tal como Zeoslib.

      Apresentaremos o procedimento de instalação de um pacote.

      Para tanto, click na aba Modules, selecione a aba que deseja instalar e click no botão Install module.

      maurinsoft.com.br