Sumário

1.

Comandos GeneXus ................................................................................................................................... 7
1.1. Assign Atributo .................................................................................................................................. 7
1.2. Assign Variável .................................................................................................................................. 7
1.3. Call ..................................................................................................................................................... 8
1.4. Change Page ....................................................................................................................................... 8
1.5. Commit ............................................................................................................................................... 8
1.6. Confirm .............................................................................................................................................. 9
1.7. Delete.................................................................................................................................................. 9
1.8. Do ‘Nome Subrotina’ ....................................................................................................................... 10
1.9. Do While .......................................................................................................................................... 10
1.10.
Eject .............................................................................................................................................. 10
1.11.
Error_Handler ............................................................................................................................... 10
1.12.
Exit ............................................................................................................................................... 11
1.13.
Footer............................................................................................................................................ 11
1.14.
For Each ....................................................................................................................................... 11
CLÁUSULA ORDER .............................................................................................................................. 12
CLÁUSULA WHERE.............................................................................................................................. 12
CLÁUSULA DEFINED BY .................................................................................................................... 13
1.15.
For Each Line ............................................................................................................................... 13
1.16.
For Each Selected line .................................................................................................................. 13
1.17.
Graph ............................................................................................................................................ 13
1.18.
Header .......................................................................................................................................... 14
1.19.
If ................................................................................................................................................... 15
1.20.
Line Number................................................................................................................................. 15
1.21.
Load .............................................................................................................................................. 15
1.22.
Margin Botton .............................................................................................................................. 15
1.23.
Margin Top ................................................................................................................................... 16
1.24.
Message ........................................................................................................................................ 16
1.25.
New Record .................................................................................................................................. 16
1.26.
NoSkip .......................................................................................................................................... 17
1.27.
Page Length .................................................................................................................................. 17
1.28.
Print If Detail ................................................................................................................................ 17
1.29.
PrinterCommand........................................................................................................................... 17
1.30.
Refresh.......................................................................................................................................... 18
1.31.
Return ........................................................................................................................................... 18
1.32.
RollBack ....................................................................................................................................... 18
1.33.
Submit .......................................................................................................................................... 18
1.34.
Subroutine .................................................................................................................................... 19
1.35.
Xfor Each ..................................................................................................................................... 19
1.36.
Xfor First ...................................................................................................................................... 19
1.37.
Xnew ............................................................................................................................................ 19
2. Regras dos Objetos GeneXus ................................................................................................................... 20
2.1. ACCEPT ........................................................................................................................................... 20
2.2. ADD ................................................................................................................................................. 21
2.3. ALLOWNULLS ............................................................................................................................... 21
2.4. <ASSIGN> ....................................................................................................................................... 21
2.5. CALL................................................................................................................................................ 21
2.6. COLOR ............................................................................................................................................ 22
2.7. DEFAULT ........................................................................................................................................ 22
2.8. DEFAULT MODE ........................................................................................................................... 23
2.9. EQUAL ............................................................................................................................................ 23
2.10.
ERROR ......................................................................................................................................... 23
2.11.
ERROR_HANDLER .................................................................................................................... 24

1

2.12. .............................................................................................................................................................. 24
2.13.
HIDDEN ....................................................................................................................................... 24
2.14.
MSG ............................................................................................................................................. 25
2.15.
NOACCEPT ................................................................................................................................. 25
2.16.
NOCHECK ................................................................................................................................... 25
2.17.
NOCONFIRM .............................................................................................................................. 25
2.18.
NOREAD ..................................................................................................................................... 26
2.19.
NOPROMPT ................................................................................................................................ 26
2.20.
ORDER ........................................................................................................................................ 26
2.21.
PARM ........................................................................................................................................... 26
2.22.
PRINTER ..................................................................................................................................... 27
2.23.
PROMPT ...................................................................................................................................... 27
2.24.
REFCALL .................................................................................................................................... 27
2.25.
REFMSG ...................................................................................................................................... 27
2.26.
SEARCH ...................................................................................................................................... 28
2.27.
SERIAL ........................................................................................................................................ 28
2.28.
SUBMIT ....................................................................................................................................... 28
2.29.
SUBTRACT ................................................................................................................................. 28
2.30.
WORKFILE_LINES .................................................................................................................... 29
2.31.
XORDER...................................................................................................................................... 29
3. Funções Disponíveis no GeneXus ............................................................................................................ 30
3.1. DAY ................................................................................................................................................. 30
3.2. MONTH ........................................................................................................................................... 30
3.3. YEAR ............................................................................................................................................... 31
3.4. TODAY ............................................................................................................................................ 31
3.5. NOW( ) ............................................................................................................................................. 31
3.6. HOUR, MINUTE, SECONDS ......................................................................................................... 31
3.7. DOW ................................................................................................................................................ 32
3.8. CDOW .............................................................................................................................................. 32
3.9. CMONTH ......................................................................................................................................... 32
3.10.
CTOD ........................................................................................................................................... 32
3.11.
CTOT............................................................................................................................................ 33
3.12.
DTOC ........................................................................................................................................... 34
3.13.
TTOC............................................................................................................................................ 34
3.14.
YMDTOD .................................................................................................................................... 35
3.15.
YmdHmstoT ................................................................................................................................. 35
3.16.
ADDMTH .................................................................................................................................... 35
3.17.
ADDYR ........................................................................................................................................ 36
3.18.
AGE .............................................................................................................................................. 36
3.19.
EOM ............................................................................................................................................. 36
3.20.
TDIFF ........................................................................................................................................... 36
3.21.
TADD ........................................................................................................................................... 37
3.22.
ASK .............................................................................................................................................. 37
3.23.
UDF .............................................................................................................................................. 37
3.24.
UDP .............................................................................................................................................. 37
3.25.
ROWS .......................................................................................................................................... 38
3.26.
COLS ............................................................................................................................................ 38
3.27.
TIME ............................................................................................................................................ 38
3.28.
SYSTIME ..................................................................................................................................... 39
3.29.
SYSDATE .................................................................................................................................... 39
3.30.
USERCLS .................................................................................................................................... 39
3.31.
USERID........................................................................................................................................ 39
3.32.
WRKST ........................................................................................................................................ 39
3.33.
STR ............................................................................................................................................... 40
3.34.
SUBSTR ....................................................................................................................................... 40
3.35.
CONCAT ...................................................................................................................................... 40

2

3.36.
SPACE.......................................................................................................................................... 41
3.37.
LEN .............................................................................................................................................. 41
3.38.
TRIM ............................................................................................................................................ 41
3.39.
LTRIM.......................................................................................................................................... 41
3.40.
RTRIM ......................................................................................................................................... 42
3.41.
UPPER.......................................................................................................................................... 42
3.42.
LOWER ........................................................................................................................................ 42
3.43.
INT ............................................................................................................................................... 42
3.44.
ROUND ........................................................................................................................................ 43
3.45.
TRUNC ........................................................................................................................................ 43
3.46.
VAL .............................................................................................................................................. 43
3.47.
COLOR ........................................................................................................................................ 43
3.48.
RGB .............................................................................................................................................. 43
3.49.
NULL ........................................................................................................................................... 44
3.50.
NULLVALUE .............................................................................................................................. 44
3.51.
LOADBITMAP ............................................................................................................................ 44
3.52.
OLD .............................................................................................................................................. 45
3.53.
PREVIOUS .................................................................................................................................. 45
3.54.
AFTER ......................................................................................................................................... 45
3.55.
LEVEL ......................................................................................................................................... 46
3.56.
INSERT/UPDATE/DELETE ....................................................................................................... 46
4. Operadores Disponíveis no GeneXus ....................................................................................................... 47
5. Variáveis Internas do GeneXus ................................................................................................................ 48
5.1. TODAY ............................................................................................................................................ 48
5.2. TIME ................................................................................................................................................ 48
5.3. PAGE................................................................................................................................................ 48
5.4. LINE ................................................................................................................................................. 48
5.5. OUTPUT .......................................................................................................................................... 48
5.6. PGMDESC ....................................................................................................................................... 49
5.7. PGMNAME ...................................................................................................................................... 49
5.8. MODE .............................................................................................................................................. 49
6. Propriedades do GeneXus ........................................................................................................................ 50
6.1. VISIBLE ........................................................................................................................................... 50
6.2. TOLLTIP .......................................................................................................................................... 50
6.3. CAPTION ......................................................................................................................................... 51
6.4. ENABLE .......................................................................................................................................... 51
6.5. ACTIVEPAGE ................................................................................................................................. 51
6.6. PAGECOUNT .................................................................................................................................. 52
6.7. BACKCOLOR, FORECOLOR ........................................................................................................ 52
6.8. TOP, LEFT ....................................................................................................................................... 52
6.9. FILLSTYLE ..................................................................................................................................... 53
6.10.
FILLCOLOR ................................................................................................................................ 53
6.11.
DEFAULT .................................................................................................................................... 53
6.12.
BITMAP ....................................................................................................................................... 54
6.13.
BACKSTYLE............................................................................................................................... 54
6.14.
FONTNAME ................................................................................................................................ 54
6.15.
FONTITALIC, FONTUNDERLINE, FONTBOLD, FONTSTRIKETHRU ............................... 55
6.16.
FONTSIZE ................................................................................................................................... 55
6.17.
WIDTH, HEIGHT ........................................................................................................................ 55
6.18.
TITLE ........................................................................................................................................... 56
6.19.
WINDOWSTATE ........................................................................................................................ 56
6.20.
LINESELECTOR ......................................................................................................................... 56
6.21.
REDRAW ..................................................................................................................................... 57
6.22.
TITLEFORECOLOR, TITLEBACKCOLOR .............................................................................. 57
6.23.
TAG .............................................................................................................................................. 57
6.24.
BORDERSTYLE ......................................................................................................................... 58

3

.................................. 69 CONFIRMATION ....... 70 • Form Icon .........................................................................................................................................................5................................................................ 60 8.............................................................................................. 68 10..............................2...................................................................................................................... 60 8..................................................... CLEAR.............................................................................................................................................................................................................................. 59 8.................................................................................................................................................................................................. 60 8............ 64 9...........1............................. 62 8............................................ 76 • Delete Mode ....................................................................................... Propriedades das Transações ................................. REFRESH .................. 75 • Next Record ............. GERADORES ................................................................................................................................................................. 58 7.......................... 73 KEY ASSIGNMENT ....................................................................................................1................................................................................................................................................1. 71 • Automatic Border – Color .......................................8..................... 72 • Automatic Border – Display Attribute...................................... 69 • Maximize Button ....................... 59 7.......... MODEL FORMS ....................................... USER INTERFACE – INTERFACE COM USUÁRIO ...................................... 73 10................................................................ REMOVEITEM .............................................. CLICK ........................................................................................................................................................................................................................................................... 74 • Refresh Key .....................................3........................................................................................................ Eventos de Controle ....... 71 • Generate as a Popup Window ...... SORT ...... 58 7........................................................................................................................ 74 • Insert Mode.................. 73 COMMITMENT ........................................ 70 • Minimize Button ........................................................................................ 71 CHARACTER INTERFACE – INTERFACE DE CARACTERES ............................................................................................................. 60 8...4........................................................... 69 WINDOWS INTERFACE ......................................................... 74 • Prompt Key.. 61 8............................................ PRINTFORM ...........3........................................ 74 • Previous Record.................................................3............................................................ 61 8.............. REPAINT ........................... 70 • Modal Dialog .................................................................................................................................................................... LOAD .................................................................................................... 62 9............................................................................................................................................................................ 69 • Border Style ............................................ PREFERÊNCIAS .......................................................................................................................... 75 • Menu ..................................... 67 COMMIT ON EXIT ................................................................. 67 10............................ 65 9....................................2.................................................... 63 MAXIMUN NUMERIC LENGHT ................................................................................................................................................. ADDITEM ..................................... 65 9................................................................................4......................................................................................................................... 63 FUNCTIONS.................... 67 CONFIRM TRANSACTION ............................................................................7.................................................................................................................................................... 76 • Cancel ...............................................................................................................................3........................2..................... 75 • Retrieve ......... 58 7.................................................................................................................................................................................................................................................................................. 62 8......... Métodos ...6..... TRANSACTION INTEGRITY – INTEGRIDADE TRANSACIONAL ................................................................................................................................. 74 • Exit Key.................................................................. RIGHTBUTTON ......................................................................................................................................................................................................................................... 76 4 ..................................................7......................................................................................................................................2...................................................................................... ISVALID ..............................................................................................................................4.............................................. AS/400 SPECIFIC – ESPECIFICAÇÕES AS/400 ............................................................ PROMPTS ...........1.......................................................................................................................................................................................................................... 66 10................................ Propriedades do Modelo Principal ............ 72 • Automatic Border – Characters .............. SETFOCUS ........................................................................... 63 9.................................................... 64 TIME FORMAT.................................................................................................................................. 70 • Control Box ....................... DBCLICK ............................................................................................................................................................................................ 69 • MenuBar .................................................... 75 • Update Mode ............

.................................................................................. 78 LOAD AT STARTUP .................................................................. 79 11......................................... 87 • More keys ..................................................................................................................................................................................... 86 FOOTER ON LAST PAGE .........................4........................ 78 LOAD RECORDS ...... 86 PROMPT FOR CONFIRMATION ....................... 85 12............... 87 • Exit Key.... 81 CONTROL BOX ......................... 78 ALLOW USER TO CANCEL WHILE LOADING ................................................................................................................................................................................................................1.......................... 84 • Exit Key........................................................ Propriedades das Work Panels ................................................. 92 KEY ASSIGNMENT ................................................................................................... 77 • More Keys ......................................... 80 MENUBAR .. 77 • Display Mode .............................................................................................................................................................................................................. WINDOWS INTERFACE ......................................... AS/400 SPECIFIC – ESPECIFICAÇÕES AS/400 .......................... 87 • Cancel ................................................. AS/400 SPECIFIC – ESPECIFICAÇÕES AS/400 ..................................................... Propriedades dos Procedimentos ................................................... 80 MINIMIZE BUTTON ............................................................................................................................................................................................................................................... 89 ALLOW USER TO CANCEL PROCESSING .......................................................... 89 REPORT OUTPUT ...................................................................................................................................... 88 13................................................................................................................................ 80 BORDER STYLE .................. 92 5 ...........................................1.................................................................................................................................................... 80 MAXIMIZE BUTTON ........................................................................................................................................... OPTIONS ................................................ 81 MODAL DIALOG .......................................................................................................................................................................................................................................................................................................................................................................................................................... 85 • More keys .......................................... 86 ALLOW USER TO CANCEL PROCESSING .......................................................................... 90 13........................................................................ LOADING ................................................................................................................................................... 76 • First Record .............................................2....................................................................................................................................................2......................................... 90 13................................................................................................................................................................ CHARACTER INTERFACE .............................................................................................. 84 KEY ASSIGNMENT .......................................................................................... AS/400 SPECIFIC ...................... 87 • Refresh Key ............................................................................................................................ 90 COMMIT ON EXIT ........................................................................................................... 84 • Refresh Key ............................................................................... 78 11..................................................................................... 79 AUTOMATIC REFRESH............................................................................................................................................................................................................ 92 • Exit Key.............................................................................................................................................2...................................... 87 KEY ASSIGNMENT ........................................................... 89 FOOTER ON LAST PAGE ................................................• Select ........................................................................................................ 82 GENERATE AS A POPUP WINDOW ........ 81 FORM ICON ....................................................... 89 PROMPT FOR CONFIRMATION ....................................................................................................... OPTIONS ..................................................................................................................................................................................................................... 79 REFRESH TIMEOUT (Foxpro for Windows e Visual Basic) ................................... 83 11................ TRANSACTION INTEGRITY – INTEGRIDADE TRANSACIONAL .................................................1................................................................................................... 92 COMMITMENT ......... 86 REPORT OUTPUT ................................................................................................................................................................ 84 • Cancel ..................................................................................................................................................................................................................................................................................................................................................................................................................................... 81 11.........................3.......................... Propriedades dos Relatórios ......................... 83 • Automatic Border – Characters .................................... 77 11.............................................. 87 12.................................................. 89 13........................................ 83 • Automatic Border – Color ............................... 82 AUTOMATIC BORDER .................................................................................................................................................................... 83 • Automatic Border – Display Attribute....................3...........................ESPECIFICAÇÕES AS/400 ........................................ 86 12.........................................................

.......................................................................................................................................................................................................................3............................................................. Propriedades do Modelo – Visual Basic ....................................................................................................................................................................................................................................................................................... 95 GENERATE MDI APPLICATION ............................................................................... 95 15...................... 103 CALCULATOR ON SECUNDARY NUMERIC FIELDS ............................................ RIGHT BUTTON ................................................................................................................................................................................................................................................................................... 103 15...................................... 100 GRAPHIC FUNCTIONS ........................................... FORMAT .................................................... ............................ 92 • More keys ............................................5......... GENERAL .................................................................. 93 14...................................... 104 SHOW PRINTER DIALOG ON REPORTS ............................................................ 105 ESC KEY ACTION ....................................................................................................................................................................................................................................................................................................... 95 TARGET SYSTEM INTERFACE .................................................................................................................................. 98 LOCK TYPE ............... 112 NEXT RECORD ........................... 113 15................... 112 15..............................................................................................8................................................................. 108 15........... TYPE CHECKING .............................................................................................................................. 94 WEBMASTER’S MAIL ADDRESS ...................................................................................... 97 CONFIRM .............................................................. 106 DECIMAL SEPARATOR...........4........................................................................................................................................ 101 COMMOM DIALOG FUNCTIONS ................................................................................ FOOTER ................................................................................................................................................ 107 TIME FORMAT............................................................................................................................. 112 FIRST RECORD ................. 98 PSEUDO CONVERSATIONAL DIALOG ....................1.............................................................................................................. 112 15..................................................................................................... 92 • Cancel .......................................................................................................................................................................................................................................................................................2.......... 109 FUNCTIONS............................................................................................................................................................................. 112 REFRESH KEY . 104 PRINT METHOD ..............................................................................................................................................1............................................................................... 101 15................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................. 99 LOCAL DATABASE FILE ................................. 108 PROTOCOL SPECIFICATION......... 106 DATE FORMAT .......................................................................................................................................................................................................... 107 FIRST YEAR OF 20th CENTURY ................................................................................................................................................................................................................................................................................................ 100 MAIL FUNCTIONS .................................................................................................................... 105 FIELD EXIT...............................................................9.................................................. 95 VISUAL BASIC VERSION ......................................................................................................................................................... 105 15....................................................................................................... 103 CALENDAR ON DATE FIELDS .................................................. 95 GRID VERSION ....................... 100 EXCEL OLE FUNCTIONS ...................... PRINTING ........................................... 97 AUTOSKIP .................................................................................................. 113 MAXIMUN WORKFILE LINES ................... 94 15........................................................................................................ 96 ALLOW COLUMN RESIZING ........................... 112 PREVIOUS RECORD ......................................................................... 106 DATE FORMAT IN CTOD FUNCTION (VISUAL BASIC) .................... 97 SKIP READ-ONLY COLUMNS ....7........................................ OTHER ............................................................................................... Propriedades das Web Panels ............................................... KEY CONFIGURATION ......... 108 15.. 94 14............................................................................................................................................................................................6....................................................................................................................................................................................... 112 LAST RECORD ............... 103 LAN PRINTER .......... 112 PROMPT KEY ................................................................ WEB INFORMATION .............• Refresh Key .................................................. 113 6 ...... 109 CHECK TYPE ERRORS .................................. 94 FOOTER IMAGE ..............................................................

Qualquer atributo dessas tabelas poderá ser atualizado. A expressão associada a <Exp> pode ser: • um Atributo • uma Variável • uma Constante • uma Função • uma Expressão Aritmética (Data e tipo Numérico somente) A atualização precisa ser feita dentro de um grupo FOR EACH – ENDFOR. GENEXUS torna isso possível via VARIÁVEIS LOCAIS. 1. Work Panel) &<Var> = <Exp> Associa o valor de uma expressão para uma variável.1. Procedure. Várias tabelas podem ser associadas a um grupo FOR EACH – ENDFOR. Comandos GeneXus 1. A expressão associada a <Exp> pode ser: • Um Atributo 7 . Relatório.1. Algumas vezes é necessário definir cálculos locais dentro de um objeto. Assign Variável (Transação.2. por exemplo: • Tabela Base • Tabelas que podem ser acessadas pela Tabela Base (Tabelas Estendidas). Assign Atributo (Procedure) <Att> = <Exp> Associa o valor de uma expressão para um atributo (Este comando atualiza o banco de dados). Essas variáveis existem somente no ambiente do objeto correspondente e em nenhum outro lugar.

Work Panel) Commit Força um COMMIT quando incluído em um programa. Se o programa que você estiver chamando já existir. 1. GENEXUS irá checar se o programa realmente existe. Relatório. 1. Relatório) CP <nlines> Causa um salto de página quando faltarem menos linhas que <nlines> na página que está sendo impressa. se nenhum dos dois comandos NOCOMMITMENT ou NOENDTRN tiverem sido especificados. Commit (Procedure. GENEXUS irá ativar o controle de Commitment para todas as Procedures e Transações.5. não será necessário escrever o nome entre apóstrofos. Call (Transação. Todos os parâmetros servem para entrada e saída. 8 . Relatório. assim valores podem ser retornados em qualquer dos parâmetros.parm2. Parâmetros podem ser atributos. variáveis ou valores constantes..[parm1.• • • • Uma Uma Uma Uma Variável Constante Função (permitido quando uma associação é utilizada) Expressão Aritmética (Data e tipo Numérico somente) 1.. O Nome do programa que será chamado pode ser uma variável ou um atributo.] Este comando é usado para chamar uma rotina externa ou um objeto GENEXUS.3.4. Work Panel) CALL([‘]Pgmname[‘]. será gerado um COMMIT no final da execução da Procedure ou Transação. Procedure.. Change Page (Procedure. Esse comando é equivalente a: EJECT if Pagelenght – Currentline for menor que <nlines>.

dependendo do ambiente de trabalho) e aguarda uma resposta do usuário que pode ser ‘Sim’ ou ‘Não’. Work Panel) Confirm(‘msg’ | &<Var> [.Y | N]) Mostra uma mensagem e aguarda até o usuário informar ‘Sim ou ‘Não. Regras: • Um comando DELETE pode somente ser usado em um FOR EACHENDFOR. • A Exclusão é executada exatamente no momento em que o comando DELETE é encontrado. NOTA: • Se o comando DELETE é especificado em um grupo que contenha grupos aninhados. respectivamente) em uma janela (ou linha de mensagem. 1. Confirm (Transação. 9 . embora eles não serão fisicamente deletados. Mostra o texto/variável (‘msg’ /&<var>.7. Delete (Procedure) Delete Exclui o registro da Tabela Base associado ao grupo onde o comando DELETE foi especificado. Para saber se o operador confirmou ou rejeitou a mensagem.6. • A integridade referencial não é automaticamente checada quando o comando DELETE é especificado. Isto evita qualquer possível cancelamento ou travamento do registro. Em ambiente AS/400 os valores possíveis são F12=Cancel ou Reject e Enter=Accept ou Confirm. os dados do grupo corrente podem ser usados dentro dos grupos aninhados. • Recomendação: primeiro exclua os níveis internos antes dos externos. a função CONFIRMED( ) é usada.1.

Para forçar a saída do grupo do DO WHILE pode ser usado o comando EXIT.11. subname é o nome de uma subrotina. ou limpa a tela quando a saída está associada a tela. Procedure. Work Panel e Web Panels) DO ‘RoutineName’ Permite você chamar uma subrotina (definida usando o comando “Sub”).1. Quando usado como comando. Do While (Transação. Relatório. 1. Relatório. Procedure. Não é permitida a passagem de parâmetros. onde. 1.9.10.8. Work Panel e Web Panels) Do while <Cond> Enddo Serão executados todos os comandos entre o DO WHILE e o ENDDO enquanto a condição <Cond> for verdadeira. Work Panel) Implementado para tratamento de erros para Client/Server. Procedure. 1. Do ‘Nome Subrotina’ (Transação. a sintaxe é: Error_handler(‘subname’). TODAS as variáveis do mesmo programa também podem ser utilizados pela subrotina. a sintaxe é: Error_handler([‘subname’]). Error_Handler (Transação. quando a saída selecionada está associada a impressora. Quando usado como regra. 10 . Eject (Procedure. Relatório) Eject Este comando força um salto de página no programa gerado. A regra/comando error_handler provê uma maneira dinâmica para executar ações específicas quando um erro no database é relatado em tempo de execução do programa. Relatório.

NOTA: O comando Exit não é valido dentro de um FOR EACH LINE. Footer (Procedure. da mesma forma como HEADERS pode.. 1. Relatório) Footer End Define as linhas de rodapé a serem impressas no final de cada página.14. FOOTERS podem também ser definidos com um FOR EACH dentro. Se as linhas de FOOTER não couberem dentro da área da margem inferior a impressão irá continuar na próxima página.. o comando For Each é usado para definir acesso ao Banco de Dados. Xfor Each ou Do While.. Relatório. O próximo comando a ser executado após um exit é o próximo comando após o comando EndFor. Relatório. e o Genexus 11 . Work Panel) For each [order <Att1> <Att2> .1.] [Where <Condition> ] [Defined by <Att1> <Att2> . Você somente precisa mencionar QUAIS os Atributos que você precisa.12. Procedure..] Endfor Define um grupo de atributos genéricos por operações. XendFor ou EndDo correspondente ao grupo que contém o comando Exit. Não existem referências explícitas para tabelas em um FOR EACH. Exit (Transação. 1. Work Panel) Exit O comando Exit permite abandonar um grupo For Each. Os comandos entre a cláusula FOOTER e a cláusula END são executadas quando chega-se ao final da página. Se existirem linhas de impressão entre o FOOTER e o END. elas irão ser impressas dentro da margem inferior (parâmetro MB). For Each (Procedure.13.

A maneira COMO GENEXUS vai efetuar a navegação pode ser vista no relatório de Especificação. Regras: • Vários comandos WHERE podem ser especificados após um FOR EACH. • Um comando WHERE pode. Neste caso. somente. 12 . as condições WHERE funcionarão como se elas estivessem separadas por um operador “.resolve o problema de COMO encontrá-los. Para forçar uma saída de um grupo FOR EACH você pode usar o comando EXIT. conhecidas como Tabelas Estendidas.AND. informados logo após o comando FOR EACH. CLÁUSULA WHERE WHERE <Condição> A cláusula WHERE pode ser especificada para estabelecer uma condição para o grupo For Each – EndFor. Se existirem atributos que não façam parte da Tabela Base nem das Tabelas Estendidas irá aparecer uma mensagem de erro no relatório de Especificação e o programa não será gerado. • Tabelas que podem ser alcançadas pela Tabela Base. CLÁUSULA ORDER ORDER < Lista de Atributos > A ordem para acessar a Tabela Base de um for Each pode ser especificada por uma lista ordenada de atributos. Uma quebra é definida sempre que nós temos a mesma tabela base em dois grupos For Each. NOTA: A cláusula ordem é bastante usada para definir quebras (Break) em grupos For Each aninhados. Existem dois tipos de tabelas associadas a um grupo FOR EACH: • Uma TABELA BASE. ser especificado imediatamente após um FOR EACH ou após outro comando WHERE. os atributos da Quebra estão definidos pelo conjunto de atributos especificados na cláusula Ordem.”.

para marcar todas as linhas que satisfaçam uma certa condição.17.: mais de uma tabela pode ser encontrada como Tabela Base). 1. 13 . porém somente serão consideradas as linhas marcadas (selecionadas).][<List>]). For Each Selected line (Work Panel) For each select line EndFor Esse comando funciona de forma similar ao for each lline. FOR EACH LINE tem as seguintes restrições: • Ele somente irá processar os registros que foram carregados no subfile.16. For Each Line (Work Panel) For each line EndFor Força o processamento de todas as linhas (carregadas) no subfile em uma Work panel. Algumas vezes. Se você quiser processar todos os registros do Subfile. a regra LOAD ALL precisa ser usada. Graph (Work Panel) graph([‘<GraphName>’. os atributos dentro do grupo não determinam exatamente a Tabela Base (ex. Assim é necessário declarar um grupo para determinar qual a Tabela Base que tem mais prioridade. os atributos dentro do FOR EACH determinam a Tabela Base. informando uma Lista de Atributos na cláusula DEFINED BY. Geralmente quando se está definido Procedures/Reports/Work Panels. tenham elas sido modificadas ou não.15. por exemplo. • Ele processa todas as linhas. 1. 1. Esse comando pode ser usado.CLÁUSULA DEFINED BY DEFINED BY < Lista de Atributos > Este comando permite definir a Tabela Base de um grupo FOR EACH ENDFOR.

Este comando irá armazenar todas as definições do gráfico (portanto o Graph Wizard não precisa ser usado todas as vezes). data ou numérico) e todas as outras variáveis precisam ser numéricas (eixo Y). Os dados dentro desse grupo são impressos no início de cada página do relatório.18. Você pode também definir um cabeçalho para cada “FOR EACH” definido no Layout. 14 . Relatório) Header End Define o cabeçalho a ser impresso no topo de cada página. O eixo X pode receber qualquer type variável (caractere. Isto pode somente ser utilizada por programas gerados para Foxpro for Windows ou Visual Basic. • <List> é uma lista com os atributos e variáveis do Subfile que devem ser incluíds no gráfico. o programa MS-GRAPH (Incluído no Foxpro for Windows) é executado sempre que esse comando for localizado.Permite gerar um gráfico a partir das informações contidas no Subfile. • conteúdo do subfile é usado como o dado para o gráfico e o usuário pode escolher qual o tipo de gráfico que será usado. O primeiro grupo no Layout padrão das Procedures/Reports é o grupo HEADER. Se o arquivo correspondente ao gráfico não existir. o Graph Wizard será chamado. É possível alterar os valores. Se você quiser modificar a definição do gráfico você precisa dar um duplo clique sobre a janela do gráfico. etc. imprimir o gráfico e vê-lo em 3D. Quando gerado no Foxpro for Windows. 1. Uma vez que o gráfico é definido você precisará salvá-lo com o mesmo nome usado em <GraphName>. Onde: • <GraphName> corresponde ao caminho e nome para o arquivo que contém o gráfico. Header (Procedure.

1. Load (Work Panel) Load Este comando força a carga de uma nova linha dentro do subfile. Ela é bastante usada quando o Work Panel não tem uma tabela Base. Relatório. 6 linhas serão assumidas (<nlines> = 6).1.21. Line Number (Procedure. 1. 1. Procedure. If (Transação.20. Relatório) Lineno <Lineno> Especifica o número da linha onde o dado será impresso. Work Panel) If <Cond> [Else] Endif Executam um bloco de comando se a condição for avaliada como verdadeira. Margin Botton (Procedure.22.19. Relatório) MB <nlines> Configura o número de linhas em branco no final de uma página. Se margin Botton não for especificado. 15 . e consequentemente a carga precisa ser feita “na mão” ou quando precisamos fazer filtros com atributos de várias tabelas.

Relatório.status]) Usado para mostrar mensagens de aviso. Caso você deseje fazer alguma alteração nesse registro já existente. Margin Top (Procedure.25. 1.nowait] [. New Record (Procedure) New [When Duplicate] EndNew O comando NEW insere um registro na Tabela Base determinada pelo atributo no grupo NEW-ENDNEW. Status: A mensagem é mostrada no momento em que é originada.1. O usuário não irá ver mensagem até que o processamento do programa se encerre. Ela é usada principalmente para dar ao usuário informações sobre status de processamento. Work Panel) Msg(‘msg’ | &<var> [.24. Nenhuma Opção Especificada: Exibe a mensagem e aguarda pelo pressionamento do <ENTER>. Isto garante uma melhor performance com menos telas de I/O requeridas. Procedure. 16 .23. Nowait: Armazena a mensagem em uma variável interna e continua o processamento. 1. um grupo FOR EACH – ENDFOR precisa ser especificado dentro do WHEN DUPLICATE. Relatório) MT <nlines> Define o número de linhas em branco no topo da página. Message (Transação. Pode mostrar um literal ou uma variável contendo uma mensagem. Se a chave já existir. Chaves duplicadas são checadas. todos os comandos entre o WHEN DUPLICATE e o ENDNEW serão executados.

Relatório) NoSkip Inibe salto de linhas de impressão consecutivas. 1.26.1. Relatório) PrnCmd <\Onn | String> Manda seqüências de controle para a impressora. <\Onn | String> é um string caracter contendo caracteres ou um código ASCII de 3 dígitos precedido por uma “\” onde no mínimo um espaço separa o PRNCMD and <\Onn | String>. O número de linhas que serão impressos é o número especificado por <nlines>.29. Este comando precisa ser colocado imediatamente após o print block. Relatório) Print if Detail Evita a impressão do registro se não existirem registros no Subfile.28. 1. Ele pode ser colocado em qualquer lugar dentro de um grupo. menos a margem inferior (valor default é 6).27. Este comando precisa ser especificado sempre que você quiser inibir o processamento de um FOR EACH caso não haja registros de detalhe para ele. Os parâmetros dependem de cada impressora e podem ser encontrado no Manual da Impressora. Print If Detail (Procedure. 1. PrinterCommand (Procedure. Relatório) PL <nlines> Configura o tamanho da página para Reports/Procedures. NoSkip (Procedure. Page Length (Procedure. 17 .

Work Panel) RollBack O comando ROLLBACK invalida um conjunto de alterações do banco de dados em uma LWU (Logical work Unit). 1. Return (Transação. 1.. Relatório. 1. Procedure. Procedure. RollBack (Transação.30. Opção KEEP: Este parâmetro indica que quando o comando Refresh for executado. Considerações: O comando ROLLBACK é ignorado pelos ambientes que não usam Integridade Transacional. Submit (Transação. Work Panel) Return Encerra o programa e retorna a execução ao programa que o chamou.33.’SubmitParms’[<Parm1> <Parm2> .1. Relatório. Procedure. o Subfile será posicionado sobre o registro que estava em foco anteriormente.]) Processa certas tarefas da aplicação em modo batch. Os ambientes que não permitem a execução de tarefas batch (como o DOS) consideram o SUBMIT como se fosse um comando CALL e ignoram os parâmetros específicos do SUBMIT. 18 ..31. Refresh (Work Panel) Refresh [Keep] Atualiza as informações mostradas no subfile. Work Panel) SUBMIT(‘Usr-pgm’.32. Relatório.

34. 1.37. Relatório. Ele retorna o primeiro registro (se existir um registro) de um arquivo externo utilizando o índice especificado e filtrando dados de acordo com a condição declarada na opção WHERE.35. porém ele não fica em loop. Relatório. Xfor Each (Procedure. Work Panel) Sub ‘RoutineName’ EndSub Permite que sejam definidas rotinas que serão disparadas quando um comando DO for executado. Work Panel) Xfor first ‘<FileName>’ [INDEX ‘<IndexName>’] Where <Condition> Xendfor Este comando é similar ao comando XFOR EACH. 1. Todas as variáveis do mesmo programa fonte pode também ser usadas dentro da subrotina. Work Panel) Xfor each ‘<FileName>’ [INDEX ‘<Indexname>’] Where <Condition> Xendfor Define um loop interativo para um arquivo externo (File View). Subroutine (Transação. 1. Procedure.36. Xfor First (Procedure. Xnew (Procedure) Xnew ‘<FileName>’ Xendnew 19 . usando índice especificado (se existir) e filtra dados de acordo com a condição declarada na opção WHERE.1. Relatório.

Regras dos Objetos GeneXus 2. 2. 20 .1. A ordem da entrada do valor para a Variável em um Nível. Atributo). ACCEPT (Transações) Accept(&variável. dependerá da posição das Variáveis e dos Atributos na Tela.O comando XNEW insere um registro em um File View (arquivo externo). Esta Regra permite aceitação de uma Variável em Tela.

.2. o Atributo Qtdestq também o será.. AtribN ) Esta regra é usada para permitir valores NULOS para atributos nos quais são feitos verificação da integridade referencial.4. o valor é atribuído ao Atributo ou à variável somente quando a Transação estiver sendo processada. 2. Desvia a execução temporariamente para outro programa. Qtdestq). ADD (Transações) Add( Atributo1. Exemplo: 21 . que pode ser: um nome de programa.. Procedimentos. Work Panels) CALL(‘Prog_usuário’... será chamado sempre que a “Condição” for avaliada como Verdadeira.3. Relatório/Procedimentos) Atributo | &Variável = Expressão IF Condição. 2. O Prog_usuário. Esta regra adiciona o valor de Atributo1 ao Atributo2. se a Condição for avaliada como verdadeira.. Atrib2. Esta Adição leva em conta as operações de Inserção. Se o atributo Qtdcompra for atualizado. Atualização e Remoção. <ASSIGN> (Transações.. Esta regra é usada para assinalar o valor de uma expressão a um dado atributo. ALLOWNULLS (Transações) Allownulls( Atrib1. Relatórios.Parn) IF Condição. Exemplo: Add( Qtdcompra.5.2. atributo ou variável.Par1. Atributo2) if Condição. . CALL (Transações. 2. Em contraste com Fórmulas. pelo valor diferencial da atualização.

DEFAULT (Transações. Color(<gxcolor>. Onde: <GxColor> = ‘ ‘ ‘<Displaycolor>[‘. Work Panels) Color( <gxcolor> ). //Permite a definição das cores default para tela. Ex.7. Work Panels) 22 .<AcceptColor>]’ ‘ ‘ <DisplayColor> = <ColorPair> <AcceptColor> = <ColorPair> <ColorPair> = <ColorSet> [‘/’ <ColorSet>] <ColorSet> = <Color> [ <DsAttri> ] <Color> = ‘WHT’ | ‘BLK’ | ‘RED’ | ‘GRN’ | ‘BRW’ | ‘MGN’ ‘BLU’ | ‘CYN’ | ‘YLW’ | ‘RI’ | ‘X’ <DspAttri> = ‘+’ | ‘*’ Cada <ColorPair> define a cor de frente e a cor de fundo.: color(‘RED+’. 2.6. Color(‘WHT’. //Define cores para atributos ou variáveis. Abreviaturas de Cores: ‘WHT’ = branco ‘BLK’ = preto ‘RED’ = vermelho ‘GRN’ = verde ‘BRW’ = marrom ‘MGN’ = magenta ‘BLU’ = azul ‘CYN’ = cinza ‘YLW’ = amarelo ‘RI’ = imagem reversa ‘X’ = escondido Um asterisco (‘*’) em <DspAttri> representa um elemento BLINKING e um sinal mais (‘+’).[<attri>|<var>)(if <cond>].&V2). em HIGHLIGHTS. COLOR (Transações. &V1. Procedimentos/Relatórios.&Pgm = ‘WProg’ Call(&Pgm. Saldo) if saldo > = 0. Saldo) if saldo < 0. 2.

8. Esta Regra assinala o valor de xxx ao Atributo no momento da Inserção. ERROR (Transações) Error(‘Texto de Mensagem’) IF Condiçaõ. Exemplo: Default(Peddat. EQUAL (Transações) Equal( Atributo. e permite que o usuário mude esse valor. Esse valor não pode ser mudado pelo usuário. 2. Atributo). 2. Se não for especificado nenhum Atributo. DEFAULT MODE (Transações) Default_mode(Ação. será assumido o primeiro Nível. Constante ou Função. Constante ou Função. Ação: Pode ser uma das seguintes: INSERT. UPDATE ou DELETE. xxx). today( ) ). Onde xxx pode ser: Atributo. É usada para forçar um modo específico em um Nível de Transação. Onde xxx pode ser: Atributo. Esta Regra assinala o valor de xxx ao Atributo no momento da Inserção.10. xxx). 23 . Atributo: É usado para indicar o Nível.9. 2.Default( Atributo. Esta regra não é válida para um Atributo que faça parte de uma Chave.

<Parmn>). 2. ERROR_HANDLER (Transação. 24 . HIDDEN (Work Panels) Hidden(<Parm1>. não serão executadas..12. mas não se quer que ele apareça na tela. Work Panel) Implementado para tratamento de erros para Client/Server. a regra Error deverá ser a última.<Parm2>. inclusive outras regras. Portanto. a sintaxe é: Error_handler([‘subname’]) Onde: Subname é o nome de uma subrotina. Ela é bastante utilizada quando precisa-se de um código no Subfile.13.Esta Regra faz com que a “string” definida em ‘Texto de Mensagem’ seja apresentada na Janela de Erro da Transação. Esta regra é usada para incluir atributos ou variáveis específicas no Subfile.11. Quando usado como regra. Todo processamento subsequente. a sintaxe é: Error_handler(‘subname’). Relatório. Procedure. 2. para que as outras possam ser executadas. 2... se muitas regras estiverem associadas a uma única condição. se a condição for avaliada como verdade.. que eventualmente não aparecem na tela. Quando usado como comando. A regra/comando error_handler provê uma maneira dinâmica para executar ações específicas quando um erro no database é relatado em tempo de execução do programa.

15.16. Atributo: É usado para indicar o nível. Work Panels) Noaccept( Atributo | &Variável) IF Condição. dependendo de uma condição. MSG (Transações) Msg(‘Texto de Mensagem’) IF Condição. A regra Noconfirm é usada para evitar a confirmação no Nível. NOCHECK (Transações) Nocheck( Atributo1. NOCONFIRM (Transações) Noconfirm(Atributo). A regra Nocheck é usada para inibir a checagem de integridade referencial.2. Esta regra é usada para enviar mensagens de aviso para o operador. pode haver ocasiões em que não se deseja que o usuário introduza dados. Atributo2. será assumido o primeiro nível. Se não for especificado nenhum atributo. usa-se esta regra. NOACCEPT (Transações. 2. uma mensagem é apresentada. pedindo a confirmação dos dados. e quais Atributos são saída de dados. Para se evitar o pedido de confirmação. 2. Quando se passa de um Nível para o seguinte. 2. GeneXus avalia quais Atributos são entrada de dados. Esta regra faz com que a Transação não aceite a digitação de dados para o Atributo ou variável associado. . 25 . Todavia.. A “string” definida em ‘Texto de Mensagem’ será apresentada na Janela de erro da Transação se a for avaliada como verdade.17...14. Atributon).

. Estabelece a ordem de leitura da tabela base da Work Panel. NOPROMPT (Transações) Noprompt( Atrib1. NOREAD (Procedimentos/Relatórios. 26 . Essa regra permite inibir a leitura de uma tabela que é navegada e mostrada no diagrama de navegação quando especificado. 2. Work Panels) Noread(<Att1>.. ORDER (Work Panels) Order(<Att1>.<Attn>).. . AtribN são identificadores da chave da tabela.18.<Attn>). PARM (Transações...21.2.. Se essa regra é omitida. Procedimentos/Relatórios.<Att2>.. Par2..: • Transações que possuem a regra PARM( ) não aparecem no Menu. Atrib2.. a chave primária da tabela base será usada. 2. AtribN) Atrib1.. Atrib2. Essa regra é usada para evitar o “Prompt” (‘Visualizar’) quando se entra com um valor para a Chave Estrangeira que não existe na Tabela. Obs. Parn)... Work Panels) Parm( Par1.. Recebe os programas enviados por outro programa..<Att2>. 2.19.20. .

REFCALL (Transações) Reffcall(‘Nome_prog’... na geração Xbase.24.• Quando um Objeto é chamado de outro programa. PRINTER (Procedimentos/Relatórios) Printer(‘<PrinterFile>’). Esta regra é usada para chamar um Programa quando a integridade referencial tenta ser quebrada. . AtribN) 27 . Atrib1. Atrib1. ao invés do programa default criado pelo GeneXus. Chama o programa definido.23. 2. PROMPT (Transações) Prompt(‘Programa’... 2. Atrib1.. AtribN). definido por uma variável de ambientes DOS. os parâmetros recebidos pela regra PARM( ) são considerados como uma regra Equal. . . 2.. . REFMSG (Transações) Refmsg(‘Texto’.25.. AtribN).22. 2. Seleciona o arquivo de impressão a ser usado pelo AS/400 ou o nome da impressora. . quando seleciona-se ‘Visualizar’. Atrib2.

. Se Atributo1 não faz parte do Identificador..<Parm1>. 2. para que Atributo1 assuma o modo INSERÇÃO. 28 .28. desde que esses não tenham interações com o usuário.26.. 2. Exemplo: Refmsg(‘O CLIENTE NÃO ESTA CADASTRADO’. ela somente posiciona o ponteiro. SUBMIT (Transações) SUBMIT(‘Usr-pgm’. SUBTRACT (Transações) Subtract( Atributo1. toda vez que um novo registro for adicionado à Tabela onde Atributo1 esteja. Esta regra faz com que o Atributo1 seja incrementado para o valor contido em Atributo2 mais o valor do Passo. e receba o próximo valor serializado. 2. Passo). o usuário deverá digitar um valor que não existe.’SubmitParms’[.<Parm2>. Clicod). Atributo2) if condição.27. Atributo2. SERIAL (Transações) Serial( Atributo1. SEARCH (Work Panels) Search(<Cond>).29. A diferença dessa regra para uma condition é que ela não filtra os dados do subfile.])[IF <Cond>]. 2. Seleciona um posicionamento condicional para o subfile.Esta regra é usada para mudar as mensagens geradas por GeneXus quando verificando as Integridades Referenciais em tempo de Inserção ou Atualização. Processa relatórios e procedimentos em modo batch.

Exemplo: Subtract( Qtd. WORKFILE_LINES (Work Panels) Workfile_lines(<NoLines>). Ela indica qual é o arquivo base do subfile. 2.31. Neste caso um arquivo temporário contendo 300. e qual índice será usado para carregá-lo (caso não seja indicado. XORDER (Work Panels) Essa regra é utilizada em Work Panels que utilizam arquivos externos. O tamanho máximo para o subfile no AS/400 é de 9. Os Subfiles em um ambiente PC são carregadas em um arquivo temporário. Atualização e Remoção.30. por exemplo. não existem restrições quando PC ou LAN’s são usados. se você está trabalhando com uma Work Panel ou Transação que carrega 300.000 registros da tabela base e o usuário vai para o fim do arquivo (Ctrl-End). Esta liberdade pode causar problemas. contudo. Qtdestq).Esta regra Subtrai o valor de Atributo1 do Atributo2. a ordem física será usada). 2.000 registros será gerado. Esta Subtração leva em conta as operações de Inserção.999 linhas. 29 . se a Condição for avaliada como verdadeira. Estabelece o tamanho máximo para o subfile.

Work Panels) Day(<Date>) Tipo retornado: N(2) Retorna o dia de uma data informada. 30 . MONTH (Transações. Funções Disponíveis no GeneXus 3. DAY (Transações.2.1. o valor 0 será retornado.3. Se <Date> for uma data nula. Um valor nulo (0) será retornado se a <Date> não for uma data nula. Procedimentos/Relatórios. Work Panels) Month(<Date>) Tipo retornado: N(2) Retorna o número do mês de uma data informada. Procedimentos/Relatórios. 3.

Tipo retornado: Numérico Retorna um valor numérico representando as horas/minutos/segundos respectivamente. Relatórios. no formato da hora informado do datetime. Work Panels) Today( ) Tipo retornado: Date Retorna a data do sistema operacional. Work Panels.6. Web Panels) Now( ) Tipo retornado: Datetime Retorna a data e a hora corrente. um valor nulo será retornado. Web Panels) Hour( <Date Time> ) / Minute(<DateTime>) / Seconds(<Date Time>). Procedimentos/Relatórios. 3. TODAY (Transações. HOUR. Relatórios.5. Work Panels) Year(<Date>) Tipo retornado: N(4) Retorna o ano de uma data informada. NOW( ) (Transações. Procedimentos. SECONDS (Transações. Se <Date> não for uma data válida. 3. Procedimentos. YEAR (Transações. MINUTE.4.3. Work Panels. Procedimentos/Relatórios.3. 3. 31 .

3. CTOD (Transações. Procedimentos/Relatórios.10.8. Este número está associado ao dia da semana (Domingo=1). 3. Se a data contida em <Date> for nula. Procedimentos/Relatórios. o valor retornado será 0. Procedimentos/Relatórios. DOW (Transações. CDOW (Transações.9. Work Panels) Ctod(‘nn/nn/yy’) 32 . Work Panels) Cmonth(<Date>[ . será utilizada a linguagem selecionada no ‘Model Properties’): spa – Espanhol eng – Inglês por – Português ita . Procedimentos/Relatórios. ‘<Language>’]) Tipo retornado: C(9) Retorna o nome do mês da data informada na linguagem selecionada. CMONTH (Transações. Work Panels) Cdow(<Date>[‘<Language>’]) Tipo retornado: C(9) Retorna o nome do dia da semana de uma determinada data na linguagem selecionada. Se nenhuma linguagem for selecionada. <Language> deve ser uma das seguintes (caso não seja informada. Work Panels) Dow(<Date>) Tipo retornado: N(1) Retorna um número entre 1 e 7. Espaços serão retornados se o valor de <Date> for inválido. 3.7.Italiano 3. será utilizada a que estiver definida em ‘Model Properties’.

é assumido nulo. nn/nn/yy tem o formato M/D/A ou o especificado na preferência ‘Date format in CTOD function’. hh pode variar de 0-12. Se AM|PM é especificado. irá variar entre 0-23. • Se não for especificdo nem AM nem PM. o formato 24-horas é assumido. onde: mm representa o mês com dois dígitos. Meio-dia {00:00:00} a {11:59:59} é equivalente a {12:00:00AM} a {11:59:59AM} {12:00:00} a {23:59:59} é equivalente a {12:00:00PM} a {11:59:59PM} 24:00:00 não é uma hora válida. Work Panels e Web Panels) CtoT(‘nn/nn/yy hh[:mm[:ss]][AM|PM]’) Tipo retornado: C(9) Converte uma String em DateTime. CTOT (Transações. Meia-noite {00:00:00PM} é equivalente a {12:00:00PM}. Procedimentos. o valor default depende da linguagem selecionada: Inglês ‘mm/dd/yy’ Português/Espanhol ‘dd/mm/yy’ 3. 33 . A primeira parte dos parâmetros representa a data e a segunda parte a hora. {00:00:00AM} é equivalente a {12:00:00AM}. Em ambiente Micro. Relatórios. • Se qualquer parte da string não é válida. Notas: • A data e a hora da string de parâmetros devem ser separados por pelo menos um branco. • Se qualquer parte da string (data e hora) for omitido. A string de caracteres pode ser ‘mm/dd/yy’ ou ‘dd/mm/yy’ dependendo da linguagem corrente. dd representa o dia com 2 dígitos. Caso contrário.11.Converte uma String em Data. o DateTime resultante será nulo. yy representa a ano com 2 dígitos.

É possível também setar valor nulo (0) para N. Procedimentos/Relatórios.N]]) Tipo retornado: Caractere Retorna caractere associado ao DateTime. 8. Work Panels) Dtoc(<Date>) Retorna a String associada a data especificada.M[ . Neste caso. com o formato especificado por M e N.13. 3. Valores possíveis para M: 0 Data não é pedida nem mostrada 8 Data é mostrada em 8 dígitos (99/99/99) 9 Data é mostrada em 10 dígitos (99/99/9999) Valores possíveis para N: 2 Somente a parte das horas é mostrado no formato 24 horas 5 Hora e minuto são mostrados separados pelo símbolo separador de horas. Relatórios. O formato 24 horas é usado. 0) NÃO é válido. O formato 24 horas é utilizado. 0. 0) TtoC( DT.12. • No caso da combinação M/N não ser válida. seus valores default são os parâmetros utilizados para definição do DateTime (primeiro parâmetro). DTOC (Transações. 8 Hora completa é mostrada (incluindo segundos). TTOC (Transações. somente a parte da data é obtido. Procedimentos.3. Exemplos: TtoC( DT. Os valores possíveis para M e N são os mesmos usados na definição do tipo DateTime. Work Panels e Web Panels) TtoC( <DateTime>[ . Notas: • No caso de M e/ou N serem omitidos. 34 . 10. 0) TtoC( DT. os valores assumidos são: M=10 e N=8.

<NExp2> e <NExp3> devem ser expressões numéricas.• O formato da string retornada é o mesmo da função CtoT. Parâmetros omitidos assumem o valor zero.<NExp5> [ . <NExp2>. YmdHmstoT (Transações. Procedimentos/Relatórios. <NExp1>. Relatórios. 12. Todos os parâmetros são expressões numéricas. 15) irá retornar um datetime válido com a parte da data nula.14. ADDMTH (Transações.<NExpression>) 35 . NExp6 – representa os segundos. A hora será 12:10:15. NExp5 – representa os minutos. Work Panels e Web Panels) YmdHmstoT( <NExp1>. <NExp4> [ . 10. YMDTOD (Transações. Procedimentos. NExp4 – representa a hora. Work Panels) Ymdtod(<NExp1>.15. ou seja. <NExp2> é o mês e <NExp3> é o dia. 2. somente este será considerado. Hora deve ser especificado no formato 24horas. 31. <NExp3> [ .<NExp2>. 3. NExp1 – representa o ano. 3. NExp3 – representa o dia.16. Nota: Se somente um dos componentes (dat ou hora) é válido. Procedimentos/Relatórios. NExp2 – representa o mês.<NExp3>) Retorna a data onde <NExp1> é o ano. Este valor não se ajusta ao que for indicado na preferência ‘First year of 20th century’. Work Panels) Addmth(<Date>. 3. Por exemplo: YMDHMStoT(1990.<NExp6>]]]) Tipo retornado: Date Time Retorna um Date Time associado a data e hora especificados no parâmetro. a data depende da preferência ‘Date format in CtoD function’ e a hora é sempre no formato 24 horas.

20. TDIFF (Transações. 3. 3. AGE (Transações.17. Procedimentos/Relatórios. um valor negativo será retornado.18. Work Panels e Web Panels) TDiff( <DateTimeExpr1>. Work Panels) Eom(<Date>) Retorna o número do último dia correspondente ao mês referente a data informada. 3. Procedimentos/Relatórios. 36 .19. Procedimentos.<DExpression2>]) Retorna a quantidade de anos entre <DExpression1> e <DExpression2>.<NExpression>) Retorna a data correspondente a <Date> mais <NExpression> anos.Retorna a data referente a adição de <NExpression> meses para <Date>. Relatórios. Work Panels) Age(<DExpression1>[ . Work Panels) Addyr(<Date>. Procedimentos/Relatórios. <DateTimeExpr2>) Tipo retornado: Numérico. Retorna os segundos da diferença entre dois DateTime recebidos como parâmetros (DateTimeExpr1 – DateTimeExpr2) Se DateTimeExpr2 for maior que DateTimeExpr1. 3. Se <DExpression2> não for especificada. ADDYR (Transações. Um valor nulo é retornado se <Date> for uma data inválida. a função Today( ) é assumida. EOM (Transações.

ASK (Transações. Procedimentos/Relatórios. ‘msg text’ é a mensagem que será mostrada quando for solicitado o valor. . Par1. 3.. Exemplo: TotalPoints = UDF(‘PCalPts’.. TADD (Transações. que deverá conter o valor retornado para a função. Procedimentos. Procedimentos/Relatórios.. Work Panels) Ask(‘msg text’) Pede ao usuário para que informe o valor de um Atributo ou variável antes de entrar no objeto. Quando você escreve o código para ‘UsrPgm’.23. Work Panels) Udp(‘Usr-pgm’. UDF (Transações. <SecondsExpr> ) Tipo retornado: DateTime Soma os segundos informados <DateTimeEspr>. Relatórios. .24. Parn) 37 . Os outros parâmetros não poderão retornar nenhum valor. Parn) Chama uma rotina que não usa tabelas e retorna um resultado. Paar1. Programas que NÃO USAM TABELAS podem ser referenciados usando a função UDF.3. PilotNbr) 3. Work Panels e Web Panels) TAdd( <DateTimeExpr>.22.. &CliFin = ask(‘Cliente Final: ‘).. Procedimentos/Relatórios. deve incluir um parâmetro a mais no final da lista de parâmetros. Exemplo: &CliIni = ask(‘Cliente Inicial: ‘).21. em <SecondsExpr>) ao datetime 3. UDP (Transações. Work Panels) Udf(‘Usr-Pgm’.

A função UDP chama um programa que pode USAR TABELAS e retorna um valor. Work Panels) Cols(&Array( )) Retorna o número de colunas de um vetor bidimensional. e abre-as novamente após retornar. esta função retorna a hora inicial do JOB. Work Panels) Rows(&Array( )) Retorna o número de linhas definidas para um vetor.25. Se ‘Usr-Pgm’ não usa tabelas. assim Time( ) e SYSTIME( ) são equivalentes. Note que a função UDP fecha as tabelas antes da chamada ser feita. COLS (Procedimentos/Relatórios. um parâmetro o qual conterá o valor que será retornado pela função. a função UDF é recomendada para que ganhe performance. 38 . TIME (Transações. 3. Procedimentos/Relatórios.27. 3. retorna a HORA DO SISTEMA. deverá ser incluído no final da lista de parâmetros. Work Panels) Time( ) Retorna a hora no formato ‘hh:mm:ss’. No AS/400. No ambiente Micro/LAN. 3.26. ROWS (Procedimentos/Relatórios. Quando o código para o programa ‘UsrPgm’ for escrito.

30. Procedimentos/Relatórios. esta função retorna a identificação do usuário definida no User Profile. Work Panels) Userid( ) No ambiente AS/400. Procedimentos/Relatórios. WRKST (Transações.28. Procedimentos/Relatórios. Procedimentos/Relatórios.31. Work Panels) Sysdate( ) Retorna a data do sistema. Em um ambiente Client/Server esta função retorna a identificação do usuário conectado ao servidor. USERID (Transações. No ambiente Micro/Lan esta função retorna o conteúdo da variável de ambiente do DOS chamada LOGNAME. USERCLS (Transações. 3. SYSDATE (Transações. 3. essa variável deverá ser criada para todas as estações. Para habilitar o uso dessa função. 3. SYSTIME (Transações. 3. Esta regra é válida somente no AS/400. Procedimentos/Relatórios.29.3. Work Panels) Usercls( ) Retorna a classe do Usuário definida no User Profile. Work Panels) Systime( ) Retorna a hora do sistema no formato ‘hh:mm:ss’.32. Work Panels) Wrkst( ) 39 .

<N2> é o tamanho total de <N1> (incluindo o sinal e o ponto decimal).N2 [ .Retorna a identificação da Estação de Trabalho correspondente.34. com um tamanho de N2 caracteres. S2 [ . Retorna a substring de S1 começando na Posição N1. Em ambiente Micro/Lan retorna o conteúdo da variável de ambiente do DOS. PSTATION. • O valor Default para N2 = 10 • O valor Default para N3 = 0 3. 3. Procedimentos/Relatórios.N1. Work Panels) Substr(S1. Procedimentos/Relatórios. Para habilitar o uso dessa função. alinhado pela direita. o valor será arredondado.N3]]) Converte o valor da expressão numérica em <N1> para uma string caracter. Notas: • Zeros não significativos serão truncados. Procedimentos/Relatórios.35. Se você especificar menos decimais do que a expressão numérica <N1> possui. 3. Work Panels) Concat( S1.33. SUBSTR (Transações.S3]) Concatena duas strings incluindo um separador se informado.N2) Retorna a substring de um dado informado. você precisa setar esta variável de ambiente. STR (Transações. 40 . e <N3> é o número de decimais. CONCAT (Transações. Work Panels) Str(N1 [ .

Retorna a string resultante da concatenação de S1 e S2 e o separador
S3. Os brancos das strings S1 e S2 são truncados. Se S3 não for especificado,
não serão inseridos separadores.

3.36. SPACE
(Transações, Procedimentos/Relatórios, Work Panels)
Space(<Att | Var | Const>)
Retorna uma string caracter com a quantidade informada de espaços em
branco.
No AS/400, o atributo ou variável que recebe a função, será
completamente preenchido com espaços, independente do valor informado para
o argumento.

3.37. LEN
(Transações, Procedimentos/Relatórios, Work Panels)
Len(S1)
Retorna o número de caracteres de uma expressão.

3.38. TRIM
(Transações, Procedimentos/Relatórios, Work Panels)
Trim(<Str>)
Remove todos os brancos a esquerda e a direita da expressão caracter
<Str> informada.

3.39. LTRIM
(Transações, Procedimentos/Relatórios, Work Panels)
LTrim (<Str>)

41

Remove todos os brancos a esquerda da expressão caracter <Str>. Esta
função é especialmente útil para remover os brancos que são inseridos quando
você utiliza a função Str( ) para converter um valor numérico para uma string
caracter.

3.40. RTRIM
(Transações, Procedimentos/Relatórios, Work Panels)
Rtrim(<Str>)
Remove os brancos a direita de uma string caracter informada.

3.41. UPPER
(Transações, Procedimentos/Relatórios, Work Panels)
Upper(<Str>)
Retorna a correspondente maiúscula da string <Str>. Cada letra
minúscula (a - z) é convertida em letra maiúscula (A - Z) no resultado da
função, todos os outros caracteres permanecem inalterados.

3.42. LOWER
(Transações, Procedimentos/Relatórios, Work Panels)
Lower( <Str>)
Converte todas as letras maiúsculas (A – Z) da expressão caracter <Str>
para letras minúsculas (a – z). Todos os outros caracteres da expressão
permanecerão inalterados.

3.43. INT
(Transações, Procedimentos/Relatórios, Work Panels)
Int( <Exp>)
Esta função retorna a parte inteira da expressão <Exp>.

42

3.44. ROUND
(Transações, Procedimentos/Relatórios, Work Panels)
Round(<NExp1>,<NCte>)
Arredonda o valor de <NExp1> para <NCte> casas decimais.

3.45. TRUNC
(Transações, Procedimentos/Relatórios, Work Panels)
Trunc(<NExp1>,<NCte>)
Trunca o valor de <NExp1> para <NCte> decimais.

3.46. VAL
(Transações, Procedimentos/Relatórios, Work Panels)
Val(<CExpression>)
Esta função converte um número de uma expressão caracter para um
valor do tipo numérico. Ela processa os números em uma expressão caracter da
esquerda para a direita até que um caracter não numérico é encontrado.

3.47. COLOR
(Procedimentos/Relatórios, Work Panels)
Color(<GXColor>);
Color(<GXColor>,[<Att1>|&<Var>]) [IF <Cond>];
Permite o uso de cores para os atributos, variáveis e tela.
(Idem a regra COLOR).

3.48. RGB
(Procedimentos/Relatórios, Work Panels)
RGB( <Red>,<Grn>,<Blu>)

43

verde e azul para gerar uma determinada cor. Work Panels) LoadBitmap(< ’FileName’|Att|Var>) Incorpora Bitmaps no design do Form.51. 44 . NULLVALUE (Transações. • Green : Número na faixa de 0 até 255. que representa o componente verde da cor. inclusive. 3. Procedimentos/Relatórios. Work Panels) Nullvalue(<Att | Var>) Retorna um valor nulo do mesmo tipo da definição do Atributo/Variável. A função LoaBitmap é usada para definir qual bitmap será associada a uma variável. que representa o componente azul da cor. Work Panels) Null(<Att | Var>) Retorna um valor Boleano ‘true’ se o valor do atributo ou variável for nulo. 3. Um valor de cor RGB especifica a intensidade relativa de vermelho. inclusive. NULL (Transações. • Blue : Número na faixa de 0 até 255. Procedimentos/Relatórios. O valor nulo para campos do tipo Numérico é zero. dados os 3 seguintes parâmetros: • Red : Número na faixa de 0 até 255.50. e para campos tipo Caracter e Data é uma string em branco. 3.49. Procedimentos/Relatórios. inclusive. LOADBITMAP (Transações. que representa o componente vermelho da cor.Retorna um número representando um valor de cor RGB.

PREVIOUS (Transações) Previous( ) Previous(<Att>) Retorna o valor de <Att> usado na última inserção da transação do programa corrente. Entretanto. ocorreu uma Ação em uma Transação ou toda a transação foi finalizada.53. um certo atributo foi informado.52. o usuário pode forçar que o GeneXus execute uma determinada regra depois que um dos eventos seja mencionado. Este evento pode ser disparado porque a execução de uma Transação passou por um certo Nível. GeneXus automaticamente realiza onde e como uma regra precisa ser executada. OLD (Transações) Old(<Att>) Retorna o último valor armazenado de um dado atributo <Att> 3. o atributo que está sendo assinalado é assumido.54. Se o atributo <Att> não for especificado. AFTER (Transações) After(<Event>) Retorna Verdadeiro ou Falso dependendo de que estágio a transação se encontre.3. <Event> pode ser: Insert Update Delete Confirm 45 . 3. Retorna Verdadeiro se um evento especificado está acontecendo naquele momento na transação. O valor não é armazenado e ele é perdido assim que o usuário deixa a Transação.

Inserção/Alteração/Deleção. caso contrário retorna Falso. 3. 3. 46 . Contudo o usuário pode forçar GeneXus a executar uma dada regra a um Nível especificado da transação. a regra será executada SOMENTE imediatamente após o evento After ocorrer e em nenhum outro lugar. INSERT/UPDATE/DELETE (Transações) Insert Update Delete Retorna Verdadeiro quando a transação está em modo de. GeneXus automaticamente realiza onde e quando uma regra precisa ser executada. respectivamente.55. LEVEL (Transações) Level(<Att>) Retorna Verdadeiro se a execução da Transação está no Nível de um dado Atributo.Trn <Att> Level(<Att>) Nota: Quando for incluída a regra After em uma regra condicional.56.

..AND....... )..... -. =..... • Operadores relacionais . *. ..OR.. .: (...... >=. <=....... Operadores Disponíveis no GeneXus • Operadores aritméticos . <.... ^ • Operadores lógicos .: +.NOT. LIKE 47 . <>............ >...... /....4..: .................

5.5. Nota: Tome cuidado para não alterar o valor de &Line. Formato: DD/MM/AAAA 5. porque senão GeneXus perderá o controle de ejeção. Formato: HH:MM:SS 5. Procedimentos/Relatórios. 5.3.1. TODAY (Transações. Pode ser : ‘SRC’ ou ‘PRN’ 48 . Procedimentos/Relatórios. ou Procedimento. no momento da execução.5. LINE (Procedimentos/Relatórios) A variável &Line contém a linha corrente do Relatório. Variáveis Internas do GeneXus 5. TIME (Transações. PAGE (Procedimentos/Relatórios) Formato : N(4) Contém a página corrente do Relatório. OUTPUT (Procedimentos/Relatórios) A variável de saída contém o código do dispositivo de saída corrente.2.4. Work Panels) Contém a hora do sistema. Work Panels) Contém a data do sistema.

&Pgmname. Procedimentos. Relatórios. Esta descrição é a informada na opção Information. Relatórios.. MODE (Transações) Formato : C(3) Permite determinar o modo válido pelo qual a Transação poderá trabalhar. PGMNAME (Transações. O nome é o especificado na opção Information. Apesar de não estar disponível na lista de variáveis do GeneXus. Parm1. nós podemos incluir o nome do programa na lista de parâmetros para identificar quem está chamando o procedimento.5. Funciona somente se recebido como parâmetro. Tipo é Caracter(30).). Suponha que tenhamos a procedure (‘Pprocess’) que é chamado por vários programas. 5.6. Esta procedure processa as informações conforme o programa chamador. Tipo é caracter(30). . ao você defini-la. Work Panels e Web Panels) Esta variável contém o nome do programa ativo.. 49 . 5. Procedimentos. Se é chamado por vários.8. Work Panels E Web Panels) Esta variável contém a descrição do programa ativo. PGMDESC (Transações.7. independente das características que informar. Exemplo: call(‘Pprocess’. o formato acima sempre prevalecerá. Valores válidos: ‘INS´ para inserir ‘ UPD’ para atualizar ´DEL´ para deletar Nota: O conteúdo de &Mode deve ser letras maiúsculas.

2. TOLLTIP (Tipos de controle: Button. Check Box) Atribui um tip à um controle quando o mouse estiver posicionado sobre o mesmo. Edit.Visible = 1 if RoupaCat <>2.Visible=1). Exemplo: bitmap. Bitmap.tooltiptext=’ informações para teste’ EndEvent 50 . Event start Teste. NOTA: Uma vez que o controle foi assinalado “invisível” (Controle. Para mostrar a foto da roupa dependendo da categoria. os demais geradores vão ignorá-las. deveríamos fazer as regras acima. 1: Verdadeiro -> o controle será visível no form. Exemplo: Assinalando um tip ao botão cujo nome é TESTE.Visible = 0 if RoupaCat = 2. 6. Propriedades do GeneXus Importante: estas propriedades somente são válidas para Visual Basic e Visual Foxpro. Uma string deve ser informada. VISIBLE (Tipos de controle: Todos) Determina qual controle é visível ou escondido. Valores: 0: Falso -> o controle não será visível no form.Visible=0) ele permanece dessa maneira até que você o torne visível novamente (Controle. 6.1.6.

Valores: 1: (Verdadeiro) Permite o objeto responder aos eventos.6. Exemplo: MyTab.5. ACTIVEPAGE (Tipos de controle: Tab) É usada para indicar qual é a página ativa de um tab control.ActivePage = 1 // a primeira página é ativada 51 . Exemplos: 1) EvtBtn. Radio Button) Forms: Determina o texto a ser mostrado como título na barra de títulos do form..Enabled = 0 if . o título do form muda dependendo do modo corrente (ins. 2) Att2. o texto é mostrado abaixo do ícone do Form.4. Text. CAPTION (Tipos de controle: Button. Form.Enabled = 0 if update. Null(Att1). O subfile não pode ser acessado se estiver em modo Update (Dados no subfile não podem ser modificados). Subfile.Caption = ´My Form – Update’ if update. Atributo Att2 não pode ser editado se atributo Att1 não for nulo. Combo Box. Radio Button. Outros controles: Determina o texto a ser mostrado no controle.3. Text) Determina se o controle pode responder aos eventos de usuário. 2: (Falso) Impede o objeto de responder aos eventos.Enabled = 0 if update.not. Edit. Este botão é DESABILITADO se estiver em modo Update. 6. ou alt. Exemplo: Form. 6.). ENABLE (Tipos de controle: Button.Caption = ´My Form – Insert’ if insert. Frame. Neste exemplo. Frame. Check Box. Esta será “visível” para o usuário.Caption = ´My Form – Delete’ if delete. Quando o form é minimizado. del. Form. 3) subfile.

devemos fazer: EditCrtl.ActivePage + 1 ELSE Btn_Next.255) 6. NOTA: esta propriedade não é implementada no gerador Visual Basic 4.6. LEFT (Tipos de controle: Todos) Determina a distância interna (em pixels) entre o canto superior/esquerdo do controle e o canto superior/esquerdo de quem contém (Frame ou Screen). Um valor numérico representando um ‘RGB color value’ deve ser assinalado.0) Exemplo: Para que a cor de frente de um controle de edição seja azul.ActivePage = MyTab.8. devemos fazer: EditCrtl. Exemplo: Form. TOP. PAGECOUNT (Tipos de controle: Tab) É usada para obter o número de páginas de um tab control.Forecolor = RGB(0. É normalmente usada junto com a propriedade ActivePage.ActivePage < MyTab. Exemplo: Para que a cor de fundo de um controle de edição seja verde. BACKCOLOR. 52 .ActivePage = Mytab.0 6.Top = 500.MyTab.PageCount MyTab.0 6.Caption = “Finish” ENDIF NOTA: esta propriedade não é implementada no gerador Visual Basic 4.Activepage + 1 // move para a próxima página. Form.255.Backcolor = RGB(0. Exemplo: IF MyTab.7.0. FORECOLOR (Tipos de controle: Todos) Determina as cores de fundo e frente respectivamente de um controle.Left = 600.

Valores: 0 Solid 1 Transparente 2 Linha Horizontal 3 Linha Vertical 4 Upward Diagonal 5 Downward Diagonal 6 Cruzado 7 Cruzado em Diagonal Exemplo: textframe.FillColor = rgb(255. O ‘Fill check box’ no diálogo de propriedades do controle retângulo também deve ser assinalado.10. DEFAULT (Tipos de controle: Botão) 53 . Neste exemplo o retângulo cujo nome nome é “textframe” será exibido assim: TEXTO 6. FILLCOLOR (Tipos de controle: Retângulo) Determina a cor usada para preenchimento do retângulo.11. FILLSTYLE (Tipos de controle: Retângulo) Determina a ‘sombra’ utilizada para preenchimento do retângulo.0). 6. 6.FillStyle = 2.9. Exemplo: textframe.Neste exemplo o form do objeto será mostrado 500 pixels abaixo do topo da página e 600 pixels à esquerda na execução.255. Um valor numérico representado um ‘RGB color value’ deve ser assinalado.

fontName = ‘Times New Roman’ Onde EvtBtn é o nome do controle de um botão. Check box. BITMAP (Tipos de controle: Botão e Bitmap) É usada para mostrar o bitmap assinalado no path.bmp’.12. Exemplos: 1) EventBtn. BACKSTYLE (Tipos de controle: Texto) Determina se um rótulo ou fundo de um objeto é transparente ou opaco. Valores: 0: Transparente – cor de fundo e qualquer gráfico são visíveis atrás do controle. 6.bmp será mostrado sobre o botão “EventBtn”.13.É utilizado para especificar qual é o botão de comando default. Subfile. 54 . Nestes exemplo o bitmap gravado em c:\mypath\mypict. EventBtn. Quando um botão de comando é setado como verdadeiro.Bitmap = loadbitmap(‘c:\mypath\mypict. Edit. 1: Opaco (Default) – a cor de fundo do controle preenche o controle e oculta qualquer cor ou gráfico atrás dele.14. Você deve assinalar uma expressão tipo string especificando o fontname a ser usado. Radio Button. Valores: 0: Falso 1: Verdadeiro Somente um botão de comando no form pode ser default. Exemplo: EvtBtn.bmp’) 2) &bmp = ‘c:\mypath\mypict. Combo Box. Dynamic Combo Box. FONTNAME (Tipos de controle: Button. 6.Bitmap = loadbitmap(&bmp). Column) Determina a fonte usada para mostrar o texto num controle. automaticamente todos os demais botões no form serão setados como Falso. 6.

FONTITALIC. Valores: 1: (Verdadeiro) Ativa a formatação no estilo escolhido.15. Um valor numérico deve ser assinalado. você deve mudar FontName antes de setar o tamanho e estilo dos atributos com as propriedades FontSize.17.Em geral.16. FONTSTRIKETHRU (Tipos de controle: Button. Edit. FontBold. Text) Determina a largura e altura respectivamente do controle. Exemplo: EvtBtn. FontStrikethru. Check Box. 55 . Check Box. Combo Box. FontBold. combo Box. Dynamic Combo Box. FontUnderline. 2: (Falso) Desativa a formatação no estilo escolhido. WIDTH. FONTBOLD. Edit. Column) Determina o estilo da fonte nos seguintes formatos: FontItalic. FONTUNDERLINE. HEIGHT (Tipos de controle: Button. FontStrikethru e FontUnderline. Check Box. FONTSIZE (Tipos de controle: Button. Frame. FontItalic. Radio Button. Exemplo: subcol1. Combo Box. Dynamic Combo Box. 6. Dynamic Combo Box. Edit. Subfile. Radio Button.fontSize = 20 Onde EvtBtn é o nome de um controle botão e 20 é o tamanho utilizado para a font default (ou para a fonte setada na propriedade FontName). Subfile. Column) Determina o tamanho da fonte a ser usado para mostrar o texto no controle.FontItalic = 1 (onde subcoll é o nome de uma coluna do subfile) 6. 6. NOTA: A unidade de escala para medir largura e altura em Visual Basic é TWIPS (aproximadamente 1/15 pixel) que é a unidade padrão do VB. Radio Button. Subfile.

2: Maximizado (aumenta para o estado máximo). 6. 1: Verdadeiro.20. 6. Neste exemplo o form será maximizado (embora o usuário possa manualmente mudar o tamanho do form durante a execução) 6.19. 1: Minimizado (diminui para um ícone).Em versões futuras deste gerador. LINESELECTOR (Tipos de controle: Subfile) Esta propriedade indica se o subfile possui a borda esquerda.Title = ‘Descrição’. Valores: 0: Falso. 56 .Height = 200 A dimensão deste controle tipo bitmap será 200 x 200 unidades. O subfile terá a borda esquerda. WINDOWSTATE (Tipos de controle: Frame) Determina o estado visual de um form em tempo de execução. a unidade de escala será pixels. Uma string de caracteres deve ser informada. Exemplo: subfcol1. O subfile NÃO terá a borda esquerda. Exemplo: foto.18. Exemplo: Form. Valores: 0: Normal. TITLE (Tipos de controle: Column) Determina o título das colunas do subfile em tempo de execução. A unidade de escala para medir largura e altura em Visual FoxPro é pixels.Width = 200 (foto é um controle tipo bitmap) Foto.WindowState = 2.

subfale. todas as alterações no subfile são executadas antes (nome das colunas. subfile.TitleBackColor = rgb(0 .TitleForeColor = rgb(0 .21. Valores: 1: Verdadeiro. Uma string de caracteres deve ser informada.FontItalic = 1. Isto é feito somente para melhorar performance. fontes.Title = ‘Name’. O subfile não será redesenhado. 6. Isto mudará a cor de fundo do título da coluna para verde. Exemplo: subfcol1. Esta propriedade é muito útil quando você precisa checar a identificação do controle. subfcol2. do título de uma coluna do subfile. TITLEFORECOLOR.23. TAG (Tipos de controle: Todos) Esta propriedade é usada para assinalar uma string de identificação ao controle (sem afetar nenhuma das outras propriedades setadas).0 ).FontName = ‘Small Fonts’.Redraw = 0.Redraw = 1. Isto mudará a cor de frente do título da coluna para verde. O subfile será redesenhado. Exemplo: subfile.Title = ‘Address’. Neste exemplo. subfcol1.255 .255 . 6. etc) e então o subfile é redesenhado. Um valor numérico representando uma ‘RGB color value’ deve ser informado.22. REDRAW (Tipos de controle: Subfile) Esta propriedade indica se o subfile será redesenhado. 2: Falso. 57 . Exemplo: subfcol1. TITLEBACKCOLOR (Tipos de controle: Column) Determina a cor de frente e de fundo respectivamente.6.0). subfcol2.

7. o evento DblClick ocorre quando o usuário dá um duplo clique sobre um controle desabilitado ou uma área em branco do Form. 7. uma Work panel. Exemplo: subfile. que mostra as informações do cliente. Para um Form.BorderStyle = 0. Para um controle. Combo Box.tag = “associated text” 6. DBCLICK (Tipos de controle: Bitmap. 3: Fixed Double (Borda 3D e sem alteração de tamanho).DblClick Call(wShowcli. Radio Button.1. CLICK (Tipos de controle: Bitmap. Valores: 0: None (Sem borda) 1: Fixed Single (borda simples e sem alteração de tamanho).Exemplo: CrtlName. isto ocorre quando o usuário dá um duplo clique sobre um controle com o botão esquerdo do mouse. Text. Text. Column. CliCode) Endevent Neste exemplo quando o usuário clicar duplamente sobre o bitmap que contém a foto do cliente. Edit) 58 . Neste exemplo o subfile não terá borda. Edit) Ocorre quando o usuário pressiona o botão esquerdo do mouse duas vezes sobre um mesmo controle. BORDERSTYLE (Tipos de controle: Subfile) Determina o estilo de borda de um subfile. 2: Sizable (Este é o valor default). Exemplo: Event foto. Dynamic Combo Box. Eventos de Controle 7.24.2. é chamada. Check Box.

outra transação para digitar as informações da cliente é chamada se o código do cliente digitado for válido. Exemplo: Event CliCode.. 7.. Exemplo: Event text. Exemplo: Event CliCode..’) Endevent Neste exemplo uma mensagem será exibida quando o usuário clicar sobre o controle tipo texto chamado “text”. value range: 1-100’) Endevent Neste exemplo o botão direito é usado para mostrar um texto explicativo.Click Msg(‘Explained text: ..3... Combo Box. 7.4. RIGHTBUTTON (Tipos de controle: Edit) Ocorre quando o botão da direita do mouse é pressionado sobre o controle. Check Box. ISVALID (Tipos de controle: Radio Button.. Dynamic Combo Box.CliCode) EndEvent Neste exemplo quando o usuário informar o código do cliente. Edit) Ocorre quando a entrada do campo é válida.RightButton Msg(‘Enter client code... 59 ...Ocorre quando o usuário clica o botão esquerdo do mouse sobre o controle.IsValid Call(TclientInfo..

os demais geradores irão ignorá-los.Setfocus() EndEvent Suponha que tenhamos um botão no Form que chama um procedimento para obter o nome do cliente indicado no código e nós queremos direcionar a entrada de dados (posicionar o cursor) no atributo SupCode depois do call. por exemplo cor. Button. Dynamic Combo Box.1. CliCode. fonte. 8. Retângulo) Este método muda as propriedades do controle.3. Radio Button.8. CLEAR. Subfile.Repaint( ) 8. Radio Button. PoNbr. etc. Frame) Direciona a entrada de dados a um controle específico. CliName) SupCod. e você quer mostrar as mudanças. Exemplo: Event ‘GetClient’ Call( PgetCli. REPAINT (Tipos de controle: Edit. como mostrado acima.2. Combo Box. tamanho. ADDITEM (Tipos de controle: Combo Box e Dynamic Combo Box) 60 . Check Box.FontBold = 1 PoNbr. Check Box. Isto pode ser feito usando o método setfocus com o atributo SupCode dentro do evento associado ao botão. Dynamic Combo Box. Exemplo: Este método é usado para ‘repintar’ o controle se qualquer das suas propriedades foi modificada. SETFOCUS (Tipos de controle: Edit. com exceção do Método SetFocus que foi implementado em todos os geradores. Text. Combo Box. Métodos Importante: MÉTODOS somente funcionam em Visual Basic e Visual Foxpro. 8.

o primeiro item será ‘All’ . de um combo Box ou Dynamic Combo Box.Clear: Apaga todos os itens de um Combo Box ou Dynamic Combo Box.índice]) ‘índice é opcional e representa a posição onde o item é inserido.removeitem(code) Remove o primeiro ‘code’ que for encontrado. descrição[ . Deve ser utilizado dentro do evento Load como no exemplo: Event Load For each InvCode &InvCode = InvCode &InvDat = InvDate &Type = “INV” 61 . Sintaxe: controle. AddItem: Adiciona um novo ítem no fim de um Combo Box ou Dynamic Combo Box.CountryName) EndFor 8.4.additem(código. Se nenhum índice é especificado o ítem é adicionado no fim. REMOVEITEM (Tipos de controle: Combo Box e Dynamic Combo Box) Apaga o item.clear( ) &Var. cujo código é indicado pelo ‘código’. Exemplo: Vamos apagar o conteúdo de um Combo Box antes de adicionar novos itens da tabela e carregá-lo com todos os países do continente Americano. &Var. ‘All’) for each Where continentCod = ‘AME’ &Var.5. Sintaxe: control. Este método é o mesmo que o comando Load. LOAD (Tipos de controle: Subfile) Carrega uma nova linha ao subfile de Work Panels e Web Panels.additem(0.additem(CountryCod. 8.

. Neste caso você especifica para qual subfile a linha deve ser carregada. sem a criação de um índice temporário.7. sfl_1...Load( ) 8.Load( ) or sfl_2. REFRESH (Tipos de controle: Frame e Subfile) Atualiza os valores no subfile ou form. se não existir nenhum índice ordenado pelo atributo escolhido (esta é a diferença entre o método SORT e a regra ORDER) 8. NOTA: Este método não está implementado em Visual Foxpro.8. Exemplo: Event ‘Print’ Form. PRINTFORM (Tipos de controle: Frame) Imprime a janela da Work Panel ou transação na impressora default.printform( ) EndEvent Este evento pode ser associado a um botão e imprime a janela corrente..6.Load( ) Endfor EndEvent Este método é muito útil quando você tem mais de um subfile no form (esta feature será liberada em versões futuras). SORT (Tipos de controle: Subfile) Ordena o subfile pelo atributo especificado.. Exemplo: sfl_1. 62 . 8.Sort(PrdName) Onde: PrdName é um atributo do subfile. sfl_1. O subfile será ordenado então por PrdName.

63 . mas pode ser alterado para qualquer valor entre 4 e 30. mas é possível mudar estes controles.Refresh( ) or sfl_2. No canto superior esquerdo do editor de propriedades. NOTA: Sempre use o botão para assinalar o valor default. NOTA: • Valores maiores que 18 somente são suportados pelo gerador RPG. em outras palavras. Esta preferência é usada para especificar o tamanho máximo de um campo numérico.Refresh( ) Também pode ser utilizado para atualizar valores de qualquer atributo. são válidas para todos os modelos. Propriedades do Modelo Principal 9. tornando o trabalho em diferentes plataformas viável à partir de uma única definição. PREFERÊNCIAS Estas preferências são definidas para a Base de Conhecimento. GeneXus controla a maioria das suas limitações. não tecle o caractere ‘*’. há 3 botões usados para salvar ou cancelar as modificações e assinalar o valor default. Neste caso você pode especificar qual subfile você quer realizar o refresh: Sfl_1.1. 9. e selecione a opção desejada no Combo Box no topo da tela. MAXIMUN NUMERIC LENGHT Por default.Este método é muito útil se você tem mais de um subfile no form (esta feature será liberada em versões futuras). Valores: O valor default desta preferência é 18. Modo de uso: Posicione o cursor sobre a propriedade que você deseja editar.

Assim. Esta preferência somente é válida quando os objetos são salvados. Esta preferência é definida na Base de Conhecimento (design) mas. é recomendável verificar se o novo valor é correto. cada modelo pode ter um valor diferente para a mesma. você poderá salvar um objeto que utilize uma função não standard se esta preferência no modelo de design estiver setada como “Allow standard functions only”.• Atributos e variáveis não são verificados quando este valor é modificado para um valor menor que 18. • Allows non-standard functionsnon saving: (Permite funções nãostandard) Funções são documentadas pelo GeneXus podem ser utilizadas. FUNCTIONS Esta preferência é usada quando você deseja utilizar funções que não são explicitamente suportadas pelo GeneXus. Também controla o tamanho dos atributos/variáveis do tipo Date Time. Valores: • Allows standard functions only on saving: (Permite somente funções standard) Somente funções standard suportadas pelo GeneXus podem ser utilizadas. TIME FORMAT Controla o formato no qual a parte das horas dos atributos tipo Date Time são pedidos e mostrados (tanto na tela quanto na impressão). (Essa preferência nos modelos de prototipação e produção será validada na especificação). Valor default: Allows standard functions only on saving. assim. Valores: • Language dependent: depende da linguagem selecionada de acordo com a tabela seguinte: Linguagem Formato da Hora Inglês 12 horas Espanhol 24 horas Português 24 horas 64 .

Há 2 tipos de geradores pré-definidos: Default (usado como default na geração dos programas) e Reorg (usado para reorganização das base de dados) cujos nomes não podem ser mudados. os campos terão 3 caracteres a mais (tela ou impressora) correspondendo às strings ‘AM’ ou ‘PM’. Escolha o botão New Type para adicionar um tipo novo.Italiano 24 horas • Valor default: depende da linguagem. A lista do lado direito é específica para cada modelo. RPG. com os botões de Add e Remove você pode selecionar quais forms irá utilizar no modelo corrente. você deve definir um nome para o novo tipo de gerador. MODEL FORMS Você pode definir mais de uma tela para projetos que utilizem forms (Transação/Work Panels). de acordo com a linguagem selecionada.3. A lista do lado esquerdo inclui todas as forms classes existentes na Base de Conhecimento. Estas não podem ser apagadas ou renomeadas. Cada modelo tem uma lista de Form Classes válidas. 9. Há duas forms classes pré-definidas: G – Gráfica e T – Texto. Na especificação você pode escolher um dos forms definidos. 9. dependendo do modelo. 65 . Todos os tipos de geradores definidos aqui irão aparecer na lista de geradores possíveis (Generators Tab) em cada modelo da Base de Conhecimento.2.). Então em cada modelo você assinalará um gerador em particular (ex. Tecle o botão Delete Type para apagar o tipo de gerador selecionado. GERADORES Neste diálogo você pode definir todos os tipos de geradores que você usará nos modelos para gerar seus programas. NOTA: Se o uso do formato 12 Horas é especificado ou inferido.: Visual Basic. Se o tipo de gerador selecionado estiver sendo usado em qualquer modelo você não será capaz de apagá-lo (uma mensagem de erro será mostrada). etc.

a cor especificada aqui terá preferência sobre qualquer cor especificada para este atributo em qualquer form. PROMPTS Aqui você pode setar as opções de prompts para o modelo principal (Design). as opções especificadas aqui podem ser utilizadas nos outros modelos. Se você escolher esta opção. você poderá especificar um efeito par aos prompts no modelo corrente.4. o que foi setado no modelo de design será utilizado no modelo corrente. Se você selecionar Design Model Settings. • Colored Prompt: O atributo aparecerá com uma cor diferente. nenhum efeito especial será usado. a cor especificada aqui terá preferência sobre qualquer cor especificada para este atributo em qualquer form. Se você escolher esta opção. • Button Prompt: O atributo aparecerá com uma seta para cima ao lado do mesmo. deverão aparecer nos Forms. 66 . • Colored Prompt: O atributo aparecerá com uma cor diferente. Se você selecionar botão Default Settings. • Button Prompt: O atributo aparecerá com uma seta para cima ao lado do mesmo. Aqui você indicará como os atributos para os quais GeneXus gera prompts. Selecionando o botão Design Model Settings.9. Outros Modelos Você pode setar a opção de prompt. A opção especificada aqui somente terá validade para os atributos definidos como EDIT.

...... ........... Esta propriedade faz sentido em Transações e Procedures que alteram a bse de dados e são chamados por outros programas. . CALL Tfunção ...............10............. o programa chamador (ou programa chamador do chamador) é responsável pelo commit ou rollback da LW (Logical Work Unit)....1......................... um CALL para a segunda TRN..... .. nós colocamos no final da primeira transação... não ao objeto GeneXus).. O valor default depende do gerador selecionado.... Neste caso............... TRN: Funcionário TRN: Função ............. Work Panels.... TRANSACTION INTEGRITY – INTEGRIDADE TRANSACIONAL COMMIT ON EXIT Programas gerados pelo GeneXus executam commits no fim de cada transação (referenciando-se ao conceito database transaction................... Commit 67 .............. Propriedades das Transações 10..... Muitos dados devem ser digitados na Transação de cadastramento de funcionário..... Para ter as duas transações funcionando em conjunto............ • NO – o programa gerado não executa um commit no fim da LWU...... Valores: • YES – o programa gerado executa um commit no fim da LWU...................... Exemplo: Você pode encontrar a situação de ter que dividir uma transação em duas.......... assim necessitamos dividir a mesma em duas: dados do empregado e dados da função...... . Este commit automático é incluído em todos os programas que atualizam base de dados......... Um exemplo típico é descrito no exemplo que segue.. Web Panels e procedimentos que não atualizam base de dados..... Esta propriedade é usada para controlar ou não se o commmit automático é realizado. .. Não é incluído em Reports..

para fazer isso é necessário: • A primeira transação deve ter uma CALL chamando a segunda. No caso de qualquer uma delas existir. O valor default depende do gerador. NOTA: .Também será ignorada se o controle da integridade transacional for desabilitada nas propriedades do modelo – Transactional Integrity = NO. Neste caso. o usuário pode confirmar (COMMIT) ou não (ROLLBACK) as alterações feitas na base de dados durante a LWU. . nós iremos imediatamente dar entrada nos dados da segunda TRN. NOTA: • É válido somente em transações que não possuam nem a propriedade “Commit on Exit = YES” nem “Commitment = Disabled”.É válido somente em transações que não tenham a propriedade do AS/400 – Commitment = Disabled – neste caso a propriedade será ignorada. • NO – Nenhuma confirmação da LWU é pedida e automaticamente é executado o comando COMMIT. CONFIRM TRANSACTION Força a confirmação da transação permitindo COMMIT ou ROLLBACK. Valores: • YES – Força uma confirmação a nível de LWU (Unidade Lógica de Trabalho) ou transação. Esta propriedade somente aparecerá se o gerador que você estiver usando permitir este tipo de controle. • Remover o COMMIT da segunda TRN usando a propriedade – Commit on Exit = NO – para que o COMMMIT da primeira TRN faça o COMMMIT em ambas como um todo após o retorno do CALL. a propriedade “Confirm Transactions = YES” será ignorada. (Foxpro for Windows não mostrará esta opção). 68 .Commit on Exit = YES Commit on Exit = NO O que mostra o exemplo acima é que uma vez dado entrada nos dados na primeira transação. antes que o commit seja executado. Mas nós queremos unificar as duas TRNs para que formem uma única LWU (Unidade Lógica de Trabalho).

2. 10.• Também será ignorada se o controle da integridade transacional for desabilitado nas propriedades do modelo – “Transactional Integrity = NO”. WINDOWS INTERFACE • MenuBar Esta propriedade é usada para associar um menubar a um objeto. então um menubar default será utilizado. Em outras palavras. • Never prompt: nenhuma confirmação é pedida em nenhum nível da transação. Válida somente para os geradores: Visual Basic e Visual Foxpro. Se um objeto não tiver um menubar associado. O valor default depende do gerador selecionado. o objeto usará o menubar indicado nesta propriedade. Valores: • Always prompt: mostrará uma mensagem e pedirá confirmação das alterações em todos os níveis. com exceção do primeiro nível. NOTA: A regra Noconfirm(<Atributo>) permite a você indicar um nível específico que não deve ser pedido confirmação. • Border Style Esta propriedade especifica o tipo da borda do form. Ao passar de um nível para o próximo. uma mensagem é mostrada e o usuário deve confirmar a entrada de dados. 69 . • Do not prompt on first level: pedirá confirmação em todos os níveis da transação. O Combo mostrará todos os menubars existentes. Esta propriedade é válida somente para Transações e Work Panels. USER INTERFACE – INTERFACE COM USUÁRIO CONFIRMATION Indica se o usuário deseja ou não que a confirmação seja pedida ao passar de um nível para outro.

Fixed Dialog: a janela terá borda 3D e seu tamanho não poderá ser mudado.YES: o form terá botão de minimização . O valor default é Sizeable. .NO: o form não terá botão de minimização O valor default é YES.None: a janela não terá borda nem título. você deve informar o nome do ícone.YES: o form terá botão de maximização .Sizeable: este é o tipo normal de borda.Valores: . Valores: Não possui nenhum valor pré-definido. Valores: . Válido somente para geradores: Visual Basic e Visual Foxpro. . • Minimize Button Especifica se o form deve ter um botão de minimização. Válido somente para geradores: Visual Basic e Visual Foxpro.Fixed Single: a janela terá borda simples e seu tamanho não poderá ser mudado. que é: 3D e você pode mudar o tamanho da janela com o mouse.NO: o form não terá botão de maximização O valor default é YES. • Control Box Esta propriedade é usada para especificar se o menu no canto superior esquerdo da janela será ativado com um click do mouse. Válido somente para geradores: Visual Basic e Visual Foxpro. • Maximize Button Especifica se o form deve ter um botão de maximização. . Valores: . 70 . • Form Icon Esta propriedade é utilizada para especificar um nome para o ícone do form.

NO: A janela é mostrada totalmente como poup-up. if parameters specified. • Modal Dialog Esta propriedade é usada para indicar se o objeto utiliza diálogo Modal ou não. Valores: .NO: o menu não será ativado com um click do mouse. . parte das duas janelas podem ser vistas simultaneamente.YES. Ao contrário. se não houver parâmetros então o diálogo Não-modal será usado. Diálogo Modal significa que o programa chamador ficará inativo até que o objeto chamado seja fechado. automatic border: O form será gerado como janela popup e a borda será desenhada de forma automática. if parameters specified: Se o objeto tem parâmetros então o diálogo Modal será usado. quer dizer. .YES: o menu será ativado com um click do mouse. Valores: .Valores: . quando são passados parâmetros e o objeto chamado retorna valores ao objeto chamador. onde a transação espera valores retornados pelo prompt. Diálogo Não-Modal é sempre melhor que diálogo modal. O valor default é YES. 71 . Neste caso. . Em particular. então o diálogo Modal deve ser usado. O valor default é: YES.NO: Diálogo Não-Modal é utilizado. você pode trabalhar com ambos simultaneamente. Os prompts são um exemplo típico desse tipo de diálogo. o diálogo Não-Modal ambos os objetos ficam ativos ao mesmo tempo. . mas nem sempre é possível utilizá-lo.YES: Diálogo Modal é utilizado. CHARACTER INTERFACE – INTERFACE DE CARACTERES • Generate as a Popup Window Esta propriedade é usada para indicar que o form deve ser carregado como uma janela de Poupup (sobrepor a janela anterior ao invés de substituí-la).YES.

No display: Não mostrar. há algumas limitações de linhas e colunas que devem ser respeitados.Branco . 72 . uma mensagem é dada dentro do relatório de navegação na especificação.Blinking: Piscando .YES. . esta é a cor no GeneXus. esta é a cor no GeneXus. NOTA: Quando a tela é definida como popup. IMPORTANTE: Esta propriedade não é válida para geração em ambiente windows. - • Automatic Border – Color Esta propriedade é usada para controlar a cor da borda da janela dos objetos definidos como janelas popup no AS/400. . No AS/400 é convertido para Pink (rosa).Azul .Cinza. user defined border: O form será gerado como janela popup e a borda pode ser desenhada pelo usuário no form.Vermelho . O default é: Default to color rule. Este valor só é válido para geradores de interface gráfica. VERDE é utilizado. • Automatic Border – Display Attribute Esta propriedade é usada para definir como deve ser mostrado o atributo dos objetos definidos como janelas popup no AS/400. .High: Mostrar mais forte (negrito) .Magenta. O valor default depende do gerador selecionado. Caso contrário.Default to color rule: Segue a cor da regra color se a mesma existir. Se a tela desenhada ultrapassa esses limites.Verde .Reverse Image: Imagem reversa .Default to color rule: Segue a cor da regra color se a mesma existir. Valores: . No AS/400 é convertido para Turquesa. O valor default é: Default to color rule.Amarelo . Valores: .

AS/400 SPECIFIC – ESPECIFICAÇÕES AS/400 COMMITMENT Habilita e desabilita o controle da integridade transacional nos programas gerados.3.Enabled: O programa é gerado COM os controles de integridade transacional. Cada caracter é usado para desenhar (em ordem): Caracter Desenha 1 topo-esquerdo-canto 2 topo-borda 3 toopo-direito-canto 4 esquerda-borda 5 direita-borda 6 Botão-esquerdo-canto 7 Botão-borda 8 Bptão-dirieito-canto Estes caracteres são enviados diretamente à palavra chave WDWBORDER da DDS language para telas. procure no manual de referência da DDS. Para obter informações adicionais sobre esta palavra chave. NOTA: Não use o caracter ‘ (apóstrofo) nesta propriedade. os atributos de tela dependerão dos valores default do AS/400. 73 . .• Automatic Border – Characters Esta propriedade é usada para definir os caracteres a serem usados para cada um dos cantos e lados da janela do objeto definido como janela popup no AS/400.Disabled: O programa é gerado SEM os controles de integridade transacional. Valores: . 10. Isto é. Não há valor default para esta preferência. Deve ter exatamente 8 caracteres. se nenhum valor for especificado na preferência. O valor default depende do gerador selecionado.

O valor default é 5. não será possível alterar para Modo de Inserção na transação. • Prompt Key Esta propriedade é usada para alterar a chave de função relacionada ao Prompt. o gerador ignora-o. Esta propriedade aplica-se somente ao objeto.NOTA: Esta opção é ignorada para Client Server (geradores DB/2 e Oracle). • Insert Mode Esta propriedade é usada para alterar a chave de função relacionada ao Insert Mode. • Refresh Key Esta propriedade é usada para alterar a chave de função relacionada ao Refresh. Esses DBMs não permitem a desativação da integridade transacional. O valor default é 4. neste caso. Valores: Qualquer número de chave de função válida. Esta propriedade aplica-se somente ao objeto. Se for desabilitada. Valores: Qualquer número de chave de função válida. KEY ASSIGNMENT • Exit Key Esta propriedade é usada para alterar a chave de função relacionada ao Exit. Esta função pode inclusive ser desabilitada assinalando-se à mesma o valor default ‘0’. Esta função pode inclusive ser desabilitada assinalando-se à mesma o valor ‘0’. Valores: Qualquer número de chave de função válida. O valor default é 3. O código para inserção de registros é gerado. 74 . NOTA: Apesar de aceitar 1 como valor válido. o programa não responde às prompts key e os programas de prompt não serão gerados.

• Retrieve Esta propriedade é usada para alterar a chave de função relacionada ao Retrieve. • Next Record Esta propriedade é usada para alterar a chave de função relacionada ao Next Record. Valores: Qualquer número de chave de função válida. Esta função pode inclusive ser desabilitada assinalando-se à mesma o valor default ‘0’. O valor default é 7. 75 . Esta função pode inclusive ser desabilitada assinalando-se à mesma o valor default ‘0’. Esta propriedade aplica-se somente ao objeto. não será possível mover-se ao próximo registro e o código correspondente não é gerado. neste caso. neste caso. não será possível mover-se ao registro anterior e o código correspondente não é gerado. • Previous Record Esta propriedade é usada para alterar a chave de função relacionada ao Previous Record. Retrieve não pode ser desabilitada porque aplica-se somente em Menus. Esta propriedade aplica-se somente ao objeto. neste caso. O valor default é 8.Valores: Qualquer número de chave de função válida. O valor default é 6. Valores: Qualquer número de chave de função válida. Esta função pode inclusive ser desabilitada assinalando-se à mesma o valor default ‘0’. não será possível acessar o menu bar e o código correspondente não é gerado. Esta propriedade aplica-se somente ao objeto. • Menu Esta propriedade é usada para alterar a chave de função relacionada ao acesso ao Menu Bar. Valores: Qualquer número de chave de função válida. Valores: Qualquer número de chave de função válida. Esta propriedade aplica-se somente ao objeto. O valor default é 9.

Esta função pode inclusive ser desabilitada assinalando-se à mesma o valor default ‘0’. O valor default é 11. Valores: Qualquer número de chave de função válida. Esta propriedade aplica-se somente ao objeto. neste caso.O valor default é 10. não será possível alterar o modo para Deleção na transação e o código de alteração é gerado. o programa não responderá à chave de autoprompt e o código de Autoprompt não é gerado. O valor default é 12. O valor default é 16. • Update Mode Esta propriedade é usada para alterar a chave de função relacionada ao Modo de Update. Valores: Qualquer número de chave de função válida. 76 . Esta função pode inclusive ser desabilitada assinalando-se à mesma o valor ‘0’. Esta propriedade aplica-se somente ao objeto. Esta propriedade aplica-se somente ao objeto. Valores: Qualquer número de chave de função válida. neste caso. não será possível alterar para Update na transação e o código de alteração é gerado. Valores: Qualquer número de chave de função válida. • Select Esta propriedade é usada para alterar a chave de função relacionada ao Select. Esta função pode inclusive ser desabilitada assinalando-se à mesma o valor default ‘O’. • Cancel Esta propriedade é usada para alterar a chave de função relacionada ao Cancel. • Delete Mode Esta propriedade é usada para alterar a chave de função relacionada ao Modo Delete. O valor default é 13. neste caso.

não será possível acessar o primeiro registro e o código correspondente não é gerado. • Display Mode Esta propriedade é usada para alterar a chave de função relacionada ao Modo de Display. Valores: Qualquer número de chave de função válida. neste caso. Esta função pode inclusive ser desabilitada assinalando-se à mesma o valor default ‘0’. O valor default é 19. neste caso. O valor default é 14. Esta função pode inclusive ser desabilitada assinalando-se à mesma o valor default ‘0’. Valores: Qualquer número de chave de função válida. Esta propriedade aplica-se somente ao objeto. Valores: Qualquer número de chave de função válida.• First Record Esta propriedade é usada para alterar a chave de função relacionada ao First Record. Esta propriedade aplica-se somente ao objeto. não será possível alterar para modo de Display na transação e o código correspondente é gerado. 77 . O valor default é 24. • More Keys Esta propriedade é usada para alterar a chave de função relacionada ao More Keys.

Isto é feito para ganhar performance. . Valores: . 78 .NO – o subfile é carregado após pedir a parte fixa da tela. Esta propriedade indica que nós não desejamos que o subfile seja carregado logo no início. O valor default depende do gerador selecionado.1. então outras telas são carregadas.Load all records – carrega todos os registros no subfile no Evento Load. Valores: . nós queremos que a parte fixa da tela seja pedida antes (normalmente usadas nas conditions) e então carregar o subfile. conforme o usuário avança. LOAD AT STARTUP Indica se o subfile é carregado logo no início ou após pedir a parte fixa do form.YES – o subfile é carregado imediatamente após a carga da tela.11. somente a primeira tela é carregada e. . nós poderemos necessitar carregar o subfile inteiro de uma vez. LOADING LOAD RECORDS Indica como os registros são carregados no subfile. Para fazer isto. Quando a Work Panel tem um subfile. Propriedades das Work Panel incluem duas principais características: funções enquanto estiver fazendo a carga e como será a interface.Load on request – carrega os registros na tela de subfile cada vez que dados são requeridos. ao invés disso. o subfile é carregado pela primeira vez imediatamente após a tela ser carregada. Inicialmente. Mas em alguns casos. Esta propriedade indica que o subfile será carregado por inteiro de uma única vez. Normalmente. Propriedades das Work Panels Propriedades permitem definir funções gerais para o objeto. o subfile é carregado mediante uma requisição explícita. devemos setar a propriedade Load Records como ‘Load All Records’. 11.

essa propriedade não tem efeito. 79 . e o subfile é carregado após pedir a parte fixa ser pedida. ALLOW USER TO CANCEL WHILE LOADING Permite ou inibe o usuário de cancelar a execução do programa enquanto estiver sendo feita a carga do subfile. .YES – o programa pode ser cancelado pressionando ESC enquanto estiver sendo feita a carga do subfile. O valor default depende do gerador selecionado. REFRESH TIMEOUT (Foxpro for Windows e Visual Basic) Esta propriedade é usada para executar um refresh do subfile sem que o usuário execute nenhuma opção durante certo período de tempo. Valores: Não há valores pré-definidos. Se esta propriedade for setada como YES. O valor default depende do gerador selecionado. Valores: . Este intervalo de tempo deve ser especificado em segundos. Se 0 ou default são especificados nenhum timeout será gerado. Um valor em segundos deve ser especificado.When any variable change: o refresh é executado cada vez que qualquer variável da parte fixa da tela é modificado. RESTRIÇÕES: Quando não há Tabela Base associada à Work Panel.O valor default depende do gerador selecionado. AUTOMATIC REFRESH Esta propriedade é muito utilizada quando o subfile é composto somente por variáveis e você deseja executar um refresh cada vez que houver uma mudança na parte fixa da Work Panel. .Only when variables in conditions change: a work panel trabalha da forma tradicioanl. a Work Panel poderá ser cancelada com ESC.NO – o programa não pode ser cancelado enquanto estiver sendo feita a carga do subfile. Valores: .

. Válida somente para os geradores: Visual Basic e Visual Foxpro.None: a janela não terá borda nem título.Sizeable: este é o tipo normal de borda. BORDER STYLE Esta propriedade especifica o tipo da borda do form. Valores: . 80 .Fixed Dialog: a janela terá borda 3D e seu tamanho não poderá ser mudado. que é 3D e você pode mudar o tamanho da janela com o mouse.2. Esta propriedade somente é válida para transações e work panels. Valores: . O combo mostrará todos os menubars existentes. . O valor default é Sizeable. Válido somente para geradores: Visual Basic e Visual Foxpro. Se um objeto não tiver um menubar associado então um menubar default será utilizado.11. .YES: o form terá botão de maximização . Em outras palavras. WINDOWS INTERFACE MENUBAR Esta propriedade é usada para associar um menubar a um objeto. MAXIMIZE BUTTON Especifica se o form deve ter um botão de maximização. o objeto usará o menubar indicado nesta propriedade.NO: o form não terá botão de maximização O valor default é YES.Fixed Single: a janela terá borda simples e seu tamanho não poderá ser mudado.

MODAL DIALOG Esta propriedade é usada para indicar se o objeto utiliza diálogo Modal ou não. FORM ICON Esta propriedade é utilizada para especificar um nome para o ícone do form.YES: o menu será ativado com um click do mouse.NO: o form não terá botão de minimização O valor default é YES. Valores: .NO: o menu não será ativado com um click do mouse. Ao contrário. . você deve informar o nome do ícone. Valores: . quer dizer.MINIMIZE BUTTON Especifica se o form deve ter um botão de minimização. você pode trabalhar com ambos simultaneamente. Válido somente para geradores: Visual Basic e Visual Foxpro. com diálogo Não-Modal ambos os objetos ficam ativos ao mesmo tempo. CONTROL BOX Esta propriedade é usada para especificar se o menu no canto superior esquerdo da janela será ativado com um click do mouse. Diálogo Modal significa que o programa chamador ficará inativo até que o objeto chamado seja fechado. Valores: Não possui nenhum valor pré-definido. 81 . Válido somente para geradores: Visual Basic e Visual Foxpro.YES: o form terá botão de minimização . O valor default é YES.

se não houver parâmetros então o diálogo Não-Modal será usado. . automatic border: o form será gerado como janela popup e a borda será desenhada de forma automática. Valores: . if parameters specified. if parameters specified: se o objeto tem parâmetros então o diálogo Modal será usado. Valores: . parte das duas janelas podem ser vistas simultaneamente. . 82 . onde a transação espera valores retornados pelo prompt. quando são passados parâmetros e o objeto chamado retorna valores ao objeto chamador.3.Diálogo Não-Modal é sempre melhor que o diálogo modal. CHARACTER INTERFACE GENERATE AS A POPUP WINDOW Esta propriedade é usada para indicar que o form deve ser carregado como uma janela de Popup (sobrepor a janela anterior ao invés de substituí-la). Este valor só é válido para geradores de interface gráfica. mas nem sempre é possível utilizá-lo.YES. Se a tela desenhada ultrapassa esses limites.YES. IMPORTANTE: Esta propriedade não é válida para geração em ambiente windows. . O valor default depende do gerador selecionado. há algumas limitações de linhas e colunas que devem ser respeitados. O valor default é: YES. Em particular. uma mensagem é dada dentro do relatório de navegação na especificação. então o diálogo Modal deve ser usado. user defined border: o form será gerado como janela popup e a borda pode ser desenhada pelo usuário no form. .YES.YES: Diálogo Modal é utilizado. 11. Neste caso.NO: a janela é mostrada totalmente como popup.NO: Diálogo Não-Modal é utilizado. Os Prompts são um exemplo típico desse tipo de diálogo. NOTA: Quando a tela é definida como popup.

.AUTOMATIC BORDER • Automatic Border – Color Esta propriedade é usada para controlar a cor da borda da janela dos objetos definidos como janelas popup no AS/400. esta é a cor no GeneXus. Deve ter exatamente 8 caracteres. No AS/400 é convertido para Pink (rosa). Valores: . O valor default é: Default to color rule.Magenta. Caso contrário.High: Mostrar mais forte (negrito) .Cinza.Vermelho . VERDE é utilizado. No AS/400 é convertido para Turquesa.Blinking: Piscando .Azul .Verde . O default é: Default to color rule.No display: Não mostrar.Default to color rule: Segue a cor da regra color se a mesma existir.Reverse Image: Imagem reversa . • Automatic Border – Characters Esta propriedade é usada para definir os caracteres a serem usados para cada um dos cantos e lados da janela do objeto definido como janela popup no AS/400. . Cada caracter é usado para desenhar (em ordem): Caracter Desenha 83 .Branco . esta é a cor no GeneXus. . • Automatic Border – Display Attribute Esta propriedade é usada para definir como deve ser mostrado o atributo dos objetos definidos como janelas popup no AS/400. Valores: .Default to color rule: Segue a cor da regra color se a mesma existir.Amarelo .

Não há valor default para esta preferência. os atributos de tela dependerão dos valores default do AS/400. NOTA: Não use o caracter ‘ (apóstrofo) nesta propriedade. 84 . se nenhum valor for especificado na preferência. O valor default é 5. O valor default é 3. Valores: Qualquer número de chave de função válida. procure no manual de referência da DDS. Isto é. • Refresh Key Esta propriedade é usada para alterar a chave de função relacionada ao Refresh.4. 11.1 topo-esquerdo-canto 2 topo-borda 3 topo-direito-canto 4 esquerda-borda 5 direita-borda 6 Botão-esquerdo-canto 7 Botão-borda 8 Botão-direito-canto Esses caracteres são enviados diretamente à palavra chave WDWBORDER da DDS language para telas. AS/400 SPECIFIC – ESPECIFICAÇÕES AS/400 KEY ASSIGNMENT • Exit Key Esta propriedade é usada para alterar a chave de função relacionada ao Exit. Valores: Qualquer número de chave de função válida. Para obter informações adicionais sobre esta palavra chave.

85 . Valores: Qualquer número de chave de função válida. O valor default é 24. O valor default é 12. Valores: Qualquer número de chave de função válida. • More keys Esta propriedade é usada para alterar a chave de função relacionada à opção More Keys.• Cancel Esta propriedade é usada para alterar a chave de função relacionada ao Cancel.

. O valor default depende do gerador selecionado.YES – é possível cancelar o programa. Propriedades dos Relatórios 12. Valores: .12.NO – não é possível cancelar o programa. .Ask User: O usuário será questionado para onde deseja enviar a saída em tempo de execução. para ter certeza que a nota será sempre impressa. Valores: .NO – Evita confirmação. .YES – Ao usuário é pedido confirmação após entrada de dados. Num relatório que imprime nota e é chamado de uma transação. Valores: . 86 .Only to Printer: A saída é enviada direto para impressora. . é muito apropriado setar esta propriedade como NO. ALLOW USER TO CANCEL PROCESSING Indica se o programa pode ser cancelado pela tecla ESC. O valor default depende do gerador selecionado.Only to Screen: A saída é enviada direto para tela. OPTIONS REPORT OUTPUT Especifica a saída a ser utilizada para Report/Procedure.1. O valor default depende da gerador selecionado. PROMPT FOR CONFIRMATION É usado para evitar a confirmação usual que ocorre após as funções ASK (para pedir dados) de Report/Procedures.

Valores: Qualquer número de chave de função válida. AS/400 SPECIFIC . . O valor default é 5. • Cancel Esta propriedade é usada para alterar a chave de função relacionada ao Cancel.ESPECIFICAÇÕES AS/400 KEY ASSIGNMENT • Exit Key Esta propriedade é usada para alterar a chave de função relacionada ao Exit. Valores: Qualquer número de chave de função válida. Valores: Qualquer número de chave de função válida.2. inclusive na última.NO – O rodapé não é impresso na última página. Valores: . 12. O valor default depende do gerador selecionado.YES – O rodapé será impresso em todas as páginas.FOOTER ON LAST PAGE Esta propriedade é usada para indicar se os rodapés definidos pelo usuário devem ou não ser impressos na última página de um relatório. • Refresh Key Esta propriedade é usada para alterar a chave de função relacionada ao Refresh. O valor default é 3. O valor default é 12. 87 .

• More keys Esta propriedade é usada para alterar a chave de função relacionada à opção More Keys. Valores: Qualquer número de chave de função válida. O valor default é 24. 88 .

NO – não é possível cancelar o programa. . O valor default depende do gerador selecionado. O valor default depende do gerador selecionado.13. .Only to Printer: A saída é enviada direto para impressora.NO – Evita confirmação. Valores: . O valor default depende do gerador selecionado. PROMPT FOR CONFIRMATION É usado para evitar a confirmação usual que ocorre após as funções ASK (para pedir dados) de Report/Procedures. . 89 . OPTIONS REPORT OUTPUT Especifica a saída utilizada para Report/Procedure. Propriedades dos Procedimentos 13.Ask User: O usuário será questionado para onde deseja enviar a saída em tempo de execução.YES – Ao usuário é pedido confirmação após entrada de dados. para ter certeza que a nota será sempre impressa. Valores: . é muito apropriado setar esta propriedade como NO. . Num relatório que imprime nota e é chamado de uma transação.YES – é possível cancelar o programa. ALLOW USER TO CANCEL PROCESSING Indica se o programa pode ser cancelado pela tecla ESC.Only to Screen: A saída é enviada direto para tela.1. Valores: .

Work Panels. Esta propriedade faz sentido em Transações e Procedures que alteram a base de dados e são chamados por outros programas. Exemplo: Você pode encontrar a situação de ter que dividir em duas.2. . Valores: . não ao objeto GeneXus). Este commit automático é incluído em todos os programas que atualizam base de dados. 13. O valor default depende do gerador selecionado.YES – o programa gerado executa um commit no fim da LWU. O valor default depende do gerador selecionado. Neste caso.NO – O rodapé não é impresso na última página. o programa chamador (ou o programa chamador do chamador) é responsável pelo commit ou rollback da LWU (Logical Work Unit). assim necessitamos dividir a mesma em duas: dados do empregado e dados da função. . TRANSACTION INTEGRITY – INTEGRIDADE TRANSACIONAL COMMIT ON EXIT Programas gerados pelo GeneXus executam commits no fim da cada transação (referenciando-se ao conceito de database transaction. Não é incluído em Reports.YES – O rodapé será impresso em todas as páginas. Web Panels e procedimentos que não atualizam a base de dados. Um exemplo típico é descrito no exemplo que segue: muitos dados devem ser digitados na transação de cadastramento de funcionário. Esta propriedade é usada para controlar ou não se o commit automático é realizado. Valores: . inclusive na última.FOOTER ON LAST PAGE Esta propriedade é usada para indicar se os rodapés definidos pelo usuário devem ou não ser impressos na última página de um relatório.NO – o programa gerado não executa um commit no fim da LWU. Para ter as 90 .

........................... .. TRN: Funcionário ........... Mas nós queremos unificar as duas TRNs para que formem uma única LWU (Unidade Lógica de Trabalho). 91 ..... para fazer isso é necessário: .. (Foxpro for Windows não mostrará esta opção)...... Esta propriedade somente aparecerá se o gerador que você estiver usando permitir este tipo de controle. ............. um CALL para a segunda TRN.duas transações funcionando em conjunto........ Commit TRN: Função ...... NOTA: ............... ....Remover o COMMIT da segunda TRN usando a propriedade – Commit on Exit = NO – para que o COMMIT da primeira TRN faça o COMMIT em ambas como um todo após o retorno do CALL...... ................A primeira transação deve ter um CALL chamando a segunda..... CALL Tfuncao ......... ..........................É válido somente em transações que não tenham a propriedade do AS/400 – Commitment = Disabled – neste caso a propriedade será ignorada....... nós iremos imediatamente dar entrada nos dados da segunda TRN.... Commit on Exit = YES Commit on Exit = NO O que mostra o exemplo acima é que uma vez dado entrada nos dados na primeira transação......... nós colocamos no final da primeira transação. antes que o commit seja executado.... ...Também será ignorada se o controle da integridade transacional for desabilitado nas propriedades do modelo – Transactional Integrity = NO.

AS/400 SPECIFIC – ESPECIFICAÇÕES AS/400 COMMITMENT Inibe ou desabilita o controle da integridade transacional nos programas gerados. O valor default é 5. O valor default depende do gerador selecionado. . 92 . O valor default é 3. KEY ASSIGNMENT • Exit Key Esta propriedade é usada para alterar a chave de função relacionada ao Exit.Disabled – o programa é gerado sem os controles de integridade transacional. Valores: Qualquer número de chave de função válida. Valores: Qualquer número de chave de função válida. • Refresh Key Esta propriedade é usada para alterar a chave de função relacionada ao Refresh. Valores: Qualquer número de chave de função válida. • Cancel Esta propriedade é usada para alterar a chave de função relacionada ao Cancel. NOTA: Esta opção é ignorada para Client Server (geradores DB/2 e Oracle) porque este DBMs não permitem a desativação da integridade Transacional. Valores: .Enabled – o programa é gerado com controle de integridade transacional.3.13.

O valor default é 12. O valor default é 24. 93 . • More keys Esta propriedade é usada para alterar a chave de função relacionada à opção More Keys. Valores: Qualquer número de chave de função válida.

FOOTER FOOTER IMAGE (Ainda não implementado) WEBMASTER’S MAIL ADDRESS Ainda não implementado) 94 . Propriedades das Web Panels 14.14.1.

Sheridan DataGrid 2.0c TARGET SYSTEM INTERFACE Indica qual a versão de sistema no usuário final (destino).Visual Basic 4.Visual Basic 4.Windows 95 – a interface do sistema destino será Windows95 95 .0 (16 bits) . Valores: .0 e executamos sob Windows 3.0 (32 bits) .0.1. Propriedades do Modelo – Visual Basic 15. Valores: . GRID VERSION O gerador Visual Basic utiliza DataGrid Sheridan (incluindo no produto Data Widgets) para implementar o grid dos subfiles (NOTA: você deve instalar Sheridan’s Data Widgets para ser capaz de executar corretamente suas aplicações Visual Basic).Sheridan DataGrid 3.0c .x.O valor default é: Sheridan DataGrid 2.15. Valores: . É utilizada para evitar problemas com a edição que acontece quando geramos Visual Basic 4.Visual Basic 5.0 O valor default é Visual Basic 5. GENERAL VISUAL BASIC VERSION Use esta opção para setar a versão do gerador Visual Basic que será utilizado. Esta preferência é usada para especificar a versão do produto que você está usando.0 .

Windows 3.x – a interface do sistema destino será Windows3.1 ou
Windows3.11
O valor default é Windows95.
-

Caso 1: Se você está desenvolvendo uma aplicação numa máquina
executando abaixo do Windows 3.11, e a interface do sistema destino é
Windows 95, para evitar problemas com os controles de edição você deve
fazer o seguinte:
1. Desenvolver a aplicação (durante a fase de protótipo) com esta
preferência setada para “Windows 3.x”, para poder prototipá-la.
2. Uma vez que a fase de protótipo tenha terminado, mude esta
preferência “Windows 95” e gere todos os programas novamente,
então você pode distribuir sua aplicação para seus clientes.
Caso 2: Se você está desenvolvendo uma aplicação numa máquina
executando abaixo do Windows 95, e a interface do sistema destino é
Windows 3.11, sete esta preferência “Windows 3.x”, e teste a aplicação como
se estivesse no ambiente do cliente.
Caso 3: Se você está desenvolvendo uma aplicação numa máquina
executando abaixo do Windows 95, e a interface do sistema destino é
Windows 95, você não terá nenhum problema.
Caso 4: Se você está desenvolvendo uma aplicação numa máquina
executando abaixo do Windows 3.11, e a interface do sistema destino é
Windows 3.11, você não terá nenhum problema.

GENERATE MDI APPLICATION
Esta preferência é usada para indicar qual tipo de interface de
documento terão as aplicações geradas: SDI (Single Document Interface –
Interface de documentação simples) ou MDI (Multiple Document Interface –
Interface de documentação múltipla).
Com SDI toda transação ou Work Panel será uma janela independente
(esta é a interface utilizada pela Microsoft Exchange). No caso do MDI, todo
objeto é considerado “child window” da janela principal (esta é a interface
utilizada pela Microsoft Word).
Valores:
- YES – Aplicação MDI será gerada
- NO – Aplicação SDI será gerada
O valor default é YES.
96

NOTA: Se o valor dessa preferência é setada como NO (SDI), e mais
tarde é modificada para YES (MDI) você deve forçar a geração de todos os
programas.

ALLOW COLUMN RESIZING
Com esta opção você pode permitir ao usuário mudar o tamanho das colunas do
subfile em tempo de execução.
Valores:
- YES – o usuário será capaz de modificar o tamanho das colunas do
subfile a qualquer momento.
- NO – o tamanho das colunas do subfile do programa gerado será
especificado no desenho do mesmo e o usuário não será capaz de
mudá-los em tempo de execução.
O valor default é YES.

SKIP READ-ONLY COLUMNS
Esta preferência é usada para setar o comportamento da ‘Tab Key’ em
subfiles ao gerar código Visual Basic.
Valores:
- YES – a Tab Key pula variáveis e atributos read-only.
- NO – a Tab Key passa por todos os campos, independente de serem
“read-only” ou não.
O valor default é YES.
NOTA: Esta preferência não afeta o comportamento do mouse, porque o
mouse pode ser posicionado em qualquer campo.

CONFIRM
Esta propriedade, baseada na sua escolha, vai estabelecer se você
deseja confirmar as seguintes ações
- Insert, Delete e Update executadas a nível de Transação.
- Confirm each action: o usuário será questionado sobre
confirmação após ter finalizado a entrada de dados nas ações de

97

-

Inserção e Alteração ou selecionando o modo de deleção em algum
nível da transação.
Do not confirm each action: o usuário NÃO será questionado
sobre confirmação após ter finalizado a entrada de dados nas
ações de Inserção e Alteração ou selecionando o modo de deleção
em algum nível da transação.

Entrada de parâmetros em Reports e Procedures
- Confirm each action: após a entrada de parâmetros nas
Reports/Procedures, o usuário será questionado sobre a
confirmação dos mesmos.
- Do not confirm each action: após a entrada de parâmetros nas
Reports/Procedures, o usuário NÃO será questionado sobre a
confirmação dos mesmos.
O valor default é Confirm each action.
NOTA; Você pode sobrescrever esta propriedade num objeto em
particular alterando a propriedade Confirm para o objeto selecionado.
-

AUTOSKIP
Salto automático para o próximo campo quando o corrente é preenchido.
Por exemplo: quando o quarto dígito de um campo de 4 dígitos é digitado, é
feito um salto automático para o próximo campo.
Opções:
- YES – Salto automático para o próximo campo quando o corrente é
preenchido.
- NO – Uma tecla de entrada deve ser pressionada para mover o cursor
para o próximo campo, quando o corrente é preenchido.
O valor default é NO.

LOCK TYPE
Esta preferência controla o tipo de ‘lock’ que será executado pelo Visual
Basic no Access.
Valores:
- Pessimistic: o lock é executado quando o registro é lido.

98

em tempo de processamento. NOTA: Você deve levar em consideração que o Access loca páginas e não registros. o controle é executado sobre todas as tabelas dos atributos envolvidos na transação. Se a tabela é modificada dentro de um nível. verificar se nenhum outro usuário já alterou o mesmo registro. você pode escolher se a aplicação gerada terá Diálogo Conversacional ou Diálogo Pseudo Conversacional para implementar o controle de concorrência.Optimistic: o lock não é executado quando o registro é lido e sim controla se ele foi modificado ou não por outro usuário na hora de regravá-lo. Valores: . . O conceito básico é ler sem locar. o controle é executado a nível de tabela. Isto incrementa a concorrência na base de dados. o que quer dizer que somente serão locados os registros durante o process-time. permitindo ao usuário fazer alterações e então. NOTA: Dependendo da linguagem e plataforma que você está gerando. todos os atributos daquela tabela que estão envolvidos na transação são controlados. O problema dessa implementação aparece quando há usuários que baseiam suas decisões em tabelas não alteradas na transação. . Com o diálogo pseudo-conversacional nós tendemos a reduzir o tempo de lock de registro ao mínimo. O valor default é Pessimistic. o diálogo Pseudo conversacional é implementado para todas as operações 99 . pois situações incontroláveis não existirão. Neste caso. Este parece ser o nível de controle mais indicado. O valor default é: Check updated tables only.Check all acessed tables: implementa diálogo pseudo-conversacional. Neste caso.Check updated tables only: implementa diálogo pseudoconversacional. - PSEUDO CONVERSATIONAL DIALOG Com esta opção. uma mensagem de erro é mostrada e o usuário de refazer a operação. Se isto ocorrer.Use conversational dialog: implementa diálogo conversacional.

NO: o desenvolvedor NÃO será capaz de executar GeneXus mail functions. NOTA: você necessitará ter corretamente instalado todos os componentes para enviar mensagens via MAPI (Microsoft Messaging API) e também ter instalado não somente o Mail (Microsoft Mail e/ou compatível) mas também o arquivo VBX para utilizar a interface (MSMAPI. GXGETGRAPHPROPERTY. mas você é capaz de assinalar o nome que desejar. GXSETGRAPHPROPERTY. LOCAL DATABASE FILE Especifica o nome da base de dados local quando gerando Visual Basic. 100 .YES: o desenvolvedor será capaz de executar GeneXus mail functions .VBX). Você deve setar esta preferência para YES para ser capaz de usar estas funções gráficas e comandos gráficos do GeneXus. . Valores: . GRAPHIC FUNCTIONS O gerador GeneXus Visual Basic prevê uma série de funções para customizar seus gráficos: GXMKGR.NO: Você NÃO será capaz de chamar as funções gráficas usando o comando CALL do GeneXus e o comando GeneXus graph. Valores: O nome default é GX_DATA. Valores: . MAIL FUNCTIONS Você deve setar esta preferência para YES para ser capaz de usar as mail functions. O valor default é NO.executadas na Transação (Cobol e RPG para AS/400) ou somente no nível da transação (nos casos dos Xbase ou Visual Basic). GXKILLGRAPH.MDB.YES: Você será capaz de chamar as funções gráficas usando o comando CALL do GeneXus e o comando GeneXus graph.

Valores: .&selected. escolher uma fonte. Valores: . Um exemplo de Common Dialogs são: abrir um arquivo. A sintaxe para usar estas rotinas é a seguinte: Select Color Dialog Call(“GxSelColor”.. Você deve setar esta preferência para YES para ser capaz de usar Excel do GeneXus para Visual Basic.O valor default é NO. algumas funções standard devem ser avaliadas.&caption) &selected = Diretório de saída selecionado (String) 101 .&default) &selected = Cor de output selecionada (Long) &Default = Cor default (Long) Select Directory Dialog Call(“GxSelDir”. .. EXCEL OLE FUNCTIONS Você pode usar OLE para estabelecer a comunicação entre uma aplicação gerada pelo GeneXus e Excel. . COMMOM DIALOG FUNCTIONS ‘Common Dialogs’ são uma série de diálogos usados por diferentes aplicações e válidas no Windows.&defaultpath.&selected.YES: o desenvolvedor será capaz de chamar o GeneXus Common Dialogs com o comando CALL.NO: o desenvolvedor NÃO será capaz de executar as funções Excel do GeneXus. O valor default é NO. etc.NO: o desenvolvedor NÃO será capaz de chamar o GeneXus Common Dialogs com o comando CALL. Para ser capaz de fazer isso.YES: o desenvolvedor será capaz de executar as funções Excel do GeneXus. Você deve setar esta preferência para YES para ser capaz de usar o GeneXus Common Dialogs. O valor default é NO. escolher uma cor.

&extensions.&cap tion) &selected = Nome do arquivo de saída selecionado (String) &initialpath = Input Caminho default para procura (String) &defaultname = Input Default nome de arquivo (String) &extensions = default de extensão (String) &caption = Título do Box (String) Select Font Dialog Call(“GxSelFont”. &buttontype) &selected = Nome do arquivo de saída selecionado (String) &initialpath = Caminho default (String) &extensions = default de extensão (String) &caption = Título do Box (String) &buttoncaption = Nome do botão de seleção (String) &buttontype = Flag para habilitar o botão no Diálogo (inteiro) Save as Dialog Call(“GxNewFile”.&selected.&defaultpath = Diretório default de entrada (String) &caption = Edit Box Caption (String) File Open Dialog Call(“GxSelFile”.&SelectedFont.&initialpath.&buttoncap tion.&extensions.&selected.&caption.&extensions.&initialpath.&defaultname.&selected.&SelectedStyle) &SelectedFont = Nome da fonte de saída selecionado (String) &SelectedSize = Tamanho da fonte selecionada (String) &SelectedStyle = Nome da fonte de saída selecionado (String) Select Picture File Dialog Call(“GxSelPict”.&caption.&buttoncap tion) &selected = Arquivo Selecionado (String) &initialpath = Input Caminho default para procura (String) &extensions = default de extensão (String) &caption = Título do Box (String) &buttoncaption = Nome botão selecionado (String) Printer Dialog Call(“GxSelPrn”.&SelectedSize.&initialpath.&selected) &selected = Nome da Impressora Selecionada (String) Copy File 102 .

RIGHT BUTTON CALCULATOR ON SECUNDARY NUMERIC FIELDS Para os campos numéricos que não tem associado um prompt. um calendário será mostrado permitindo a você selecionar uma data. .&Target) &Source = Nome do arquivo de entrada (String) &Target = Nome do arquivo de destino (String) Calculator Call(“GxCalculate”.Call(“GxXopyFile”. uma calculadora será chamada quando for clicado o botão direito do mouse sobre o mesmo. 15.NO: Você NÃO terá facilidade de chamar um calendário ao clicar o botão direito do mouse sobre um campo tipo DATE. O valor default é YES. O valor default é YES. PRINTING 103 .NO: Você NÃO terá a facilidade de chamar a calculadora clicando o botão direito do mouse sobre o campo numérico. Valores: . CALENDAR ON DATE FIELDS Se você clicar o botão direito do mouse sobre um campo tipo DATE.YES: Você será capaz de chamar um calendário ao clicar o botão direito do mouse sobre um campo tipo DATE.YES: Você será capaz de chamar a calculadora clicando o botão direito do mouse sobre o campo numérico.&Result) &Result = valor numérico de entrada/saída (Numérico) 15.3. . Valores: .&Source.2.

Diferentes strings devem ser definidos dependendo da linguagem e do tipo de rede: Para FoxPro e DBASE os seguintes devem ser definidos: Sintaxe para Microsoft Networks: \\<server>\<printer> Onde <server> é o nome do servidor <printer> é o nome da impressora Exemplo: \\ARTECH\\PRXX Sintaxe para Novell networks: \\<spooler> Para maiores informações sobre o comando SET PRINTER TO. GeneXus procura pela impressora de rede indicada no Model Property e imprime o relatório na impressora indicada. . Se Printer Property é definida para um objeto em particular. Se nenhuma Impressora de Rede é especificada.LAN PRINTER Essa propriedade permite você definir a impressora default para onde os relatórios serão enviados. então a default (LTP1) é assumida. Se Printer Property não é definida. 104 . Se nenhuma propriedade de impressora de rede é encontrada então LPT1 é usada.YES – o diálogo da impressora será mostrado antes dos relatórios serem enviados à impressora. 3. Nenhum <diálogo de impressora> será mostrado. 2. Valores: . Exemplo: \\SPOOLER \N \Q=WORD4039 Para Clipper: Sintaxe para LAN Printer: <printer port> Exemplo: LPT2. Quando o relatório é impresso. então o relatório é enviado à impressora indicada no objeto. procure nos manuais de referência do FoxPro ou DbaseIV. os seguintes passos são efetuados: 1. SHOW PRINTER DIALOG ON REPORTS Permite você especificar se deseja mostrar o <Printer Dialog> antes de imprimir seu relatório ou você deseja enviá-lo diretamente à impressora.NO – o relatório será enviado diretamente à impressora.

4.Enter. Combo Boxes.VB Native Printing: relatórios são impressos usando Visual Basic Native printing. Shift-Tab: o movimento de avanço é feito com a tecla Tab e a combinação das teclas Shift-Tab faz o movimento de volta. . Tab. Enter. Down Arrow. PRINT METHOD Essa preferência é usada para selecionar o método de impressão que o gerador Visual Basic deve utilizar. O valor default é: VB Native Printing. Tab. FORMAT FIELD EXIT Essa preferência controla a tecla que é capaz de mover o cursor entre os campos do programa gerado. . de outro jeito Report Viewer não funcionará corretamente. 15. Você pode escolher impressão nativa Visual Basic ou Report Viewer GeneXus. etc) Valores: .Report Viewer: relatórios são impressos usando GeneXus Report Viewer. Isto afeta exclusivamente o tipo de controle Edit (não afeta Radio Buttons.+. Down Arrow. Up Arrow.Tab. . Seta para baixo e Tab serão interpretadas como ‘movimento’ para o próximo campo e a Seta para Cima e Shift-tab serão interpretadas como ‘movimento’ para o campo anterior. NOTA: se você utilizar GeneXus Report Viewer você deve ter instalado um driver de impressora na máquina onde o programa será executado. Shift-Tab: as teclas Enter. Shift Tab: as teclas +.O valor defualt é YES. Valores: . Seta para baixo e Tab serão interpretadas como 'movimento' para o 105 . Up Arrow.

..: “mm/dd/yy” Português: “dd/mm/yy” Espanhol.” Vírgula. DATE FORMAT Essa opção permite você especificar o formato no qual os atributos do tipo DATA devem ser pedidos/mostrados nos programas gerados. DECIMAL SEPARATOR Esta opção permite ao usuário configurar o separador decimal que deseja usar.Language Dependent: o formato do tipo date dependerá da linguagem selecionada no modelo corrente. O valor default corresponde à linguagem do modelo do Design Model.Exit Form: você abortará o programa que está executando ao pressionar a tecla ESC. O valor default é: Exit Form..” Ponto.” Vírgula...Português: assume “.. ESC KEY ACTION Essa preferência somente afeta transações com múltiplos níveis e permite você estabelecer como você deseja que a tecla ESC funcione.Change Level: a tecla ESC vai alternar o nível ao ser pressionada. .. . Os formatos assumidos para cada linguagem são: Inglês.Inglês: assume “.Italiano: assume “.próximo campo e a Seta para Cima e Shift-Tab serão interpretadas como 'movimento' para o campo anterior. Valores: .: “dd/mm/yy” Italiano. .” Vírgula.Espanhol: assume “. . O valor default é: Tab. Shift-Tab...: “dd/mm/yy” 106 . . Valores: ..

.: “dd/mm/yy” Mm/dd/yy: mês/dia/ano dd/mm/yy: dia/mês/ano O valor default é: Language Dependent.... Essa preferência é aplicada à Base de Conhecimento..... DATE FORMAT IN CTOD FUNCTION (VISUAL BASIC) Essa opção permite você especificar o formato no qual a função CTOD interpretará os parâmetros... TIME FORMAT Controla o formato no qual a parte das horas dos atributos tipo datetime são pedidos e mostrados (tanto na tela como na impressão). mas cada modelo pode ter um valor diferente para essa preferência.: “mm/dd/yy” Português: “dd/mm/yy” Espanhol.Mm/dd/yy: mês/dia/ano dd/mm/yy: dia/mês/ano O valor default é: Language Dependent.: “dd/mm/yy” Italiano. Também controla o tamanho dos atributos/variáveis tipo datetime.Language Dependent: o formato do tipo date dependerá da linguagem selecionada no modelo corrente.Language Dependent: Depende da linguagem selecionada de acordo com a seguinte tabela: Linguagem Formato Hora Inglês 12 horas Espanhol 24 horas Português 24 horas Italiano 24 horas 107 . Os formatos assumidos para cada linguagem são: Inglês. Valores: . Valores: .

O objetivo é identificar qual o protocolo default a ser usado quando os links são construídos. Um link tem a seguinte estrutura: <A HREF=”protocol:program[?parameters]”>Text</A> Valores: .. 108 .Unsecure (HTTP): força a geração do protocolo HTTP. nós recomendamos o uso do ‘Do Not Specify’ para obter um código gerado mais versátil (pode ser executado com qualquer protocolo). o protocolo ‘atual’ é usado. HTTPS indica que o protocolo a ser usado é Secure Hypertext Transfer Protocol. Esses links são gerados quando um comando CALL entre duas Web Panels é detectado. 15. O valor default é: Unsecure (HTTP). .). os campos terão 3 caracteres a mais (tela ou impressora) correspondente às strings ‘AM’ ou ‘PM’.Secure (HTTPS): força a geração do protocolo HTTPS. .. HTTP indica que o protocolo a ser usado é Hypertext Transfer Protocol. dependendo da linguagem selecionada. Todo ano (parte de um campo date) menor que o informado nesta preferência. Em geral.Do Not Specify: nenhum protocolo é especificado. WEB INFORMATION PROTOCOL SPECIFICATION Esta preferência se aplica à geração automática de links entre as Web Panels. será considerado século 21 (2000. O valor default é: 40. NOTA: Se o uso do formato 12 horas é especificado ou inferido.5.O valor default é: language Dependent. FIRST YEAR OF 20th CENTURY Informe a partir de qual ano que deve ser considerado como século 20.

você deve ter Secure Web Server.YES: Se por algum motivo você deseja que o mesmo critério que é utilizado pelo gerador AS/400 seja utilizado para ambientes Xbases (PC). Você pode definir se quer que sejam mostrados mensagens de erro e advertência quando o Type Control é carregado. há alguns browsers (normalmente versões antigas) que não suportam links sem protocolo especificado. Em particular. quando uma geração PC é executada (o mesmo se aplica para protótipo ou Produção) as mensagens são Warnings que permitem que você prossiga na geração dos programas.6. o tipo de mensagem que é mostrada depende da plataforma. condições. o AS/400 mostra mensagens de erro e não permite a geração dos programas. Mesmo que o tipo de controlador não dependa da plataforma em que se está gerando uma aplicação. Tipos de controle em expressões: Todas as expressões GeneXus serão analisadas para testar sua compatibilidade em cálculos ou funções. 15. fórmulas e regras são válidas. o tipo de controle para Xbase é executado na especificação. você deve selecionar YES para esta propriedade. nós recomendamos não utilizar ´Do not specify’ nesta preferência. TYPE CHECKING CHECK TYPE ERRORS Type Controls são usados para checar se expressões.Entretanto. Por esta razão. e se você deseja suportar tantos browsers quanto possível. Entretanto. Por exemplo: &no Numérico(10) &char Caracter(10) &data Date Você pode definir a seguinte expressão em Program Source/Layout/Events/Rules: &no = &data + month(&char) 109 . Valores: . . O valor default é: YES. NOTA: se o protocolo HTTPS é usado.NO: Se você selecionar NO.

Reports e Work Panels são controladas bem como as cláusulas WHERE. 110 ... .Type mismatch in expression month(&char) at line 15. Tipos de controle em Fórmulas: Há basicamente dois tipos de fórmulas: .Type mismatch in Assignment <Invalid Assignment> <at line X> (Tipos não são compatíveis na igualdade) onde <Invalid Assignment> mostra uma assinalação inválida.10) > CTOD(&data) . . Uma expressão de igualdade obriga que ambos os lados da igualdade sejam do mesmo tipo.Type mismatch in assignment &no=&data + month(&char) at line 15 Tipos de controle em Conditions: Condições nas Procedures..Type mismatch in expression <Invalid Expression> <at line X> (Tipos não são compatíveis) onde <Invalid Expression> é parte da expressão onde o erro foi detectado e <at line X> indica a linha da procedure ou report onde o erro foi encontrado. Assim o diagrama de navegação irá mostrar todos os Warnings (ou erros dependendo da plataforma) indicando que a expressão não é correta: . ..A expressão acima tem dois problemas: A função month( ) requer um parâmetro tipo Date. Ex.EXPRESSIONS: Expressões serão analisadas para controlar se as assinalações são corretas e se as condições são corretas.10) > CTOD(&data). (Esses casos já forma mostrados em Expressions e Conditions). ENDIF As mensagens ou erros nas conditions serão os seguintes: . Por exemplo: IF str(&no. IF ou DO WHILE.Type mismatch in conditional expression <condition> onde <condition> indica qual a condição incorreta. .Type mismatch in expression CTOD(&data).Type mismatch in conditional expression str(&no.: &no=&data + month(&char) Do exemplo acima as mensagens mostradas serão as seguintes: vamos supor que o erro aconteceu na linha 15 de um relatório: .

Return) O atributo “Return” é usado quando fórmulas MAX( ) e MIN( ) são utilizadas.A validade da condição também é controlada. count). A mensagem correspondente à condição na fórmula é: Type mismatch in condition str(AttrNo. Subtract. min.Type mismatch in formula <Formula> in <TypeOfParameter> parameter onde <formula> é o atributo formula e <TypeOfParameter> indica o parâmetro inválido. As regras Default. etc. AttrReturn) Type mismatch in formula in default parameter Type mismatch in formula in return parameter. sum. . Elas são compostas dos seguintes parâmetros: Fórmula = formula(Atributo. Equal. - Tipos de controle nas Regras das Transações: A maioria das regras das transações são transformadas em assinalações e a consistência dos tipos de dados também deve ser controlado. ex.> Error. find. etc também são controladas. No caso de haver parâmetros com erro é mostrado: . . As regras condicionais também tem sua consistência checada.’90’.Fórmula e Return devem ser do mesmo tipo. 111 .Fórmula e Default devem ser do mesmo tipo.Default.Fórmula e Atributo devem ser do mesmo tipo (Exceto para as fórmulas MAX( ) e MIN( )).10) <> CTOD(AttrData) in fórmula Formula. Msg.Condition.str(AttrNo. set. . Exemplo: Formula = Numérico(10) AttrNo = Numérico(10) AttrData = Date 8 AttrFirst = Caracter(10) AttrReturn = Date 8 A fórmula mostrada abaixo dará as seguintes mensagens: Formula = max(AttrFirst.10)>CTOD(AttrData). Os seguintes casos são controlados: . Add.AGGREGATE-SELECT: Há seis tipos de fórmulas Aggregate-Select (max.

que não são suportadas por todos os geradores. . Se funções específicas não são explicitamente suportados pelo GeneXus (ex. etc.Em ambos os casos as mensagens mostradas são as mesmas mostradas acima. 15. O valor default é: Error on non-standard functions when specyfing.: TRIM. Valores: . PROMPT KEY Permite você selecionar qual tecla será utilizada como Prompt das Transações.Allows non-standard functions when specyfing: inibe o controle da sintaxe mencionada acima na especificação. 112 . porque são válidos no AS/400) e elas são utilizadas. LEFT. KEY CONFIGURATION FIRST RECORD LAST RECORD NEXT RECORD PREVIOUS RECORD REFRESH KEY Permite você selecionar qual tecla será utilizada como tecla de Refresh.Error on non-standard functions when specyfing: o controle da sintaxe mencionada acima é feita na especificação. O valor default é F5. um erro será mostrado. FUNCTIONS Permite o uso de funções específicas.7.

15. Valores: qualquer valor numérico positivo. Quando o limite é ultrapassado. OTHER MAXIMUN WORKFILE LINES Os subfiles em ambiente PC são carregados em arquivos temporários.000 registros e o usuário vai para o final do mesmo (Ctrl-End). 15.000 registros.O valor default é F4. Você deve evitar assinalar a mesma tecla de função para duas ações diferentes porque isso não é controlado pelo gerador. neste caso o arquivo temporário carregará 300. a seguinte mensagem é mostrada: Number of lines exceeded xxxx E você pode continuar trabalhando. Se nenhuma das condições acima é satisfeita então 9. mas em ambiente PC ou rede não há restrições.8. mas nenhum outro registro será carregado.999 linhas. por exemplo: se você está trabalhando com uma Work Panel ou Transação que carrega 300.9.999 linhas são assumidas como limite do subfile. 113 . O tamanho máximo de um subfile na AS/400 é 9. Esta liberdade pode causar problemas.